Android快速换肤之App内部换肤

目录

原理


添加多套values和drawable文件,通过Android-skin-support框架动态的替换来实现切换主题的效果。

实现步骤

  • 添加依赖

    1
    2
    3
    4
    implementation 'skin.support:skin-support:3.1.0-beta1'                   // skin-support 基础控件支持
    implementation 'skin.support:skin-support-design:3.1.0-beta1' // skin-support-design material design 控件支持[可选]
    implementation 'skin.support:skin-support-cardview:3.1.0-beta1' // skin-support-cardview CardView 控件支持[可选]
    implementation 'skin.support:skin-support-constraint-layout:3.1.0-beta1' // skin-support-constraint-layout ConstraintLayout 控件支持[可选]
  • 创建MyApplication类在onCreate方法中进行初始化

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    public class MyApplication extends Application {
    @Override
    public void onCreate() {
    super.onCreate();
    SkinCompatManager.withoutActivity(this) // 基础控件换肤初始化
    .addInflater(new SkinMaterialViewInflater()) // material design 控件换肤初始化[可选]
    .addInflater(new SkinCardViewInflater()) // CardView v7 控件换肤初始化[可选]
    .setSkinStatusBarColorEnable(true) //切换状态栏颜色
    // .setSkinStatusBarColorEnable(false) // 关闭状态栏换肤,默认打开[可选]
    // .setSkinWindowBackgroundEnable(false) // 关闭windowBackground换肤,默认打开[可选]
    .loadSkin();
    }
    }
  • 添加皮肤(例如皮肤名为night则需要创建res-night文件夹来存放对应的资源文件,然后需要在app的gradle文件中添加如下代码)

    1
    sourceSets {main {res.srcDirs = ['src/main/res', 'src/main/res-night']}}

同时需要将对应的资源文件加上_night后缀

  • 然后将控件的属性设置为引用资源的方式
  • 然后在代码中只需要执行一行代码即可实现换肤
    1
    2
    SkinCompatManager.getInstance().restoreDefaultTheme();//恢复默认皮肤
    SkinCompatManager.getInstance().loadSkin("night", null, SkinCompatManager.SKIN_LOADER_STRATEGY_BUILD_IN);//切换皮肤名为night的皮肤

实例演示

这是我在学习换皮肤时做的一个案例,在这将它分享出来https://github.com/myml666/AndroidSkinDemo

坚持原创技术分享,您的支持将鼓励我继续创作!
-------------本文结束感谢您的阅读-------------