diff --git a/RichSpin96/.gitignore b/RichSpin96/.gitignore new file mode 100644 index 0000000..956c004 --- /dev/null +++ b/RichSpin96/.gitignore @@ -0,0 +1,2 @@ +/build +/release \ No newline at end of file diff --git a/RichSpin96/build.gradle b/RichSpin96/build.gradle new file mode 100644 index 0000000..0196455 --- /dev/null +++ b/RichSpin96/build.gradle @@ -0,0 +1,48 @@ +plugins { + id 'com.android.application' + id 'com.google.gms.google-services' +} + +android { + compileSdkVersion 31 + buildToolsVersion "30.0.3" + + defaultConfig { + applicationId "com.web.RichSpin96" + minSdkVersion 24 + targetSdkVersion 31 + versionCode 107 + versionName "v1.0.7" + testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" + } + + signingConfigs { + debug { + storeFile file('ppn.jks') + storePassword "2014123456" + keyAlias 'key0' + keyPassword "2014123456" + } + release { + storeFile file('ppn.jks') + storePassword "2014123456" + keyAlias 'key0' + keyPassword "2014123456" + } + } + + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' + } + } + compileOptions { + sourceCompatibility JavaVersion.VERSION_1_8 + targetCompatibility JavaVersion.VERSION_1_8 + } +} + +dependencies { + implementation project(path: ':base') +} \ No newline at end of file diff --git a/RichSpin96/google-services.json b/RichSpin96/google-services.json new file mode 100644 index 0000000..6426be9 --- /dev/null +++ b/RichSpin96/google-services.json @@ -0,0 +1,29 @@ +{ + "project_info": { + "project_number": "360261673317", + "project_id": "richspin96", + "storage_bucket": "richspin96.firebasestorage.app" + }, + "client": [ + { + "client_info": { + "mobilesdk_app_id": "1:360261673317:android:852b67f273cf2ff43c018c", + "android_client_info": { + "package_name": "com.web.RichSpin96" + } + }, + "oauth_client": [], + "api_key": [ + { + "current_key": "AIzaSyCAb2ES7o7VPmJZhLDsIwHlSvrq87c6pQg" + } + ], + "services": { + "appinvite_service": { + "other_platform_oauth_client": [] + } + } + } + ], + "configuration_version": "1" +} \ No newline at end of file diff --git a/RichSpin96/ppn.jks b/RichSpin96/ppn.jks new file mode 100644 index 0000000..5898029 Binary files /dev/null and b/RichSpin96/ppn.jks differ diff --git a/RichSpin96/proguard-rules.pro b/RichSpin96/proguard-rules.pro new file mode 100644 index 0000000..107b7ee --- /dev/null +++ b/RichSpin96/proguard-rules.pro @@ -0,0 +1,32 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile + +-dontwarn dalvik.** +-dontwarn com.tencent.smtt.** + +-keep class com.tencent.smtt.** { + *; +} + +-keep class com.tencent.tbs.** { + *; +} \ No newline at end of file diff --git a/RichSpin96/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java b/RichSpin96/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java new file mode 100644 index 0000000..44b9f39 --- /dev/null +++ b/RichSpin96/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java @@ -0,0 +1,26 @@ +package Tptogiar.calculcator; + +import android.content.Context; + +import androidx.test.platform.app.InstrumentationRegistry; +import androidx.test.ext.junit.runners.AndroidJUnit4; + +import org.junit.Test; +import org.junit.runner.RunWith; + +import static org.junit.Assert.*; + +/** + * Instrumented test, which will execute on an Android device. + * + * @see Testing documentation + */ +@RunWith(AndroidJUnit4.class) +public class ExampleInstrumentedTest { + @Test + public void useAppContext() { + // Context of the app under test. + Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); + assertEquals("Tptogiar.calculcator", appContext.getPackageName()); + } +} \ No newline at end of file diff --git a/RichSpin96/src/main/AndroidManifest.xml b/RichSpin96/src/main/AndroidManifest.xml new file mode 100644 index 0000000..c5f7a67 --- /dev/null +++ b/RichSpin96/src/main/AndroidManifest.xml @@ -0,0 +1,113 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/java/com/web/RichSpin96/MainActivity2.java b/RichSpin96/src/main/java/com/web/RichSpin96/MainActivity2.java new file mode 100644 index 0000000..3e5f7df --- /dev/null +++ b/RichSpin96/src/main/java/com/web/RichSpin96/MainActivity2.java @@ -0,0 +1,56 @@ +package com.web.RichSpin96; + + +import android.content.pm.PackageInfo; +import android.content.pm.PackageManager; +import android.os.Bundle; + +import androidx.annotation.NonNull; + +import com.google.android.gms.tasks.OnCompleteListener; +import com.google.android.gms.tasks.Task; +import com.google.firebase.messaging.FirebaseMessaging; +import com.web.base.MainActivity; + +public class MainActivity2 extends com.web.base.MainActivity2 { + + @Override + protected void onCreate(Bundle savedInstanceState) { + userId = 123; + saveInt(MainActivity2.this,"user_code",userId); + saveInt(MainActivity2.this,"version_code",getVersion()); + MainActivity.saveString(this, "base_url","https://richspin.net/"); + //网页的底部NavigationBar颜色 + MainActivity.saveString(this, "style_color", "#202020"); + //页面的大背景颜色 + MainActivity.saveString(this, "windows_color", "#212121"); + //任务栏的文字颜色 0 黑 1白 默认黑 + saveInt(MainActivity2.this,"is_white",1); + super.onCreate(savedInstanceState); + //用于修改大背景渐变色 不设置 大背景就是 windows_color 的颜色 + setBackDrawables(R.drawable.big_bg); + setImageView(false); + //订阅主题 + FirebaseMessaging.getInstance().subscribeToTopic("demo") + .addOnCompleteListener(task -> { + String msg = "Subscribed"; + if (!task.isSuccessful()) { + msg = "Subscribe failed"; + } + + }); + } + + public int getVersion(){ + try { + PackageManager packageManager = getPackageManager(); + PackageInfo packageInfo = packageManager.getPackageInfo(getPackageName(), 0); + int versionCode = packageInfo.versionCode; // 版本码 + return versionCode; + } catch (PackageManager.NameNotFoundException e) { + return 0; + } + + } + +} diff --git a/RichSpin96/src/main/java/com/web/RichSpin96/MyFirebaseMessageingService.java b/RichSpin96/src/main/java/com/web/RichSpin96/MyFirebaseMessageingService.java new file mode 100644 index 0000000..713cc47 --- /dev/null +++ b/RichSpin96/src/main/java/com/web/RichSpin96/MyFirebaseMessageingService.java @@ -0,0 +1,171 @@ +package com.web.RichSpin96; + +import android.app.NotificationChannel; +import android.app.NotificationManager; +import android.app.PendingIntent; +import android.content.ComponentName; +import android.content.Context; +import android.content.Intent; +import android.os.Build; + +import androidx.annotation.NonNull; +import androidx.core.app.NotificationCompat; + +import com.google.firebase.messaging.FirebaseMessagingService; +import com.google.firebase.messaging.RemoteMessage; +import com.google.gson.Gson; +import com.web.base.GsonUtils; +import com.web.base.MessageInfo; + +import java.util.Map; +import java.util.Random; + +public class MyFirebaseMessageingService extends FirebaseMessagingService { + + public MyFirebaseMessageingService() { + } + + @Override + public void onMessageReceived(@NonNull RemoteMessage remoteMessage) { + super.onMessageReceived(remoteMessage); + Map serviceData = remoteMessage.getData(); //后台推送数据 + if (serviceData != null && serviceData.containsKey("message")) { + String value = serviceData.get("message"); + Gson gson = new Gson(); + MessageInfo messageInfo = gson.fromJson(value, MessageInfo.class); + showNotification(messageInfo); +// if (remoteMessage.getNotification() != null) { +// showNotification(remoteMessage.getNotification().getTitle(), remoteMessage.getNotification().getBody()); +// } + } else { + //收到通知 创建notify + if (remoteMessage.getNotification() != null) { + showNotification(remoteMessage.getNotification().getTitle(), remoteMessage.getNotification().getBody()); + } + } + + + } + + private void showNotification(MessageInfo messageInfo) { + Intent notifyIntent = new Intent(this, com.web.base.MainActivity2.class); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.CUPCAKE) { + ComponentName launchComponent = null; + launchComponent = getApplication() + .getPackageManager() + .getLaunchIntentForPackage(getApplication().getPackageName()) + .getComponent(); + notifyIntent.setComponent(launchComponent); + } + + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); + notifyIntent.setAction(Intent.ACTION_VIEW); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 + notifyIntent.putExtra("message", messageInfo); + + PendingIntent pendingIntent = PendingIntent.getActivity(this, new Random().nextInt(10000), notifyIntent, PendingIntent.FLAG_IMMUTABLE); + +// Intent notifyIntent = new Intent(this, MainActivity2.class); +// notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); +// // notifyIntent.putExtra("message", messageInfo); +// notifyIntent.setAction(Intent.ACTION_VIEW); +// notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 +// PendingIntent pendingIntent; +// pendingIntent = PendingIntent.getActivity +// (this, 0, notifyIntent, PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE); + + NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); + NotificationChannel channelwinway = null; + NotificationCompat.Builder notificationBuilder = null; + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + channelwinway = new NotificationChannel(getString(com.web.base.R.string.app_name), "notify", NotificationManager.IMPORTANCE_DEFAULT); + channelwinway.enableLights(true); + channelwinway.enableVibration(true); + notificationManager.createNotificationChannel(channelwinway); + notificationBuilder = new NotificationCompat.Builder(this, channelwinway.getId()) + .setSmallIcon(R.mipmap.app_logo1) + .setContentTitle(messageInfo.getTitle()) + .setContentText(messageInfo.getContent()) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } else { + notificationBuilder = new NotificationCompat.Builder(this, getString(com.web.base.R.string.app_name)) + .setSmallIcon(R.mipmap.app_logo1) + .setContentTitle(messageInfo.getTitle()) + .setContentText(messageInfo.getContent()) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } + notificationManager.notify(0, notificationBuilder.build()); + } + + private void showNotification(String title, String body) { + Intent notifyIntent = new Intent(this, MainActivity2.class); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.CUPCAKE) { + ComponentName launchComponent = null; + launchComponent = getApplication() + .getPackageManager() + .getLaunchIntentForPackage(getApplication().getPackageName()) + .getComponent(); + notifyIntent.setComponent(launchComponent); + } + notifyIntent.putExtra("message", body); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); + notifyIntent.setAction(Intent.ACTION_VIEW); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 + + + PendingIntent pendingIntent = PendingIntent.getActivity(this, new Random().nextInt(10000), notifyIntent, PendingIntent.FLAG_IMMUTABLE); + NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); + NotificationChannel channelwinway = null; + NotificationCompat.Builder notificationBuilder = null; + MessageInfo messageInfo = GsonUtils.getObjFromJSON(body, MessageInfo.class); + if (messageInfo != null) { + body = messageInfo.getContent(); + } + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + channelwinway = new NotificationChannel(getString(com.web.base.R.string.app_name), "notify", NotificationManager.IMPORTANCE_DEFAULT); + channelwinway.enableLights(true); + channelwinway.enableVibration(true); + notificationManager.createNotificationChannel(channelwinway); + notificationBuilder = new NotificationCompat.Builder(this, channelwinway.getId()) + .setSmallIcon(R.mipmap.app_logo1) + .setContentTitle(title) + .setContentText(body) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } else { + notificationBuilder = new NotificationCompat.Builder(this, getString(com.web.base.R.string.app_name)) + .setSmallIcon(R.mipmap.app_logo1) + .setContentTitle(title) + .setContentText(body) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } + notificationManager.notify(0, notificationBuilder.build()); + //存储数据 + // saveNotifyMessage(body); + } + + +// public void saveNotifyMessage(String body) { +// MessageInfo messageInfo = GsonUtils.getObjFromJSON(body, MessageInfo.class); +// String savenotify = Utils.get(getApplication(),ApiService.savenotify,""); +// if(messageInfo!=null){ +// if(TextUtils.isEmpty(savenotify)){ +// GsonUtils.getListFromJSON(savenotify,) +// } +// } +// String jsonString = GsonUtils.beanToJSONString(chatMessageBeans); +// } +// +// /** +// * @param key 要设置的key +// */ +// public static void set(Context activity, String key, String is) { +// SharedPreferences nameSetting = getConfigShared(activity); +// SharedPreferences.Editor namePref = nameSetting.edit(); +// namePref.putString(key, is); +// namePref.commit(); +// } +} diff --git a/RichSpin96/src/main/java/com/web/RichSpin96/WebApplication.java b/RichSpin96/src/main/java/com/web/RichSpin96/WebApplication.java new file mode 100644 index 0000000..111a2b6 --- /dev/null +++ b/RichSpin96/src/main/java/com/web/RichSpin96/WebApplication.java @@ -0,0 +1,37 @@ +package com.web.RichSpin96; + +import android.app.Application; +import android.content.Context; + +import com.tencent.smtt.export.external.TbsCoreSettings; +import com.tencent.smtt.sdk.QbSdk; + +import java.util.HashMap; + +public class WebApplication extends Application { + + + public static Context application; + @Override + public void onCreate() { + super.onCreate(); +// 设置开启优化方案 + application = this; + HashMap map = new HashMap(); + map.put(TbsCoreSettings.TBS_SETTINGS_USE_SPEEDY_CLASSLOADER, true); + map.put(TbsCoreSettings.TBS_SETTINGS_USE_DEXLOADER_SERVICE, true); + QbSdk.initTbsSettings(map); + QbSdk.initX5Environment(this, new QbSdk.PreInitCallback() { + @Override + public void onCoreInitFinished() { + + } + + @Override + public void onViewInitFinished(boolean b) { + + } + }); + QbSdk.setDownloadWithoutWifi(true); + } +} diff --git a/RichSpin96/src/main/res/drawable-anydpi/ic_action_back.xml b/RichSpin96/src/main/res/drawable-anydpi/ic_action_back.xml new file mode 100644 index 0000000..013ab07 --- /dev/null +++ b/RichSpin96/src/main/res/drawable-anydpi/ic_action_back.xml @@ -0,0 +1,11 @@ + + + diff --git a/RichSpin96/src/main/res/drawable-hdpi/ic_action_back.png b/RichSpin96/src/main/res/drawable-hdpi/ic_action_back.png new file mode 100644 index 0000000..1560c04 Binary files /dev/null and b/RichSpin96/src/main/res/drawable-hdpi/ic_action_back.png differ diff --git a/RichSpin96/src/main/res/drawable-mdpi/ic_action_back.png b/RichSpin96/src/main/res/drawable-mdpi/ic_action_back.png new file mode 100644 index 0000000..d5841d2 Binary files /dev/null and b/RichSpin96/src/main/res/drawable-mdpi/ic_action_back.png differ diff --git a/RichSpin96/src/main/res/drawable-v24/ic_launcher_foreground.xml b/RichSpin96/src/main/res/drawable-v24/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/RichSpin96/src/main/res/drawable-v24/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/drawable-xhdpi/ic_action_back.png b/RichSpin96/src/main/res/drawable-xhdpi/ic_action_back.png new file mode 100644 index 0000000..5c14e41 Binary files /dev/null and b/RichSpin96/src/main/res/drawable-xhdpi/ic_action_back.png differ diff --git a/RichSpin96/src/main/res/drawable-xxhdpi/ic_action_back.png b/RichSpin96/src/main/res/drawable-xxhdpi/ic_action_back.png new file mode 100644 index 0000000..0516d08 Binary files /dev/null and b/RichSpin96/src/main/res/drawable-xxhdpi/ic_action_back.png differ diff --git a/RichSpin96/src/main/res/drawable/big_bg.xml b/RichSpin96/src/main/res/drawable/big_bg.xml new file mode 100644 index 0000000..aac19ae --- /dev/null +++ b/RichSpin96/src/main/res/drawable/big_bg.xml @@ -0,0 +1,8 @@ + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/drawable/ic_launcher_background.xml b/RichSpin96/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/RichSpin96/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/RichSpin96/src/main/res/drawable/input_bg.xml b/RichSpin96/src/main/res/drawable/input_bg.xml new file mode 100644 index 0000000..4e895aa --- /dev/null +++ b/RichSpin96/src/main/res/drawable/input_bg.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + + diff --git a/RichSpin96/src/main/res/drawable/pass_word_bg.xml b/RichSpin96/src/main/res/drawable/pass_word_bg.xml new file mode 100644 index 0000000..2724e60 --- /dev/null +++ b/RichSpin96/src/main/res/drawable/pass_word_bg.xml @@ -0,0 +1,28 @@ + + + + + + + + + + + + + + + + + + diff --git a/RichSpin96/src/main/res/drawable/pass_word_bg1.xml b/RichSpin96/src/main/res/drawable/pass_word_bg1.xml new file mode 100644 index 0000000..d10d780 --- /dev/null +++ b/RichSpin96/src/main/res/drawable/pass_word_bg1.xml @@ -0,0 +1,23 @@ + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/drawable/pass_word_bg2.xml b/RichSpin96/src/main/res/drawable/pass_word_bg2.xml new file mode 100644 index 0000000..916d99c --- /dev/null +++ b/RichSpin96/src/main/res/drawable/pass_word_bg2.xml @@ -0,0 +1,23 @@ + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/drawable/shape_btn_bg.xml b/RichSpin96/src/main/res/drawable/shape_btn_bg.xml new file mode 100644 index 0000000..af87a0d --- /dev/null +++ b/RichSpin96/src/main/res/drawable/shape_btn_bg.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/drawable/shape_dialog_bg2.xml b/RichSpin96/src/main/res/drawable/shape_dialog_bg2.xml new file mode 100644 index 0000000..7837a42 --- /dev/null +++ b/RichSpin96/src/main/res/drawable/shape_dialog_bg2.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/drawable/shape_dialog_bg3.xml b/RichSpin96/src/main/res/drawable/shape_dialog_bg3.xml new file mode 100644 index 0000000..ca0a18d --- /dev/null +++ b/RichSpin96/src/main/res/drawable/shape_dialog_bg3.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/drawable/shape_dialog_bg_new.xml b/RichSpin96/src/main/res/drawable/shape_dialog_bg_new.xml new file mode 100644 index 0000000..e96d4e0 --- /dev/null +++ b/RichSpin96/src/main/res/drawable/shape_dialog_bg_new.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/RichSpin96/src/main/res/mipmap-anydpi-v26/ic_launcher.xml new file mode 100644 index 0000000..eca70cf --- /dev/null +++ b/RichSpin96/src/main/res/mipmap-anydpi-v26/ic_launcher.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/RichSpin96/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml new file mode 100644 index 0000000..eca70cf --- /dev/null +++ b/RichSpin96/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/mipmap-hdpi/ic_empty.png b/RichSpin96/src/main/res/mipmap-hdpi/ic_empty.png new file mode 100644 index 0000000..72473d6 Binary files /dev/null and b/RichSpin96/src/main/res/mipmap-hdpi/ic_empty.png differ diff --git a/RichSpin96/src/main/res/mipmap-hdpi/ic_pull_down.png b/RichSpin96/src/main/res/mipmap-hdpi/ic_pull_down.png new file mode 100644 index 0000000..7dc0ec3 Binary files /dev/null and b/RichSpin96/src/main/res/mipmap-hdpi/ic_pull_down.png differ diff --git a/RichSpin96/src/main/res/mipmap-xhdpi/ic_close.png b/RichSpin96/src/main/res/mipmap-xhdpi/ic_close.png new file mode 100644 index 0000000..c0b0127 Binary files /dev/null and b/RichSpin96/src/main/res/mipmap-xhdpi/ic_close.png differ diff --git a/RichSpin96/src/main/res/mipmap-xhdpi/ic_menu.png b/RichSpin96/src/main/res/mipmap-xhdpi/ic_menu.png new file mode 100644 index 0000000..2b55ec5 Binary files /dev/null and b/RichSpin96/src/main/res/mipmap-xhdpi/ic_menu.png differ diff --git a/RichSpin96/src/main/res/mipmap-xxhdpi/app_logo.png b/RichSpin96/src/main/res/mipmap-xxhdpi/app_logo.png new file mode 100644 index 0000000..47cbbc8 Binary files /dev/null and b/RichSpin96/src/main/res/mipmap-xxhdpi/app_logo.png differ diff --git a/RichSpin96/src/main/res/mipmap-xxhdpi/app_logo1.png b/RichSpin96/src/main/res/mipmap-xxhdpi/app_logo1.png new file mode 100644 index 0000000..87db6d0 Binary files /dev/null and b/RichSpin96/src/main/res/mipmap-xxhdpi/app_logo1.png differ diff --git a/RichSpin96/src/main/res/values-en/strings.xml b/RichSpin96/src/main/res/values-en/strings.xml new file mode 100644 index 0000000..1bccc0b --- /dev/null +++ b/RichSpin96/src/main/res/values-en/strings.xml @@ -0,0 +1,52 @@ + + RichSpin96 + Please Set Your Password + Cancel + Sure + New Version Update + Next Update + Update Immediately + Click to close notification + Click to re-download + Download failed + Click to install + Download completed + Downloading... + Version update + Downloading game + Getting download data... + Version update + Downloading game + Need to turn on mobile phone notification permission + Exit + Setting + Tip + Please enter the invitation code + My invitation code: + Superior invitation code: + Total number of invites: + App download link: + Share + Check Invitation Records + Invitation Records + Total number of invitees: %d + No Data + Withdrawal Record + Withdrawal Application + Edit Bank Card Information + 60 + Name: + Please enter the bank card name + Bank card account: + Please enter the bank card account + Country: + Please select a country + Bank Name: + Please select a bank name + Note: Please enter the country code before selecting the bank name! + Balance: %s + Total Earnings: %s + Amount: %s + Please enter the withdrawal amount + Withdrawal application has been submitted + \ No newline at end of file diff --git a/RichSpin96/src/main/res/values-night/themes.xml b/RichSpin96/src/main/res/values-night/themes.xml new file mode 100644 index 0000000..3b0f1a2 --- /dev/null +++ b/RichSpin96/src/main/res/values-night/themes.xml @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/values/colors.xml b/RichSpin96/src/main/res/values/colors.xml new file mode 100644 index 0000000..7895913 --- /dev/null +++ b/RichSpin96/src/main/res/values/colors.xml @@ -0,0 +1,18 @@ + + + #FFFFFF + #FFFFFF + #FFFFFF + #FF03DAC5 + #FF018786 + #FF000000 + #FFFFFFFF + #EF4723 + #FFFFFFFF + + #2C2C2E + #FFA722 + #434343 + #BCBCBC + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/values/strings.xml b/RichSpin96/src/main/res/values/strings.xml new file mode 100644 index 0000000..c5ce978 --- /dev/null +++ b/RichSpin96/src/main/res/values/strings.xml @@ -0,0 +1,74 @@ + + RichSpin96 + 请输入6位密码 + 取消 + 确定 + 版本更新 + 下次更新 + 立即更新 + 点击关闭通知 + 点击重新下载 + 下载失败 + 点击安装 + 下载完成 + 正在下载… + 版本更新 + 下载游戏中 + 版本更新 + 下载游戏中 + 正在获取下载数据… + 需要打开手机通知权限 + 退出 + 设置 + 提示 + 请输入邀请码 + 我的邀请码: + 上级邀请码: + 总邀请人数: + 邀请您下载: + 分享 + 查看邀请记录 + 邀请记录 + 总邀请人数: %d + 暂无数据 + 提现记录 + 提现申请 + 编辑银行卡信息 + 86 + 持卡人姓名: + 请输入持卡人姓名 + 国家地区: + 请选择国家地区 + 开户行名称: + 请选择开户行名称 + 银行户口: + 请输入银行卡户口 + (注:请先输入国家区号再选择开户行名称!) + 余额: %s + 总收益: %s + 金额: %s + 请输入提现金额 + 提现申请已提交 + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/values/themes.xml b/RichSpin96/src/main/res/values/themes.xml new file mode 100644 index 0000000..e1c80ec --- /dev/null +++ b/RichSpin96/src/main/res/values/themes.xml @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/xml/app_updater_paths.xml b/RichSpin96/src/main/res/xml/app_updater_paths.xml new file mode 100644 index 0000000..1254450 --- /dev/null +++ b/RichSpin96/src/main/res/xml/app_updater_paths.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/xml/network_security_config.xml b/RichSpin96/src/main/res/xml/network_security_config.xml new file mode 100644 index 0000000..dca93c0 --- /dev/null +++ b/RichSpin96/src/main/res/xml/network_security_config.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/RichSpin96/src/main/res/xml/provider_paths.xml b/RichSpin96/src/main/res/xml/provider_paths.xml new file mode 100644 index 0000000..c9a897a --- /dev/null +++ b/RichSpin96/src/main/res/xml/provider_paths.xml @@ -0,0 +1,13 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/RichSpin96/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java b/RichSpin96/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java new file mode 100644 index 0000000..3259554 --- /dev/null +++ b/RichSpin96/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java @@ -0,0 +1,35 @@ +package Tptogiar.calculcator; + +import org.junit.Test; + +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import static org.junit.Assert.*; + +/** + * Example local unit test, which will execute on the development machine (host). + * + * @see Testing documentation + */ +public class ExampleUnitTest { + @Test + public void addition_isCorrect() { + assertEquals(4, 2 + 2); + } + + @Test + public void TestPattern(){ +// + Pattern compile = Pattern.compile( "^(\\-|\\+)?\\d+(\\.\\d+)?$"); + String a="+45.5"; + boolean matches = compile.matcher(a).matches(); + System.out.println(matches); + String result = compile.matcher(a).replaceAll(""); + System.out.println(result); + + + } + + +} \ No newline at end of file diff --git a/base/src/main/java/com/web/base/MainActivity2.java b/base/src/main/java/com/web/base/MainActivity2.java index e287bdc..66c23ad 100644 --- a/base/src/main/java/com/web/base/MainActivity2.java +++ b/base/src/main/java/com/web/base/MainActivity2.java @@ -1394,7 +1394,9 @@ public class MainActivity2 extends AppCompatActivity { } else { progressBar.setVisibility(View.VISIBLE); } - if (url1.contains("facebook") || url1.contains("https://t.me") || url1.contains("instagram") || url1.contains("https://x.com")||url1.contains("https://wa.me")) { + if (url1.contains("facebook") || url1.contains("https://t.me") || + url1.contains("instagram") || url1.contains("https://x.com")||url1.contains("https://wa.me")|| + url1.contains("https://m.me")||url1.contains("http://m.me")) { try { Intent intent = new Intent(); intent.setAction(Intent.ACTION_VIEW); @@ -1447,7 +1449,9 @@ public class MainActivity2 extends AppCompatActivity { toStopPlayers(); } } - if (url1.contains("facebook") || url1.contains("https://t.me") || url1.contains("instagram") || url1.contains("https://x.com")||url1.contains("https://wa.me")) { + if (url1.contains("facebook") || url1.contains("https://t.me") || url1.contains("instagram") + || url1.contains("https://x.com")||url1.contains("https://wa.me")|| + url1.contains("https://m.me")||url1.contains("http://m.me")) { try { Intent intent = new Intent(); intent.setAction(Intent.ACTION_VIEW); @@ -1525,7 +1529,7 @@ public class MainActivity2 extends AppCompatActivity { private int rawRes = -1; private void toPlayers() { - AudioManager audioManager = (AudioManager) MainActivity2.this.getSystemService(Context.AUDIO_SERVICE); +// AudioManager audioManager = (AudioManager) MainActivity2.this.getSystemService(Context.AUDIO_SERVICE); // stop(context); if (mp == null) { if (rawRes == -1) { @@ -1610,7 +1614,9 @@ public class MainActivity2 extends AppCompatActivity { } } - if (url.contains("facebook") || url.contains("https://t.me") || url.contains("instagram") || url.contains("https://x.com")||url.contains("https://wa.me")) { + if (url.contains("facebook") || url.contains("https://t.me") || url.contains("instagram") + || url.contains("https://x.com")||url.contains("https://wa.me")|| + url.contains("https://m.me")||url.contains("http://m.me")) { try { Intent intent = new Intent(); intent.setAction(Intent.ACTION_VIEW); diff --git a/base/src/main/res/layout/activity_main2.xml b/base/src/main/res/layout/activity_main2.xml index 1e3ef13..ac589c6 100644 --- a/base/src/main/res/layout/activity_main2.xml +++ b/base/src/main/res/layout/activity_main2.xml @@ -355,7 +355,7 @@ diff --git a/boda8/build.gradle b/boda8/build.gradle index c1a4944..bd6340f 100644 --- a/boda8/build.gradle +++ b/boda8/build.gradle @@ -12,8 +12,8 @@ android { applicationId "com.web.boda8" minSdkVersion 24 targetSdkVersion 31 - versionCode 104 - versionName "v1.0.4" + versionCode 108 + versionName "v1.0.8" testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" } diff --git a/boda8/src/main/java/com/web/boda8/MainActivity2.java b/boda8/src/main/java/com/web/boda8/MainActivity2.java index 019e587..2073305 100644 --- a/boda8/src/main/java/com/web/boda8/MainActivity2.java +++ b/boda8/src/main/java/com/web/boda8/MainActivity2.java @@ -10,6 +10,7 @@ import androidx.annotation.NonNull; import com.google.android.gms.tasks.OnCompleteListener; import com.google.android.gms.tasks.Task; import com.google.firebase.messaging.FirebaseMessaging; +import com.web.base.MainActivity; public class MainActivity2 extends com.web.base.MainActivity2 { @@ -18,19 +19,17 @@ public class MainActivity2 extends com.web.base.MainActivity2 { userId = 58; saveInt(MainActivity2.this,"user_code",userId); saveInt(MainActivity2.this,"version_code",getVersion()); + MainActivity.saveString(this, "base_url","https://bk888.co/"); + //网页的底部NavigationBar颜色 + MainActivity.saveString(this, "style_color", "#4e1b82"); + //页面的大背景颜色 + MainActivity.saveString(this, "windows_color", "#000000"); + //任务栏的文字颜色 0 黑 1白 默认黑 + saveInt(MainActivity2.this,"is_white",1); super.onCreate(savedInstanceState); - //订阅主题 - FirebaseMessaging.getInstance().subscribeToTopic("demo") - .addOnCompleteListener(new OnCompleteListener() { - @Override - public void onComplete(@NonNull Task task) { - String msg = "Subscribed"; - if (!task.isSuccessful()) { - msg = "Subscribe failed"; - } - - } - }); + //用于修改大背景渐变色 不设置 大背景就是 windows_color 的颜色 + setBackDrawables(R.drawable.big_bg); + setImageView(false); } public int getVersion(){ diff --git a/boda8/src/main/res/drawable/big_bg.xml b/boda8/src/main/res/drawable/big_bg.xml new file mode 100644 index 0000000..ce0215e --- /dev/null +++ b/boda8/src/main/res/drawable/big_bg.xml @@ -0,0 +1,8 @@ + + + + \ No newline at end of file diff --git a/dapatcuci/.gitignore b/dapatcuci/.gitignore new file mode 100644 index 0000000..956c004 --- /dev/null +++ b/dapatcuci/.gitignore @@ -0,0 +1,2 @@ +/build +/release \ No newline at end of file diff --git a/dapatcuci/build.gradle b/dapatcuci/build.gradle new file mode 100644 index 0000000..18c8b93 --- /dev/null +++ b/dapatcuci/build.gradle @@ -0,0 +1,48 @@ +plugins { + id 'com.android.application' + id 'com.google.gms.google-services' +} + +android { + compileSdkVersion 31 + buildToolsVersion "30.0.3" + + defaultConfig { + applicationId "com.web.dapatcuci" + minSdkVersion 24 + targetSdkVersion 31 + versionCode 107 + versionName "v1.0.7" + testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" + } + + signingConfigs { + debug { + storeFile file('ppn.jks') + storePassword "2014123456" + keyAlias 'key0' + keyPassword "2014123456" + } + release { + storeFile file('ppn.jks') + storePassword "2014123456" + keyAlias 'key0' + keyPassword "2014123456" + } + } + + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' + } + } + compileOptions { + sourceCompatibility JavaVersion.VERSION_1_8 + targetCompatibility JavaVersion.VERSION_1_8 + } +} + +dependencies { + implementation project(path: ':base') +} \ No newline at end of file diff --git a/dapatcuci/google-services.json b/dapatcuci/google-services.json new file mode 100644 index 0000000..032b9e7 --- /dev/null +++ b/dapatcuci/google-services.json @@ -0,0 +1,29 @@ +{ + "project_info": { + "project_number": "915589275915", + "project_id": "dapatcuci-f9fbe", + "storage_bucket": "dapatcuci-f9fbe.firebasestorage.app" + }, + "client": [ + { + "client_info": { + "mobilesdk_app_id": "1:915589275915:android:77e4bdc5b7b8cc29bb820e", + "android_client_info": { + "package_name": "com.web.dapatcuci" + } + }, + "oauth_client": [], + "api_key": [ + { + "current_key": "AIzaSyB-IEI1Jru5ZT121-oPw6pKlFYYb6zHgAg" + } + ], + "services": { + "appinvite_service": { + "other_platform_oauth_client": [] + } + } + } + ], + "configuration_version": "1" +} \ No newline at end of file diff --git a/dapatcuci/ppn.jks b/dapatcuci/ppn.jks new file mode 100644 index 0000000..5898029 Binary files /dev/null and b/dapatcuci/ppn.jks differ diff --git a/dapatcuci/proguard-rules.pro b/dapatcuci/proguard-rules.pro new file mode 100644 index 0000000..107b7ee --- /dev/null +++ b/dapatcuci/proguard-rules.pro @@ -0,0 +1,32 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile + +-dontwarn dalvik.** +-dontwarn com.tencent.smtt.** + +-keep class com.tencent.smtt.** { + *; +} + +-keep class com.tencent.tbs.** { + *; +} \ No newline at end of file diff --git a/dapatcuci/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java b/dapatcuci/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java new file mode 100644 index 0000000..44b9f39 --- /dev/null +++ b/dapatcuci/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java @@ -0,0 +1,26 @@ +package Tptogiar.calculcator; + +import android.content.Context; + +import androidx.test.platform.app.InstrumentationRegistry; +import androidx.test.ext.junit.runners.AndroidJUnit4; + +import org.junit.Test; +import org.junit.runner.RunWith; + +import static org.junit.Assert.*; + +/** + * Instrumented test, which will execute on an Android device. + * + * @see Testing documentation + */ +@RunWith(AndroidJUnit4.class) +public class ExampleInstrumentedTest { + @Test + public void useAppContext() { + // Context of the app under test. + Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); + assertEquals("Tptogiar.calculcator", appContext.getPackageName()); + } +} \ No newline at end of file diff --git a/dapatcuci/src/main/AndroidManifest.xml b/dapatcuci/src/main/AndroidManifest.xml new file mode 100644 index 0000000..0eec171 --- /dev/null +++ b/dapatcuci/src/main/AndroidManifest.xml @@ -0,0 +1,113 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/java/com/web/dapatcuci/MainActivity2.java b/dapatcuci/src/main/java/com/web/dapatcuci/MainActivity2.java new file mode 100644 index 0000000..f9943ee --- /dev/null +++ b/dapatcuci/src/main/java/com/web/dapatcuci/MainActivity2.java @@ -0,0 +1,56 @@ +package com.web.dapatcuci; + + +import android.content.pm.PackageInfo; +import android.content.pm.PackageManager; +import android.os.Bundle; + +import androidx.annotation.NonNull; + +import com.google.android.gms.tasks.OnCompleteListener; +import com.google.android.gms.tasks.Task; +import com.google.firebase.messaging.FirebaseMessaging; +import com.web.base.MainActivity; + +public class MainActivity2 extends com.web.base.MainActivity2 { + + @Override + protected void onCreate(Bundle savedInstanceState) { + userId = 125; + saveInt(MainActivity2.this,"user_code",userId); + saveInt(MainActivity2.this,"version_code",getVersion()); + MainActivity.saveString(this, "base_url","https://dp18aaa.xyz/"); + //网页的底部NavigationBar颜色 + MainActivity.saveString(this, "style_color", "#183207"); + //页面的大背景颜色 + MainActivity.saveString(this, "windows_color", "#0b1009"); + //任务栏的文字颜色 0 黑 1白 默认黑 + saveInt(MainActivity2.this,"is_white",1); + super.onCreate(savedInstanceState); + //用于修改大背景渐变色 不设置 大背景就是 windows_color 的颜色 + setBackDrawables(R.drawable.big_bg); + setImageView(false); + //订阅主题 + FirebaseMessaging.getInstance().subscribeToTopic("demo") + .addOnCompleteListener(task -> { + String msg = "Subscribed"; + if (!task.isSuccessful()) { + msg = "Subscribe failed"; + } + + }); + } + + public int getVersion(){ + try { + PackageManager packageManager = getPackageManager(); + PackageInfo packageInfo = packageManager.getPackageInfo(getPackageName(), 0); + int versionCode = packageInfo.versionCode; // 版本码 + return versionCode; + } catch (PackageManager.NameNotFoundException e) { + return 0; + } + + } + +} diff --git a/dapatcuci/src/main/java/com/web/dapatcuci/MyFirebaseMessageingService.java b/dapatcuci/src/main/java/com/web/dapatcuci/MyFirebaseMessageingService.java new file mode 100644 index 0000000..317e040 --- /dev/null +++ b/dapatcuci/src/main/java/com/web/dapatcuci/MyFirebaseMessageingService.java @@ -0,0 +1,171 @@ +package com.web.dapatcuci; + +import android.app.NotificationChannel; +import android.app.NotificationManager; +import android.app.PendingIntent; +import android.content.ComponentName; +import android.content.Context; +import android.content.Intent; +import android.os.Build; + +import androidx.annotation.NonNull; +import androidx.core.app.NotificationCompat; + +import com.google.firebase.messaging.FirebaseMessagingService; +import com.google.firebase.messaging.RemoteMessage; +import com.google.gson.Gson; +import com.web.base.GsonUtils; +import com.web.base.MessageInfo; + +import java.util.Map; +import java.util.Random; + +public class MyFirebaseMessageingService extends FirebaseMessagingService { + + public MyFirebaseMessageingService() { + } + + @Override + public void onMessageReceived(@NonNull RemoteMessage remoteMessage) { + super.onMessageReceived(remoteMessage); + Map serviceData = remoteMessage.getData(); //后台推送数据 + if (serviceData != null && serviceData.containsKey("message")) { + String value = serviceData.get("message"); + Gson gson = new Gson(); + MessageInfo messageInfo = gson.fromJson(value, MessageInfo.class); + showNotification(messageInfo); +// if (remoteMessage.getNotification() != null) { +// showNotification(remoteMessage.getNotification().getTitle(), remoteMessage.getNotification().getBody()); +// } + } else { + //收到通知 创建notify + if (remoteMessage.getNotification() != null) { + showNotification(remoteMessage.getNotification().getTitle(), remoteMessage.getNotification().getBody()); + } + } + + + } + + private void showNotification(MessageInfo messageInfo) { + Intent notifyIntent = new Intent(this, com.web.base.MainActivity2.class); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.CUPCAKE) { + ComponentName launchComponent = null; + launchComponent = getApplication() + .getPackageManager() + .getLaunchIntentForPackage(getApplication().getPackageName()) + .getComponent(); + notifyIntent.setComponent(launchComponent); + } + + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); + notifyIntent.setAction(Intent.ACTION_VIEW); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 + notifyIntent.putExtra("message", messageInfo); + + PendingIntent pendingIntent = PendingIntent.getActivity(this, new Random().nextInt(10000), notifyIntent, PendingIntent.FLAG_IMMUTABLE); + +// Intent notifyIntent = new Intent(this, MainActivity2.class); +// notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); +// // notifyIntent.putExtra("message", messageInfo); +// notifyIntent.setAction(Intent.ACTION_VIEW); +// notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 +// PendingIntent pendingIntent; +// pendingIntent = PendingIntent.getActivity +// (this, 0, notifyIntent, PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE); + + NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); + NotificationChannel channelwinway = null; + NotificationCompat.Builder notificationBuilder = null; + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + channelwinway = new NotificationChannel(getString(com.web.base.R.string.app_name), "notify", NotificationManager.IMPORTANCE_DEFAULT); + channelwinway.enableLights(true); + channelwinway.enableVibration(true); + notificationManager.createNotificationChannel(channelwinway); + notificationBuilder = new NotificationCompat.Builder(this, channelwinway.getId()) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(messageInfo.getTitle()) + .setContentText(messageInfo.getContent()) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } else { + notificationBuilder = new NotificationCompat.Builder(this, getString(com.web.base.R.string.app_name)) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(messageInfo.getTitle()) + .setContentText(messageInfo.getContent()) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } + notificationManager.notify(0, notificationBuilder.build()); + } + + private void showNotification(String title, String body) { + Intent notifyIntent = new Intent(this, MainActivity2.class); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.CUPCAKE) { + ComponentName launchComponent = null; + launchComponent = getApplication() + .getPackageManager() + .getLaunchIntentForPackage(getApplication().getPackageName()) + .getComponent(); + notifyIntent.setComponent(launchComponent); + } + notifyIntent.putExtra("message", body); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); + notifyIntent.setAction(Intent.ACTION_VIEW); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 + + + PendingIntent pendingIntent = PendingIntent.getActivity(this, new Random().nextInt(10000), notifyIntent, PendingIntent.FLAG_IMMUTABLE); + NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); + NotificationChannel channelwinway = null; + NotificationCompat.Builder notificationBuilder = null; + MessageInfo messageInfo = GsonUtils.getObjFromJSON(body, MessageInfo.class); + if (messageInfo != null) { + body = messageInfo.getContent(); + } + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + channelwinway = new NotificationChannel(getString(com.web.base.R.string.app_name), "notify", NotificationManager.IMPORTANCE_DEFAULT); + channelwinway.enableLights(true); + channelwinway.enableVibration(true); + notificationManager.createNotificationChannel(channelwinway); + notificationBuilder = new NotificationCompat.Builder(this, channelwinway.getId()) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(title) + .setContentText(body) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } else { + notificationBuilder = new NotificationCompat.Builder(this, getString(com.web.base.R.string.app_name)) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(title) + .setContentText(body) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } + notificationManager.notify(0, notificationBuilder.build()); + //存储数据 + // saveNotifyMessage(body); + } + + +// public void saveNotifyMessage(String body) { +// MessageInfo messageInfo = GsonUtils.getObjFromJSON(body, MessageInfo.class); +// String savenotify = Utils.get(getApplication(),ApiService.savenotify,""); +// if(messageInfo!=null){ +// if(TextUtils.isEmpty(savenotify)){ +// GsonUtils.getListFromJSON(savenotify,) +// } +// } +// String jsonString = GsonUtils.beanToJSONString(chatMessageBeans); +// } +// +// /** +// * @param key 要设置的key +// */ +// public static void set(Context activity, String key, String is) { +// SharedPreferences nameSetting = getConfigShared(activity); +// SharedPreferences.Editor namePref = nameSetting.edit(); +// namePref.putString(key, is); +// namePref.commit(); +// } +} diff --git a/dapatcuci/src/main/java/com/web/dapatcuci/WebApplication.java b/dapatcuci/src/main/java/com/web/dapatcuci/WebApplication.java new file mode 100644 index 0000000..390ed89 --- /dev/null +++ b/dapatcuci/src/main/java/com/web/dapatcuci/WebApplication.java @@ -0,0 +1,37 @@ +package com.web.dapatcuci; + +import android.app.Application; +import android.content.Context; + +import com.tencent.smtt.export.external.TbsCoreSettings; +import com.tencent.smtt.sdk.QbSdk; + +import java.util.HashMap; + +public class WebApplication extends Application { + + + public static Context application; + @Override + public void onCreate() { + super.onCreate(); +// 设置开启优化方案 + application = this; + HashMap map = new HashMap(); + map.put(TbsCoreSettings.TBS_SETTINGS_USE_SPEEDY_CLASSLOADER, true); + map.put(TbsCoreSettings.TBS_SETTINGS_USE_DEXLOADER_SERVICE, true); + QbSdk.initTbsSettings(map); + QbSdk.initX5Environment(this, new QbSdk.PreInitCallback() { + @Override + public void onCoreInitFinished() { + + } + + @Override + public void onViewInitFinished(boolean b) { + + } + }); + QbSdk.setDownloadWithoutWifi(true); + } +} diff --git a/dapatcuci/src/main/res/drawable-anydpi/ic_action_back.xml b/dapatcuci/src/main/res/drawable-anydpi/ic_action_back.xml new file mode 100644 index 0000000..013ab07 --- /dev/null +++ b/dapatcuci/src/main/res/drawable-anydpi/ic_action_back.xml @@ -0,0 +1,11 @@ + + + diff --git a/dapatcuci/src/main/res/drawable-hdpi/ic_action_back.png b/dapatcuci/src/main/res/drawable-hdpi/ic_action_back.png new file mode 100644 index 0000000..1560c04 Binary files /dev/null and b/dapatcuci/src/main/res/drawable-hdpi/ic_action_back.png differ diff --git a/dapatcuci/src/main/res/drawable-mdpi/ic_action_back.png b/dapatcuci/src/main/res/drawable-mdpi/ic_action_back.png new file mode 100644 index 0000000..d5841d2 Binary files /dev/null and b/dapatcuci/src/main/res/drawable-mdpi/ic_action_back.png differ diff --git a/dapatcuci/src/main/res/drawable-v24/ic_launcher_foreground.xml b/dapatcuci/src/main/res/drawable-v24/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/dapatcuci/src/main/res/drawable-v24/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/drawable-xhdpi/ic_action_back.png b/dapatcuci/src/main/res/drawable-xhdpi/ic_action_back.png new file mode 100644 index 0000000..5c14e41 Binary files /dev/null and b/dapatcuci/src/main/res/drawable-xhdpi/ic_action_back.png differ diff --git a/dapatcuci/src/main/res/drawable-xxhdpi/ic_action_back.png b/dapatcuci/src/main/res/drawable-xxhdpi/ic_action_back.png new file mode 100644 index 0000000..0516d08 Binary files /dev/null and b/dapatcuci/src/main/res/drawable-xxhdpi/ic_action_back.png differ diff --git a/dapatcuci/src/main/res/drawable/big_bg.xml b/dapatcuci/src/main/res/drawable/big_bg.xml new file mode 100644 index 0000000..5889937 --- /dev/null +++ b/dapatcuci/src/main/res/drawable/big_bg.xml @@ -0,0 +1,8 @@ + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/drawable/ic_launcher_background.xml b/dapatcuci/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/dapatcuci/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/dapatcuci/src/main/res/drawable/input_bg.xml b/dapatcuci/src/main/res/drawable/input_bg.xml new file mode 100644 index 0000000..4e895aa --- /dev/null +++ b/dapatcuci/src/main/res/drawable/input_bg.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + + diff --git a/dapatcuci/src/main/res/drawable/pass_word_bg.xml b/dapatcuci/src/main/res/drawable/pass_word_bg.xml new file mode 100644 index 0000000..2724e60 --- /dev/null +++ b/dapatcuci/src/main/res/drawable/pass_word_bg.xml @@ -0,0 +1,28 @@ + + + + + + + + + + + + + + + + + + diff --git a/dapatcuci/src/main/res/drawable/pass_word_bg1.xml b/dapatcuci/src/main/res/drawable/pass_word_bg1.xml new file mode 100644 index 0000000..d10d780 --- /dev/null +++ b/dapatcuci/src/main/res/drawable/pass_word_bg1.xml @@ -0,0 +1,23 @@ + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/drawable/pass_word_bg2.xml b/dapatcuci/src/main/res/drawable/pass_word_bg2.xml new file mode 100644 index 0000000..916d99c --- /dev/null +++ b/dapatcuci/src/main/res/drawable/pass_word_bg2.xml @@ -0,0 +1,23 @@ + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/drawable/shape_btn_bg.xml b/dapatcuci/src/main/res/drawable/shape_btn_bg.xml new file mode 100644 index 0000000..af87a0d --- /dev/null +++ b/dapatcuci/src/main/res/drawable/shape_btn_bg.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/drawable/shape_dialog_bg2.xml b/dapatcuci/src/main/res/drawable/shape_dialog_bg2.xml new file mode 100644 index 0000000..7837a42 --- /dev/null +++ b/dapatcuci/src/main/res/drawable/shape_dialog_bg2.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/drawable/shape_dialog_bg3.xml b/dapatcuci/src/main/res/drawable/shape_dialog_bg3.xml new file mode 100644 index 0000000..ca0a18d --- /dev/null +++ b/dapatcuci/src/main/res/drawable/shape_dialog_bg3.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/drawable/shape_dialog_bg_new.xml b/dapatcuci/src/main/res/drawable/shape_dialog_bg_new.xml new file mode 100644 index 0000000..e96d4e0 --- /dev/null +++ b/dapatcuci/src/main/res/drawable/shape_dialog_bg_new.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/dapatcuci/src/main/res/mipmap-anydpi-v26/ic_launcher.xml new file mode 100644 index 0000000..eca70cf --- /dev/null +++ b/dapatcuci/src/main/res/mipmap-anydpi-v26/ic_launcher.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/dapatcuci/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml new file mode 100644 index 0000000..eca70cf --- /dev/null +++ b/dapatcuci/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/mipmap-hdpi/ic_empty.png b/dapatcuci/src/main/res/mipmap-hdpi/ic_empty.png new file mode 100644 index 0000000..72473d6 Binary files /dev/null and b/dapatcuci/src/main/res/mipmap-hdpi/ic_empty.png differ diff --git a/dapatcuci/src/main/res/mipmap-hdpi/ic_pull_down.png b/dapatcuci/src/main/res/mipmap-hdpi/ic_pull_down.png new file mode 100644 index 0000000..7dc0ec3 Binary files /dev/null and b/dapatcuci/src/main/res/mipmap-hdpi/ic_pull_down.png differ diff --git a/dapatcuci/src/main/res/mipmap-xhdpi/ic_close.png b/dapatcuci/src/main/res/mipmap-xhdpi/ic_close.png new file mode 100644 index 0000000..c0b0127 Binary files /dev/null and b/dapatcuci/src/main/res/mipmap-xhdpi/ic_close.png differ diff --git a/dapatcuci/src/main/res/mipmap-xhdpi/ic_menu.png b/dapatcuci/src/main/res/mipmap-xhdpi/ic_menu.png new file mode 100644 index 0000000..2b55ec5 Binary files /dev/null and b/dapatcuci/src/main/res/mipmap-xhdpi/ic_menu.png differ diff --git a/dapatcuci/src/main/res/mipmap-xxhdpi/app_logo.png b/dapatcuci/src/main/res/mipmap-xxhdpi/app_logo.png new file mode 100644 index 0000000..64e95b4 Binary files /dev/null and b/dapatcuci/src/main/res/mipmap-xxhdpi/app_logo.png differ diff --git a/dapatcuci/src/main/res/values-en/strings.xml b/dapatcuci/src/main/res/values-en/strings.xml new file mode 100644 index 0000000..61bd072 --- /dev/null +++ b/dapatcuci/src/main/res/values-en/strings.xml @@ -0,0 +1,52 @@ + + DAPATCUCI + Please Set Your Password + Cancel + Sure + New Version Update + Next Update + Update Immediately + Click to close notification + Click to re-download + Download failed + Click to install + Download completed + Downloading... + Version update + Downloading game + Getting download data... + Version update + Downloading game + Need to turn on mobile phone notification permission + Exit + Setting + Tip + Please enter the invitation code + My invitation code: + Superior invitation code: + Total number of invites: + App download link: + Share + Check Invitation Records + Invitation Records + Total number of invitees: %d + No Data + Withdrawal Record + Withdrawal Application + Edit Bank Card Information + 60 + Name: + Please enter the bank card name + Bank card account: + Please enter the bank card account + Country: + Please select a country + Bank Name: + Please select a bank name + Note: Please enter the country code before selecting the bank name! + Balance: %s + Total Earnings: %s + Amount: %s + Please enter the withdrawal amount + Withdrawal application has been submitted + \ No newline at end of file diff --git a/dapatcuci/src/main/res/values-night/themes.xml b/dapatcuci/src/main/res/values-night/themes.xml new file mode 100644 index 0000000..3b0f1a2 --- /dev/null +++ b/dapatcuci/src/main/res/values-night/themes.xml @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/values/colors.xml b/dapatcuci/src/main/res/values/colors.xml new file mode 100644 index 0000000..7895913 --- /dev/null +++ b/dapatcuci/src/main/res/values/colors.xml @@ -0,0 +1,18 @@ + + + #FFFFFF + #FFFFFF + #FFFFFF + #FF03DAC5 + #FF018786 + #FF000000 + #FFFFFFFF + #EF4723 + #FFFFFFFF + + #2C2C2E + #FFA722 + #434343 + #BCBCBC + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/values/strings.xml b/dapatcuci/src/main/res/values/strings.xml new file mode 100644 index 0000000..9d6dca4 --- /dev/null +++ b/dapatcuci/src/main/res/values/strings.xml @@ -0,0 +1,74 @@ + + DAPATCUCI + 请输入6位密码 + 取消 + 确定 + 版本更新 + 下次更新 + 立即更新 + 点击关闭通知 + 点击重新下载 + 下载失败 + 点击安装 + 下载完成 + 正在下载… + 版本更新 + 下载游戏中 + 版本更新 + 下载游戏中 + 正在获取下载数据… + 需要打开手机通知权限 + 退出 + 设置 + 提示 + 请输入邀请码 + 我的邀请码: + 上级邀请码: + 总邀请人数: + 邀请您下载: + 分享 + 查看邀请记录 + 邀请记录 + 总邀请人数: %d + 暂无数据 + 提现记录 + 提现申请 + 编辑银行卡信息 + 86 + 持卡人姓名: + 请输入持卡人姓名 + 国家地区: + 请选择国家地区 + 开户行名称: + 请选择开户行名称 + 银行户口: + 请输入银行卡户口 + (注:请先输入国家区号再选择开户行名称!) + 余额: %s + 总收益: %s + 金额: %s + 请输入提现金额 + 提现申请已提交 + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/values/themes.xml b/dapatcuci/src/main/res/values/themes.xml new file mode 100644 index 0000000..e1c80ec --- /dev/null +++ b/dapatcuci/src/main/res/values/themes.xml @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/xml/app_updater_paths.xml b/dapatcuci/src/main/res/xml/app_updater_paths.xml new file mode 100644 index 0000000..1254450 --- /dev/null +++ b/dapatcuci/src/main/res/xml/app_updater_paths.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/xml/network_security_config.xml b/dapatcuci/src/main/res/xml/network_security_config.xml new file mode 100644 index 0000000..dca93c0 --- /dev/null +++ b/dapatcuci/src/main/res/xml/network_security_config.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/dapatcuci/src/main/res/xml/provider_paths.xml b/dapatcuci/src/main/res/xml/provider_paths.xml new file mode 100644 index 0000000..c9a897a --- /dev/null +++ b/dapatcuci/src/main/res/xml/provider_paths.xml @@ -0,0 +1,13 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/dapatcuci/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java b/dapatcuci/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java new file mode 100644 index 0000000..3259554 --- /dev/null +++ b/dapatcuci/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java @@ -0,0 +1,35 @@ +package Tptogiar.calculcator; + +import org.junit.Test; + +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import static org.junit.Assert.*; + +/** + * Example local unit test, which will execute on the development machine (host). + * + * @see Testing documentation + */ +public class ExampleUnitTest { + @Test + public void addition_isCorrect() { + assertEquals(4, 2 + 2); + } + + @Test + public void TestPattern(){ +// + Pattern compile = Pattern.compile( "^(\\-|\\+)?\\d+(\\.\\d+)?$"); + String a="+45.5"; + boolean matches = compile.matcher(a).matches(); + System.out.println(matches); + String result = compile.matcher(a).replaceAll(""); + System.out.println(result); + + + } + + +} \ No newline at end of file diff --git a/emu668/.gitignore b/emu668/.gitignore new file mode 100644 index 0000000..956c004 --- /dev/null +++ b/emu668/.gitignore @@ -0,0 +1,2 @@ +/build +/release \ No newline at end of file diff --git a/emu668/build.gradle b/emu668/build.gradle new file mode 100644 index 0000000..c1bcc66 --- /dev/null +++ b/emu668/build.gradle @@ -0,0 +1,48 @@ +plugins { + id 'com.android.application' + id 'com.google.gms.google-services' +} + +android { + compileSdkVersion 31 + buildToolsVersion "30.0.3" + + defaultConfig { + applicationId "com.web.emu668" + minSdkVersion 24 + targetSdkVersion 31 + versionCode 107 + versionName "v1.0.7" + testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" + } + + signingConfigs { + debug { + storeFile file('ppn.jks') + storePassword "2014123456" + keyAlias 'key0' + keyPassword "2014123456" + } + release { + storeFile file('ppn.jks') + storePassword "2014123456" + keyAlias 'key0' + keyPassword "2014123456" + } + } + + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' + } + } + compileOptions { + sourceCompatibility JavaVersion.VERSION_1_8 + targetCompatibility JavaVersion.VERSION_1_8 + } +} + +dependencies { + implementation project(path: ':base') +} \ No newline at end of file diff --git a/emu668/google-services.json b/emu668/google-services.json new file mode 100644 index 0000000..38f9cc8 --- /dev/null +++ b/emu668/google-services.json @@ -0,0 +1,29 @@ +{ + "project_info": { + "project_number": "600201709621", + "project_id": "emu668-aa969", + "storage_bucket": "emu668-aa969.firebasestorage.app" + }, + "client": [ + { + "client_info": { + "mobilesdk_app_id": "1:600201709621:android:5c181347f6242b5726897c", + "android_client_info": { + "package_name": "com.web.emu668" + } + }, + "oauth_client": [], + "api_key": [ + { + "current_key": "AIzaSyD4-mbW4mU36N75zKbJh1BoiAWLxHYO-fc" + } + ], + "services": { + "appinvite_service": { + "other_platform_oauth_client": [] + } + } + } + ], + "configuration_version": "1" +} \ No newline at end of file diff --git a/emu668/ppn.jks b/emu668/ppn.jks new file mode 100644 index 0000000..5898029 Binary files /dev/null and b/emu668/ppn.jks differ diff --git a/emu668/proguard-rules.pro b/emu668/proguard-rules.pro new file mode 100644 index 0000000..107b7ee --- /dev/null +++ b/emu668/proguard-rules.pro @@ -0,0 +1,32 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile + +-dontwarn dalvik.** +-dontwarn com.tencent.smtt.** + +-keep class com.tencent.smtt.** { + *; +} + +-keep class com.tencent.tbs.** { + *; +} \ No newline at end of file diff --git a/emu668/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java b/emu668/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java new file mode 100644 index 0000000..44b9f39 --- /dev/null +++ b/emu668/src/androidTest/java/Tptogiar/calculcator/ExampleInstrumentedTest.java @@ -0,0 +1,26 @@ +package Tptogiar.calculcator; + +import android.content.Context; + +import androidx.test.platform.app.InstrumentationRegistry; +import androidx.test.ext.junit.runners.AndroidJUnit4; + +import org.junit.Test; +import org.junit.runner.RunWith; + +import static org.junit.Assert.*; + +/** + * Instrumented test, which will execute on an Android device. + * + * @see Testing documentation + */ +@RunWith(AndroidJUnit4.class) +public class ExampleInstrumentedTest { + @Test + public void useAppContext() { + // Context of the app under test. + Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); + assertEquals("Tptogiar.calculcator", appContext.getPackageName()); + } +} \ No newline at end of file diff --git a/emu668/src/main/AndroidManifest.xml b/emu668/src/main/AndroidManifest.xml new file mode 100644 index 0000000..e365261 --- /dev/null +++ b/emu668/src/main/AndroidManifest.xml @@ -0,0 +1,113 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/emu668/src/main/java/com/web/emu668/MainActivity2.java b/emu668/src/main/java/com/web/emu668/MainActivity2.java new file mode 100644 index 0000000..a1b8645 --- /dev/null +++ b/emu668/src/main/java/com/web/emu668/MainActivity2.java @@ -0,0 +1,56 @@ +package com.web.emu668; + + +import android.content.pm.PackageInfo; +import android.content.pm.PackageManager; +import android.os.Bundle; + +import androidx.annotation.NonNull; + +import com.google.android.gms.tasks.OnCompleteListener; +import com.google.android.gms.tasks.Task; +import com.google.firebase.messaging.FirebaseMessaging; +import com.web.base.MainActivity; + +public class MainActivity2 extends com.web.base.MainActivity2 { + + @Override + protected void onCreate(Bundle savedInstanceState) { + userId = 124; + saveInt(MainActivity2.this,"user_code",userId); + saveInt(MainActivity2.this,"version_code",getVersion()); + MainActivity.saveString(this, "base_url","https://emu668.co/"); + //网页的底部NavigationBar颜色 + MainActivity.saveString(this, "style_color", "#110c09"); + //页面的大背景颜色 + MainActivity.saveString(this, "windows_color", "#110c09"); + //任务栏的文字颜色 0 黑 1白 默认黑 + saveInt(MainActivity2.this,"is_white",1); + super.onCreate(savedInstanceState); + //用于修改大背景渐变色 不设置 大背景就是 windows_color 的颜色 + setBackDrawables(R.drawable.big_bg); + setImageView(false); + //订阅主题 + FirebaseMessaging.getInstance().subscribeToTopic("demo") + .addOnCompleteListener(task -> { + String msg = "Subscribed"; + if (!task.isSuccessful()) { + msg = "Subscribe failed"; + } + + }); + } + + public int getVersion(){ + try { + PackageManager packageManager = getPackageManager(); + PackageInfo packageInfo = packageManager.getPackageInfo(getPackageName(), 0); + int versionCode = packageInfo.versionCode; // 版本码 + return versionCode; + } catch (PackageManager.NameNotFoundException e) { + return 0; + } + + } + +} diff --git a/emu668/src/main/java/com/web/emu668/MyFirebaseMessageingService.java b/emu668/src/main/java/com/web/emu668/MyFirebaseMessageingService.java new file mode 100644 index 0000000..abc134f --- /dev/null +++ b/emu668/src/main/java/com/web/emu668/MyFirebaseMessageingService.java @@ -0,0 +1,171 @@ +package com.web.emu668; + +import android.app.NotificationChannel; +import android.app.NotificationManager; +import android.app.PendingIntent; +import android.content.ComponentName; +import android.content.Context; +import android.content.Intent; +import android.os.Build; + +import androidx.annotation.NonNull; +import androidx.core.app.NotificationCompat; + +import com.google.firebase.messaging.FirebaseMessagingService; +import com.google.firebase.messaging.RemoteMessage; +import com.google.gson.Gson; +import com.web.base.GsonUtils; +import com.web.base.MessageInfo; + +import java.util.Map; +import java.util.Random; + +public class MyFirebaseMessageingService extends FirebaseMessagingService { + + public MyFirebaseMessageingService() { + } + + @Override + public void onMessageReceived(@NonNull RemoteMessage remoteMessage) { + super.onMessageReceived(remoteMessage); + Map serviceData = remoteMessage.getData(); //后台推送数据 + if (serviceData != null && serviceData.containsKey("message")) { + String value = serviceData.get("message"); + Gson gson = new Gson(); + MessageInfo messageInfo = gson.fromJson(value, MessageInfo.class); + showNotification(messageInfo); +// if (remoteMessage.getNotification() != null) { +// showNotification(remoteMessage.getNotification().getTitle(), remoteMessage.getNotification().getBody()); +// } + } else { + //收到通知 创建notify + if (remoteMessage.getNotification() != null) { + showNotification(remoteMessage.getNotification().getTitle(), remoteMessage.getNotification().getBody()); + } + } + + + } + + private void showNotification(MessageInfo messageInfo) { + Intent notifyIntent = new Intent(this, com.web.base.MainActivity2.class); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.CUPCAKE) { + ComponentName launchComponent = null; + launchComponent = getApplication() + .getPackageManager() + .getLaunchIntentForPackage(getApplication().getPackageName()) + .getComponent(); + notifyIntent.setComponent(launchComponent); + } + + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); + notifyIntent.setAction(Intent.ACTION_VIEW); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 + notifyIntent.putExtra("message", messageInfo); + + PendingIntent pendingIntent = PendingIntent.getActivity(this, new Random().nextInt(10000), notifyIntent, PendingIntent.FLAG_IMMUTABLE); + +// Intent notifyIntent = new Intent(this, MainActivity2.class); +// notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); +// // notifyIntent.putExtra("message", messageInfo); +// notifyIntent.setAction(Intent.ACTION_VIEW); +// notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 +// PendingIntent pendingIntent; +// pendingIntent = PendingIntent.getActivity +// (this, 0, notifyIntent, PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE); + + NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); + NotificationChannel channelwinway = null; + NotificationCompat.Builder notificationBuilder = null; + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + channelwinway = new NotificationChannel(getString(com.web.base.R.string.app_name), "notify", NotificationManager.IMPORTANCE_DEFAULT); + channelwinway.enableLights(true); + channelwinway.enableVibration(true); + notificationManager.createNotificationChannel(channelwinway); + notificationBuilder = new NotificationCompat.Builder(this, channelwinway.getId()) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(messageInfo.getTitle()) + .setContentText(messageInfo.getContent()) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } else { + notificationBuilder = new NotificationCompat.Builder(this, getString(com.web.base.R.string.app_name)) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(messageInfo.getTitle()) + .setContentText(messageInfo.getContent()) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } + notificationManager.notify(0, notificationBuilder.build()); + } + + private void showNotification(String title, String body) { + Intent notifyIntent = new Intent(this, MainActivity2.class); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.CUPCAKE) { + ComponentName launchComponent = null; + launchComponent = getApplication() + .getPackageManager() + .getLaunchIntentForPackage(getApplication().getPackageName()) + .getComponent(); + notifyIntent.setComponent(launchComponent); + } + notifyIntent.putExtra("message", body); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); + notifyIntent.setAction(Intent.ACTION_VIEW); + notifyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // 必须 + + + PendingIntent pendingIntent = PendingIntent.getActivity(this, new Random().nextInt(10000), notifyIntent, PendingIntent.FLAG_IMMUTABLE); + NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); + NotificationChannel channelwinway = null; + NotificationCompat.Builder notificationBuilder = null; + MessageInfo messageInfo = GsonUtils.getObjFromJSON(body, MessageInfo.class); + if (messageInfo != null) { + body = messageInfo.getContent(); + } + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + channelwinway = new NotificationChannel(getString(com.web.base.R.string.app_name), "notify", NotificationManager.IMPORTANCE_DEFAULT); + channelwinway.enableLights(true); + channelwinway.enableVibration(true); + notificationManager.createNotificationChannel(channelwinway); + notificationBuilder = new NotificationCompat.Builder(this, channelwinway.getId()) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(title) + .setContentText(body) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } else { + notificationBuilder = new NotificationCompat.Builder(this, getString(com.web.base.R.string.app_name)) + .setSmallIcon(R.mipmap.app_logo) + .setContentTitle(title) + .setContentText(body) + .setAutoCancel(true) + .setContentIntent(pendingIntent); + } + notificationManager.notify(0, notificationBuilder.build()); + //存储数据 + // saveNotifyMessage(body); + } + + +// public void saveNotifyMessage(String body) { +// MessageInfo messageInfo = GsonUtils.getObjFromJSON(body, MessageInfo.class); +// String savenotify = Utils.get(getApplication(),ApiService.savenotify,""); +// if(messageInfo!=null){ +// if(TextUtils.isEmpty(savenotify)){ +// GsonUtils.getListFromJSON(savenotify,) +// } +// } +// String jsonString = GsonUtils.beanToJSONString(chatMessageBeans); +// } +// +// /** +// * @param key 要设置的key +// */ +// public static void set(Context activity, String key, String is) { +// SharedPreferences nameSetting = getConfigShared(activity); +// SharedPreferences.Editor namePref = nameSetting.edit(); +// namePref.putString(key, is); +// namePref.commit(); +// } +} diff --git a/emu668/src/main/java/com/web/emu668/WebApplication.java b/emu668/src/main/java/com/web/emu668/WebApplication.java new file mode 100644 index 0000000..7fc3591 --- /dev/null +++ b/emu668/src/main/java/com/web/emu668/WebApplication.java @@ -0,0 +1,37 @@ +package com.web.emu668; + +import android.app.Application; +import android.content.Context; + +import com.tencent.smtt.export.external.TbsCoreSettings; +import com.tencent.smtt.sdk.QbSdk; + +import java.util.HashMap; + +public class WebApplication extends Application { + + + public static Context application; + @Override + public void onCreate() { + super.onCreate(); +// 设置开启优化方案 + application = this; + HashMap map = new HashMap(); + map.put(TbsCoreSettings.TBS_SETTINGS_USE_SPEEDY_CLASSLOADER, true); + map.put(TbsCoreSettings.TBS_SETTINGS_USE_DEXLOADER_SERVICE, true); + QbSdk.initTbsSettings(map); + QbSdk.initX5Environment(this, new QbSdk.PreInitCallback() { + @Override + public void onCoreInitFinished() { + + } + + @Override + public void onViewInitFinished(boolean b) { + + } + }); + QbSdk.setDownloadWithoutWifi(true); + } +} diff --git a/emu668/src/main/res/drawable-anydpi/ic_action_back.xml b/emu668/src/main/res/drawable-anydpi/ic_action_back.xml new file mode 100644 index 0000000..013ab07 --- /dev/null +++ b/emu668/src/main/res/drawable-anydpi/ic_action_back.xml @@ -0,0 +1,11 @@ + + + diff --git a/emu668/src/main/res/drawable-hdpi/ic_action_back.png b/emu668/src/main/res/drawable-hdpi/ic_action_back.png new file mode 100644 index 0000000..1560c04 Binary files /dev/null and b/emu668/src/main/res/drawable-hdpi/ic_action_back.png differ diff --git a/emu668/src/main/res/drawable-mdpi/ic_action_back.png b/emu668/src/main/res/drawable-mdpi/ic_action_back.png new file mode 100644 index 0000000..d5841d2 Binary files /dev/null and b/emu668/src/main/res/drawable-mdpi/ic_action_back.png differ diff --git a/emu668/src/main/res/drawable-v24/ic_launcher_foreground.xml b/emu668/src/main/res/drawable-v24/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/emu668/src/main/res/drawable-v24/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/drawable-xhdpi/ic_action_back.png b/emu668/src/main/res/drawable-xhdpi/ic_action_back.png new file mode 100644 index 0000000..5c14e41 Binary files /dev/null and b/emu668/src/main/res/drawable-xhdpi/ic_action_back.png differ diff --git a/emu668/src/main/res/drawable-xxhdpi/ic_action_back.png b/emu668/src/main/res/drawable-xxhdpi/ic_action_back.png new file mode 100644 index 0000000..0516d08 Binary files /dev/null and b/emu668/src/main/res/drawable-xxhdpi/ic_action_back.png differ diff --git a/emu668/src/main/res/drawable/big_bg.xml b/emu668/src/main/res/drawable/big_bg.xml new file mode 100644 index 0000000..1caf6a2 --- /dev/null +++ b/emu668/src/main/res/drawable/big_bg.xml @@ -0,0 +1,8 @@ + + + + \ No newline at end of file diff --git a/emu668/src/main/res/drawable/ic_launcher_background.xml b/emu668/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/emu668/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/emu668/src/main/res/drawable/input_bg.xml b/emu668/src/main/res/drawable/input_bg.xml new file mode 100644 index 0000000..4e895aa --- /dev/null +++ b/emu668/src/main/res/drawable/input_bg.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + + diff --git a/emu668/src/main/res/drawable/pass_word_bg.xml b/emu668/src/main/res/drawable/pass_word_bg.xml new file mode 100644 index 0000000..2724e60 --- /dev/null +++ b/emu668/src/main/res/drawable/pass_word_bg.xml @@ -0,0 +1,28 @@ + + + + + + + + + + + + + + + + + + diff --git a/emu668/src/main/res/drawable/pass_word_bg1.xml b/emu668/src/main/res/drawable/pass_word_bg1.xml new file mode 100644 index 0000000..d10d780 --- /dev/null +++ b/emu668/src/main/res/drawable/pass_word_bg1.xml @@ -0,0 +1,23 @@ + + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/drawable/pass_word_bg2.xml b/emu668/src/main/res/drawable/pass_word_bg2.xml new file mode 100644 index 0000000..916d99c --- /dev/null +++ b/emu668/src/main/res/drawable/pass_word_bg2.xml @@ -0,0 +1,23 @@ + + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/drawable/shape_btn_bg.xml b/emu668/src/main/res/drawable/shape_btn_bg.xml new file mode 100644 index 0000000..af87a0d --- /dev/null +++ b/emu668/src/main/res/drawable/shape_btn_bg.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/drawable/shape_dialog_bg2.xml b/emu668/src/main/res/drawable/shape_dialog_bg2.xml new file mode 100644 index 0000000..7837a42 --- /dev/null +++ b/emu668/src/main/res/drawable/shape_dialog_bg2.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/drawable/shape_dialog_bg3.xml b/emu668/src/main/res/drawable/shape_dialog_bg3.xml new file mode 100644 index 0000000..ca0a18d --- /dev/null +++ b/emu668/src/main/res/drawable/shape_dialog_bg3.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/drawable/shape_dialog_bg_new.xml b/emu668/src/main/res/drawable/shape_dialog_bg_new.xml new file mode 100644 index 0000000..e96d4e0 --- /dev/null +++ b/emu668/src/main/res/drawable/shape_dialog_bg_new.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/emu668/src/main/res/mipmap-anydpi-v26/ic_launcher.xml new file mode 100644 index 0000000..eca70cf --- /dev/null +++ b/emu668/src/main/res/mipmap-anydpi-v26/ic_launcher.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/emu668/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml new file mode 100644 index 0000000..eca70cf --- /dev/null +++ b/emu668/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/mipmap-hdpi/ic_empty.png b/emu668/src/main/res/mipmap-hdpi/ic_empty.png new file mode 100644 index 0000000..72473d6 Binary files /dev/null and b/emu668/src/main/res/mipmap-hdpi/ic_empty.png differ diff --git a/emu668/src/main/res/mipmap-hdpi/ic_pull_down.png b/emu668/src/main/res/mipmap-hdpi/ic_pull_down.png new file mode 100644 index 0000000..7dc0ec3 Binary files /dev/null and b/emu668/src/main/res/mipmap-hdpi/ic_pull_down.png differ diff --git a/emu668/src/main/res/mipmap-xhdpi/ic_close.png b/emu668/src/main/res/mipmap-xhdpi/ic_close.png new file mode 100644 index 0000000..c0b0127 Binary files /dev/null and b/emu668/src/main/res/mipmap-xhdpi/ic_close.png differ diff --git a/emu668/src/main/res/mipmap-xhdpi/ic_menu.png b/emu668/src/main/res/mipmap-xhdpi/ic_menu.png new file mode 100644 index 0000000..2b55ec5 Binary files /dev/null and b/emu668/src/main/res/mipmap-xhdpi/ic_menu.png differ diff --git a/emu668/src/main/res/mipmap-xxhdpi/app_logo.png b/emu668/src/main/res/mipmap-xxhdpi/app_logo.png new file mode 100644 index 0000000..412d7ff Binary files /dev/null and b/emu668/src/main/res/mipmap-xxhdpi/app_logo.png differ diff --git a/emu668/src/main/res/values-en/strings.xml b/emu668/src/main/res/values-en/strings.xml new file mode 100644 index 0000000..5e4fd14 --- /dev/null +++ b/emu668/src/main/res/values-en/strings.xml @@ -0,0 +1,52 @@ + + EMU668 + Please Set Your Password + Cancel + Sure + New Version Update + Next Update + Update Immediately + Click to close notification + Click to re-download + Download failed + Click to install + Download completed + Downloading... + Version update + Downloading game + Getting download data... + Version update + Downloading game + Need to turn on mobile phone notification permission + Exit + Setting + Tip + Please enter the invitation code + My invitation code: + Superior invitation code: + Total number of invites: + App download link: + Share + Check Invitation Records + Invitation Records + Total number of invitees: %d + No Data + Withdrawal Record + Withdrawal Application + Edit Bank Card Information + 60 + Name: + Please enter the bank card name + Bank card account: + Please enter the bank card account + Country: + Please select a country + Bank Name: + Please select a bank name + Note: Please enter the country code before selecting the bank name! + Balance: %s + Total Earnings: %s + Amount: %s + Please enter the withdrawal amount + Withdrawal application has been submitted + \ No newline at end of file diff --git a/emu668/src/main/res/values-night/themes.xml b/emu668/src/main/res/values-night/themes.xml new file mode 100644 index 0000000..3b0f1a2 --- /dev/null +++ b/emu668/src/main/res/values-night/themes.xml @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/values/colors.xml b/emu668/src/main/res/values/colors.xml new file mode 100644 index 0000000..7895913 --- /dev/null +++ b/emu668/src/main/res/values/colors.xml @@ -0,0 +1,18 @@ + + + #FFFFFF + #FFFFFF + #FFFFFF + #FF03DAC5 + #FF018786 + #FF000000 + #FFFFFFFF + #EF4723 + #FFFFFFFF + + #2C2C2E + #FFA722 + #434343 + #BCBCBC + + \ No newline at end of file diff --git a/emu668/src/main/res/values/strings.xml b/emu668/src/main/res/values/strings.xml new file mode 100644 index 0000000..59ed3ae --- /dev/null +++ b/emu668/src/main/res/values/strings.xml @@ -0,0 +1,74 @@ + + EMU668 + 请输入6位密码 + 取消 + 确定 + 版本更新 + 下次更新 + 立即更新 + 点击关闭通知 + 点击重新下载 + 下载失败 + 点击安装 + 下载完成 + 正在下载… + 版本更新 + 下载游戏中 + 版本更新 + 下载游戏中 + 正在获取下载数据… + 需要打开手机通知权限 + 退出 + 设置 + 提示 + 请输入邀请码 + 我的邀请码: + 上级邀请码: + 总邀请人数: + 邀请您下载: + 分享 + 查看邀请记录 + 邀请记录 + 总邀请人数: %d + 暂无数据 + 提现记录 + 提现申请 + 编辑银行卡信息 + 86 + 持卡人姓名: + 请输入持卡人姓名 + 国家地区: + 请选择国家地区 + 开户行名称: + 请选择开户行名称 + 银行户口: + 请输入银行卡户口 + (注:请先输入国家区号再选择开户行名称!) + 余额: %s + 总收益: %s + 金额: %s + 请输入提现金额 + 提现申请已提交 + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/values/themes.xml b/emu668/src/main/res/values/themes.xml new file mode 100644 index 0000000..e1c80ec --- /dev/null +++ b/emu668/src/main/res/values/themes.xml @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/xml/app_updater_paths.xml b/emu668/src/main/res/xml/app_updater_paths.xml new file mode 100644 index 0000000..1254450 --- /dev/null +++ b/emu668/src/main/res/xml/app_updater_paths.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/emu668/src/main/res/xml/network_security_config.xml b/emu668/src/main/res/xml/network_security_config.xml new file mode 100644 index 0000000..dca93c0 --- /dev/null +++ b/emu668/src/main/res/xml/network_security_config.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/emu668/src/main/res/xml/provider_paths.xml b/emu668/src/main/res/xml/provider_paths.xml new file mode 100644 index 0000000..c9a897a --- /dev/null +++ b/emu668/src/main/res/xml/provider_paths.xml @@ -0,0 +1,13 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/emu668/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java b/emu668/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java new file mode 100644 index 0000000..3259554 --- /dev/null +++ b/emu668/src/test/java/Tptogiar/calculcator/ExampleUnitTest.java @@ -0,0 +1,35 @@ +package Tptogiar.calculcator; + +import org.junit.Test; + +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import static org.junit.Assert.*; + +/** + * Example local unit test, which will execute on the development machine (host). + * + * @see Testing documentation + */ +public class ExampleUnitTest { + @Test + public void addition_isCorrect() { + assertEquals(4, 2 + 2); + } + + @Test + public void TestPattern(){ +// + Pattern compile = Pattern.compile( "^(\\-|\\+)?\\d+(\\.\\d+)?$"); + String a="+45.5"; + boolean matches = compile.matcher(a).matches(); + System.out.println(matches); + String result = compile.matcher(a).replaceAll(""); + System.out.println(result); + + + } + + +} \ No newline at end of file diff --git a/settings.gradle b/settings.gradle index d099552..c93f281 100644 --- a/settings.gradle +++ b/settings.gradle @@ -43,4 +43,7 @@ include ':ppn88' include ':we1win' include ':rezeki44' include ':nova668' -include ':bk888' \ No newline at end of file +include ':bk888' +include ':RichSpin96' +include ':emu668' +include ':dapatcuci' \ No newline at end of file diff --git a/vv88/build.gradle b/vv88/build.gradle index 117cd5a..adccfcd 100644 --- a/vv88/build.gradle +++ b/vv88/build.gradle @@ -31,18 +31,18 @@ android { // keyAlias 'key0' // keyPassword "dskj2024" // } - debug { - storeFile file('dskjweb.jks') - storePassword "dskj2024" - keyAlias 'dskjalias' - keyPassword "dskj2024" - } - release { - storeFile file('dskjweb.jks') - storePassword "dskj2024" - keyAlias 'dskjalias' - keyPassword "dskj2024" - } +// debug { +// storeFile file('dskjweb.jks') +// storePassword "dskj2024" +// keyAlias 'dskjalias' +// keyPassword "dskj2024" +// } +// release { +// storeFile file('dskjweb.jks') +// storePassword "dskj2024" +// keyAlias 'dskjalias' +// keyPassword "dskj2024" +// } } buildTypes {