Compare commits
16 Commits
apputils-v
...
apputils-v
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ac7b5bb1a2 | ||
|
|
eeae184e7e | ||
|
|
d5f34ad618 | ||
|
|
3ad1863a5f | ||
|
|
291080aa15 | ||
|
|
973a0ff94f | ||
|
|
e04ea7f035 | ||
|
|
ecbaf639a0 | ||
|
|
050fd46d81 | ||
|
|
d4ea79b950 | ||
|
|
06a40a4298 | ||
|
|
35835d746e | ||
|
|
5f3d03ba7d | ||
|
|
1d372ff9ae | ||
|
|
4a1e398755 | ||
|
|
107be6d6ad |
@@ -18,18 +18,18 @@ def genVersionName(def versionName){
|
|||||||
}
|
}
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 32
|
compileSdkVersion 30
|
||||||
buildToolsVersion "33.0.3"
|
buildToolsVersion "30.0.3"
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
applicationId "cc.winboll.studio.apputils"
|
applicationId "cc.winboll.studio.apputils"
|
||||||
minSdkVersion 21
|
minSdkVersion 26
|
||||||
targetSdkVersion 30
|
targetSdkVersion 29
|
||||||
versionCode 1
|
versionCode 1
|
||||||
// versionName 更新后需要手动设置
|
// versionName 更新后需要手动设置
|
||||||
// 项目模块目录的 build.gradle 文件的 stageCount=0
|
// 项目模块目录的 build.gradle 文件的 stageCount=0
|
||||||
// Gradle编译环境下合起来的 versionName 就是 "${versionName}.0"
|
// Gradle编译环境下合起来的 versionName 就是 "${versionName}.0"
|
||||||
versionName "9.3"
|
versionName "9.4"
|
||||||
if(true) {
|
if(true) {
|
||||||
versionName = genVersionName("${versionName}")
|
versionName = genVersionName("${versionName}")
|
||||||
}
|
}
|
||||||
@@ -50,6 +50,29 @@ android {
|
|||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
api project(':libapputils')
|
api project(':libapputils')
|
||||||
|
|
||||||
api fileTree(dir: 'libs', include: ['*.jar'])
|
api fileTree(dir: 'libs', include: ['*.jar'])
|
||||||
|
|
||||||
|
// SSH
|
||||||
|
implementation 'com.jcraft:jsch:0.1.55'
|
||||||
|
// Html 解析
|
||||||
|
implementation 'org.jsoup:jsoup:1.13.1'
|
||||||
|
// 二维码类库
|
||||||
|
implementation 'com.google.zxing:core:3.4.1'
|
||||||
|
implementation 'com.journeyapps:zxing-android-embedded:3.6.0'
|
||||||
|
// 应用介绍页类库
|
||||||
|
implementation 'io.github.medyo:android-about-page:2.0.0'
|
||||||
|
// 吐司类库
|
||||||
|
implementation 'com.github.getActivity:ToastUtils:10.5'
|
||||||
|
// 网络连接类库
|
||||||
|
implementation 'com.squareup.okhttp3:okhttp:4.4.1'
|
||||||
|
|
||||||
|
// Android 类库
|
||||||
|
implementation 'androidx.appcompat:appcompat:1.1.0'
|
||||||
|
implementation 'androidx.viewpager:viewpager:1.0.0'
|
||||||
|
implementation 'androidx.vectordrawable:vectordrawable:1.1.0'
|
||||||
|
implementation 'androidx.vectordrawable:vectordrawable-animated:1.1.0'
|
||||||
|
implementation 'androidx.fragment:fragment:1.1.0'
|
||||||
|
implementation 'com.google.android.material:material:1.4.0'
|
||||||
|
|
||||||
|
implementation 'cc.winboll.studio:libappbase:2.1.3'
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Thu Feb 06 11:02:45 HKT 2025
|
#Sat Mar 08 03:59:02 HKT 2025
|
||||||
stageCount=2
|
stageCount=3
|
||||||
libraryProject=libapputils
|
libraryProject=libapputils
|
||||||
baseVersion=9.3
|
baseVersion=9.4
|
||||||
publishVersion=9.3.1
|
publishVersion=9.4.2
|
||||||
buildCount=0
|
buildCount=0
|
||||||
baseBetaVersion=9.3.2
|
baseBetaVersion=9.4.3
|
||||||
|
|||||||
@@ -8,7 +8,7 @@
|
|||||||
android:allowBackup="true"
|
android:allowBackup="true"
|
||||||
android:icon="@drawable/ic_winboll"
|
android:icon="@drawable/ic_winboll"
|
||||||
android:label="@string/app_name"
|
android:label="@string/app_name"
|
||||||
android:theme="@style/WinBoll.SupportThemeNoActionBar"
|
android:theme="@style/MyAppTheme"
|
||||||
android:supportsRtl="true">
|
android:supportsRtl="true">
|
||||||
|
|
||||||
<activity
|
<activity
|
||||||
|
|||||||
@@ -7,15 +7,12 @@ package cc.winboll.studio.apputils;
|
|||||||
*/
|
*/
|
||||||
import android.app.Application;
|
import android.app.Application;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.view.Gravity;
|
|
||||||
import android.widget.Toast;
|
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.libapputils.app.MyActivityLifecycleCallbacks;
|
import cc.winboll.studio.libapputils.app.MyActivityLifecycleCallbacks;
|
||||||
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
||||||
import cc.winboll.studio.libapputils.bean.DebugBean;
|
import cc.winboll.studio.libapputils.bean.DebugBean;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
|
||||||
import com.hjq.toast.ToastUtils;
|
|
||||||
import com.hjq.toast.style.WhiteToastStyle;
|
|
||||||
|
|
||||||
public class App extends GlobalApplication {
|
public class App extends GlobalApplication {
|
||||||
|
|
||||||
@@ -57,15 +54,15 @@ public class App extends GlobalApplication {
|
|||||||
// 应用环境初始化, 基本调试环境
|
// 应用环境初始化, 基本调试环境
|
||||||
//
|
//
|
||||||
// 初始化日志模块
|
// 初始化日志模块
|
||||||
LogUtils.init(this);
|
//LogUtils.init(this);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// 初始化 Toast 框架
|
// 初始化 Toast 框架
|
||||||
ToastUtils.init(this);
|
// ToastUtils.init(this);
|
||||||
// 设置 Toast 布局样式
|
// // 设置 Toast 布局样式
|
||||||
//ToastUtils.setView(R.layout.view_toast);
|
// //ToastUtils.setView(R.layout.view_toast);
|
||||||
ToastUtils.setStyle(new WhiteToastStyle());
|
// ToastUtils.setStyle(new WhiteToastStyle());
|
||||||
ToastUtils.setGravity(Gravity.BOTTOM, 0, 200);
|
// ToastUtils.setGravity(Gravity.BOTTOM, 0, 200);
|
||||||
// 设置应用调试标志
|
// 设置应用调试标志
|
||||||
DebugBean debugBean = DebugBean.loadBean(this, DebugBean.class);
|
DebugBean debugBean = DebugBean.loadBean(this, DebugBean.class);
|
||||||
if (debugBean == null) {
|
if (debugBean == null) {
|
||||||
|
|||||||
@@ -13,14 +13,15 @@ import android.widget.Toast;
|
|||||||
import androidx.appcompat.app.AppCompatActivity;
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
import androidx.appcompat.widget.Toolbar;
|
import androidx.appcompat.widget.Toolbar;
|
||||||
import cc.winboll.studio.apputils.R;
|
import cc.winboll.studio.apputils.R;
|
||||||
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
|
import cc.winboll.studio.libappbase.LogView;
|
||||||
import cc.winboll.studio.libapputils.activities.AssetsHtmlActivity;
|
import cc.winboll.studio.libapputils.activities.AssetsHtmlActivity;
|
||||||
|
import cc.winboll.studio.libapputils.activities.LogActivity;
|
||||||
import cc.winboll.studio.libapputils.activities.QRCodeDecodeActivity;
|
import cc.winboll.studio.libapputils.activities.QRCodeDecodeActivity;
|
||||||
import cc.winboll.studio.libapputils.app.AboutActivityFactory;
|
import cc.winboll.studio.libapputils.app.AboutActivityFactory;
|
||||||
import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
||||||
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
||||||
import cc.winboll.studio.libapputils.bean.APPInfo;
|
import cc.winboll.studio.libapputils.bean.APPInfo;
|
||||||
import cc.winboll.studio.libapputils.log.LogActivity;
|
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
|
||||||
import cc.winboll.studio.libapputils.view.AboutView;
|
import cc.winboll.studio.libapputils.view.AboutView;
|
||||||
import cc.winboll.studio.libapputils.view.YesNoAlertDialog;
|
import cc.winboll.studio.libapputils.view.YesNoAlertDialog;
|
||||||
import com.hjq.toast.ToastUtils;
|
import com.hjq.toast.ToastUtils;
|
||||||
@@ -34,6 +35,7 @@ final public class MainActivity extends AppCompatActivity implements IWinBollAct
|
|||||||
public static final int REQUEST_QRCODEDECODE_ACTIVITY = 0;
|
public static final int REQUEST_QRCODEDECODE_ACTIVITY = 0;
|
||||||
|
|
||||||
Toolbar mToolbar;
|
Toolbar mToolbar;
|
||||||
|
LogView mLogView;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AppCompatActivity getActivity() {
|
public AppCompatActivity getActivity() {
|
||||||
@@ -58,7 +60,7 @@ final public class MainActivity extends AppCompatActivity implements IWinBollAct
|
|||||||
return appInfo;
|
return appInfo;
|
||||||
//return null;
|
//return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getTag() {
|
public String getTag() {
|
||||||
return TAG;
|
return TAG;
|
||||||
@@ -84,6 +86,9 @@ final public class MainActivity extends AppCompatActivity implements IWinBollAct
|
|||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
|
|
||||||
|
mLogView = findViewById(R.id.logview);
|
||||||
|
mLogView.start();
|
||||||
|
|
||||||
// 初始化工具栏
|
// 初始化工具栏
|
||||||
mToolbar = findViewById(R.id.activitymainToolbar1);
|
mToolbar = findViewById(R.id.activitymainToolbar1);
|
||||||
setSupportActionBar(mToolbar);
|
setSupportActionBar(mToolbar);
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ public class TestStringToQrCodeViewActivity extends AppCompatActivity implements
|
|||||||
public APPInfo getAppInfo() {
|
public APPInfo getAppInfo() {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getTag() {
|
public String getTag() {
|
||||||
return TAG;
|
return TAG;
|
||||||
|
|||||||
@@ -27,7 +27,7 @@
|
|||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="TestLog"
|
android:text="TestLog"
|
||||||
android:textAllCaps="false"
|
android:textAllCaps="false"
|
||||||
android:onClick="onTestLogClick"/>
|
android:onClick="onTestLogClick"/>
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
@@ -39,35 +39,28 @@
|
|||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:gravity="right">
|
android:gravity="right">
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:textAllCaps="false"
|
android:textAllCaps="false"
|
||||||
android:text="Test Javascript Html Activity"
|
android:text="Test Javascript Html Activity"
|
||||||
android:onClick="onTestJavascriptHtmlActivity"/>
|
android:onClick="onTestJavascriptHtmlActivity"/>
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<LinearLayout
|
<cc.winboll.studio.libappbase.LogView
|
||||||
android:orientation="horizontal"
|
android:layout_width="match_parent"
|
||||||
android:layout_width="match_parent"
|
android:layout_height="0dp"
|
||||||
android:layout_height="wrap_content"
|
android:text="Button"
|
||||||
android:gravity="right">
|
android:id="@+id/logview"
|
||||||
|
android:layout_weight="1.0"/>
|
||||||
|
|
||||||
<cc.winboll.studio.libapputils.view.AboutBranchButton
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="About"
|
|
||||||
android:textAllCaps="false"/>
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|||||||
@@ -4,7 +4,4 @@
|
|||||||
<color name="colorPrimary">#FF196ABC</color>
|
<color name="colorPrimary">#FF196ABC</color>
|
||||||
<color name="colorPrimaryDark">#FF002B57</color>
|
<color name="colorPrimaryDark">#FF002B57</color>
|
||||||
<color name="colorAccent">#FF80BFFF</color>
|
<color name="colorAccent">#FF80BFFF</color>
|
||||||
<color name="colorToastFrame">#FFA9A9A9</color>
|
|
||||||
<color name="colorToastShadow">#FF000000</color>
|
|
||||||
<color name="colorToastBackgroung">#FFFFFFFF</color>
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@@ -1,3 +1,14 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
|
|
||||||
|
<style name="MyAppTheme" parent="APPBaseTheme">
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<style name="GlobalCrashActivityTheme" parent="@android:style/Theme.DeviceDefault.Light.NoActionBar">
|
||||||
|
<item name="colorTittle">@color/colorAccent</item>
|
||||||
|
<item name="colorTittleBackgound">@color/colorPrimary</item>
|
||||||
|
<item name="colorText">@color/colorAccent</item>
|
||||||
|
<item name="colorTextBackgound">@color/colorPrimaryDark</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@@ -4,12 +4,12 @@ apply from: '../.winboll/winboll_lib_build.gradle'
|
|||||||
apply from: '../.winboll/winboll_lint_build.gradle'
|
apply from: '../.winboll/winboll_lint_build.gradle'
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 32
|
compileSdkVersion 30
|
||||||
buildToolsVersion "33.0.3"
|
buildToolsVersion "30.0.3"
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 21
|
minSdkVersion 26
|
||||||
targetSdkVersion 30
|
targetSdkVersion 29
|
||||||
}
|
}
|
||||||
buildTypes {
|
buildTypes {
|
||||||
release {
|
release {
|
||||||
@@ -17,28 +17,32 @@ android {
|
|||||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
compileOptions {
|
|
||||||
sourceCompatibility JavaVersion.VERSION_11
|
|
||||||
targetCompatibility JavaVersion.VERSION_11
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
// 二维码使用的类库
|
|
||||||
api 'com.google.zxing:core:3.4.1'
|
|
||||||
api 'com.journeyapps:zxing-android-embedded:3.6.0'
|
|
||||||
|
|
||||||
api 'io.github.medyo:android-about-page:2.0.0'
|
|
||||||
api 'com.github.getActivity:ToastUtils:10.5'
|
|
||||||
api 'com.jcraft:jsch:0.1.55'
|
|
||||||
api 'org.jsoup:jsoup:1.13.1'
|
|
||||||
api 'com.squareup.okhttp3:okhttp:4.4.1'
|
|
||||||
|
|
||||||
api 'androidx.appcompat:appcompat:1.0.0'
|
|
||||||
api 'androidx.fragment:fragment:1.0.0'
|
|
||||||
api 'com.google.android.material:material:1.0.0'
|
|
||||||
|
|
||||||
api 'cc.winboll.studio:libappbase:1.2.0'
|
|
||||||
|
|
||||||
api fileTree(dir: 'libs', include: ['*.jar'])
|
api fileTree(dir: 'libs', include: ['*.jar'])
|
||||||
|
|
||||||
|
// SSH
|
||||||
|
implementation 'com.jcraft:jsch:0.1.55'
|
||||||
|
// Html 解析
|
||||||
|
implementation 'org.jsoup:jsoup:1.13.1'
|
||||||
|
// 二维码类库
|
||||||
|
implementation 'com.google.zxing:core:3.4.1'
|
||||||
|
implementation 'com.journeyapps:zxing-android-embedded:3.6.0'
|
||||||
|
// 应用介绍页类库
|
||||||
|
implementation 'io.github.medyo:android-about-page:2.0.0'
|
||||||
|
// 吐司类库
|
||||||
|
implementation 'com.github.getActivity:ToastUtils:10.5'
|
||||||
|
// 网络连接类库
|
||||||
|
implementation 'com.squareup.okhttp3:okhttp:4.4.1'
|
||||||
|
|
||||||
|
// Android 类库
|
||||||
|
implementation 'androidx.appcompat:appcompat:1.1.0'
|
||||||
|
implementation 'androidx.viewpager:viewpager:1.0.0'
|
||||||
|
implementation 'androidx.vectordrawable:vectordrawable:1.1.0'
|
||||||
|
implementation 'androidx.vectordrawable:vectordrawable-animated:1.1.0'
|
||||||
|
implementation 'androidx.fragment:fragment:1.1.0'
|
||||||
|
implementation 'com.google.android.material:material:1.4.0'
|
||||||
|
|
||||||
|
implementation 'cc.winboll.studio:libappbase:2.1.3'
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#Created by .winboll/winboll_app_build.gradle
|
#Created by .winboll/winboll_app_build.gradle
|
||||||
#Thu Feb 06 11:02:45 HKT 2025
|
#Sat Mar 08 03:59:02 HKT 2025
|
||||||
stageCount=2
|
stageCount=3
|
||||||
libraryProject=libapputils
|
libraryProject=libapputils
|
||||||
baseVersion=9.3
|
baseVersion=9.4
|
||||||
publishVersion=9.3.1
|
publishVersion=9.4.2
|
||||||
buildCount=0
|
buildCount=0
|
||||||
baseBetaVersion=9.3.2
|
baseBetaVersion=9.4.3
|
||||||
|
|||||||
@@ -29,7 +29,7 @@
|
|||||||
android:launchMode="standard"/>
|
android:launchMode="standard"/>
|
||||||
|
|
||||||
<activity
|
<activity
|
||||||
android:name=".log.LogActivity"
|
android:name=".activities.LogActivity"
|
||||||
android:label="LogActivity"
|
android:label="LogActivity"
|
||||||
android:launchMode="standard"/>
|
android:launchMode="standard"/>
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,6 @@ import android.content.Intent;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
import androidx.appcompat.widget.Toolbar;
|
import androidx.appcompat.widget.Toolbar;
|
||||||
@@ -18,7 +17,6 @@ import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
|||||||
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
||||||
import cc.winboll.studio.libapputils.bean.APPInfo;
|
import cc.winboll.studio.libapputils.bean.APPInfo;
|
||||||
import cc.winboll.studio.libapputils.view.AboutView;
|
import cc.winboll.studio.libapputils.view.AboutView;
|
||||||
import com.hjq.toast.ToastUtils;
|
|
||||||
|
|
||||||
final public class AboutActivity extends AppCompatActivity implements IWinBollActivity {
|
final public class AboutActivity extends AppCompatActivity implements IWinBollActivity {
|
||||||
|
|
||||||
|
|||||||
@@ -11,16 +11,15 @@ import android.net.Uri;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
import androidx.appcompat.widget.Toolbar;
|
import androidx.appcompat.widget.Toolbar;
|
||||||
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import cc.winboll.studio.libapputils.R;
|
import cc.winboll.studio.libapputils.R;
|
||||||
import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
import cc.winboll.studio.libapputils.bean.APPInfo;
|
||||||
import cc.winboll.studio.libapputils.view.SimpleWebView;
|
import cc.winboll.studio.libapputils.view.SimpleWebView;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import cc.winboll.studio.libapputils.bean.APPInfo;
|
|
||||||
|
|
||||||
public class AssetsHtmlActivity extends AppCompatActivity implements IWinBollActivity {
|
public class AssetsHtmlActivity extends AppCompatActivity implements IWinBollActivity {
|
||||||
|
|
||||||
|
|||||||
@@ -1,14 +1,16 @@
|
|||||||
package cc.winboll.studio.libapputils.log;
|
package cc.winboll.studio.libapputils.activities;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author ZhanGSKen@QQ.COM
|
* @Author ZhanGSKen@AliYun.Com
|
||||||
* @Date 2024/08/12 15:07:58
|
* @Date 2025/03/08 00:19:39
|
||||||
* @Describe WinBoll 应用日志窗口
|
* @Describe LogActivity
|
||||||
*/
|
*/
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
import androidx.appcompat.widget.Toolbar;
|
import androidx.appcompat.widget.Toolbar;
|
||||||
import cc.winboll.studio.libappbase.GlobalApplication;
|
import cc.winboll.studio.libappbase.GlobalApplication;
|
||||||
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
|
import cc.winboll.studio.libappbase.LogView;
|
||||||
import cc.winboll.studio.libapputils.R;
|
import cc.winboll.studio.libapputils.R;
|
||||||
import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
||||||
import cc.winboll.studio.libapputils.bean.APPInfo;
|
import cc.winboll.studio.libapputils.bean.APPInfo;
|
||||||
@@ -18,7 +20,7 @@ public class LogActivity extends AppCompatActivity implements IWinBollActivity {
|
|||||||
public static final String TAG = "LogActivity";
|
public static final String TAG = "LogActivity";
|
||||||
|
|
||||||
LogView mLogView;
|
LogView mLogView;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AppCompatActivity getActivity() {
|
public AppCompatActivity getActivity() {
|
||||||
return this;
|
return this;
|
||||||
@@ -28,7 +30,7 @@ public class LogActivity extends AppCompatActivity implements IWinBollActivity {
|
|||||||
public APPInfo getAppInfo() {
|
public APPInfo getAppInfo() {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getTag() {
|
public String getTag() {
|
||||||
return TAG;
|
return TAG;
|
||||||
@@ -55,14 +57,13 @@ public class LogActivity extends AppCompatActivity implements IWinBollActivity {
|
|||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setContentView(R.layout.activity_log);
|
setContentView(R.layout.activity_log);
|
||||||
mLogView = findViewById(R.id.logview);
|
mLogView = findViewById(R.id.logview);
|
||||||
|
mLogView.start();
|
||||||
if (GlobalApplication.isDebuging()) { mLogView.start(); }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onResume() {
|
protected void onResume() {
|
||||||
LogUtils.d(TAG, "onResume");
|
LogUtils.d(TAG, "onResume");
|
||||||
super.onResume();
|
super.onResume();
|
||||||
mLogView.start();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,18 +1,16 @@
|
|||||||
package cc.winboll.studio.libapputils.app;
|
package cc.winboll.studio.libapputils.app;
|
||||||
import android.content.Context;
|
|
||||||
import android.content.Intent;
|
|
||||||
import cc.winboll.studio.libapputils.activities.AboutActivity;
|
|
||||||
import cc.winboll.studio.libapputils.app.AboutActivityFactory;
|
|
||||||
import cc.winboll.studio.libapputils.bean.APPInfo;
|
|
||||||
import com.hjq.toast.ToastUtils;
|
|
||||||
import java.util.regex.Matcher;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author ZhanGSKen@QQ.COM
|
* @Author ZhanGSKen@QQ.COM
|
||||||
* @Date 2025/02/06 08:45:23
|
* @Date 2025/02/06 08:45:23
|
||||||
* @Describe 关于活动窗口的介绍窗口工厂
|
* @Describe 关于活动窗口的介绍窗口工厂
|
||||||
*/
|
*/
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import cc.winboll.studio.libapputils.activities.AboutActivity;
|
||||||
|
import cc.winboll.studio.libapputils.app.AboutActivityFactory;
|
||||||
|
import cc.winboll.studio.libapputils.bean.APPInfo;
|
||||||
|
|
||||||
public class AboutActivityFactory {
|
public class AboutActivityFactory {
|
||||||
|
|
||||||
public static final String TAG = "AboutActivityFactory";
|
public static final String TAG = "AboutActivityFactory";
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ package cc.winboll.studio.libapputils.app;
|
|||||||
* @Date 2024/08/12 14:45:35
|
* @Date 2024/08/12 14:45:35
|
||||||
* @Describe 应用版本工具集
|
* @Describe 应用版本工具集
|
||||||
*/
|
*/
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
package cc.winboll.studio.libapputils.app;
|
package cc.winboll.studio.libapputils.app;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author ZhanGSKen@QQ.COM
|
* @Author ZhanGSKen@AliYun.Com
|
||||||
* @Date 2025/02/04 10:20:16
|
* @Date 2025/03/08 00:15:36
|
||||||
* @Describe WinBoll Activity 接口
|
* @Describe WinBoll 活动窗口通用接口
|
||||||
*/
|
*/
|
||||||
import android.view.View;
|
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
import androidx.appcompat.widget.Toolbar;
|
import androidx.appcompat.widget.Toolbar;
|
||||||
import cc.winboll.studio.libapputils.bean.APPInfo;
|
import cc.winboll.studio.libapputils.bean.APPInfo;
|
||||||
@@ -15,11 +14,10 @@ public interface IWinBollActivity {
|
|||||||
public static final String TAG = "IWinBollActivity";
|
public static final String TAG = "IWinBollActivity";
|
||||||
|
|
||||||
// 获取当前具有 IWinBoll 特征的 AppCompatActivity 活动窗口
|
// 获取当前具有 IWinBoll 特征的 AppCompatActivity 活动窗口
|
||||||
AppCompatActivity getActivity();
|
abstract public AppCompatActivity getActivity();
|
||||||
|
|
||||||
abstract public APPInfo getAppInfo();
|
abstract public APPInfo getAppInfo();
|
||||||
abstract public String getTag();
|
abstract public String getTag();
|
||||||
abstract Toolbar initToolBar();
|
abstract public Toolbar initToolBar();
|
||||||
abstract boolean isEnableDisplayHomeAsUp();
|
abstract public boolean isEnableDisplayHomeAsUp();
|
||||||
abstract boolean isAddWinBollToolBar();
|
abstract public boolean isAddWinBollToolBar();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,9 +8,8 @@ import android.app.Activity;
|
|||||||
import android.app.Application;
|
import android.app.Application;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import com.hjq.toast.ToastUtils;
|
import com.hjq.toast.ToastUtils;
|
||||||
import android.content.Context;
|
|
||||||
|
|
||||||
public class MyActivityLifecycleCallbacks implements Application.ActivityLifecycleCallbacks {
|
public class MyActivityLifecycleCallbacks implements Application.ActivityLifecycleCallbacks {
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ import android.app.ActivityManager;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import androidx.core.app.TaskStackBuilder;
|
import androidx.core.app.TaskStackBuilder;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|||||||
@@ -1,18 +0,0 @@
|
|||||||
package cc.winboll.studio.libapputils.app;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Author ZhanGSKen@QQ.COM
|
|
||||||
* @Date 2025/02/04 10:19:34
|
|
||||||
* @Describe WinBoll 工厂
|
|
||||||
*/
|
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
|
||||||
|
|
||||||
public class WinBollFactory {
|
|
||||||
|
|
||||||
public static final String TAG = "WinBollFactory";
|
|
||||||
|
|
||||||
public static AppCompatActivity buildAppCompatActivity(IWinBollActivity iWinBoll) {
|
|
||||||
return iWinBoll.getActivity();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,5 +1,4 @@
|
|||||||
package cc.winboll.studio.libapputils.bean;
|
package cc.winboll.studio.libapputils.bean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author ZhanGSKen@QQ.COM
|
* @Author ZhanGSKen@QQ.COM
|
||||||
* @Date 2025/01/20 14:19:02
|
* @Date 2025/01/20 14:19:02
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ package cc.winboll.studio.libapputils.bean;
|
|||||||
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.libapputils.log.LogUtils;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import cc.winboll.studio.libapputils.util.FileUtils;
|
import cc.winboll.studio.libapputils.util.FileUtils;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
package cc.winboll.studio.libapputils.git;
|
package cc.winboll.studio.libapputils.git;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|||||||
@@ -1,371 +0,0 @@
|
|||||||
package cc.winboll.studio.libapputils.log;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Author ZhanGSKen@QQ.COM
|
|
||||||
* @Date 2024/08/12 13:44:06
|
|
||||||
* @Describe LogUtils
|
|
||||||
* @Describe 应用日志类
|
|
||||||
*/
|
|
||||||
import android.content.Context;
|
|
||||||
import cc.winboll.studio.libappbase.GlobalApplication;
|
|
||||||
import cc.winboll.studio.libapputils.util.FileUtils;
|
|
||||||
import dalvik.system.DexFile;
|
|
||||||
import java.io.BufferedReader;
|
|
||||||
import java.io.BufferedWriter;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.io.OutputStreamWriter;
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.Modifier;
|
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Enumeration;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
|
|
||||||
public class LogUtils {
|
|
||||||
|
|
||||||
public static final String TAG = "LogUtils";
|
|
||||||
|
|
||||||
public static enum LOG_LEVEL { Off, Error, Warn, Info, Debug, Verbose }
|
|
||||||
|
|
||||||
static volatile boolean _IsInited = false;
|
|
||||||
static Context _mContext;
|
|
||||||
// 日志显示时间格式
|
|
||||||
static SimpleDateFormat mSimpleDateFormat = new SimpleDateFormat("[yyyyMMdd_HHmmSS]", Locale.getDefault());
|
|
||||||
// 应用日志文件夹
|
|
||||||
static File _mfLogCacheDir;
|
|
||||||
static File _mfLogDataDir;
|
|
||||||
// 应用日志文件
|
|
||||||
static File _mfLogCatchFile;
|
|
||||||
static File _mfLogUtilsBeanFile;
|
|
||||||
static LogUtilsBean _mLogUtilsBean;
|
|
||||||
public static Map<String, Boolean> mapTAGList = new HashMap<String, Boolean>();
|
|
||||||
|
|
||||||
//
|
|
||||||
// 初始化函数
|
|
||||||
//
|
|
||||||
public static void init(Context context) {
|
|
||||||
_mContext = context;
|
|
||||||
init(context, LOG_LEVEL.Off);
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 初始化函数
|
|
||||||
//
|
|
||||||
public static void init(Context context, LOG_LEVEL logLevel) {
|
|
||||||
if (GlobalApplication.isDebuging()) {
|
|
||||||
// 初始化日志缓存文件路径
|
|
||||||
_mfLogCacheDir = new File(context.getApplicationContext().getExternalCacheDir(), TAG);
|
|
||||||
if (!_mfLogCacheDir.exists()) {
|
|
||||||
_mfLogCacheDir.mkdirs();
|
|
||||||
}
|
|
||||||
_mfLogCatchFile = new File(_mfLogCacheDir, "log.txt");
|
|
||||||
|
|
||||||
// 初始化日志配置文件路径
|
|
||||||
_mfLogDataDir = context.getApplicationContext().getExternalFilesDir(TAG);
|
|
||||||
if (!_mfLogDataDir.exists()) {
|
|
||||||
_mfLogDataDir.mkdirs();
|
|
||||||
}
|
|
||||||
_mfLogUtilsBeanFile = new File(_mfLogDataDir, TAG + ".json");
|
|
||||||
} else {
|
|
||||||
// 初始化日志缓存文件路径
|
|
||||||
_mfLogCacheDir = new File(context.getApplicationContext().getCacheDir(), TAG);
|
|
||||||
if (!_mfLogCacheDir.exists()) {
|
|
||||||
_mfLogCacheDir.mkdirs();
|
|
||||||
}
|
|
||||||
_mfLogCatchFile = new File(_mfLogCacheDir, "log.txt");
|
|
||||||
|
|
||||||
// 初始化日志配置文件路径
|
|
||||||
_mfLogDataDir = new File(context.getApplicationContext().getFilesDir(), TAG);
|
|
||||||
if (!_mfLogDataDir.exists()) {
|
|
||||||
_mfLogDataDir.mkdirs();
|
|
||||||
}
|
|
||||||
_mfLogUtilsBeanFile = new File(_mfLogDataDir, TAG + ".json");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Toast.makeText(context,
|
|
||||||
// "_mfLogUtilsBeanFile : " + _mfLogUtilsBeanFile
|
|
||||||
// + "\n_mfLogCatchFile : " + _mfLogCatchFile,
|
|
||||||
// Toast.LENGTH_SHORT).show();
|
|
||||||
//
|
|
||||||
_mLogUtilsBean = LogUtilsBean.loadBeanFromFile(_mfLogUtilsBeanFile.getPath(), LogUtilsBean.class);
|
|
||||||
if (_mLogUtilsBean == null) {
|
|
||||||
_mLogUtilsBean = new LogUtilsBean();
|
|
||||||
_mLogUtilsBean.saveBeanToFile(_mfLogUtilsBeanFile.getPath(), _mLogUtilsBean);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 加载当前应用下的所有类的 TAG
|
|
||||||
addClassTAGList();
|
|
||||||
loadTAGBeanSettings();
|
|
||||||
_IsInited = true;
|
|
||||||
LogUtils.d(TAG, String.format("mapTAGList : %s", mapTAGList.toString()));
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Map<String, Boolean> getMapTAGList() {
|
|
||||||
return mapTAGList;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void loadTAGBeanSettings() {
|
|
||||||
ArrayList<LogUtilsClassTAGBean> list = new ArrayList<LogUtilsClassTAGBean>();
|
|
||||||
LogUtilsClassTAGBean.loadBeanList(_mContext, list, LogUtilsClassTAGBean.class);
|
|
||||||
for (int i = 0; i < list.size(); i++) {
|
|
||||||
LogUtilsClassTAGBean beanSetting = list.get(i);
|
|
||||||
for (Map.Entry<String, Boolean> entry : mapTAGList.entrySet()) {
|
|
||||||
if (entry.getKey().equals(beanSetting.getTag())) {
|
|
||||||
entry.setValue(beanSetting.getEnable());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void saveTAGBeanSettings() {
|
|
||||||
ArrayList<LogUtilsClassTAGBean> list = new ArrayList<LogUtilsClassTAGBean>();
|
|
||||||
for (Map.Entry<String, Boolean> entry : mapTAGList.entrySet()) {
|
|
||||||
list.add(new LogUtilsClassTAGBean(entry.getKey(), entry.getValue()));
|
|
||||||
}
|
|
||||||
LogUtilsClassTAGBean.saveBeanList(_mContext, list, LogUtilsClassTAGBean.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void addClassTAGList() {
|
|
||||||
//ClassLoader classLoader = getClass().getClassLoader();
|
|
||||||
try {
|
|
||||||
//String packageName = context.getPackageName();
|
|
||||||
String packageNamePrefix = "cc.winboll.studio";
|
|
||||||
List<String> classNames = new ArrayList<>();
|
|
||||||
String apkPath = _mContext.getPackageCodePath();
|
|
||||||
//Log.d("APK_PATH", "The APK path is: " + apkPath);
|
|
||||||
LogUtils.d(TAG, String.format("apkPath : %s", apkPath));
|
|
||||||
//String apkPath = "/data/app/" + packageName + "-";
|
|
||||||
|
|
||||||
//DexFile dexfile = new DexFile(apkPath + "1/base.apk");
|
|
||||||
DexFile dexfile = new DexFile(apkPath);
|
|
||||||
|
|
||||||
int countTemp = 0;
|
|
||||||
Enumeration<String> entries = dexfile.entries();
|
|
||||||
while (entries.hasMoreElements()) {
|
|
||||||
countTemp++;
|
|
||||||
String className = entries.nextElement();
|
|
||||||
if (className.startsWith(packageNamePrefix)) {
|
|
||||||
classNames.add(className);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
LogUtils.d(TAG, String.format("countTemp : %d\nClassNames size : %d", countTemp, classNames.size()));
|
|
||||||
|
|
||||||
for (String className : classNames) {
|
|
||||||
try {
|
|
||||||
Class<?> clazz = Class.forName(className);
|
|
||||||
Field[] fields = clazz.getDeclaredFields();
|
|
||||||
for (Field field : fields) {
|
|
||||||
if (Modifier.isStatic(field.getModifiers()) && Modifier.isPublic(field.getModifiers()) && field.getType() == String.class && "TAG".equals(field.getName())) {
|
|
||||||
String tagValue = (String) field.get(null);
|
|
||||||
//Log.d("TAG_INFO", "Class: " + className + ", TAG value: " + tagValue);
|
|
||||||
//LogUtils.d(TAG, String.format("Tag Value : %s", tagValue));
|
|
||||||
//mapTAGList.put(tagValue, true);
|
|
||||||
mapTAGList.put(tagValue, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (NoClassDefFoundError | ClassNotFoundException | IllegalAccessException e) {
|
|
||||||
LogUtils.d(TAG, e.getMessage(), Thread.currentThread().getStackTrace());
|
|
||||||
//LogUtils.d(TAG, e, Thread.currentThread().getStackTrace());
|
|
||||||
//Toast.makeText(context, TAG + " : " + e.getMessage(), Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
LogUtils.d(TAG, e, Thread.currentThread().getStackTrace());
|
|
||||||
//Toast.makeText(context, TAG + " : " + e.getMessage(), Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void setTAGListEnable(String tag, boolean isEnable) {
|
|
||||||
Iterator<Map.Entry<String, Boolean>> iterator = mapTAGList.entrySet().iterator();
|
|
||||||
while (iterator.hasNext()) {
|
|
||||||
Map.Entry<String, Boolean> entry = iterator.next();
|
|
||||||
if (tag.equals(entry.getKey())) {
|
|
||||||
entry.setValue(isEnable);
|
|
||||||
//System.out.println("Key: " + entry.getKey() + ", Value: " + entry.getValue());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
saveTAGBeanSettings();
|
|
||||||
LogUtils.d(TAG, String.format("mapTAGList : %s", mapTAGList.toString()));
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void setALlTAGListEnable(boolean isEnable) {
|
|
||||||
Iterator<Map.Entry<String, Boolean>> iterator = mapTAGList.entrySet().iterator();
|
|
||||||
while (iterator.hasNext()) {
|
|
||||||
Map.Entry<String, Boolean> entry = iterator.next();
|
|
||||||
entry.setValue(isEnable);
|
|
||||||
//System.out.println("Key: " + entry.getKey() + ", Value: " + entry.getValue());
|
|
||||||
}
|
|
||||||
saveTAGBeanSettings();
|
|
||||||
LogUtils.d(TAG, String.format("mapTAGList : %s", mapTAGList.toString()));
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void setLogLevel(LOG_LEVEL logLevel) {
|
|
||||||
LogUtils._mLogUtilsBean.setLogLevel(logLevel);
|
|
||||||
_mLogUtilsBean.saveBeanToFile(_mfLogUtilsBeanFile.getPath(), _mLogUtilsBean);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static LOG_LEVEL getLogLevel() {
|
|
||||||
return LogUtils._mLogUtilsBean.getLogLevel();
|
|
||||||
}
|
|
||||||
|
|
||||||
static boolean isLoggable(String tag, LOG_LEVEL logLevel) {
|
|
||||||
return _IsInited && mapTAGList.get(tag) && isInTheLevel(logLevel);
|
|
||||||
}
|
|
||||||
|
|
||||||
static boolean isInTheLevel(LOG_LEVEL logLevel) {
|
|
||||||
return (LogUtils._mLogUtilsBean.getLogLevel().ordinal() == logLevel.ordinal()
|
|
||||||
|| LogUtils._mLogUtilsBean.getLogLevel().ordinal() > logLevel.ordinal());
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 获取应用日志文件夹
|
|
||||||
//
|
|
||||||
public static File getLogCacheDir() {
|
|
||||||
return _mfLogCacheDir;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 调试日志写入函数
|
|
||||||
//
|
|
||||||
public static void e(String szTAG, String szMessage) {
|
|
||||||
if (isLoggable(szTAG, LogUtils.LOG_LEVEL.Error)) {
|
|
||||||
saveLog(szTAG, LogUtils.LOG_LEVEL.Error, szMessage);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 调试日志写入函数
|
|
||||||
//
|
|
||||||
public static void w(String szTAG, String szMessage) {
|
|
||||||
if (isLoggable(szTAG, LogUtils.LOG_LEVEL.Warn)) {
|
|
||||||
saveLog(szTAG, LogUtils.LOG_LEVEL.Warn, szMessage);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 调试日志写入函数
|
|
||||||
//
|
|
||||||
public static void i(String szTAG, String szMessage) {
|
|
||||||
if (isLoggable(szTAG, LogUtils.LOG_LEVEL.Info)) {
|
|
||||||
saveLog(szTAG, LogUtils.LOG_LEVEL.Info, szMessage);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 调试日志写入函数
|
|
||||||
//
|
|
||||||
public static void d(String szTAG, String szMessage) {
|
|
||||||
if (isLoggable(szTAG, LogUtils.LOG_LEVEL.Debug)) {
|
|
||||||
saveLog(szTAG, LogUtils.LOG_LEVEL.Debug, szMessage);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 调试日志写入函数
|
|
||||||
// 包含线程调试堆栈信息
|
|
||||||
//
|
|
||||||
public static void d(String szTAG, String szMessage, StackTraceElement[] listStackTrace) {
|
|
||||||
if (isLoggable(szTAG, LogUtils.LOG_LEVEL.Debug)) {
|
|
||||||
StringBuilder sbMessage = new StringBuilder(szMessage);
|
|
||||||
sbMessage.append(" \nAt ");
|
|
||||||
sbMessage.append(listStackTrace[2].getMethodName());
|
|
||||||
sbMessage.append(" (");
|
|
||||||
sbMessage.append(listStackTrace[2].getFileName());
|
|
||||||
sbMessage.append(":");
|
|
||||||
sbMessage.append(listStackTrace[2].getLineNumber());
|
|
||||||
sbMessage.append(")");
|
|
||||||
saveLog(szTAG, LogUtils.LOG_LEVEL.Debug, sbMessage.toString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 调试日志写入函数
|
|
||||||
// 包含异常信息和线程调试堆栈信息
|
|
||||||
//
|
|
||||||
public static void d(String szTAG, Exception e, StackTraceElement[] listStackTrace) {
|
|
||||||
if (isLoggable(szTAG, LogUtils.LOG_LEVEL.Debug)) {
|
|
||||||
StringBuilder sbMessage = new StringBuilder(e.getClass().toGenericString());
|
|
||||||
sbMessage.append(" : ");
|
|
||||||
sbMessage.append(e.getMessage());
|
|
||||||
sbMessage.append(" \nAt ");
|
|
||||||
sbMessage.append(listStackTrace[2].getMethodName());
|
|
||||||
sbMessage.append(" (");
|
|
||||||
sbMessage.append(listStackTrace[2].getFileName());
|
|
||||||
sbMessage.append(":");
|
|
||||||
sbMessage.append(listStackTrace[2].getLineNumber());
|
|
||||||
sbMessage.append(")");
|
|
||||||
saveLog(szTAG, LogUtils.LOG_LEVEL.Debug, sbMessage.toString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 调试日志写入函数
|
|
||||||
//
|
|
||||||
public static void v(String szTAG, String szMessage) {
|
|
||||||
if (isLoggable(szTAG, LogUtils.LOG_LEVEL.Verbose)) {
|
|
||||||
saveLog(szTAG, LogUtils.LOG_LEVEL.Verbose, szMessage);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 日志文件保存函数
|
|
||||||
//
|
|
||||||
static void saveLog(String szTAG, LogUtils.LOG_LEVEL logLevel, String szMessage) {
|
|
||||||
try {
|
|
||||||
BufferedWriter out = null;
|
|
||||||
out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(_mfLogCatchFile, true), "UTF-8"));
|
|
||||||
out.write("[" + logLevel + "] " + mSimpleDateFormat.format(System.currentTimeMillis()) + " [" + szTAG + "]\n" + szMessage + "\n");
|
|
||||||
out.close();
|
|
||||||
} catch (IOException e) {
|
|
||||||
LogUtils.d(TAG, "IOException : " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 历史日志加载函数
|
|
||||||
//
|
|
||||||
public static String loadLog() {
|
|
||||||
if (_mfLogCatchFile.exists()) {
|
|
||||||
StringBuffer sb = new StringBuffer();
|
|
||||||
try {
|
|
||||||
BufferedReader in = null;
|
|
||||||
in = new BufferedReader(new InputStreamReader(new FileInputStream(_mfLogCatchFile), "UTF-8"));
|
|
||||||
String line = "";
|
|
||||||
while ((line = in.readLine()) != null) {
|
|
||||||
sb.append(line);
|
|
||||||
sb.append("\n");
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
LogUtils.d(TAG, "IOException : " + e.getMessage());
|
|
||||||
}
|
|
||||||
return sb.toString();
|
|
||||||
}
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// 清理日志函数
|
|
||||||
//
|
|
||||||
public static void cleanLog() {
|
|
||||||
if (_mfLogCatchFile.exists()) {
|
|
||||||
try {
|
|
||||||
FileUtils.writeStringToFile(_mfLogCatchFile.getPath(), "");
|
|
||||||
//LogUtils.d(TAG, "cleanLog");
|
|
||||||
} catch (IOException e) {
|
|
||||||
LogUtils.d(TAG, e, Thread.currentThread().getStackTrace());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,71 +0,0 @@
|
|||||||
package cc.winboll.studio.libapputils.log;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Author ZhanGSKen@QQ.COM
|
|
||||||
* @Date 2024/08/23 15:39:07
|
|
||||||
* @Describe LogUtils 数据配置类。
|
|
||||||
*/
|
|
||||||
import android.util.JsonReader;
|
|
||||||
import android.util.JsonWriter;
|
|
||||||
import cc.winboll.studio.libapputils.bean.BaseBean;
|
|
||||||
import java.io.IOException;
|
|
||||||
public class LogUtilsBean extends BaseBean {
|
|
||||||
|
|
||||||
public static final String TAG = "LogUtilsBean";
|
|
||||||
|
|
||||||
LogUtils.LOG_LEVEL logLevel;
|
|
||||||
|
|
||||||
public LogUtilsBean() {
|
|
||||||
this.logLevel = LogUtils.LOG_LEVEL.Off;
|
|
||||||
}
|
|
||||||
|
|
||||||
public LogUtilsBean(LogUtils.LOG_LEVEL logLevel) {
|
|
||||||
this.logLevel = logLevel;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setLogLevel(LogUtils.LOG_LEVEL logLevel) {
|
|
||||||
this.logLevel = logLevel;
|
|
||||||
}
|
|
||||||
|
|
||||||
public LogUtils.LOG_LEVEL getLogLevel() {
|
|
||||||
return logLevel;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getName() {
|
|
||||||
return LogUtilsBean.class.getName();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void writeThisToJsonWriter(JsonWriter jsonWriter) throws IOException {
|
|
||||||
super.writeThisToJsonWriter(jsonWriter);
|
|
||||||
LogUtilsBean bean = this;
|
|
||||||
jsonWriter.name("logLevel").value(bean.getLogLevel().ordinal());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean initObjectsFromJsonReader(JsonReader jsonReader, String name) throws IOException {
|
|
||||||
if (super.initObjectsFromJsonReader(jsonReader, name)) { return true; } else {
|
|
||||||
if (name.equals("logLevel")) {
|
|
||||||
setLogLevel(LogUtils.LOG_LEVEL.values()[jsonReader.nextInt()]);
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public BaseBean readBeanFromJsonReader(JsonReader jsonReader) throws IOException {
|
|
||||||
jsonReader.beginObject();
|
|
||||||
while (jsonReader.hasNext()) {
|
|
||||||
String name = jsonReader.nextName();
|
|
||||||
if (!initObjectsFromJsonReader(jsonReader, name)) {
|
|
||||||
jsonReader.skipValue();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// 结束 JSON 对象
|
|
||||||
jsonReader.endObject();
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,88 +0,0 @@
|
|||||||
package cc.winboll.studio.libapputils.log;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Author ZhanGSKen@QQ.COM
|
|
||||||
* @Date 2025/01/04 14:17:02
|
|
||||||
* @Describe 日志类class TAG 标签数据类
|
|
||||||
*/
|
|
||||||
import android.util.JsonReader;
|
|
||||||
import android.util.JsonWriter;
|
|
||||||
import cc.winboll.studio.libapputils.bean.BaseBean;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
public class LogUtilsClassTAGBean extends BaseBean {
|
|
||||||
|
|
||||||
public static final String TAG = "LogUtilsClassTAGBean";
|
|
||||||
|
|
||||||
// 标签名
|
|
||||||
String tag;
|
|
||||||
// 是否启用
|
|
||||||
Boolean enable;
|
|
||||||
|
|
||||||
public LogUtilsClassTAGBean() {
|
|
||||||
this.tag = TAG;
|
|
||||||
this.enable = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public LogUtilsClassTAGBean(String tag, Boolean enable) {
|
|
||||||
this.tag = tag;
|
|
||||||
this.enable = enable;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTag(String tag) {
|
|
||||||
this.tag = tag;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getTag() {
|
|
||||||
return tag;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setEnable(Boolean enable) {
|
|
||||||
this.enable = enable;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Boolean getEnable() {
|
|
||||||
return enable;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getName() {
|
|
||||||
return LogUtilsClassTAGBean.class.getName();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void writeThisToJsonWriter(JsonWriter jsonWriter) throws IOException {
|
|
||||||
super.writeThisToJsonWriter(jsonWriter);
|
|
||||||
LogUtilsClassTAGBean bean = this;
|
|
||||||
jsonWriter.name("tag").value(bean.getTag());
|
|
||||||
jsonWriter.name("enable").value(bean.getEnable());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean initObjectsFromJsonReader(JsonReader jsonReader, String name) throws IOException {
|
|
||||||
if (super.initObjectsFromJsonReader(jsonReader, name)) { return true; } else {
|
|
||||||
if (name.equals("tag")) {
|
|
||||||
setTag(jsonReader.nextString());
|
|
||||||
} else if (name.equals("enable")) {
|
|
||||||
setEnable(jsonReader.nextBoolean());
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public BaseBean readBeanFromJsonReader(JsonReader jsonReader) throws IOException {
|
|
||||||
jsonReader.beginObject();
|
|
||||||
while (jsonReader.hasNext()) {
|
|
||||||
String name = jsonReader.nextName();
|
|
||||||
if (!initObjectsFromJsonReader(jsonReader, name)) {
|
|
||||||
jsonReader.skipValue();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// 结束 JSON 对象
|
|
||||||
jsonReader.endObject();
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,386 +0,0 @@
|
|||||||
package cc.winboll.studio.libapputils.log;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Author ZhanGSKen@QQ.COM
|
|
||||||
* @Date 2024/08/12 14:36:18
|
|
||||||
* @Describe 日志视图类,继承 RelativeLayout 类。
|
|
||||||
*/
|
|
||||||
import android.content.ClipData;
|
|
||||||
import android.content.ClipboardManager;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.os.Handler;
|
|
||||||
import android.os.Message;
|
|
||||||
import android.util.AttributeSet;
|
|
||||||
import android.view.LayoutInflater;
|
|
||||||
import android.view.View;
|
|
||||||
import android.view.ViewGroup;
|
|
||||||
import android.widget.AdapterView;
|
|
||||||
import android.widget.ArrayAdapter;
|
|
||||||
import android.widget.CheckBox;
|
|
||||||
import android.widget.RelativeLayout;
|
|
||||||
import android.widget.ScrollView;
|
|
||||||
import android.widget.Spinner;
|
|
||||||
import android.widget.TextView;
|
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
|
||||||
import cc.winboll.studio.libapputils.R;
|
|
||||||
import java.text.Collator;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.Comparator;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
public class LogView extends RelativeLayout {
|
|
||||||
|
|
||||||
public static final String TAG = "LogView";
|
|
||||||
|
|
||||||
public volatile boolean mIsHandling;
|
|
||||||
public volatile boolean mIsAddNewLog;
|
|
||||||
|
|
||||||
Context mContext;
|
|
||||||
ScrollView mScrollView;
|
|
||||||
TextView mTextView;
|
|
||||||
CheckBox mSelectableCheckBox;
|
|
||||||
CheckBox mSelectAllTAGCheckBox;
|
|
||||||
TAGListAdapter mTAGListAdapter;
|
|
||||||
LogViewThread mLogViewThread;
|
|
||||||
LogViewHandler mLogViewHandler;
|
|
||||||
Spinner mLogLevelSpinner;
|
|
||||||
ArrayAdapter<CharSequence> mLogLevelSpinnerAdapter;
|
|
||||||
// 标签列表
|
|
||||||
RecyclerView recyclerView;
|
|
||||||
|
|
||||||
public LogView(Context context) {
|
|
||||||
super(context);
|
|
||||||
initView(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
public LogView(Context context, AttributeSet attrs) {
|
|
||||||
super(context, attrs);
|
|
||||||
initView(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
public LogView(Context context, AttributeSet attrs, int defStyleAttr) {
|
|
||||||
super(context, attrs, defStyleAttr);
|
|
||||||
initView(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
public LogView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
|
|
||||||
super(context, attrs, defStyleAttr, defStyleRes);
|
|
||||||
initView(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void start() {
|
|
||||||
mLogViewThread = new LogViewThread(LogView.this);
|
|
||||||
mLogViewThread.start();
|
|
||||||
// 显示日志
|
|
||||||
showAndScrollLogView();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void scrollLogUp() {
|
|
||||||
mScrollView.post(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
mScrollView.fullScroll(ScrollView.FOCUS_DOWN);
|
|
||||||
// 日志显示结束
|
|
||||||
mLogViewHandler.setIsHandling(false);
|
|
||||||
// 检查是否添加了新日志
|
|
||||||
if (mLogViewHandler.isAddNewLog()) {
|
|
||||||
// 有新日志添加,先更改新日志标志
|
|
||||||
mLogViewHandler.setIsAddNewLog(false);
|
|
||||||
// 再次发送显示日志的显示
|
|
||||||
Message message = mLogViewHandler.obtainMessage(LogViewHandler.MSG_LOGVIEW_UPDATE);
|
|
||||||
mLogViewHandler.sendMessage(message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void initView(Context context) {
|
|
||||||
mContext = context;
|
|
||||||
mLogViewHandler = new LogViewHandler();
|
|
||||||
// 加载视图布局
|
|
||||||
addView(inflate(mContext, cc.winboll.studio.libapputils.R.layout.view_log, null));
|
|
||||||
// 初始化日志子控件视图
|
|
||||||
//
|
|
||||||
mScrollView = findViewById(cc.winboll.studio.libapputils.R.id.viewlogScrollViewLog);
|
|
||||||
mTextView = findViewById(cc.winboll.studio.libapputils.R.id.viewlogTextViewLog);
|
|
||||||
// 获取Log Level spinner实例
|
|
||||||
mLogLevelSpinner = findViewById(cc.winboll.studio.libapputils.R.id.viewlogSpinner1);
|
|
||||||
|
|
||||||
(findViewById(cc.winboll.studio.libapputils.R.id.viewlogButtonClean)).setOnClickListener(new View.OnClickListener(){
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
LogUtils.cleanLog();
|
|
||||||
LogUtils.d(TAG, "Log is cleaned.");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
(findViewById(cc.winboll.studio.libapputils.R.id.viewlogButtonCopy)).setOnClickListener(new View.OnClickListener(){
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
|
|
||||||
ClipboardManager cm = (ClipboardManager) mContext.getSystemService(Context.CLIPBOARD_SERVICE);
|
|
||||||
cm.setPrimaryClip(ClipData.newPlainText(mContext.getPackageName(), LogUtils.loadLog()));
|
|
||||||
LogUtils.d(TAG, "Log is copied.");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
mSelectableCheckBox = findViewById(cc.winboll.studio.libapputils.R.id.viewlogCheckBoxSelectable);
|
|
||||||
mSelectableCheckBox.setOnClickListener(new View.OnClickListener(){
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
if (mSelectableCheckBox.isChecked()) {
|
|
||||||
setDescendantFocusability(ViewGroup.FOCUS_BEFORE_DESCENDANTS);
|
|
||||||
} else {
|
|
||||||
setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// 设置日志级别列表
|
|
||||||
ArrayList<String> adapterItems = new ArrayList<>();
|
|
||||||
for (LogUtils.LOG_LEVEL e : LogUtils.LOG_LEVEL.values()) {
|
|
||||||
adapterItems.add(e.name());
|
|
||||||
}
|
|
||||||
// 假设你有一个字符串数组作为选项列表
|
|
||||||
//String[] options = {"Option 1", "Option 2", "Option 3"};
|
|
||||||
// 创建一个ArrayAdapter来绑定数据到spinner
|
|
||||||
mLogLevelSpinnerAdapter = ArrayAdapter.createFromResource(
|
|
||||||
context, cc.winboll.studio.libapputils.R.array.enum_loglevel_array, android.R.layout.simple_spinner_item);
|
|
||||||
mLogLevelSpinnerAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
|
|
||||||
|
|
||||||
// 设置适配器并将它应用到spinner上
|
|
||||||
mLogLevelSpinnerAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); // 设置下拉视图样式
|
|
||||||
mLogLevelSpinner.setAdapter(mLogLevelSpinnerAdapter);
|
|
||||||
// 为Spinner添加监听器
|
|
||||||
mLogLevelSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
|
|
||||||
@Override
|
|
||||||
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
|
|
||||||
//String selectedOption = mLogLevelSpinnerAdapter.getItem(position);
|
|
||||||
// 处理选中的选项...
|
|
||||||
LogUtils.setLogLevel(LogUtils.LOG_LEVEL.values()[position]);
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public void onNothingSelected(AdapterView<?> parent) {
|
|
||||||
// 如果没有选择,则执行此操作...
|
|
||||||
}
|
|
||||||
});
|
|
||||||
// 获取默认值的索引
|
|
||||||
int defaultValueIndex = LogUtils.getLogLevel().ordinal();
|
|
||||||
|
|
||||||
if (defaultValueIndex != -1) {
|
|
||||||
// 如果找到了默认值,设置默认选项
|
|
||||||
mLogLevelSpinner.setSelection(defaultValueIndex);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 加载标签列表
|
|
||||||
Map<String, Boolean> mapTAGList = LogUtils.getMapTAGList();
|
|
||||||
boolean isAllSelect = true;
|
|
||||||
for (Map.Entry<String, Boolean> entry : mapTAGList.entrySet()) {
|
|
||||||
if (entry.getValue() == false) {
|
|
||||||
isAllSelect = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
CheckBox cbALLTAG = findViewById(cc.winboll.studio.libapputils.R.id.viewlogCheckBox1);
|
|
||||||
cbALLTAG.setChecked(isAllSelect);
|
|
||||||
|
|
||||||
// 加载标签表
|
|
||||||
recyclerView = findViewById(cc.winboll.studio.libapputils.R.id.viewlogRecyclerView1);
|
|
||||||
LinearLayoutManager layoutManager = new LinearLayoutManager(mContext, LinearLayoutManager.HORIZONTAL, false);
|
|
||||||
recyclerView.setLayoutManager(layoutManager);
|
|
||||||
mTAGListAdapter = new TAGListAdapter(mapTAGList);
|
|
||||||
recyclerView.setAdapter(mTAGListAdapter);
|
|
||||||
|
|
||||||
// 可以添加点击监听器来处理勾选框状态变化后的逻辑,比如获取当前勾选情况等
|
|
||||||
mTAGListAdapter.notifyDataSetChanged();
|
|
||||||
|
|
||||||
mSelectAllTAGCheckBox = findViewById(cc.winboll.studio.libapputils.R.id.viewlogCheckBox1);
|
|
||||||
mSelectAllTAGCheckBox.setOnClickListener(new View.OnClickListener(){
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
LogUtils.setALlTAGListEnable(mSelectAllTAGCheckBox.isChecked());
|
|
||||||
//LogUtils.setALlTAGListEnable(false);
|
|
||||||
//mTAGListAdapter.notifyDataSetChanged();
|
|
||||||
mTAGListAdapter.reload();
|
|
||||||
//ToastUtils.show(String.format("onClick\nmSelectAllTAGCheckBox.isChecked() : %s", mSelectAllTAGCheckBox.isChecked()));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
// 设置滚动时不聚焦日志
|
|
||||||
setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateLogView() {
|
|
||||||
if (mLogViewHandler.isHandling() == true) {
|
|
||||||
// 正在处理日志显示,
|
|
||||||
// 就先设置一个新日志标志位
|
|
||||||
// 以便日志显示完后,再次显示新日志内容
|
|
||||||
mLogViewHandler.setIsAddNewLog(true);
|
|
||||||
} else {
|
|
||||||
//LogUtils.d(TAG, "LogListener showLog(String path)");
|
|
||||||
Message message = mLogViewHandler.obtainMessage(LogViewHandler.MSG_LOGVIEW_UPDATE);
|
|
||||||
mLogViewHandler.sendMessage(message);
|
|
||||||
mLogViewHandler.setIsAddNewLog(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void showAndScrollLogView() {
|
|
||||||
mTextView.setText(LogUtils.loadLog());
|
|
||||||
scrollLogUp();
|
|
||||||
}
|
|
||||||
|
|
||||||
class LogViewHandler extends Handler {
|
|
||||||
|
|
||||||
final static int MSG_LOGVIEW_UPDATE = 0;
|
|
||||||
volatile boolean isHandling;
|
|
||||||
volatile boolean isAddNewLog;
|
|
||||||
|
|
||||||
public LogViewHandler() {
|
|
||||||
setIsHandling(false);
|
|
||||||
setIsAddNewLog(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setIsHandling(boolean isHandling) {
|
|
||||||
this.isHandling = isHandling;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isHandling() {
|
|
||||||
return isHandling;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setIsAddNewLog(boolean isAddNewLog) {
|
|
||||||
this.isAddNewLog = isAddNewLog;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isAddNewLog() {
|
|
||||||
return isAddNewLog;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void handleMessage(Message msg) {
|
|
||||||
switch (msg.what) {
|
|
||||||
case MSG_LOGVIEW_UPDATE:{
|
|
||||||
if (isHandling() == false) {
|
|
||||||
setIsHandling(true);
|
|
||||||
showAndScrollLogView();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
super.handleMessage(msg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public class TAGItemModel {
|
|
||||||
private String tag;
|
|
||||||
private boolean isChecked;
|
|
||||||
|
|
||||||
public TAGItemModel(String tag, boolean isChecked) {
|
|
||||||
this.tag = tag;
|
|
||||||
this.isChecked = isChecked;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getTag() {
|
|
||||||
return tag;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTag(String tag) {
|
|
||||||
this.tag = tag;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isChecked() {
|
|
||||||
return isChecked;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setChecked(boolean checked) {
|
|
||||||
isChecked = checked;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public class TAGListAdapter extends RecyclerView.Adapter<TAGListAdapter.ViewHolder> {
|
|
||||||
|
|
||||||
private Map<String, Boolean> mapOrigin;
|
|
||||||
private List<TAGItemModel> itemList;
|
|
||||||
|
|
||||||
public TAGListAdapter(Map<String, Boolean> map) {
|
|
||||||
mapOrigin = map;
|
|
||||||
loadMap(mapOrigin);
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadMap(Map<String, Boolean> map) {
|
|
||||||
itemList = new ArrayList<TAGItemModel>();
|
|
||||||
for (Map.Entry<String, Boolean> entry : map.entrySet()) {
|
|
||||||
itemList.add(new TAGItemModel(entry.getKey(), entry.getValue()));
|
|
||||||
}
|
|
||||||
// 添加排序功能,按照tag进行升序排序
|
|
||||||
Collections.sort(itemList, new SortMapEntryByKeyString(true));
|
|
||||||
//Collections.sort(itemList, new SortMapEntryByKeyString(false));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void reload() {
|
|
||||||
loadMap(mapOrigin);
|
|
||||||
super.notifyDataSetChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
@NonNull
|
|
||||||
@Override
|
|
||||||
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
|
|
||||||
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.view_logtag, parent, false);
|
|
||||||
return new ViewHolder(view);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
|
|
||||||
final TAGItemModel item = itemList.get(position);
|
|
||||||
holder.tvText.setText(item.getTag());
|
|
||||||
holder.cbChecked.setChecked(item.isChecked());
|
|
||||||
holder.cbChecked.setOnClickListener(new View.OnClickListener(){
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
LogUtils.setTAGListEnable(item.getTag(), ((CheckBox)v).isChecked());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getItemCount() {
|
|
||||||
return itemList.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
public class ViewHolder extends RecyclerView.ViewHolder {
|
|
||||||
TextView tvText;
|
|
||||||
CheckBox cbChecked;
|
|
||||||
|
|
||||||
public ViewHolder(@NonNull View itemView) {
|
|
||||||
super(itemView);
|
|
||||||
tvText = itemView.findViewById(R.id.viewlogtagTextView1);
|
|
||||||
cbChecked = itemView.findViewById(R.id.viewlogtagCheckBox1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class SortMapEntryByKeyString implements Comparator<TAGItemModel> {
|
|
||||||
private boolean mIsDesc = true;
|
|
||||||
// isDesc 是否降序排列
|
|
||||||
public SortMapEntryByKeyString(boolean isDesc) {
|
|
||||||
mIsDesc = isDesc;
|
|
||||||
}
|
|
||||||
Collator cmp = Collator.getInstance(java.util.Locale.CHINA);
|
|
||||||
@Override
|
|
||||||
public int compare(TAGItemModel o1, TAGItemModel o2) {
|
|
||||||
if (mIsDesc) {
|
|
||||||
return o1.getTag().compareTo(o2.getTag());
|
|
||||||
} else {
|
|
||||||
return o2.getTag().compareTo(o1.getTag());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,79 +0,0 @@
|
|||||||
package cc.winboll.studio.libapputils.log;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Author ZhanGSKen@QQ.COM
|
|
||||||
* @Date 2024/08/12 14:43:50
|
|
||||||
* @Describe 日志视图线程类
|
|
||||||
*/
|
|
||||||
import android.os.FileObserver;
|
|
||||||
import java.lang.ref.WeakReference;
|
|
||||||
|
|
||||||
public class LogViewThread extends Thread {
|
|
||||||
|
|
||||||
public static final String TAG = "LogViewThread";
|
|
||||||
|
|
||||||
// 线程退出标志
|
|
||||||
volatile boolean isExist = false;
|
|
||||||
// 应用日志文件监听实例
|
|
||||||
LogListener mLogListener;
|
|
||||||
// 日志视图弱引用
|
|
||||||
WeakReference<LogView> mwrLogView;
|
|
||||||
|
|
||||||
//
|
|
||||||
// 构造函数
|
|
||||||
// @logView : 日志显示输出视图类
|
|
||||||
public LogViewThread(LogView logView) {
|
|
||||||
mwrLogView = new WeakReference<LogView>(logView);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setIsExist(boolean isExist) {
|
|
||||||
this.isExist = isExist;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isExist() {
|
|
||||||
return isExist;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
String szLogDir = LogUtils.getLogCacheDir().getPath();
|
|
||||||
mLogListener = new LogListener(szLogDir);
|
|
||||||
mLogListener.startWatching();
|
|
||||||
while (isExist() == false) {
|
|
||||||
try {
|
|
||||||
Thread.sleep(1000);
|
|
||||||
} catch (InterruptedException e) {}
|
|
||||||
}
|
|
||||||
mLogListener.stopWatching();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// 日志文件监听类
|
|
||||||
//
|
|
||||||
class LogListener extends FileObserver {
|
|
||||||
public LogListener(String path) {
|
|
||||||
super(path);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onEvent(int event, String path) {
|
|
||||||
int e = event & FileObserver.ALL_EVENTS;
|
|
||||||
switch (e) {
|
|
||||||
case FileObserver.CLOSE_WRITE:{
|
|
||||||
if (mwrLogView.get() != null) {
|
|
||||||
mwrLogView.get().updateLogView();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case FileObserver.DELETE:{
|
|
||||||
if (mwrLogView.get() != null) {
|
|
||||||
mwrLogView.get().updateLogView();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -5,15 +5,11 @@ import android.content.ComponentName;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.ServiceConnection;
|
import android.content.ServiceConnection;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
import android.os.IBinder;
|
import android.os.IBinder;
|
||||||
import android.os.IInterface;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import android.os.Parcel;
|
|
||||||
import android.os.RemoteException;
|
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
|
||||||
import cc.winboll.studio.libapputils.util.ServiceUtils;
|
import cc.winboll.studio.libapputils.util.ServiceUtils;
|
||||||
import com.hjq.toast.ToastUtils;
|
import com.hjq.toast.ToastUtils;
|
||||||
import java.io.FileDescriptor;
|
|
||||||
import android.graphics.drawable.Drawable;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author ZhanGSKen@QQ.COM
|
* @Author ZhanGSKen@QQ.COM
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ import android.content.Intent;
|
|||||||
import android.content.res.AssetManager;
|
import android.content.res.AssetManager;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import androidx.core.content.FileProvider;
|
import androidx.core.content.FileProvider;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
|||||||
@@ -6,18 +6,12 @@ package cc.winboll.studio.libapputils.util;
|
|||||||
* @Describe 二维码工具
|
* @Describe 二维码工具
|
||||||
*/
|
*/
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.widget.TextView;
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import cc.winboll.studio.libapputils.R;
|
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
|
||||||
import com.google.zxing.BarcodeFormat;
|
import com.google.zxing.BarcodeFormat;
|
||||||
import com.google.zxing.Result;
|
|
||||||
import com.google.zxing.WriterException;
|
import com.google.zxing.WriterException;
|
||||||
import com.google.zxing.common.BitMatrix;
|
import com.google.zxing.common.BitMatrix;
|
||||||
import com.google.zxing.qrcode.QRCodeWriter;
|
import com.google.zxing.qrcode.QRCodeWriter;
|
||||||
import com.journeyapps.barcodescanner.BarcodeEncoder;
|
import com.journeyapps.barcodescanner.BarcodeEncoder;
|
||||||
import java.util.concurrent.Executors;
|
|
||||||
import java.util.concurrent.ScheduledExecutorService;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
public class QRCodeGenerator {
|
public class QRCodeGenerator {
|
||||||
|
|
||||||
|
|||||||
@@ -1,34 +0,0 @@
|
|||||||
package cc.winboll.studio.libapputils.view;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Author ZhanGSKen@QQ.COM
|
|
||||||
* @Date 2025/02/06 09:02:28
|
|
||||||
* @Describe 应用分支介绍按钮
|
|
||||||
*/
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.util.AttributeSet;
|
|
||||||
import android.view.View;
|
|
||||||
import android.widget.Button;
|
|
||||||
import cc.winboll.studio.libapputils.activities.AboutActivity;
|
|
||||||
import cc.winboll.studio.libapputils.app.AboutActivityFactory;
|
|
||||||
import cc.winboll.studio.libapputils.app.IWinBollActivity;
|
|
||||||
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
|
||||||
import com.hjq.toast.ToastUtils;
|
|
||||||
import java.util.regex.Matcher;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
public class AboutBranchButton extends Button {
|
|
||||||
|
|
||||||
public static final String TAG = "AboutBranchButton";
|
|
||||||
|
|
||||||
public AboutBranchButton(final Context context, AttributeSet attrs) {
|
|
||||||
super(context, attrs);
|
|
||||||
setOnClickListener(new View.OnClickListener(){
|
|
||||||
@Override
|
|
||||||
public void onClick(View view) {
|
|
||||||
AboutActivityFactory.showAboutActivity(context, ((IWinBollActivity)context).getAppInfo());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -17,12 +17,12 @@ import android.view.View;
|
|||||||
import android.widget.EditText;
|
import android.widget.EditText;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import cc.winboll.studio.libappbase.GlobalApplication;
|
import cc.winboll.studio.libappbase.GlobalApplication;
|
||||||
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import cc.winboll.studio.libapputils.R;
|
import cc.winboll.studio.libapputils.R;
|
||||||
import cc.winboll.studio.libapputils.app.AppVersionUtils;
|
import cc.winboll.studio.libapputils.app.AppVersionUtils;
|
||||||
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
import cc.winboll.studio.libapputils.app.WinBollActivityManager;
|
||||||
import cc.winboll.studio.libapputils.bean.APPInfo;
|
import cc.winboll.studio.libapputils.bean.APPInfo;
|
||||||
import cc.winboll.studio.libapputils.bean.DebugBean;
|
import cc.winboll.studio.libapputils.bean.DebugBean;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
|
||||||
import cc.winboll.studio.libapputils.util.PrefUtils;
|
import cc.winboll.studio.libapputils.util.PrefUtils;
|
||||||
import com.hjq.toast.ToastUtils;
|
import com.hjq.toast.ToastUtils;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|||||||
@@ -19,8 +19,8 @@ import android.widget.ImageView;
|
|||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import androidx.core.content.ContextCompat;
|
import androidx.core.content.ContextCompat;
|
||||||
|
import cc.winboll.studio.libappbase.LogUtils;
|
||||||
import cc.winboll.studio.libapputils.R;
|
import cc.winboll.studio.libapputils.R;
|
||||||
import cc.winboll.studio.libapputils.log.LogUtils;
|
|
||||||
import cc.winboll.studio.libapputils.service.IWinBollClientServiceBinder;
|
import cc.winboll.studio.libapputils.service.IWinBollClientServiceBinder;
|
||||||
import cc.winboll.studio.libapputils.service.WinBollClientService;
|
import cc.winboll.studio.libapputils.service.WinBollClientService;
|
||||||
import cc.winboll.studio.libapputils.service.WinBollClientServiceBean;
|
import cc.winboll.studio.libapputils.service.WinBollClientServiceBean;
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent">
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
<cc.winboll.studio.libapputils.log.LogView
|
<cc.winboll.studio.libappbase.LogView
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
|
|||||||
Reference in New Issue
Block a user