ios 主题切换 思路_iOS 实现主题切换的最佳方案
投资证券的小伙伴儿,应该非常熟悉很多 App 的夜间模式。打开夜间模式时,App 所有的页面由白色变为黑色,这样做有两个好处:一个是可以保护眼睛;另一个是相关的红绿行情图像,也显得更加协调。Android 上称这种夜间/白天模式为「主题切换」, 实现方式大都是通过更改 Resource 文件夹的路径来实现。 作为一个iOS App 开发者, 如何实现这种主题切换的功能呢?
GitHub 上面,star 最多的是叫 DKNightVersion 的开源库,内部原理是通过 Notification 的方式, 在 UIView 中监听通知变化,切换不同的主题颜色。也有一些其他的开源库,但是底层无一例外都使用了通知来实现。
结合自己的项目,我想出了另外一种实现方式,原理如下:
iOS 切换主题.png
项目采用通常的 TabBarController 的展示方式。通过 SettingManager 管理 plist 文件,plist 中对应了不同主题的颜色。项目中所有 UIView 对象的颜色均通过 SettingManager 来设置。当切换不同主题时,通过 SettingManager 读取 plist 中对应的不同颜色值。
上述方案的顺利实现,还需要以下 2 个细节:
1 TabBarController 需要由 UINavigationController 包装一层,然后 UINavigationController 作为 window 的 rootViewController.- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds]; self.window.backgroundColor = [UIColor whiteColor];
UIStoryboard *storyBoard = [UIStoryboard storyboardWithName:@"Main" bundle:nil];
ZDTabBarController *tabBarC = [storyBoard instantiateInitialViewController];
tabBarC.view.backgroundColor = [UIColor themeColor];
UINavigationController *nav = [[UINavigationController alloc] initWithRootViewController:tabBarC];
nav.navigationBar.hidden = true; self.window.rootViewController = nav;
[self.window makeKeyAndVisible];
return YES;
}
2 Setting 页面需要以 pop 的方式弹出;与原来的 TabBarController 的 UINavigationController 相互独立;- (void)btnClick_start{
MTSettingsViewController *settingsVC = [[MTSettingsViewController alloc] init];
[settingsVC configuePushStyle:(PushStylePush)];
[settingsVC show:self.navigationController];
}
有了以上两点儿的设计,在切换主题时,通过重新生成 TabBarController , 作为 UINavigationController 的 subViewControllers。+ (void)configueTheme:(ThemeStyle) themeStyle rootViewController:(UIViewController *)vc completion:(void (^ __nullable)(void))completion{ NSMutableDictionary *settingData = [[NSMutableDictionary alloc] initWithContentsOfFile:[self shareManager].plistPath];
[settingData setValue:[NSNumber numberWithInteger:themeStyle] forKey:ThemeStyleKey];
[settingData writeToFile:[self shareManager].plistPath atomically:true];
UINavigationController *nav = (UINavigationController *)[UIApplication sharedApplication].keyWindow.rootViewController;
[nav setViewControllers:@[vc]];
if (completion) {
completion();
}
}
作者:uniapp
链接:https://www.jianshu.com/p/2b9090a00175
ios 主题切换 思路_iOS 实现主题切换的最佳方案相关推荐
- ios 主题切换 思路_iOS 使用 NSObject 的分类实现快速切换主题
PYTheme An easy way to change theme through NSObject's category for iOS. 通过 NSObject 的分类实现使用简单的主题更换. ...
- ios 主题切换 思路_iOS主题皮肤切换
如果您的企业已启用企业统一身份认证,请在企业内部系统修改密码. 切换企业 点击消息列表界面的"切换企业/组织",方便快速切换企业/组织."切换企业/组织"及企业 ...
- ios 主题切换 思路_IOS主题切换ThemeManager
#import "ThemeManager.h" #define kDefaultThemeName @"默认主题" #define kThemeName ...
- iOS Sprite Kit教程之场景的切换
iOS Sprite Kit教程之场景的切换 Sprite Kit中切换场景 每一个场景都不是单独存在的.玩家可以从一个场景中切换到另外一个场景中.本小节,我们来讲解场景切换.在每一个游戏中都会使用到 ...
- iOS开发 剖析网易新闻标签栏视图切换(addChildViewController属性介绍)
iOS开发 剖析网易新闻标签栏视图切换(addChildViewController属性介绍) 本来仅仅是打算介绍一下addChildViewController这种方法的,正好今天朋友去换工作面试问 ...
- 三人英语计算机主题口语对话,计算机英语Web Quest主题教学思路(共3641字).doc
计算机英语Web Quest主题教学思路(共3641字) 计算机英语Web Quest主题教学思路(共3641字) 计算机英语课程教学长期以来采用以教师为主的传统教学模式,教学方法多为讲授法,教学组织 ...
- 多套主题怎么灵动换肤?APP换肤方案详细解析!
背景需求 目前Android APP换肤大体可分为两大类: 两套主题的切换(比如白天/黑夜),使用一个开关按钮进行切换. 多套主题在线下载并更新. 第一种的实现基本上使用设置本地Theme来操作,即将 ...
- 谷歌浏览器有哪些好看的主题_Kibou 简洁的Typecho主题
一款基于 Bootstrap 的单栏的简洁的自适应Typecho主题.这是一款开发于17年的Typecho主题,如果您喜欢简洁的单栏主题,那么这款主题会是您不错的选择 Kibou 是一款基于 Boot ...
- jquery ui 主题_使用jQuery UI主题
主题不是一个新概念. 您可能已经使用级联样式表(CSS)样式和类推出了一些样式,以格式化网站的外观. 使用框架可以使方法标准化,并减少需要编写的工作量和代码量. jQuery UI现在是主题实现的行业 ...
最新文章
- python在windows下操作word的方法的代码
- mongochef如何链接有权限的mongodb3.x数据库
- 微服务已过时!DDD领域建模与架构设计才是未来!
- 中国江苏省动漫产业发展导向及运营前景规划咨询报告2021-2027年
- SAP UI5 应用开发教程之五:视图控制器初探
- BERT 的演进和应用
- hdu 1394Minimum Inversion Number
- 儿童智能手表方案/案列/APP/小程序/网站
- dojo实现省份地市级联报错(二)
- java笔画数_Java调用setStroke()方法设置笔画属性的语法 原创
- Java解压ZIP、RAR文件
- Ques1,debug模式打不开的原因
- simulink解微分方程
- 202.Wex5开发环境的安装与基本使用 2019.08.29
- 男人40岁后的健康生活方式
- 为什么大人学英语这么难?
- 成都链安预警:EOS竞猜类游戏SKReos再次遭受攻击
- 2022字节跳动【数据仓库工程师】日常实习面经-----一面
- Cesium之天空盒对应方位
- JavaScript 所见所得文本编辑器 Froala Editor 4.0.17Crack