码迷,mamicode.com
首页 > 移动开发 > 详细

iOS深色模式适配

时间:2020-03-25 23:03:26      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:sel   cti   text   red   win   har   dem   github   sde   

不适配深色模式

直接在info新加一个字段

User Interface Style

设置值为

Light

适配深色模式

适配深色模式info里面的那个字段就不用添加了

但是需要在每个UIWindow,UIViewController,UIView里面增加下面的这个方法

-(void)traitCollectionDidChange:(UITraitCollection *)previousTraitCollection

在这个方法里去判断和更改当前界面所有元素的颜色

我专门做了一个单例,把应用程序中的所有颜色都单独保存起来

还有两个方法,分别是把所有的颜色改成与之对应浅色或深色

其实就是一个Color,浅色是一种色值,深色是另外一种色值,一个应用程序可以定义多个Color

应用程序所有的颜色都从这个单例上取

到时候调一下单例只需要把界面刷新一下就行了

-(void)traitCollectionDidChange:(UITraitCollection *)previousTraitCollection
{
    [super traitCollectionDidChange: previousTraitCollection];
    if (@available(iOS 13.0, *))
    {
        if(UITraitCollection.currentTraitCollection.userInterfaceStyle == UIUserInterfaceStyleDark)
        {
            [[Color darkColor] setDarkColorArray];
            LRLog(@"暗黑模式");
        }
        else
        {
            [[Color darkColor] setBrightColorArray];
            LRLog(@"正常模式");
        }
        UIWindow* window = [[[UIApplication sharedApplication] delegate] window];
        [self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[Color darkColor].dataColor2,NSFontAttributeName:[UIFont systemFontOfSize:18]}];
        [self.navigationController.navigationBar setBackgroundImage:[UIImage imageWithColor:[Color darkColor].backColor] forBarMetrics:(UIBarMetricsDefault)];
        [self.navigationController.navigationBar setShadowImage:[UIImage imageWithColor:[Color darkColor].backColor]];
        [self.navigationController.navigationBar setBarTintColor:[Color darkColor].backColor];
        window.backgroundColor=[Color darkColor].backColor;
        self.view.backgroundColor=[Color darkColor].backColor;
    }
}

Demo地址 https://github.com/YouZhiZheShiJingCheng/dark

iOS深色模式适配

标签:sel   cti   text   red   win   har   dem   github   sde   

原文地址:https://www.cnblogs.com/BK-12345/p/12571045.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!