项目场景:
在开发项目的时候要实现一个功能,一键切换应用主题,于是写下这篇文章,对于这个功能的一个简单整理
自定义attr属性或使用系统自带attr属性:
- 在res-value目录下新建attr属性的资源文件,例如:theme_attrs.xml。
- theme_attrs.xml文件中新建自定义属性
<?xml version="1.0" encoding="utf-8"?>
<resources>
<attr name="自定义属性名称" format="资源引用格式(color、dimen、reference...)" />
</resources>
自定义theme主题:
<resources>
<!--这里我使用系统自带的attr属性-->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="GreenTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">@color/green</item>
<item name="colorPrimaryDark">@color/green</item>
<item name="colorAccent">@color/green</item>
</style>
<style name="RedTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">@color/red</item>
<item name="colorPrimaryDark">@color/red</item>
<item name="colorAccent">@color/red</item>
</style>
</resources>
简单的使用dialog,在这里选择相应的主题,使用SharedPreferences保存选择的主题
val dialog = AlertDialog.Builder(context)
.setTitle(getString(R.string.skin_title))
.setItems(color, DialogInterface.OnClickListener { dialog, which ->
//这里是把SharedPreferences封装成一个工具类,方便使用
var skin = SharedPreferencesUtil.instance?.getInt("SKIN")
if (skin == which) {
AlertDialog.Builder(context).apply {
setMessage(getString(R.string.true_tip))
dialog.dismiss()
}.show()
} else {
SharedPreferencesUtil.instance?.saveInt("SKIN", which)
activity?.recreate()
}
dialog.dismiss()
})
.create()
dialog.show()
创建一个app类继承Application,在onCreate方法里使用ActivityLifecycleCallbacks回调接口,通过SharedPreferences选择主题
override fun onCreate() {
super.onCreate()
//实际上是调用registerActivityLifecycleCallbacks()里ActivityLifecycleCallbacks接口里的方法
this.registerActivityLifecycleCallbacks(Application.ActivityLifecycleCallbacks() {
override fun onActivityPaused(activity: Activity) {
}
override fun onActivityStarted(activity: Activity) {
}
override fun onActivityDestroyed(activity: Activity) {
}
override fun onActivitySaveInstanceState(activity: Activity, outState: Bundle?) {
}
override fun onActivityStopped(activity: Activity) {
}
override fun onActivityCreated(activity: Activity, savedInstanceState: Bundle?) {
var skin = SharedPreferencesUtil.instance?.getInt("SKIN")
when (skin) {
//这里就是设置相应的主题
0 -> activity?.setTheme(R.style.AppTheme)
1 -> activity?.setTheme(R.style.GreenTheme)
2 -> activity?.setTheme(R.style.RedTheme)
}
}
override fun onActivityResumed(activity: Activity) {
}
})
}
最后在onTerminate方法里记得注销
override fun onTerminate() {
super.onTerminate()
this.unregisterActivityLifecycleCallbacks(Application.ActivityLifecycleCallbacks())
}
当前功能只是因本人当前技术有限,所写出的方法流程,如有不足还望指出。