android 换肤 字体颜色,Android快速换肤之App内部换肤

目录

0e5632be4de1

原理

0e5632be4de1

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

实现步骤

添加依赖

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方法中进行初始化

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文件中添加如下代码)

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

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

0e5632be4de1

0e5632be4de1

然后将控件的属性设置为引用资源的方式

0e5632be4de1

然后在代码中只需要执行一行代码即可实现换肤

SkinCompatManager.getInstance().restoreDefaultTheme();//恢复默认皮肤

SkinCompatManager.getInstance().loadSkin("night", null, SkinCompatManager.SKIN_LOADER_STRATEGY_BUILD_IN);//切换皮肤名为night的皮肤

实例演示

0e5632be4de1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值