通过ActivityLifecycleCallbacks实现应用主题切换

本文介绍了一种在Android应用中实现一键切换主题的功能。通过自定义主题样式和使用SharedPreferences保存用户选择的主题来实现主题的动态切换,并在应用启动时根据保存的主题进行加载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目场景:

在开发项目的时候要实现一个功能,一键切换应用主题,于是写下这篇文章,对于这个功能的一个简单整理


自定义attr属性或使用系统自带attr属性:

  1. 在res-value目录下新建attr属性的资源文件,例如:theme_attrs.xml。
  2. 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())
}

当前功能只是因本人当前技术有限,所写出的方法流程,如有不足还望指出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值