mirror of
http://gitea.winboll.cc/Studio/WinBoLL.git
synced 2026-07-02 21:29:32 +08:00
Compare commits
7 Commits
aes-v15.20
...
9e9486b488
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9e9486b488 | ||
|
|
4b8967b253 | ||
|
|
b1059c3f46 | ||
|
|
f3d723fbee | ||
|
|
e3c30ea9a3 | ||
|
|
ab4cef21f0 | ||
| 2754a2ad7c |
@@ -20,7 +20,7 @@ WinBoLL AndroidX 可视化元素类库。
|
|||||||
|
|
||||||
1. Fork 本仓库
|
1. Fork 本仓库
|
||||||
2. 新建 Feat_xxx 分支
|
2. 新建 Feat_xxx 分支
|
||||||
3. 提交代码 : ZhanGSKen(ZhanGSKen<zhangsken@188.com>)
|
3. 提交代码 : ZhanGSKen(ZhanGSKen<ZhanGSKen@QQ.COM>)
|
||||||
4. 新建 Pull Request
|
4. 新建 Pull Request
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Tue May 19 20:38:13 HKT 2026
|
#Wed May 27 20:22:45 HKT 2026
|
||||||
stageCount=8
|
stageCount=11
|
||||||
libraryProject=libaes
|
libraryProject=libaes
|
||||||
baseVersion=15.20
|
baseVersion=15.20
|
||||||
publishVersion=15.20.7
|
publishVersion=15.20.10
|
||||||
buildCount=0
|
buildCount=0
|
||||||
baseBetaVersion=15.20.8
|
baseBetaVersion=15.20.11
|
||||||
|
|||||||
@@ -18,8 +18,6 @@ public class App extends GlobalApplication {
|
|||||||
@Override
|
@Override
|
||||||
public void onCreate() {
|
public void onCreate() {
|
||||||
super.onCreate();
|
super.onCreate();
|
||||||
setIsDebugging(BuildConfig.DEBUG);
|
|
||||||
//setIsDebugging(false);
|
|
||||||
WinBoLLActivityManager.init(this);
|
WinBoLLActivityManager.init(this);
|
||||||
|
|
||||||
// 初始化 Toast 框架
|
// 初始化 Toast 框架
|
||||||
|
|||||||
@@ -84,11 +84,12 @@ public class MainActivity extends DrawerFragmentActivity {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
|
super.onCreateOptionsMenu(menu);
|
||||||
getMenuInflater().inflate(R.menu.toolbar_main, menu);
|
getMenuInflater().inflate(R.menu.toolbar_main, menu);
|
||||||
// if(App.isDebugging()) {
|
// if(App.isDebugging()) {
|
||||||
// getMenuInflater().inflate(cc.winboll.studio.libaes.R.menu.toolbar_studio_debug, menu);
|
// getMenuInflater().inflate(cc.winboll.studio.libaes.R.menu.toolbar_studio_debug, menu);
|
||||||
// }
|
// }
|
||||||
return super.onCreateOptionsMenu(menu);
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Wed May 20 16:12:13 HKT 2026
|
#Wed May 27 14:51:29 HKT 2026
|
||||||
stageCount=21
|
stageCount=23
|
||||||
libraryProject=libappbase
|
libraryProject=libappbase
|
||||||
baseVersion=15.20
|
baseVersion=15.20
|
||||||
publishVersion=15.20.20
|
publishVersion=15.20.22
|
||||||
buildCount=0
|
buildCount=0
|
||||||
baseBetaVersion=15.20.21
|
baseBetaVersion=15.20.23
|
||||||
|
|||||||
@@ -66,9 +66,9 @@ dependencies {
|
|||||||
//annotationProcessor 'com.github.bumptech.glide:compiler:4.9.0'
|
//annotationProcessor 'com.github.bumptech.glide:compiler:4.9.0'
|
||||||
|
|
||||||
// WinBoLL库 nexus.winboll.cc 地址
|
// WinBoLL库 nexus.winboll.cc 地址
|
||||||
api 'cc.winboll.studio:libappbase:15.20.9'
|
api 'cc.winboll.studio:libappbase:15.20.22'
|
||||||
// 备用库 jitpack.io 地址
|
// 备用库 jitpack.io 地址
|
||||||
//api 'com.github.ZhanGSKen:APPBase:appbase-v15.15.3'
|
//api 'com.github.ZhanGSKen:libappbase:appbase-v15.15.21'
|
||||||
|
|
||||||
api fileTree(dir: 'libs', include: ['*.jar'])
|
api fileTree(dir: 'libs', include: ['*.jar'])
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Tue May 19 20:38:13 HKT 2026
|
#Wed May 27 20:22:45 HKT 2026
|
||||||
stageCount=8
|
stageCount=11
|
||||||
libraryProject=libaes
|
libraryProject=libaes
|
||||||
baseVersion=15.20
|
baseVersion=15.20
|
||||||
publishVersion=15.20.7
|
publishVersion=15.20.10
|
||||||
buildCount=0
|
buildCount=0
|
||||||
baseBetaVersion=15.20.8
|
baseBetaVersion=15.20.11
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ package cc.winboll.studio.libaes.models;
|
|||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libaes.R;
|
import cc.winboll.studio.libaes.R;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class AESThemeBean extends BaseBean {
|
public class AESThemeBean extends BaseBean {
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ package cc.winboll.studio.libaes.models;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class WinBoLLClientServiceBean extends BaseBean {
|
public class WinBoLLClientServiceBean extends BaseBean {
|
||||||
|
|||||||
@@ -2,6 +2,9 @@
|
|||||||
<resources>
|
<resources>
|
||||||
|
|
||||||
<style name="AESTheme" parent="Theme.AppCompat.Light.NoActionBar">
|
<style name="AESTheme" parent="Theme.AppCompat.Light.NoActionBar">
|
||||||
|
<item name="colorPrimary">#FF03AB4E</item>
|
||||||
|
<item name="colorPrimaryDark">#FF027C39</item>
|
||||||
|
<item name="colorAccent">#FF3DDC84</item>
|
||||||
<item name="themeDebug">@style/DebugActivityTheme</item>
|
<item name="themeDebug">@style/DebugActivityTheme</item>
|
||||||
<item name="aboutViewBackgroundColor">@color/mainWindowBackgroundColor</item>
|
<item name="aboutViewBackgroundColor">@color/mainWindowBackgroundColor</item>
|
||||||
<item name="aboutViewTextColor">@color/mainWindowTextColor</item>
|
<item name="aboutViewTextColor">@color/mainWindowTextColor</item>
|
||||||
@@ -40,16 +43,16 @@
|
|||||||
|
|
||||||
<style name="AESAToolbar">
|
<style name="AESAToolbar">
|
||||||
<item name="attrAToolbarTitleTextColor">@color/colorTextColor</item>
|
<item name="attrAToolbarTitleTextColor">@color/colorTextColor</item>
|
||||||
<item name="attrAToolbarStartColor">@color/colorPrimaryDark</item>
|
<item name="attrAToolbarStartColor">?attr/colorPrimaryDark</item>
|
||||||
<item name="attrAToolbarCenterColor">@color/colorPrimary</item>
|
<item name="attrAToolbarCenterColor">?attr/colorPrimary</item>
|
||||||
<item name="attrAToolbarEndColor">@color/colorAccent</item>
|
<item name="attrAToolbarEndColor">?attr/colorAccent</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="AESASupportToolbar">
|
<style name="AESASupportToolbar">
|
||||||
<item name="attrASupportToolbarTitleTextColor">@color/colorTextColor</item>
|
<item name="attrASupportToolbarTitleTextColor">@color/colorTextColor</item>
|
||||||
<item name="attrASupportToolbarStartColor">@color/colorPrimaryDark</item>
|
<item name="attrASupportToolbarStartColor">?attr/colorPrimaryDark</item>
|
||||||
<item name="attrASupportToolbarCenterColor">@color/colorPrimary</item>
|
<item name="attrASupportToolbarCenterColor">?attr/colorPrimary</item>
|
||||||
<item name="attrASupportToolbarEndColor">@color/colorAccent</item>
|
<item name="attrASupportToolbarEndColor">?attr/colorAccent</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="DepthAESTheme" parent="AESTheme">
|
<style name="DepthAESTheme" parent="AESTheme">
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Wed May 20 16:12:13 HKT 2026
|
#Wed May 27 14:51:29 HKT 2026
|
||||||
stageCount=21
|
stageCount=23
|
||||||
libraryProject=libappbase
|
libraryProject=libappbase
|
||||||
baseVersion=15.20
|
baseVersion=15.20
|
||||||
publishVersion=15.20.20
|
publishVersion=15.20.22
|
||||||
buildCount=0
|
buildCount=0
|
||||||
baseBetaVersion=15.20.21
|
baseBetaVersion=15.20.23
|
||||||
|
|||||||
@@ -1,6 +1,8 @@
|
|||||||
package cc.winboll.studio.libappbase.views;
|
package cc.winboll.studio.libappbase.views;
|
||||||
|
|
||||||
|
import android.app.AlertDialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
@@ -12,6 +14,7 @@ import android.widget.ImageButton;
|
|||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
import android.widget.Toast;
|
||||||
import cc.winboll.studio.libappbase.GlobalApplication;
|
import cc.winboll.studio.libappbase.GlobalApplication;
|
||||||
import cc.winboll.studio.libappbase.LogUtils;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import cc.winboll.studio.libappbase.R;
|
import cc.winboll.studio.libappbase.R;
|
||||||
@@ -74,12 +77,12 @@ public class AboutView extends LinearLayout {
|
|||||||
private EditText metDevUserPassword;
|
private EditText metDevUserPassword;
|
||||||
|
|
||||||
// ===================================== 页面视图控件 =====================================
|
// ===================================== 页面视图控件 =====================================
|
||||||
private DebugSwitchImageView ivAppIcon;
|
private DebugSwitchInfoImageView ivAppIcon;
|
||||||
private TextView tvAppNameVersion;
|
private TextView tvAppNameVersion;
|
||||||
private TextView tvAppDesc;
|
private TextView tvAppDesc;
|
||||||
private LinearLayout llFunctionContainer;
|
private LinearLayout llFunctionContainer;
|
||||||
private ImageButton ibSebugStepOver;
|
private ImageButton ibSebugStepOver;
|
||||||
private ImageButton ibSigngetDialog;
|
private ImageButton ibDebugUnlock;
|
||||||
private ImageButton ibWinBoLLHostDialog;
|
private ImageButton ibWinBoLLHostDialog;
|
||||||
|
|
||||||
// ===================================== 构造方法(按参数从少到多排序) =====================================
|
// ===================================== 构造方法(按参数从少到多排序) =====================================
|
||||||
@@ -193,12 +196,12 @@ public class AboutView extends LinearLayout {
|
|||||||
llFunctionContainer = findViewById(R.id.ll_function_container);
|
llFunctionContainer = findViewById(R.id.ll_function_container);
|
||||||
// 功能按钮绑定
|
// 功能按钮绑定
|
||||||
ibSebugStepOver = findViewById(R.id.ib_debug_step_over);
|
ibSebugStepOver = findViewById(R.id.ib_debug_step_over);
|
||||||
ibSigngetDialog = findViewById(R.id.ib_signgetdialog);
|
ibDebugUnlock = findViewById(R.id.ib_debug_unlock);
|
||||||
ibWinBoLLHostDialog = findViewById(R.id.ib_winbollhostdialog);
|
ibWinBoLLHostDialog = findViewById(R.id.ib_winbollhostdialog);
|
||||||
|
|
||||||
// 调试按钮统一只在调试模式显示
|
// 调试按钮统一只在调试模式显示
|
||||||
ibWinBoLLHostDialog.setVisibility(GlobalApplication.isDebugging() ? View.VISIBLE : View.GONE);
|
ibWinBoLLHostDialog.setVisibility(GlobalApplication.isDebugging() ? View.VISIBLE : View.GONE);
|
||||||
//ibSigngetDialog.setVisibility(GlobalApplication.isDebugging() ? View.VISIBLE : View.GONE);
|
//ibDebugUnlock.setVisibility(GlobalApplication.isDebugging() ? View.VISIBLE : View.GONE);
|
||||||
ibSebugStepOver.setVisibility(GlobalApplication.isDebugging() ? View.VISIBLE : View.GONE);
|
ibSebugStepOver.setVisibility(GlobalApplication.isDebugging() ? View.VISIBLE : View.GONE);
|
||||||
|
|
||||||
// 绑定按钮点击事件
|
// 绑定按钮点击事件
|
||||||
@@ -310,6 +313,47 @@ public class AboutView extends LinearLayout {
|
|||||||
LogUtils.d(TAG, "initAboutPageView():视图组装完成,功能项加载完毕");
|
LogUtils.d(TAG, "initAboutPageView():视图组装完成,功能项加载完毕");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ===================================== 调试解锁弹窗 =====================================
|
||||||
|
private void showDebugUnlockDialog() {
|
||||||
|
final AlertDialog dialog = new AlertDialog.Builder(mContext).create();
|
||||||
|
dialog.setTitle("应用调试解锁");
|
||||||
|
dialog.setCanceledOnTouchOutside(true);
|
||||||
|
|
||||||
|
final EditText etToken = new EditText(mContext);
|
||||||
|
etToken.setHint("请输入调试Token");
|
||||||
|
dialog.setView(etToken);
|
||||||
|
|
||||||
|
dialog.setButton(DialogInterface.BUTTON_POSITIVE, "调试解锁", (DialogInterface.OnClickListener) null);
|
||||||
|
dialog.setButton(DialogInterface.BUTTON_NEGATIVE, "关闭", (DialogInterface.OnClickListener) null);
|
||||||
|
dialog.setOnShowListener(new DialogInterface.OnShowListener() {
|
||||||
|
@Override
|
||||||
|
public void onShow(DialogInterface d) {
|
||||||
|
dialog.getButton(AlertDialog.BUTTON_POSITIVE).setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
String inputToken = etToken.getText().toString().trim();
|
||||||
|
String savedToken = DebugSwitchInfoImageView.getDebugToken();
|
||||||
|
if (savedToken != null && savedToken.equals(inputToken)) {
|
||||||
|
GlobalApplication.setIsDebugging(true);
|
||||||
|
GlobalApplication.saveDebugStatus(GlobalApplication.getInstance());
|
||||||
|
Toast.makeText(mContext, "调试解锁成功,重启应用后生效", Toast.LENGTH_SHORT).show();
|
||||||
|
} else {
|
||||||
|
Toast.makeText(mContext, "调试Token不匹配", Toast.LENGTH_SHORT).show();
|
||||||
|
dialog.dismiss();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
dialog.getButton(AlertDialog.BUTTON_NEGATIVE).setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
dialog.dismiss();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
dialog.show();
|
||||||
|
}
|
||||||
|
|
||||||
// ===================================== 内部工具/事件方法 =====================================
|
// ===================================== 内部工具/事件方法 =====================================
|
||||||
/**
|
/**
|
||||||
* 绑定功能按钮点击事件,处理正版校验、调试地址配置弹窗唤起
|
* 绑定功能按钮点击事件,处理正版校验、调试地址配置弹窗唤起
|
||||||
@@ -335,6 +379,15 @@ public class AboutView extends LinearLayout {
|
|||||||
new DebugHostDialog(mContext).show();
|
new DebugHostDialog(mContext).show();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// 应用调试解锁按钮
|
||||||
|
ibDebugUnlock.setOnClickListener(new OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
LogUtils.d(TAG, "ibDebugUnlock onClick:弹出调试解锁对话框");
|
||||||
|
showDebugUnlockDialog();
|
||||||
|
}
|
||||||
|
});
|
||||||
LogUtils.d(TAG, "setBtnClickListener():功能按钮点击事件绑定完成");
|
LogUtils.d(TAG, "setBtnClickListener():功能按钮点击事件绑定完成");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,127 @@
|
|||||||
|
package cc.winboll.studio.libappbase.views;
|
||||||
|
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.content.ClipData;
|
||||||
|
import android.content.ClipboardManager;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.ImageView;
|
||||||
|
import java.util.UUID;
|
||||||
|
import cc.winboll.studio.libappbase.GlobalApplication;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author 豆包&ZhanGSKen<zhangsken@qq.com>
|
||||||
|
* @Date 2026/04/06 19:32
|
||||||
|
* @Describe 应用Logo控件,连续点击6次弹出调试Token对话框,支持复制与重置
|
||||||
|
*/
|
||||||
|
public class DebugSwitchInfoImageView extends ImageView {
|
||||||
|
|
||||||
|
public static final String TAG = "DebugSwitchInfoImageView";
|
||||||
|
|
||||||
|
// 连续点击计数
|
||||||
|
private int mClickCount = 0;
|
||||||
|
// 目标点击次数
|
||||||
|
private static final int TARGET_CLICK_COUNT = 7;
|
||||||
|
|
||||||
|
private static String mDebugToken = null;
|
||||||
|
private static final String SP_DEBUG_TOKEN = "debug_token_prefs";
|
||||||
|
private static final String KEY_DEBUG_TOKEN = "debug_token";
|
||||||
|
|
||||||
|
public static String getDebugToken() {
|
||||||
|
if (mDebugToken != null) {
|
||||||
|
return mDebugToken;
|
||||||
|
}
|
||||||
|
Context context = GlobalApplication.getInstance();
|
||||||
|
if (context != null) {
|
||||||
|
SharedPreferences sp = context.getSharedPreferences(SP_DEBUG_TOKEN, Context.MODE_PRIVATE);
|
||||||
|
mDebugToken = sp.getString(KEY_DEBUG_TOKEN, null);
|
||||||
|
if (mDebugToken == null) {
|
||||||
|
mDebugToken = UUID.randomUUID().toString();
|
||||||
|
sp.edit().putString(KEY_DEBUG_TOKEN, mDebugToken).apply();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return mDebugToken;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void resetDebugToken() {
|
||||||
|
Context context = GlobalApplication.getInstance();
|
||||||
|
if (context != null) {
|
||||||
|
mDebugToken = UUID.randomUUID().toString();
|
||||||
|
SharedPreferences sp = context.getSharedPreferences(SP_DEBUG_TOKEN, Context.MODE_PRIVATE);
|
||||||
|
sp.edit().putString(KEY_DEBUG_TOKEN, mDebugToken).apply();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void showDebugTokenDialog() {
|
||||||
|
final AlertDialog dialog = new AlertDialog.Builder(getContext()).create();
|
||||||
|
dialog.setTitle("调试Token");
|
||||||
|
dialog.setMessage(getDebugToken());
|
||||||
|
dialog.setCanceledOnTouchOutside(false);
|
||||||
|
dialog.setButton(DialogInterface.BUTTON_POSITIVE, "复制到剪贴板", (DialogInterface.OnClickListener) null);
|
||||||
|
dialog.setButton(DialogInterface.BUTTON_NEUTRAL, "重置", (DialogInterface.OnClickListener) null);
|
||||||
|
dialog.setButton(DialogInterface.BUTTON_NEGATIVE, "关闭", (DialogInterface.OnClickListener) null);
|
||||||
|
dialog.setOnShowListener(new DialogInterface.OnShowListener() {
|
||||||
|
@Override
|
||||||
|
public void onShow(DialogInterface d) {
|
||||||
|
dialog.getButton(AlertDialog.BUTTON_POSITIVE).setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
ClipboardManager cm = (ClipboardManager) getContext().getSystemService(Context.CLIPBOARD_SERVICE);
|
||||||
|
cm.setPrimaryClip(ClipData.newPlainText("DebugToken", getDebugToken()));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
dialog.getButton(AlertDialog.BUTTON_NEUTRAL).setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
resetDebugToken();
|
||||||
|
dialog.setMessage(getDebugToken());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
dialog.getButton(AlertDialog.BUTTON_NEGATIVE).setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
dialog.dismiss();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
dialog.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
public DebugSwitchInfoImageView(Context context) {
|
||||||
|
super(context);
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
|
public DebugSwitchInfoImageView(Context context, AttributeSet attrs) {
|
||||||
|
super(context, attrs);
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
|
public DebugSwitchInfoImageView(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
|
super(context, attrs, defStyleAttr);
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
|
public DebugSwitchInfoImageView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
|
||||||
|
super(context, attrs, defStyleAttr, defStyleRes);
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void init() {
|
||||||
|
setOnClickListener(new OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
mClickCount++;
|
||||||
|
if (mClickCount >= TARGET_CLICK_COUNT) {
|
||||||
|
mClickCount = 0;
|
||||||
|
showDebugTokenDialog();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -15,7 +15,7 @@
|
|||||||
android:paddingRight="16dp"
|
android:paddingRight="16dp"
|
||||||
android:paddingBottom="16dp">
|
android:paddingBottom="16dp">
|
||||||
|
|
||||||
<cc.winboll.studio.libappbase.views.DebugSwitchImageView
|
<cc.winboll.studio.libappbase.views.DebugSwitchInfoImageView
|
||||||
android:id="@+id/iv_app_icon"
|
android:id="@+id/iv_app_icon"
|
||||||
android:layout_width="48dp"
|
android:layout_width="48dp"
|
||||||
android:layout_height="48dp"
|
android:layout_height="48dp"
|
||||||
@@ -81,7 +81,8 @@
|
|||||||
android:layout_width="48dp"
|
android:layout_width="48dp"
|
||||||
android:layout_height="48dp"
|
android:layout_height="48dp"
|
||||||
android:src="@drawable/ic_key"
|
android:src="@drawable/ic_key"
|
||||||
android:id="@+id/ib_signgetdialog"
|
android:id="@+id/ib_debug_unlock"
|
||||||
|
android:contentDescription="应用调试解锁"
|
||||||
android:scaleType="fitCenter"
|
android:scaleType="fitCenter"
|
||||||
android:adjustViewBounds="true"
|
android:adjustViewBounds="true"
|
||||||
android:background="@null"/>
|
android:background="@null"/>
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
android:paddingRight="16dp"
|
android:paddingRight="16dp"
|
||||||
android:paddingBottom="16dp">
|
android:paddingBottom="16dp">
|
||||||
|
|
||||||
<cc.winboll.studio.libappbase.views.DebugSwitchImageView
|
<cc.winboll.studio.libappbase.views.DebugSwitchInfoImageView
|
||||||
android:id="@+id/iv_app_icon"
|
android:id="@+id/iv_app_icon"
|
||||||
android:layout_width="48dp"
|
android:layout_width="48dp"
|
||||||
android:layout_height="48dp"
|
android:layout_height="48dp"
|
||||||
@@ -81,7 +81,8 @@
|
|||||||
android:layout_width="48dp"
|
android:layout_width="48dp"
|
||||||
android:layout_height="48dp"
|
android:layout_height="48dp"
|
||||||
android:src="@drawable/ic_key"
|
android:src="@drawable/ic_key"
|
||||||
android:id="@+id/ib_signgetdialog"
|
android:id="@+id/ib_debug_unlock"
|
||||||
|
android:contentDescription="应用调试解锁"
|
||||||
android:scaleType="fitCenter"
|
android:scaleType="fitCenter"
|
||||||
android:adjustViewBounds="true"
|
android:adjustViewBounds="true"
|
||||||
android:background="@null"/>
|
android:background="@null"/>
|
||||||
|
|||||||
@@ -34,9 +34,23 @@ dependencies {
|
|||||||
// 添加JSch依赖(SFTP核心,com.jcraft:jsch:0.1.54)
|
// 添加JSch依赖(SFTP核心,com.jcraft:jsch:0.1.54)
|
||||||
api 'com.jcraft:jsch:0.1.54'
|
api 'com.jcraft:jsch:0.1.54'
|
||||||
|
|
||||||
|
// 米盟
|
||||||
|
api 'com.miui.zeus:mimo-ad-sdk:5.3.+'//请使用最新版sdk
|
||||||
|
//注意:以下5个库必须要引入
|
||||||
|
//implementation 'androidx.appcompat:appcompat:1.4.1'
|
||||||
|
api 'androidx.recyclerview:recyclerview:1.0.0'
|
||||||
|
api 'com.google.code.gson:gson:2.8.5'
|
||||||
|
api 'com.github.bumptech.glide:glide:4.9.0'
|
||||||
|
//annotationProcessor 'com.github.bumptech.glide:compiler:4.9.0'
|
||||||
|
|
||||||
// WinBoLL库 nexus.winboll.cc 地址
|
// WinBoLL库 nexus.winboll.cc 地址
|
||||||
api 'cc.winboll.studio:libaes:15.20.3'
|
api 'cc.winboll.studio:libappbase:15.20.21'
|
||||||
api 'cc.winboll.studio:libappbase:15.20.9'
|
api 'cc.winboll.studio:libaes:15.20.9'
|
||||||
|
|
||||||
|
// 备用库 jitpack.io 地址
|
||||||
|
//api 'com.github.ZhanGSKen:libappbase:appbase-v15.20.20'
|
||||||
|
//api 'com.github.ZhanGSKen:libaes:aes-v15.20.8'
|
||||||
|
|
||||||
|
|
||||||
api fileTree(dir: 'libs', include: ['*.jar'])
|
api fileTree(dir: 'libs', include: ['*.jar'])
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Fri May 15 08:48:45 GMT 2026
|
#Mon Jun 01 20:31:36 HKT 2026
|
||||||
stageCount=2
|
stageCount=5
|
||||||
libraryProject=libwinboll
|
libraryProject=libwinboll
|
||||||
baseVersion=15.20
|
baseVersion=15.20
|
||||||
publishVersion=15.20.1
|
publishVersion=15.20.4
|
||||||
buildCount=7
|
buildCount=0
|
||||||
baseBetaVersion=15.20.2
|
baseBetaVersion=15.20.5
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ WinBoLL 网站浏览器。
|
|||||||
|
|
||||||
1. Fork 本仓库
|
1. Fork 本仓库
|
||||||
2. 新建 Feat_xxx 分支
|
2. 新建 Feat_xxx 分支
|
||||||
3. 提交代码 : ZhanGSKen(ZhanGSKen<zhangsken@188.com>)
|
3. 提交代码 : ZhanGSKen(ZhanGSKen<ZhanGSKen@QQ.COM>)
|
||||||
4. 新建 Pull Request
|
4. 新建 Pull Request
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -104,5 +104,13 @@ dependencies {
|
|||||||
implementation 'com.termux:terminal-view:0.118.0'
|
implementation 'com.termux:terminal-view:0.118.0'
|
||||||
implementation 'com.termux:termux-shared:0.118.0'
|
implementation 'com.termux:termux-shared:0.118.0'
|
||||||
|
|
||||||
|
// WinBoLL库 nexus.winboll.cc 地址
|
||||||
|
api 'cc.winboll.studio:libappbase:15.20.22'
|
||||||
|
api 'cc.winboll.studio:libaes:15.20.10'
|
||||||
|
|
||||||
|
// 备用库 jitpack.io 地址
|
||||||
|
//api 'com.github.ZhanGSKen:libappbase:appbase-v15.20.21'
|
||||||
|
//api 'com.github.ZhanGSKen:libaes:aes-v15.20.9'
|
||||||
|
|
||||||
api fileTree(dir: 'libs', include: ['*.jar'])
|
api fileTree(dir: 'libs', include: ['*.jar'])
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Fri May 15 08:48:45 GMT 2026
|
#Mon Jun 01 20:31:36 HKT 2026
|
||||||
stageCount=2
|
stageCount=5
|
||||||
libraryProject=libwinboll
|
libraryProject=libwinboll
|
||||||
baseVersion=15.20
|
baseVersion=15.20
|
||||||
publishVersion=15.20.1
|
publishVersion=15.20.4
|
||||||
buildCount=7
|
buildCount=0
|
||||||
baseBetaVersion=15.20.2
|
baseBetaVersion=15.20.5
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ public class App extends GlobalApplication {
|
|||||||
@Override
|
@Override
|
||||||
public void onCreate() {
|
public void onCreate() {
|
||||||
super.onCreate();
|
super.onCreate();
|
||||||
setIsDebugging(BuildConfig.DEBUG);
|
//setIsDebugging(BuildConfig.DEBUG);
|
||||||
//setIsDebugging(false);
|
//setIsDebugging(false);
|
||||||
|
|
||||||
WinBoLLActivityManager.init(this);
|
WinBoLLActivityManager.init(this);
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ package cc.winboll.studio.winboll.models;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class MainServiceBean extends BaseBean {
|
public class MainServiceBean extends BaseBean {
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
package cc.winboll.studio.winboll.models;
|
package cc.winboll.studio.winboll.models;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
|
import cc.winboll.studio.winboll.models.TermuxButtonModel;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class TermuxButtonManager {
|
public class TermuxButtonManager {
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package cc.winboll.studio.winboll.models;
|
|||||||
|
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ package cc.winboll.studio.winboll.models;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class TestDemoBindServiceBean extends BaseBean {
|
public class TestDemoBindServiceBean extends BaseBean {
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ package cc.winboll.studio.winboll.models;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class TestDemoServiceBean extends BaseBean {
|
public class TestDemoServiceBean extends BaseBean {
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ package cc.winboll.studio.winboll.models;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class UserInfoModel extends BaseBean {
|
public class UserInfoModel extends BaseBean {
|
||||||
|
|||||||
@@ -7,9 +7,9 @@ package cc.winboll.studio.winboll.models;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
|
||||||
import java.io.IOException;
|
|
||||||
import cc.winboll.studio.libappbase.APPModel;
|
import cc.winboll.studio.libappbase.APPModel;
|
||||||
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
public class WinBoLLModel extends BaseBean {
|
public class WinBoLLModel extends BaseBean {
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ package cc.winboll.studio.winboll.models;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class WinBoLLNewsBean extends BaseBean {
|
public class WinBoLLNewsBean extends BaseBean {
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ package cc.winboll.studio.winboll.sos;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class SOSCenterServiceModel extends BaseBean {
|
public class SOSCenterServiceModel extends BaseBean {
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ package cc.winboll.studio.winboll.sos;
|
|||||||
*/
|
*/
|
||||||
import android.util.JsonReader;
|
import android.util.JsonReader;
|
||||||
import android.util.JsonWriter;
|
import android.util.JsonWriter;
|
||||||
import cc.winboll.studio.libappbase.BaseBean;
|
import cc.winboll.studio.libappbase.models.libs1520000.BaseBean;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public class SOSObject extends BaseBean {
|
public class SOSObject extends BaseBean {
|
||||||
|
|||||||
Reference in New Issue
Block a user