Browse Source

添加闪屏页,权限请求逻辑操作。

kaiweicai 3 years ago
parent
commit
102dd3cb1a
36 changed files with 1332 additions and 0 deletions
  1. 2 0
      demo/src/main/java/com/yyxx/commsdk/demo/SplashActivity.java
  2. BIN
      demo/src/main/res/drawable-xhdpi/qsgame_welcome.png
  3. BIN
      demo/src/main/res/drawable-xhdpi/yyxx_comm_welcome.png
  4. 69 0
      demo/src/main/res/layout-w1240dp/activity_login.xml
  5. 76 0
      demo/src/main/res/layout-w936dp/activity_login.xml
  6. 69 0
      demo/src/main/res/layout/activity_login.xml
  7. 28 0
      demo/src/main/res/navigation/nav_graph.xml
  8. 28 0
      demo/src/main/res/navigation/nav_graph2.xml
  9. 3 0
      demo/src/main/res/values-land/dimens.xml
  10. 3 0
      demo/src/main/res/values-w1240dp/dimens.xml
  11. 3 0
      demo/src/main/res/values-w600dp/dimens.xml
  12. 5 0
      demo/src/main/res/values/dimens.xml
  13. 4 0
      demo/src/main/res/values/themes.xml
  14. 51 0
      library_core/src/main/cpp/aes_kit.cpp
  15. 36 0
      library_core/src/main/cpp/aes_kit.h
  16. 320 0
      library_core/src/main/cpp/external/md5/md5.cpp
  17. 94 0
      library_core/src/main/cpp/external/md5/md5.h
  18. 34 0
      library_core/src/main/cpp/params_kit.cpp
  19. 33 0
      library_core/src/main/cpp/params_kit.h
  20. 0 0
      library_core/src/main/cpp/tool_kit.h
  21. 68 0
      library_core/src/main/cpp/yylog.cpp
  22. 41 0
      library_core/src/main/cpp/yylog.h
  23. 19 0
      library_core/src/main/java/cn/yyxx/commsdk/core/constants/Constants.java
  24. 2 0
      library_core/src/main/java/cn/yyxx/commsdk/core/permission/PermissionManager.java
  25. 2 0
      library_core/src/main/java/cn/yyxx/commsdk/core/ui/dialog/PrivacyPolicyDialog.java
  26. 35 0
      library_core/src/main/java/cn/yyxx/commsdk/core/utils/FileUtils.java
  27. 36 0
      library_core/src/main/java/cn/yyxx/commsdk/core/utils/ManifestUtils.java
  28. 69 0
      library_core/src/main/java/cn/yyxx/commsdk/core/utils/ResourceUtil.java
  29. 2 0
      library_core/src/main/java/cn/yyxx/commsdk/core/utils/SharedPreferencesUtils.java
  30. 84 0
      library_core/src/main/java/cn/yyxx/commsdk/core/utils/YYLog.java
  31. 12 0
      library_core/src/main/res/drawable/yyxx_btn_exit_bg.xml
  32. 2 0
      library_core/src/main/res/drawable/yyxx_comm_background.xml
  33. 12 0
      library_core/src/main/res/drawable/yyxx_comm_confirm_button_style.xml
  34. 81 0
      library_core/src/main/res/layout/yyxx_comm_privacy_dialog.xml
  35. 6 0
      library_core/src/main/res/values/yyxx_comm_colors.xml
  36. 3 0
      library_core/src/main/res/values/yyxx_comm_strings.xml

+ 2 - 0
demo/src/main/java/com/yyxx/commsdk/demo/SplashActivity.java

@@ -0,0 +1,2 @@
+package com.yyxx.commsdk.demo;public class SplashActivity {
+}

BIN
demo/src/main/res/drawable-xhdpi/qsgame_welcome.png


BIN
demo/src/main/res/drawable-xhdpi/yyxx_comm_welcome.png


+ 69 - 0
demo/src/main/res/layout-w1240dp/activity_login.xml

@@ -0,0 +1,69 @@
+<?xml version="1.0" encoding="utf-8"?>
+<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:app="http://schemas.android.com/apk/res-auto"
+    xmlns:tools="http://schemas.android.com/tools"
+    android:id="@+id/container"
+    android:layout_width="match_parent"
+    android:layout_height="match_parent"
+    android:paddingLeft="@dimen/activity_horizontal_margin"
+    android:paddingTop="@dimen/activity_vertical_margin"
+    android:paddingRight="@dimen/activity_horizontal_margin"
+    android:paddingBottom="@dimen/activity_vertical_margin"
+    tools:context=".ui.login.LoginActivity">
+
+    <EditText
+        android:id="@+id/username"
+        android:layout_width="0dp"
+        android:layout_height="wrap_content"
+        android:layout_marginTop="96dp"
+        android:hint="@string/prompt_email"
+        android:inputType="textEmailAddress"
+        android:selectAllOnFocus="true"
+        app:layout_constraintEnd_toEndOf="parent"
+        app:layout_constraintStart_toStartOf="parent"
+        app:layout_constraintTop_toTopOf="parent" />
+
+    <EditText
+        android:id="@+id/password"
+        android:layout_width="0dp"
+        android:layout_height="wrap_content"
+        android:layout_marginTop="8dp"
+        android:hint="@string/prompt_password"
+        android:imeActionLabel="@string/action_sign_in_short"
+        android:imeOptions="actionDone"
+        android:inputType="textPassword"
+        android:selectAllOnFocus="true"
+        app:layout_constraintEnd_toEndOf="parent"
+        app:layout_constraintStart_toStartOf="parent"
+        app:layout_constraintTop_toBottomOf="@+id/username" />
+
+    <Button
+        android:id="@+id/login"
+        android:layout_width="wrap_content"
+        android:layout_height="wrap_content"
+        android:layout_gravity="start"
+        android:layout_marginTop="16dp"
+        android:layout_marginBottom="64dp"
+        android:enabled="false"
+        android:text="@string/action_sign_in"
+        app:layout_constraintBottom_toBottomOf="parent"
+        app:layout_constraintEnd_toEndOf="parent"
+        app:layout_constraintStart_toStartOf="parent"
+        app:layout_constraintTop_toBottomOf="@+id/password"
+        app:layout_constraintVertical_bias="0.2" />
+
+    <ProgressBar
+        android:id="@+id/loading"
+        android:layout_width="wrap_content"
+        android:layout_height="wrap_content"
+        android:layout_gravity="center"
+        android:layout_marginTop="64dp"
+        android:layout_marginBottom="64dp"
+        android:visibility="gone"
+        app:layout_constraintBottom_toBottomOf="parent"
+        app:layout_constraintEnd_toEndOf="@+id/password"
+        app:layout_constraintStart_toStartOf="@+id/password"
+        app:layout_constraintTop_toTopOf="parent"
+        app:layout_constraintVertical_bias="0.3" />
+
+</androidx.constraintlayout.widget.ConstraintLayout>

+ 76 - 0
demo/src/main/res/layout-w936dp/activity_login.xml

@@ -0,0 +1,76 @@
+<?xml version="1.0" encoding="utf-8"?>
+<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:app="http://schemas.android.com/apk/res-auto"
+    xmlns:tools="http://schemas.android.com/tools"
+    android:id="@+id/container"
+    android:layout_width="match_parent"
+    android:layout_height="match_parent"
+    android:paddingLeft="@dimen/activity_horizontal_margin"
+    android:paddingTop="@dimen/activity_vertical_margin"
+    android:paddingRight="@dimen/activity_horizontal_margin"
+    android:paddingBottom="@dimen/activity_vertical_margin"
+    tools:context=".ui.login.LoginActivity">
+
+    <androidx.constraintlayout.widget.ConstraintLayout
+        android:layout_width="840dp"
+        android:layout_height="match_parent"
+        app:layout_constraintEnd_toEndOf="parent"
+        app:layout_constraintStart_toStartOf="parent">
+
+        <EditText
+            android:id="@+id/username"
+            android:layout_width="0dp"
+            android:layout_height="wrap_content"
+            android:layout_marginTop="96dp"
+            android:hint="@string/prompt_email"
+            android:inputType="textEmailAddress"
+            android:selectAllOnFocus="true"
+            app:layout_constraintEnd_toEndOf="parent"
+            app:layout_constraintStart_toStartOf="parent"
+            app:layout_constraintTop_toTopOf="parent" />
+
+        <EditText
+            android:id="@+id/password"
+            android:layout_width="0dp"
+            android:layout_height="wrap_content"
+            android:layout_marginTop="8dp"
+            android:hint="@string/prompt_password"
+            android:imeActionLabel="@string/action_sign_in_short"
+            android:imeOptions="actionDone"
+            android:inputType="textPassword"
+            android:selectAllOnFocus="true"
+            app:layout_constraintEnd_toEndOf="parent"
+            app:layout_constraintStart_toStartOf="parent"
+            app:layout_constraintTop_toBottomOf="@+id/username" />
+
+        <Button
+            android:id="@+id/login"
+            android:layout_width="wrap_content"
+            android:layout_height="wrap_content"
+            android:layout_gravity="start"
+            android:layout_marginTop="16dp"
+            android:layout_marginBottom="64dp"
+            android:enabled="false"
+            android:text="@string/action_sign_in"
+            app:layout_constraintBottom_toBottomOf="parent"
+            app:layout_constraintEnd_toEndOf="parent"
+            app:layout_constraintStart_toStartOf="parent"
+            app:layout_constraintTop_toBottomOf="@+id/password"
+            app:layout_constraintVertical_bias="0.2" />
+
+        <ProgressBar
+            android:id="@+id/loading"
+            android:layout_width="wrap_content"
+            android:layout_height="wrap_content"
+            android:layout_gravity="center"
+            android:layout_marginTop="64dp"
+            android:layout_marginBottom="64dp"
+            android:visibility="gone"
+            app:layout_constraintBottom_toBottomOf="parent"
+            app:layout_constraintEnd_toEndOf="@+id/password"
+            app:layout_constraintStart_toStartOf="@+id/password"
+            app:layout_constraintTop_toTopOf="parent"
+            app:layout_constraintVertical_bias="0.3" />
+
+    </androidx.constraintlayout.widget.ConstraintLayout>
+</androidx.constraintlayout.widget.ConstraintLayout>

+ 69 - 0
demo/src/main/res/layout/activity_login.xml

@@ -0,0 +1,69 @@
+<?xml version="1.0" encoding="utf-8"?>
+<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:app="http://schemas.android.com/apk/res-auto"
+    xmlns:tools="http://schemas.android.com/tools"
+    android:id="@+id/container"
+    android:layout_width="match_parent"
+    android:layout_height="match_parent"
+    android:paddingLeft="@dimen/activity_horizontal_margin"
+    android:paddingTop="@dimen/activity_vertical_margin"
+    android:paddingRight="@dimen/activity_horizontal_margin"
+    android:paddingBottom="@dimen/activity_vertical_margin"
+    tools:context=".ui.login.LoginActivity">
+
+    <EditText
+        android:id="@+id/username"
+        android:layout_width="0dp"
+        android:layout_height="wrap_content"
+        android:layout_marginTop="96dp"
+        android:hint="@string/prompt_email"
+        android:inputType="textEmailAddress"
+        android:selectAllOnFocus="true"
+        app:layout_constraintEnd_toEndOf="parent"
+        app:layout_constraintStart_toStartOf="parent"
+        app:layout_constraintTop_toTopOf="parent" />
+
+    <EditText
+        android:id="@+id/password"
+        android:layout_width="0dp"
+        android:layout_height="wrap_content"
+        android:layout_marginTop="8dp"
+        android:hint="@string/prompt_password"
+        android:imeActionLabel="@string/action_sign_in_short"
+        android:imeOptions="actionDone"
+        android:inputType="textPassword"
+        android:selectAllOnFocus="true"
+        app:layout_constraintEnd_toEndOf="parent"
+        app:layout_constraintStart_toStartOf="parent"
+        app:layout_constraintTop_toBottomOf="@+id/username" />
+
+    <Button
+        android:id="@+id/login"
+        android:layout_width="wrap_content"
+        android:layout_height="wrap_content"
+        android:layout_gravity="start"
+        android:layout_marginTop="16dp"
+        android:layout_marginBottom="64dp"
+        android:enabled="false"
+        android:text="@string/action_sign_in"
+        app:layout_constraintBottom_toBottomOf="parent"
+        app:layout_constraintEnd_toEndOf="parent"
+        app:layout_constraintStart_toStartOf="parent"
+        app:layout_constraintTop_toBottomOf="@+id/password"
+        app:layout_constraintVertical_bias="0.2" />
+
+    <ProgressBar
+        android:id="@+id/loading"
+        android:layout_width="wrap_content"
+        android:layout_height="wrap_content"
+        android:layout_gravity="center"
+        android:layout_marginTop="64dp"
+        android:layout_marginBottom="64dp"
+        android:visibility="gone"
+        app:layout_constraintBottom_toBottomOf="parent"
+        app:layout_constraintEnd_toEndOf="@+id/password"
+        app:layout_constraintStart_toStartOf="@+id/password"
+        app:layout_constraintTop_toTopOf="parent"
+        app:layout_constraintVertical_bias="0.3" />
+
+</androidx.constraintlayout.widget.ConstraintLayout>

+ 28 - 0
demo/src/main/res/navigation/nav_graph.xml

@@ -0,0 +1,28 @@
+<?xml version="1.0" encoding="utf-8"?>
+<navigation xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:app="http://schemas.android.com/apk/res-auto"
+    xmlns:tools="http://schemas.android.com/tools"
+    android:id="@+id/nav_graph"
+    app:startDestination="@id/FirstFragment">
+
+    <fragment
+        android:id="@+id/FirstFragment"
+        android:name="com.yyxx.commsdk.demo.ui.FirstFragment"
+        android:label="@string/first_fragment_label"
+        tools:layout="@layout/fragment_first">
+
+        <action
+            android:id="@+id/action_FirstFragment_to_SecondFragment"
+            app:destination="@id/SecondFragment" />
+    </fragment>
+    <fragment
+        android:id="@+id/SecondFragment"
+        android:name="com.yyxx.commsdk.demo.ui.SecondFragment"
+        android:label="@string/second_fragment_label"
+        tools:layout="@layout/fragment_second">
+
+        <action
+            android:id="@+id/action_SecondFragment_to_FirstFragment"
+            app:destination="@id/FirstFragment" />
+    </fragment>
+</navigation>

+ 28 - 0
demo/src/main/res/navigation/nav_graph2.xml

@@ -0,0 +1,28 @@
+<?xml version="1.0" encoding="utf-8"?>
+<navigation xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:app="http://schemas.android.com/apk/res-auto"
+    xmlns:tools="http://schemas.android.com/tools"
+    android:id="@+id/nav_graph2"
+    app:startDestination="@id/FirstFragment">
+
+    <fragment
+        android:id="@+id/FirstFragment"
+        android:name="com.yyxx.commsdk.demo.ui.FirstFragment"
+        android:label="@string/first_fragment_label"
+        tools:layout="@layout/fragment_first">
+
+        <action
+            android:id="@+id/action_FirstFragment_to_SecondFragment"
+            app:destination="@id/SecondFragment" />
+    </fragment>
+    <fragment
+        android:id="@+id/SecondFragment"
+        android:name="com.yyxx.commsdk.demo.ui.SecondFragment"
+        android:label="@string/second_fragment_label"
+        tools:layout="@layout/fragment_second">
+
+        <action
+            android:id="@+id/action_SecondFragment_to_FirstFragment"
+            app:destination="@id/FirstFragment" />
+    </fragment>
+</navigation>

+ 3 - 0
demo/src/main/res/values-land/dimens.xml

@@ -0,0 +1,3 @@
+<resources>
+    <dimen name="activity_horizontal_margin">48dp</dimen>
+</resources>

+ 3 - 0
demo/src/main/res/values-w1240dp/dimens.xml

@@ -0,0 +1,3 @@
+<resources>
+    <dimen name="activity_horizontal_margin">200dp</dimen>
+</resources>

+ 3 - 0
demo/src/main/res/values-w600dp/dimens.xml

@@ -0,0 +1,3 @@
+<resources>
+    <dimen name="activity_horizontal_margin">48dp</dimen>
+</resources>

+ 5 - 0
demo/src/main/res/values/dimens.xml

@@ -0,0 +1,5 @@
+<resources>
+    <!-- Default screen margins, per the Android Design guidelines. -->
+    <dimen name="activity_horizontal_margin">16dp</dimen>
+    <dimen name="activity_vertical_margin">16dp</dimen>
+</resources>

+ 4 - 0
demo/src/main/res/values/themes.xml

@@ -0,0 +1,4 @@
+<resources>
+
+    <style name="Theme.YYXXCommSdk" parent="Theme.MaterialComponents.Light" />
+</resources>

+ 51 - 0
library_core/src/main/cpp/aes_kit.cpp

@@ -0,0 +1,51 @@
+//
+// Created by #Suyghur, on 2021/10/15.
+//
+
+#include <string>
+#include <jni.h>
+#include "yylog.h"
+#include "aes_kit.h"
+
+
+jstring AesKit::Encrypt(JNIEnv *env, const char *input) {
+    jclass clz = env->FindClass("cn/yyxx/support/encryption/aes/AesUtils");
+    if (clz == nullptr) {
+        LOGD("aes impl clz is nullptr !!!");
+        return env->NewStringUTF("");
+    }
+    const char *method_name = "encrypt2hex";
+    const char *sig = "(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;";
+    jmethodID mid = env->GetStaticMethodID(clz, method_name, sig);
+    jstring key = env->NewStringUTF(AES_KEY);
+    jstring iv = env->NewStringUTF(IV);
+    jstring data = env->NewStringUTF(input);
+    auto result = (jstring) env->CallStaticObjectMethod(clz, mid, key, iv, data);
+    env->DeleteLocalRef(clz);
+    env->DeleteLocalRef(key);
+    env->DeleteLocalRef(iv);
+    env->DeleteLocalRef(data);
+    return result;
+}
+
+jstring AesKit::Decrypt(JNIEnv *env, const char *input) {
+    jclass clz = env->FindClass("cn/yyxx/support/encryption/aes/AesUtils");
+    if (clz == nullptr) {
+        LOGD("aes impl clz is nullptr !!!");
+        return env->NewStringUTF("");
+    }
+    const char *method_name = "decrypt2hex";
+    const char *sig = "(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;";
+    jmethodID mid = env->GetStaticMethodID(clz, method_name, sig);
+    jstring key = env->NewStringUTF(AES_KEY);
+    jstring iv = env->NewStringUTF(IV);
+    jstring data = env->NewStringUTF(input);
+    auto result = (jstring) env->CallStaticObjectMethod(clz, mid, key, iv, data);
+    env->DeleteLocalRef(clz);
+    env->DeleteLocalRef(key);
+    env->DeleteLocalRef(iv);
+    env->DeleteLocalRef(data);
+    return result;
+}
+
+

+ 36 - 0
library_core/src/main/cpp/aes_kit.h

@@ -0,0 +1,36 @@
+//
+// Created by #Suyghur, on 2021/10/15.
+//
+
+#ifndef YYXXCOMMSDK_AES_KIT_H
+#define YYXXCOMMSDK_AES_KIT_H
+
+
+#define BLOCK_LEN 16
+
+#define AES_KEY "8eb99e1f9813f24b5edb7a501ceae5ac"
+
+#define IV "8eb99e1f9813f24b"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+class AesKit {
+public:
+
+
+    static jstring Encrypt(JNIEnv *env, const char *input);
+
+    static jstring Decrypt(JNIEnv *env, const char *input);
+
+
+
+};
+
+#ifdef __cplusplus
+}
+#endif
+
+
+#endif //YYXXCOMMSDK_AES_KIT_H

+ 320 - 0
library_core/src/main/cpp/external/md5/md5.cpp

@@ -0,0 +1,320 @@
+//
+// Created by #Suyghur, on 2021/05/25.
+//
+
+#include "external/md5/md5.h"
+
+/* system implementation headers */
+#include <stdio.h>
+#include <cstring>
+
+
+// Constants for MD5Transform routine.
+#define S11 7
+#define S12 12
+#define S13 17
+#define S14 22
+#define S21 5
+#define S22 9
+#define S23 14
+#define S24 20
+#define S31 4
+#define S32 11
+#define S33 16
+#define S34 23
+#define S41 6
+#define S42 10
+#define S43 15
+#define S44 21
+
+///////////////////////////////////////////////
+
+// F, G, H and I are basic MD5 functions.
+inline MD5::uint4 MD5::F(uint4 x, uint4 y, uint4 z) {
+    return x & y | ~x & z;
+}
+
+inline MD5::uint4 MD5::G(uint4 x, uint4 y, uint4 z) {
+    return x & z | y & ~z;
+}
+
+inline MD5::uint4 MD5::H(uint4 x, uint4 y, uint4 z) {
+    return x ^ y ^ z;
+}
+
+inline MD5::uint4 MD5::I(uint4 x, uint4 y, uint4 z) {
+    return y ^ (x | ~z);
+}
+
+// rotate_left rotates x left n bits.
+inline MD5::uint4 MD5::rotate_left(uint4 x, int n) {
+    return (x << n) | (x >> (32 - n));
+}
+
+// FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4.
+// Rotation is separate from addition to prevent recomputation.
+inline void MD5::FF(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac) {
+    a = rotate_left(a + F(b, c, d) + x + ac, s) + b;
+}
+
+inline void MD5::GG(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac) {
+    a = rotate_left(a + G(b, c, d) + x + ac, s) + b;
+}
+
+inline void MD5::HH(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac) {
+    a = rotate_left(a + H(b, c, d) + x + ac, s) + b;
+}
+
+inline void MD5::II(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac) {
+    a = rotate_left(a + I(b, c, d) + x + ac, s) + b;
+}
+
+//////////////////////////////////////////////
+
+// default ctor, just initailize
+MD5::MD5() {
+    init();
+}
+
+//////////////////////////////////////////////
+
+// nifty shortcut ctor, compute MD5 for string and finalize it right away
+MD5::MD5(const std::string &text) {
+    init();
+    update(text.c_str(), text.length());
+    finalize();
+}
+
+//////////////////////////////
+
+void MD5::init() {
+    finalized = false;
+
+    count[0] = 0;
+    count[1] = 0;
+
+    // load magic initialization constants.
+    state[0] = 0x67452301;
+    state[1] = 0xefcdab89;
+    state[2] = 0x98badcfe;
+    state[3] = 0x10325476;
+}
+
+//////////////////////////////
+
+// decodes input (unsigned char) into output (uint4). Assumes len is a multiple of 4.
+void MD5::decode(uint4 output[], const uint1 input[], size_type len) {
+    for (unsigned int i = 0, j = 0; j < len; i++, j += 4)
+        output[i] = ((uint4) input[j]) | (((uint4) input[j + 1]) << 8) |
+                    (((uint4) input[j + 2]) << 16) | (((uint4) input[j + 3]) << 24);
+}
+
+//////////////////////////////
+
+// encodes input (uint4) into output (unsigned char). Assumes len is
+// a multiple of 4.
+void MD5::encode(uint1 output[], const uint4 input[], size_type len) {
+    for (size_type i = 0, j = 0; j < len; i++, j += 4) {
+        output[j] = input[i] & 0xff;
+        output[j + 1] = (input[i] >> 8) & 0xff;
+        output[j + 2] = (input[i] >> 16) & 0xff;
+        output[j + 3] = (input[i] >> 24) & 0xff;
+    }
+}
+
+//////////////////////////////
+
+// apply MD5 algo on a block
+void MD5::transform(const uint1 block[blocksize]) {
+    uint4 a = state[0], b = state[1], c = state[2], d = state[3], x[16];
+    decode(x, block, blocksize);
+
+    /* Round 1 */
+    FF(a, b, c, d, x[0], S11, 0xd76aa478); /* 1 */
+    FF(d, a, b, c, x[1], S12, 0xe8c7b756); /* 2 */
+    FF(c, d, a, b, x[2], S13, 0x242070db); /* 3 */
+    FF(b, c, d, a, x[3], S14, 0xc1bdceee); /* 4 */
+    FF(a, b, c, d, x[4], S11, 0xf57c0faf); /* 5 */
+    FF(d, a, b, c, x[5], S12, 0x4787c62a); /* 6 */
+    FF(c, d, a, b, x[6], S13, 0xa8304613); /* 7 */
+    FF(b, c, d, a, x[7], S14, 0xfd469501); /* 8 */
+    FF(a, b, c, d, x[8], S11, 0x698098d8); /* 9 */
+    FF(d, a, b, c, x[9], S12, 0x8b44f7af); /* 10 */
+    FF(c, d, a, b, x[10], S13, 0xffff5bb1); /* 11 */
+    FF(b, c, d, a, x[11], S14, 0x895cd7be); /* 12 */
+    FF(a, b, c, d, x[12], S11, 0x6b901122); /* 13 */
+    FF(d, a, b, c, x[13], S12, 0xfd987193); /* 14 */
+    FF(c, d, a, b, x[14], S13, 0xa679438e); /* 15 */
+    FF(b, c, d, a, x[15], S14, 0x49b40821); /* 16 */
+
+    /* Round 2 */
+    GG(a, b, c, d, x[1], S21, 0xf61e2562); /* 17 */
+    GG(d, a, b, c, x[6], S22, 0xc040b340); /* 18 */
+    GG(c, d, a, b, x[11], S23, 0x265e5a51); /* 19 */
+    GG(b, c, d, a, x[0], S24, 0xe9b6c7aa); /* 20 */
+    GG(a, b, c, d, x[5], S21, 0xd62f105d); /* 21 */
+    GG(d, a, b, c, x[10], S22, 0x2441453); /* 22 */
+    GG(c, d, a, b, x[15], S23, 0xd8a1e681); /* 23 */
+    GG(b, c, d, a, x[4], S24, 0xe7d3fbc8); /* 24 */
+    GG(a, b, c, d, x[9], S21, 0x21e1cde6); /* 25 */
+    GG(d, a, b, c, x[14], S22, 0xc33707d6); /* 26 */
+    GG(c, d, a, b, x[3], S23, 0xf4d50d87); /* 27 */
+    GG(b, c, d, a, x[8], S24, 0x455a14ed); /* 28 */
+    GG(a, b, c, d, x[13], S21, 0xa9e3e905); /* 29 */
+    GG(d, a, b, c, x[2], S22, 0xfcefa3f8); /* 30 */
+    GG(c, d, a, b, x[7], S23, 0x676f02d9); /* 31 */
+    GG(b, c, d, a, x[12], S24, 0x8d2a4c8a); /* 32 */
+
+    /* Round 3 */
+    HH(a, b, c, d, x[5], S31, 0xfffa3942); /* 33 */
+    HH(d, a, b, c, x[8], S32, 0x8771f681); /* 34 */
+    HH(c, d, a, b, x[11], S33, 0x6d9d6122); /* 35 */
+    HH(b, c, d, a, x[14], S34, 0xfde5380c); /* 36 */
+    HH(a, b, c, d, x[1], S31, 0xa4beea44); /* 37 */
+    HH(d, a, b, c, x[4], S32, 0x4bdecfa9); /* 38 */
+    HH(c, d, a, b, x[7], S33, 0xf6bb4b60); /* 39 */
+    HH(b, c, d, a, x[10], S34, 0xbebfbc70); /* 40 */
+    HH(a, b, c, d, x[13], S31, 0x289b7ec6); /* 41 */
+    HH(d, a, b, c, x[0], S32, 0xeaa127fa); /* 42 */
+    HH(c, d, a, b, x[3], S33, 0xd4ef3085); /* 43 */
+    HH(b, c, d, a, x[6], S34, 0x4881d05); /* 44 */
+    HH(a, b, c, d, x[9], S31, 0xd9d4d039); /* 45 */
+    HH(d, a, b, c, x[12], S32, 0xe6db99e5); /* 46 */
+    HH(c, d, a, b, x[15], S33, 0x1fa27cf8); /* 47 */
+    HH(b, c, d, a, x[2], S34, 0xc4ac5665); /* 48 */
+
+    /* Round 4 */
+    II(a, b, c, d, x[0], S41, 0xf4292244); /* 49 */
+    II(d, a, b, c, x[7], S42, 0x432aff97); /* 50 */
+    II(c, d, a, b, x[14], S43, 0xab9423a7); /* 51 */
+    II(b, c, d, a, x[5], S44, 0xfc93a039); /* 52 */
+    II(a, b, c, d, x[12], S41, 0x655b59c3); /* 53 */
+    II(d, a, b, c, x[3], S42, 0x8f0ccc92); /* 54 */
+    II(c, d, a, b, x[10], S43, 0xffeff47d); /* 55 */
+    II(b, c, d, a, x[1], S44, 0x85845dd1); /* 56 */
+    II(a, b, c, d, x[8], S41, 0x6fa87e4f); /* 57 */
+    II(d, a, b, c, x[15], S42, 0xfe2ce6e0); /* 58 */
+    II(c, d, a, b, x[6], S43, 0xa3014314); /* 59 */
+    II(b, c, d, a, x[13], S44, 0x4e0811a1); /* 60 */
+    II(a, b, c, d, x[4], S41, 0xf7537e82); /* 61 */
+    II(d, a, b, c, x[11], S42, 0xbd3af235); /* 62 */
+    II(c, d, a, b, x[2], S43, 0x2ad7d2bb); /* 63 */
+    II(b, c, d, a, x[9], S44, 0xeb86d391); /* 64 */
+
+    state[0] += a;
+    state[1] += b;
+    state[2] += c;
+    state[3] += d;
+
+    // Zeroize sensitive information.
+    memset(x, 0, sizeof x);
+}
+
+//////////////////////////////
+
+// MD5 block update operation. Continues an MD5 message-digest
+// operation, processing another message block
+void MD5::update(const unsigned char input[], size_type length) {
+    // compute number of bytes mod 64
+    size_type index = count[0] / 8 % blocksize;
+
+    // Update number of bits
+    if ((count[0] += (length << 3)) < (length << 3))
+        count[1]++;
+    count[1] += (length >> 29);
+
+    // number of bytes we need to fill in buffer
+    size_type firstpart = 64 - index;
+
+    size_type i;
+
+    // transform as many times as possible.
+    if (length >= firstpart) {
+        // fill buffer first, transform
+        memcpy(&buffer[index], input, firstpart);
+        transform(buffer);
+
+        // transform chunks of blocksize (64 bytes)
+        for (i = firstpart; i + blocksize <= length; i += blocksize)
+            transform(&input[i]);
+
+        index = 0;
+    } else
+        i = 0;
+
+    // buffer remaining input
+    memcpy(&buffer[index], &input[i], length - i);
+}
+
+//////////////////////////////
+
+// for convenience provide a verson with signed char
+void MD5::update(const char input[], size_type length) {
+    update((const unsigned char *) input, length);
+}
+
+//////////////////////////////
+
+// MD5 finalization. Ends an MD5 message-digest operation, writing the
+// the message digest and zeroizing the context.
+MD5 &MD5::finalize() {
+    static unsigned char padding[64] = {
+            0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
+    };
+
+    if (!finalized) {
+        // Save number of bits
+        unsigned char bits[8];
+        encode(bits, count, 8);
+
+        // pad out to 56 mod 64.
+        size_type index = count[0] / 8 % 64;
+        size_type padLen = (index < 56) ? (56 - index) : (120 - index);
+        update(padding, padLen);
+
+        // Append length (before padding)
+        update(bits, 8);
+
+        // Store state in digest
+        encode(digest, state, 16);
+
+        // Zeroize sensitive information.
+        memset(buffer, 0, sizeof buffer);
+        memset(count, 0, sizeof count);
+
+        finalized = true;
+    }
+
+    return *this;
+}
+
+//////////////////////////////
+
+// return hex representation of digest as string
+std::string MD5::HexDigest() const {
+    if (!finalized)
+        return "";
+
+    char buf[33];
+    for (int i = 0; i < 16; i++)
+        sprintf(buf + i * 2, "%02x", digest[i]);
+    buf[32] = 0;
+
+    return std::string(buf);
+}
+
+//////////////////////////////
+
+std::ostream &operator<<(std::ostream &out, MD5 md5) {
+    return out << md5.HexDigest();
+}
+
+//////////////////////////////
+
+std::string md5(const std::string& str) {
+    MD5 md5 = MD5(str);
+
+    return md5.HexDigest();
+}

+ 94 - 0
library_core/src/main/cpp/external/md5/md5.h

@@ -0,0 +1,94 @@
+//
+// Created by #Suyghur, on 2021/05/25.
+//
+
+#ifndef XINRUIGAMESDK_MD5_H
+#define XINRUIGAMESDK_MD5_H
+
+
+#include <string>
+#include <iostream>
+
+
+// a small class for calculating MD5 hashes of strings or byte arrays
+// it is not meant to be fast or secure
+//
+// usage:
+//      1) feed it blocks of uchars with update()
+//      2) finalize()
+//      3) get HexDigest() string
+//      or
+//      MD5(std::string).HexDigest()
+//
+// assumes that char is 8 bit and int is 32 bit
+
+#ifdef __cplusplus
+extern "C"{
+#endif
+
+class MD5 {
+public:
+    typedef unsigned int size_type; // must be 32bit
+
+    MD5();
+
+    MD5(const std::string &text);
+
+    void update(const unsigned char *buf, size_type length);
+
+    void update(const char *buf, size_type length);
+
+    MD5 &finalize();
+
+    std::string HexDigest() const;
+
+    friend std::ostream &operator<<(std::ostream &, MD5 md5);
+
+private:
+    void init();
+
+    typedef unsigned char uint1; //  8bit
+    typedef unsigned int uint4;  // 32bit
+    enum {
+        blocksize = 64
+    }; // VC6 won't eat a const static int here
+
+    void transform(const uint1 block[blocksize]);
+
+    static void decode(uint4 output[], const uint1 input[], size_type len);
+
+    static void encode(uint1 output[], const uint4 input[], size_type len);
+
+    bool finalized;
+    uint1 buffer[blocksize]; // bytes that didn't fit in last 64 byte chunk
+    uint4 count[2];   // 64bit counter for number of bits (lo, hi)
+    uint4 state[4];   // digest so far
+    uint1 digest[16]; // the result
+
+    // low level logic operations
+    static inline uint4 F(uint4 x, uint4 y, uint4 z);
+
+    static inline uint4 G(uint4 x, uint4 y, uint4 z);
+
+    static inline uint4 H(uint4 x, uint4 y, uint4 z);
+
+    static inline uint4 I(uint4 x, uint4 y, uint4 z);
+
+    static inline uint4 rotate_left(uint4 x, int n);
+
+    static inline void FF(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac);
+
+    static inline void GG(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac);
+
+    static inline void HH(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac);
+
+    static inline void II(uint4 &a, uint4 b, uint4 c, uint4 d, uint4 x, uint4 s, uint4 ac);
+};
+
+std::string md5(const std::string &str);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif //XINRUIGAMESDK_MD5_H

+ 34 - 0
library_core/src/main/cpp/params_kit.cpp

@@ -0,0 +1,34 @@
+//
+// Created by #Suyghur, on 2021/10/15.
+//
+
+#include "include/tool_kit.h"
+#include "include/yylog.h"
+#include "include/params_kit.h"
+
+std::string ParamsKit::GetGcpCode(JNIEnv *env, jobject context) {
+    return GetCnfValue(env, context, GCP_CODE);
+}
+
+std::string ParamsKit::GetChannelTag(JNIEnv *env, jobject context) {
+    return GetCnfValue(env, context, CHANNEL_TAG);
+}
+
+std::string ParamsKit::GetCnfValue(JNIEnv *env, jobject context, const std::string &key) {
+    jclass clz = env->FindClass("com/yyrh/utils/FileUtils");
+    if (clz == nullptr) {
+        LOGE("FileUtils clz is null");
+        return "";
+    }
+    const char *method_name = "readAssetsFileByKey";
+    const char *sig = "(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;";
+    jmethodID mid = env->GetStaticMethodID(clz, method_name, sig);
+    jstring file_name = env->NewStringUTF(CONFIG_FILE);
+    jstring key_name = env->NewStringUTF(key.c_str());
+    auto result = (jstring) env->CallStaticObjectMethod(clz, mid, context, file_name, key_name);
+    env->DeleteLocalRef(clz);
+    env->DeleteLocalRef(file_name);
+    env->DeleteLocalRef(key_name);
+
+    return ToolKit::JString2String(env, result);
+}

+ 33 - 0
library_core/src/main/cpp/params_kit.h

@@ -0,0 +1,33 @@
+//
+// Created by #Suyghur, on 2021/10/15.
+//
+
+#ifndef XINRUIGAMESDK_PARAMS_KIT_H
+#define XINRUIGAMESDK_PARAMS_KIT_H
+
+#include <string>
+#include <jni.h>
+
+#define CONFIG_FILE "YyrhParam.cnf"
+#define GCP_CODE "GCP_CODE"
+#define CHANNEL_TAG "CHANNELTAG"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+class ParamsKit {
+public:
+    static std::string GetGcpCode(JNIEnv *env, jobject context);
+
+    static std::string GetChannelTag(JNIEnv *env, jobject context);
+
+private:
+    static std::string GetCnfValue(JNIEnv *env, jobject context, const std::string &key);
+};
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif //XINRUIGAMESDK_PARAMS_KIT_H

+ 0 - 0
library_core/src/main/cpp/tool_kit.h


+ 68 - 0
library_core/src/main/cpp/yylog.cpp

@@ -0,0 +1,68 @@
+//
+// Created by #Suyghur, on 2021/10/15.
+//
+
+#include "include/yylog.h"
+
+bool YYLog::is_debug = true;
+
+void YYLog::D(JNIEnv *env, const std::string &msg) {
+    if (is_debug) {
+        jclass clz = env->FindClass("com/yyrh/utils/YYLog");
+        if (clz == nullptr) {
+            LOGE("YYLog clz is null");
+            return;
+        }
+        const char *method_name = "d";
+        const char *sig = "(Ljava/lang/String;Ljava/lang/Object;)V";
+        jmethodID mid = env->GetStaticMethodID(clz, method_name, sig);
+        jstring jtag = env->NewStringUTF(TAG);
+        jstring jmsg = env->NewStringUTF(msg.c_str());
+        env->CallStaticVoidMethod(clz, mid, jtag, jmsg);
+    }
+}
+
+void YYLog::I(JNIEnv *env, const std::string &msg) {
+    jclass clz = env->FindClass("com/yyrh/utils/YYLog");
+    if (clz == nullptr) {
+        LOGE("YYLog clz is null");
+        return;
+    }
+    const char *method_name = "i";
+    const char *sig = "(Ljava/lang/String;Ljava/lang/Object;)V";
+    jmethodID mid = env->GetStaticMethodID(clz, method_name, sig);
+    jstring jtag = env->NewStringUTF(TAG);
+    jstring jmsg = env->NewStringUTF(msg.c_str());
+    env->CallStaticVoidMethod(clz, mid, jtag, jmsg);
+}
+
+void YYLog::E(JNIEnv *env, const std::string &msg) {
+    jclass clz = env->FindClass("com/yyrh/utils/YYLog");
+    if (clz == nullptr) {
+        LOGE("YYLog clz is null");
+        return;
+    }
+    const char *method_name = "e";
+    const char *sig = "(Ljava/lang/String;Ljava/lang/Object;)V";
+    jmethodID mid = env->GetStaticMethodID(clz, method_name, sig);
+    jstring jtag = env->NewStringUTF(TAG);
+    jstring jmsg = env->NewStringUTF(msg.c_str());
+    env->CallStaticVoidMethod(clz, mid, jtag, jmsg);
+}
+
+void YYLog::LogHandler(JNIEnv *env, const std::string &msg) {
+    jclass clz = env->FindClass("com/yyrh/utils/YYLog");
+    if (clz == nullptr) {
+        LOGE("YYLog clz is null");
+        return;
+    }
+    const char *method_name = "logHandler";
+    const char *sig = "(Ljava/lang/String;)V";
+    jmethodID mid = env->GetStaticMethodID(clz, method_name, sig);
+    jstring jmsg = env->NewStringUTF(msg.c_str());
+    env->CallStaticVoidMethod(clz, mid, jmsg);
+}
+
+
+
+

+ 41 - 0
library_core/src/main/cpp/yylog.h

@@ -0,0 +1,41 @@
+//
+// Created by #Suyghur, on 2021/10/15.
+//
+
+#ifndef XINRUIGAMESDK_YYLOG_H
+#define XINRUIGAMESDK_YYLOG_H
+
+
+#include <string>
+#include <android/log.h>
+#include <jni.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define TAG "YYLog"
+#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,TAG,__VA_ARGS__)
+#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG,__VA_ARGS__)
+
+class YYLog {
+
+public:
+
+    static bool is_debug;
+
+    static void D(JNIEnv *env, const std::string &msg);
+
+    static void I(JNIEnv *env, const std::string &msg);
+
+    static void E(JNIEnv *env, const std::string &msg);
+
+    static void LogHandler(JNIEnv *env, const std::string &msg);
+
+};
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif //XINRUIGAMESDK_YYLOG_H

+ 19 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/constants/Constants.java

@@ -0,0 +1,19 @@
+package com.yyrh.constant;
+
+public class Constants {
+
+    public static final String UPLOADTYPE_CREATEROLE = "UPLOADTYPE_CREATEROLE";					//创建角色
+    public static final String UPLOADTYPE_ENTERGAME = "UPLOADTYPE_ENTERGAME";
+    public static final String UPLOADTYPE_LEVELUP = "UPLOADTYPE_LEVELUP";
+
+
+    public static final String LOGIN = "LOGIN";
+
+    public static final String LOGOUT = "LOGOUT";
+
+
+    public static final long CLICK_INTERVAL = 2000L;
+
+
+
+}

+ 2 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/permission/PermissionManager.java

@@ -0,0 +1,2 @@
+package cn.yyxx.commsdk.core.permission;public class PermissionManager {
+}

+ 2 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/ui/dialog/PrivacyPolicyDialog.java

@@ -0,0 +1,2 @@
+package cn.yyxx.commsdk.core.ui.dialog;public class PrivacyPolicy {
+}

+ 35 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/utils/FileUtils.java

@@ -0,0 +1,35 @@
+package com.yyrh.utils;
+
+import android.content.Context;
+
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+
+/**
+ * @author #Suyghur.
+ * Created on 2021/10/15
+ */
+public class FileUtils {
+
+    public static String readAssetsFileByKey(Context context, String fileName, String key) {
+        String value = "";
+        InputStream is = null;
+        try {
+            is = context.getAssets().open(fileName);
+            BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(is));
+            String temp = "";
+            while ((temp = bufferedReader.readLine()) != null) {
+                if (temp.contains(key)) {
+                    value = temp.substring(temp.indexOf("=") + 1);
+                    break;
+                }
+            }
+            bufferedReader.close();
+        } catch (IOException e) {
+            e.printStackTrace();
+        }
+        return value;
+    }
+}

+ 36 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/utils/ManifestUtils.java

@@ -0,0 +1,36 @@
+package com.yyrh.utils;
+
+import android.content.Context;
+import android.content.pm.ApplicationInfo;
+import android.content.pm.PackageManager;
+import android.text.TextUtils;
+
+/**
+ * @author #Suyghur.
+ * Created on 2021/10/18
+ */
+public class ManifestUtils {
+
+    public static String getMetaDataValue(Context context, String key) {
+        Object value = "";
+        if (TextUtils.isEmpty(key)) {
+            YYLog.e("metaName is empty");
+            return "";
+        }
+        try {
+            ApplicationInfo info = context.getPackageManager().getApplicationInfo(context.getPackageName(), PackageManager.GET_META_DATA);
+            value = info.metaData.get(key);
+            // 是否有引用
+            if (null != value && value.toString().contains("ref=")) {
+                String newKeyName = value.toString().split("=")[1];
+                value = getMetaDataValue(context, newKeyName);
+            }
+        } catch (PackageManager.NameNotFoundException e) {
+            YYLog.e("must config application meta data : " + key);
+        }
+        if (null == value) {
+            value = "";
+        }
+        return value.toString();
+    }
+}

+ 69 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/utils/ResourceUtil.java

@@ -0,0 +1,69 @@
+package com.yyrh.utils;
+
+import android.content.Context;
+
+import java.lang.reflect.Field;
+
+public class ResourceUtil 
+{
+	public static int getLayoutId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString, "layout", 
+                paramContext.getPackageName()); 
+    } 
+ 
+    public static int getStringId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString, "string", 
+                paramContext.getPackageName()); 
+    }
+
+ 
+    public static int getDrawableId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString, 
+                "drawable", paramContext.getPackageName()); 
+    }
+
+    public static int getMipmapId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString,
+                "mipmap", paramContext.getPackageName());
+    }
+    public static int getStyleId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString, 
+                "style", paramContext.getPackageName()); 
+    }
+
+    public static int getId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString,"id", paramContext.getPackageName()); 
+    } 
+     
+    public static int getColorId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString, 
+                "color", paramContext.getPackageName()); 
+    } 
+    public static int getArrayId(Context paramContext, String paramString) {
+        return paramContext.getResources().getIdentifier(paramString, 
+                "array", paramContext.getPackageName()); 
+    }
+
+    public static int[] getStyleableIntArray(Context context, String name) {
+        try {
+            Field[] fields = Class.forName(context.getPackageName() + ".R$styleable").getFields();//.与$ difference,$表示R的子类
+            for (Field field : fields) {
+                if (field.getName().equals(name)) {
+                    int ret[] = (int[]) field.get(null);
+                    return ret;
+                }
+            }
+        } catch (Throwable e) {
+            e.printStackTrace();
+        }
+        return null;
+    }
+
+
+    public static int getAnimId(Context paramContext, String paramString){
+
+	    return paramContext.getResources().getIdentifier(paramString,
+                "anim", paramContext.getPackageName());
+
+    }
+}

+ 2 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/utils/SharedPreferencesUtils.java

@@ -0,0 +1,2 @@
+package cn.yyxx.commsdk.core.utils;public class SharedPreferencesUtils {
+}

+ 84 - 0
library_core/src/main/java/cn/yyxx/commsdk/core/utils/YYLog.java

@@ -0,0 +1,84 @@
+package com.yyrh.utils;
+
+import android.app.Application;
+
+import com.dolin.zap.Zap;
+import com.dolin.zap.entity.Config;
+import com.dolin.zap.entity.Level;
+
+import cn.yyxx.support.hawkeye.LogUtils;
+
+public final class YYLog {
+
+    private static final String TAG = "YYLog";
+    private static boolean hasZapInit = false;
+
+    private YYLog() {
+    }
+
+    public static void initZap(Application application) {
+        Level level = null;
+        if (LogUtils.DEBUG) {
+            level = Level.DEBUG;
+        } else {
+            level = Level.INFO;
+        }
+        Config config = new Config.Builder()
+                //logcat输出最低等级
+                .setLogcatLevel(level)
+                //是否开启缓存日志
+                .setRecordEnable(true)
+                //缓存日志最低等级
+                .setRecordLevel(Level.DEBUG)
+                //是否开启压缩缓存日志内容
+                .setCompressEnable(true)
+                //缓存文件的过期时间
+                .setOverdueDay(3)
+                //缓存文件大小限制,超过则会自动扩容新文件
+                .setFileSizeLimitDay(10)
+                .create();
+        Zap.initialize(application, config);
+        hasZapInit = true;
+    }
+
+    public static void d(Object object) {
+        d(TAG, object);
+    }
+
+    public static void d(String tag, Object object) {
+        if (hasZapInit) {
+            Zap.d(tag, object);
+        } else {
+            LogUtils.d(tag, object);
+        }
+    }
+
+    public static void i(Object object) {
+        i(TAG, object);
+    }
+
+    public static void i(String tag, Object object) {
+        if (hasZapInit) {
+            Zap.i(tag, object);
+        } else {
+            LogUtils.i(tag, object);
+        }
+    }
+
+    public static void e(Object object) {
+        e(TAG, object);
+    }
+
+    public static void e(String tag, Object object) {
+        if (hasZapInit) {
+            Zap.e(tag, object);
+        } else {
+            LogUtils.e(tag, object);
+        }
+    }
+
+    public static void logHandler(String msg) {
+        LogUtils.logHandler(msg);
+    }
+
+}

+ 12 - 0
library_core/src/main/res/drawable/yyxx_btn_exit_bg.xml

@@ -0,0 +1,12 @@
+<?xml version="1.0" encoding="utf-8"?>
+<shape xmlns:android="http://schemas.android.com/apk/res/android" >
+
+
+
+    <stroke android:width="1dp" android:color="@color/hnyy_text_cyan_color"/>
+    <corners
+        android:radius="5dp"
+        />
+
+
+</shape>

+ 2 - 0
library_core/src/main/res/drawable/yyxx_comm_background.xml

@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="utf-8"?>
+<resources></resources>

+ 12 - 0
library_core/src/main/res/drawable/yyxx_comm_confirm_button_style.xml

@@ -0,0 +1,12 @@
+<?xml version="1.0" encoding="utf-8"?>
+<shape xmlns:android="http://schemas.android.com/apk/res/android" >
+
+
+
+
+
+        <gradient android:type="linear" android:useLevel="true" android:startColor="@color/hnyy_text_light_blue_color" android:endColor="@color/hnyy_text_deep_green_color" android:angle="180" />
+        <corners  android:radius="5dp" />
+
+
+</shape>

+ 81 - 0
library_core/src/main/res/layout/yyxx_comm_privacy_dialog.xml

@@ -0,0 +1,81 @@
+<?xml version="1.0" encoding="utf-8"?>
+<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
+    android:layout_width="360dp"
+    android:layout_height="280dp"
+    android:background="@drawable/hnyy_color_white_70"
+    android:orientation="vertical"
+    android:id="@+id/ll_private_policy"
+    >
+
+
+<RelativeLayout
+    android:layout_width="match_parent"
+    android:layout_height="0dp"
+    android:layout_weight="7"
+    android:layout_marginTop="10dp"
+    android:layout_marginLeft="2dp"
+    android:layout_marginRight="2dp"
+    >
+        <WebView
+            android:id="@+id/wb_user_info"
+            android:layout_width="match_parent"
+            android:layout_height="match_parent"
+            android:layout_gravity="center"
+            android:background="@color/hnyy_transparent"
+            />
+
+    <ImageView
+            android:layout_width="30dp"
+            android:layout_height="30dp"
+            android:layout_centerInParent="true"
+            android:id="@+id/hnyy_loading"
+            android:background="@mipmap/hnyy_loading"/>
+</RelativeLayout>
+    <LinearLayout
+        android:layout_width="match_parent"
+        android:layout_height="0dp"
+        android:layout_weight="3"
+        android:orientation="horizontal"
+        >
+        <View
+            android:layout_width="0dp"
+            android:layout_height="match_parent"
+            android:layout_weight="1"
+            />
+        <Button
+
+            android:id="@+id/btn_disagree"
+            android:layout_width="0dp"
+            android:layout_height="30dp"
+            android:layout_weight="2"
+            android:layout_gravity="center"
+            android:text="@string/hnyy_disagreement"
+            android:textColor="@color/hnyy_text_cyan_color"
+            android:background="@drawable/hnyy_btn_exit_bg"/>
+        <View
+            android:layout_width="0dp"
+            android:layout_height="match_parent"
+            android:layout_weight="1"
+            />
+        <View
+            android:layout_width="0dp"
+            android:layout_height="match_parent"
+            android:layout_weight="1"
+            />
+
+        <Button
+            android:id="@+id/btn_agree"
+            android:layout_width="0dp"
+            android:layout_height="30dp"
+            android:layout_weight="2"
+            android:layout_gravity="center"
+            android:background="@drawable/hnyy_login_button_style"
+            android:textColor="@color/hnyy_white"
+            android:text="@string/hnyy_agreement"/>
+        <View
+            android:layout_width="0dp"
+            android:layout_height="match_parent"
+            android:layout_weight="1"
+            />
+    </LinearLayout>
+</LinearLayout>

+ 6 - 0
library_core/src/main/res/values/yyxx_comm_colors.xml

@@ -0,0 +1,6 @@
+<?xml version="1.0" encoding="utf-8"?>
+<resources>
+    <color name="yyxx_comm_transparent">#00000000</color>
+    <color name="yyxx_comm_text_cyan">#12B2A6</color>
+    <color name="yyxx_comm_white">#FFFFFF</color>
+</resources>

+ 3 - 0
library_core/src/main/res/values/yyxx_comm_strings.xml

@@ -0,0 +1,3 @@
+<?xml version="1.0" encoding="utf-8"?>
+<resources>
+</resources>