之前在社区上提问过如何更换三种主题、评论区里有大哥提供了换肤框架 然后发现其实有一个换肤框架的学习成本很低很方便 在此记录 各位也可以参考
换肤框架 Android-skin-support
链接:https://github.com/ximsfei/Android-skin-support
只需要进行以下操作即可成功,当然还有别的方法可以实现,这里只介绍我的实现方法:
第一步,Gradle导入:
这里是有别的版本的,但是我的项目用到这里就可以了,所以没有再去往下更新版本
implementation 'skin.support:skin-support:3.1.4' // skin-support
implementation 'skin.support:skin-support-design:4.0.5' // skin-support-design material design 控件支持[可选]
implementation 'skin.support:skin-support-cardview:4.0.5' // skin-support-cardview CardView 控件支持[可选]
implementation 'skin.support:skin-support-constraint-layout:4.0.5' // ConstraintLayout 控件支持[可选]
第二步,在代码中初始化:
我是在Application里实现的,其他情况自己考虑
private void initSkin() {
SkinCompatManager.withoutActivity(this) // 基础控件换肤初始化
.addInflater(new SkinMaterialViewInflater()) // material design 控件换肤初始化[可选]
.addInflater(new SkinConstraintViewInflater()) // ConstraintLayout 控件换肤初始化[可选]
.addInflater(new SkinCardViewInflater()) // CardView v7 控件换肤初始化[可选]
.setSkinStatusBarColorEnable(false) // 关闭状态栏换肤,默认打开[可选]
.setSkinWindowBackgroundEnable(false) // 关闭windowBackground换肤,默认打开[可选]
.loadSkin();
}
// 如果Activity继承自AppCompatActivity的话,需要在Activity里重载这部分内容
@NonNull
@Override
public AppCompatDelegate getDelegate() {
return SkinAppCompatDelegateImpl.get(this, this);
}
第三步,设置你的Res文件
本质上是找到对应资源文件夹的对应名称的文件然后替换,所以这里需要在Gradle里写好你的资源路径 然后自行创建你的Res文件夹即可,里面放的资源文件就是你要换的图 还要注意的一点是,比如你的默认图名称为“icon_botton”,那么你需要更换的图片的前缀或者后缀应该是“XXXX_icon_botton”或“icon_botton_XXXX”
sourceSets {
main {
res.srcDirs = ['src/main/res', 'src/main/res-XXXX', 'src/main/res-XXXX']
}
}
第四步,代码换肤
接下来只需要在需要换肤的时候设置这么一句代码即可成功
SkinCompatManager.getInstance().loadSkin("night", SkinCompatManager.SKIN_LOADER_STRATEGY_BUILD_IN); // 后缀加载
SkinCompatManager.getInstance().loadSkin("night", SkinCompatManager.SKIN_LOADER_STRATEGY_PREFIX_BUILD_IN); // 前缀加载
// 恢复应用默认皮肤
SkinCompatManager.getInstance().restoreDefaultTheme();
结束。