关于一个换肤系统的设计解决方案(一)


       好久没有写过文章了,这篇文章分享的是设计一个基于原有UI绘画架构的换肤系统,当然,这里做的仅仅是一个解决方案设计和实现,深入的绘画用的是已有的东西(当然着色和色相变换是我添加的(*^__^*) );

       这套东西我叫theme系统,这个系统可以分为一个主控制体和三个辅助控制部分;

主控制为一SkinLoader类:所有相关到skin的图片和颜色值还有字体都需要通过这个类加载这是一个统一加载入口;

类中包含两个map,一个为不换肤的UI object,另一个存可以换肤的UI object,还有就是一个皮肤对应的拥有体;

辅组资源类SkinSource类:装载和卸载主题包含资源;(xml格式定义的一套资源标准)

辅组主题包类ThemeFileListLoader:负责搜寻查找主题包,并提供外部查询;

主题包包含有以下元素:

1.一个主题config.xml:主题是否可以被自定义着色,主题默认着色值,版本号;

2.preview图片;

3. image文件夹,包含需要被换掉的图片资源;

4. theme.xml标明换掉的image文件对应的资源路径;

公共资源layout被存放在一个名为public的文件中,里面包含窗口layout xml文件和公共image文件。

公共主题包提供默认的所有资源,配合default主题包搭载默认主题;


一个主题的基本实现逻辑实现了:(没搞过软件工程图,画得很烂,望各位多多指教)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值