动态换肤五(高级换肤)

前言

  上一章讲了 Fragment 以及系统状态栏、系统底部虚拟按键的换肤,这一章我们来完成自定义 View 的换肤以及字体换肤(字体样式)。

上一篇文章地址:https://www.jianshu.com/p/30815e811c7c

字体样式换肤

  如何进行更换字体样式呢?首先,一般我们的字体样式都是放在 assets 目录下的,然后通过 Typeface.createFromAsset();方法返回一个 Typeface,然后 TextView 有一个方法,setTypeface() 就可以设置字体的样式了。
  首先我们在换肤框架里面加上下面代码


image.png

image.png

  在 SkinResources 中添加如下代码:

    public Typeface getTypeface(int resId){
        String skinTypeface = getString(resId);
        if(TextUtils.isEmpty(skinTypeface)){
            return Typeface.DEFAULT;
        }
        Typeface typeface;
        if(isDefaultSkin){
            typeface = Typeface.createFromAsset(mAppResources.getAssets(),skinTypeface);
        }else{
            typeface = Typeface.createFromAsset(mSkinResources.getAssets(),skinTypeface);
        }
        return typeface;
    }

  在 SkinThemeUtil 中添加如下代码

    private static int[] TYPEFACE_ATTR = {
            R.attr.skinTypeface
    };
    /**
     * 获取更换字体的 Typeface
     */
    public static Typeface getSkinTypeface(Activity activity){
        int[] resId = getResId(activity, TYPEFACE_ATTR);
        return SkinResources.getInstance().getTypeface(resId[0]);
    }

  然后我们在换肤的时候需要调用一下该方法,并修改其他代码


image.png

  需要注意一下,字体的换肤一般都是全局性的字体换肤,所以我们在筛选 View 的时候要放宽一下条件


image.png

image.png

image.png

  这样就能完成字体样式换肤了
  为了能够看清楚字体,我将 MainActivity 布局中某些控件的颜色改了一下。


换肤前

换肤后

自定义 View

  随便写一个自定义 View,放到 MainActivity 的布局里面。


image.png

  如图,我放另一个圆在上面,然后颜色设置成了 @color/black,按理说应该和还原按钮的背景颜色一样,换成一样的颜色,但是...


image.png

  原因很简单,就是因为我们无法知道用户自定义 View 中自定义属性的名字到底是什么,我们无法筛选出需要换肤的自定义 View。
  那么我们就提供一个接口,SkinViewSupport
/**
 * 解决自定义 View 换肤的问题
 */

public interface SkinViewSupport {

    void applySkin();
}

  然后,如果你的自定义 View 想换肤,就必须实现我这个接口,并且重写换肤的方法,具体怎么换肤,由使用者自己来写。
  然后修改 SkinAttribute 中的代码


image.png

image.png

换肤前

换肤后

最后整理

思维导图
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,926评论 25 709
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,659评论 0 17
  • 用到的组件 1、通过CocoaPods安装 2、第三方类库安装 3、第三方服务 友盟社会化分享组件 友盟用户反馈 ...
    SunnyLeong阅读 14,736评论 1 180
  • 没人会真正的感同身受到你的痛楚,也没人会真正的去在意你一路走来所遇过的坎与负过的伤,所以别再为了寻求安慰而四处同人...
    笃学青衿阅读 140评论 4 2
  • 今天她坐上火车,第一次去他家,当然是在他的“力邀”之下,没办法 ╮_╭ 她,身高155,体重52kg,35码的脚;...
    第二十四号房间的猫阅读 689评论 0 0