一个轻量级的iOS皮肤切换方案(内附Demo)

项目代码放这里,这个方案是从实际项目中剥离而来的,你们使用中遇到什么问题或者有什么赐教欢迎随时留言~git

Demo运行效果图

Demo作的有点丑,你们多忍耐一下😅github

使用方法很是简单:

初始化:

[[SDThemeManager sharedInstance] setupThemeNameArray:@[@"SDTheme-White", @"SDTheme-Black"]];
复制代码

SDTheme-WhiteSDTheme-Black是资源主题Bundle的名称,下面会说到资源Bundle的引入方法。bash

切换主题:

[[SDThemeManager sharedInstance] changeTheme:@"SDTheme-Black"];
复制代码

具体设置皮肤:

具体调用很是简单,好比须要换肤的视图控件本来是调用backgroundColor设置颜色,只须要换成调用扩展方法theme_backgroundColor便可,例如:ui

self.view.theme_backgroundColor = @"block_bg";
self.textField.theme_textColor = @"text_h1";
self.image.theme_image = @"icon_face";
复制代码

富文本须要用SDThemeForegroundColorAttributeName替换NSForegroundColorAttributeName,例如:spa

navBar.theme_titleTextAttributes = @{SDThemeForegroundColorAttributeName:@"text_h1"};
复制代码

另外有些经常使用的属性在XIB等可视化视图也能够直接设置,例如: code

若是直接设置属性的方式不知足需求,还能够本身监听通知SDThemeChangedNotification,收到通知以后自行作颜色图标等切换。cdn

资源管理

颜色字符串和图片是放在单独的Bundle里面进行管理的,因此刚开始要新建本身的主题Bundle. Bundle中 新建ColorsMap.plistImages.xcassetsblog

  • 图片:就放在相应的主题bundle中的Images.xcassets管理,图片在不一样主题下名字要保证一致。
  • 颜色字符串:颜色字符串能够参考一下Demo中的文件,首先要有一个大分类,例如Demo中的block、text、line(跟随本身须要分类就好,这里的分类我是扒竞品富途牛牛的🤠),若是你有一个分类叫SomeThing,那分类下内容命名要带上相应的前缀SomeThing_,否则会报找不到,color string是HEX 或者AHEX格式。

Bundle 建立注意事项:

资源bundle不要直接新建文件夹以后改扩展名或者用Settings Bundle 图片

推荐Bundle建立方式:

file-> New-> Target-> macOS-> Bundle

建立完成以后,对 Base SDK 设置为 iOS Build Active Architecture Only 设置为 "YES" Installation Directory    删除掉后面的路径 Code Signing Identity   选择 Don't Code Sign   iOS Deployment Target 设置为 合适的版本 Skip Install 设置为 "NO" Strip Debug Symbols During Copy 设置为 "YES" COMBINE_HIDPI_IMAGES 设置为 "NO" 再设置一下依赖 ip

好,到如今Bundle就完成了

最后:

仓库地址:SDTheme,⭐⭐⭐若是以为本仓库对您有帮助,请不要吝啬你的⭐,感谢你的支持!⭐⭐⭐ 使用中若是有任何疑问欢迎随时留言,还请各位看官多多指教~

相关文章
相关标签/搜索