iOS OC调用SwiftTheme 图文教程 (附效果图dem
2017-07-08 本文已影响104人
翻滚的炒勺2013
SwiftTheme
先看效果
data:image/s3,"s3://crabby-images/b17e8/b17e836ba86011973e8f7544c6149e9067d60268" alt=""
因为项目是oc写的, 而SwiftTheme底层是swift,所以项目上还要做一些设置
0. 配置工程.设置Defines Module 为Yes
data:image/s3,"s3://crabby-images/737fd/737fde0d4ccd9304366a5f23ea4546cb1df5879c" alt=""
1.设置Product Module Name 为当前工程名
data:image/s3,"s3://crabby-images/86e32/86e32b42fb29b2ae736353096dccde3b78cf7e2f" alt=""
2.配置Podfile文件
data:image/s3,"s3://crabby-images/2cabf/2cabf1b205d40d8259ada9d6a8e38970454400d2" alt=""
3.安装SwiftTheme
0.打开终端.cd 你项目的路径
1.pod install
4.创建oc调用swift的桥接文件
文件名为你项目的名字-Bridging-Header
data:image/s3,"s3://crabby-images/8200a/8200a3f087fa280a203fcee8ecf364a78d0f72f5" alt=""
选择Create Bridging Header
data:image/s3,"s3://crabby-images/9924f/9924f95a47895df8bef4200ee26d3fea2a06c660" alt=""
也可以自己创建桥接文件
data:image/s3,"s3://crabby-images/5ac1d/5ac1dadfff30c010a2f45a0f763820f4c6e6cfdd" alt=""
文件名同样为你项目的名字-Bridging-Header,在文件包含SwiftTheme
data:image/s3,"s3://crabby-images/7ce60/7ce60a6b0b814cbc7f8651ff1ef3da70bfb2fc56" alt=""
修改桥接文件路径
data:image/s3,"s3://crabby-images/c333d/c333dcc01c2327d68b0e022b8874efe838d2954f" alt=""
5.在项目中使用SwiftTheme
打开SwiftTheme找到这三个文件,拖到你得工程里
data:image/s3,"s3://crabby-images/79eb7/79eb7930bb3357bfb624a877a494b6c83bb3e540" alt=""
6.你项目的pch文件里引入这三个文件
data:image/s3,"s3://crabby-images/c83d6/c83d6dfd02eb1b0caabfc35566cb9de0dcde99e4" alt=""
7.接下来你就可以像oc一样调用这个框架
怎么使用这个框架
tabBar
UITabBar *tabBar = [UITabBar appearance];
tabBar.theme_tintColor = globalBarTextColorPicker;
nav
/// 全局去掉黑线
UINavigationBar *navigationBar = [UINavigationBar appearance];
NSShadow *shadow = [[NSShadow alloc] init];
shadow.shadowOffset = CGSizeZero;
NSMutableArray *titleAttributes = [NSMutableArray array];
for (NSString *rgba in globalNavColors) {
UIColor *color = [[UIColor alloc] initWithRgba_throws:rgba error:nil];
NSDictionary *attr = @{
NSForegroundColorAttributeName: color,
NSFontAttributeName: [UIFont systemFontOfSize:20],
NSShadowAttributeName: shadow
};
[titleAttributes addObject:attr];
}
navigationBar.theme_tintColor = globalBarTextColorPicker;
navigationBar.theme_barTintColor = globalBarTintColorPicker;
navigationBar.theme_titleTextAttributes = [ThemeDictionaryPicker pickerWithDicts:titleAttributes];
调用
/// 在你需要换肤的地方,调用这个方法
[MyThemes switchToNext];
Global文件
data:image/s3,"s3://crabby-images/a6faf/a6faf207a3097046e05d1beb714ce847c49e11b8" alt=""
在这里你可以配置你需要颜色
你可能需要颜色进制转换在线工具
最后贴上效果图
data:image/s3,"s3://crabby-images/f4f79/f4f79b17a6c97566ffdddbdee63b82cb32b3f77f" alt=""