美文网首页
Flutter 暗黑模式适配

Flutter 暗黑模式适配

作者: AryCode | 来源:发表于2021-10-22 22:57 被阅读0次

业务需求

处理暗黑模式下Flutter模式的适配工作

业务背景

混合开发,原生嵌套Flutter,原生已经有一套成熟的暗黑颜色适配规则,设计设计文档时候,会备注该颜色名称,客户端段根据该名称获取颜色
例如:文档备注文字为brandColor

- (UIColor *)brandColor {
    if (_isDark) {
        return [UIColor redColor];
    }
    return [UIColor whiteColor];
}

Flutter暗黑下适配

Flutter下面如果也有iOS这么一套适配暗黑适配就OK了,找了一圈,发现没有,有一个使用内置名称适配暗黑的方法如下

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      // 配置暗黑和普通模式下textTheme得颜色
      theme: ThemeData(
        brightness: Brightness.light,
        textTheme: const TextTheme(
          subtitle1: TextStyle(
            color: Colors.red
          )
        )
      ),
      darkTheme: ThemeData(
        brightness: Brightness.dark,
          textTheme: const TextTheme(
            subtitle1: TextStyle(
              color: Colors.blue
            )
          )
        // textTheme:
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

使用(关注文字颜色即可)

Text( '普通模式下是蓝色,暗盒下是红色', style: Theme.of(context).textTheme.subtitle1,),
普通模式.png 暗黑模式.png

缺点

  • 指定适配样式固定的名称例如:subtitle1,不好记,而且不好配合当前(客户端已有的)框架
  • subtitle1这样的名称数量有限

Flutter暗黑颜色适配新方案

新建颜色管理文件:app_color_theme.dart

import 'package:flutter/material.dart';

bool isDark = false;

class YSColorTheme extends StatelessWidget {

  const YSColorTheme({Key? key,required this.child}) : super(key: key);
  final Widget child;
  @override
  Widget build(BuildContext context) {
    isDark = (Theme.of(context).brightness == Brightness.dark);
    return child;
  }
}

class YSColor {
  static Color get brandColor  {
    if(isDark) {
      return Colors.red;
    }
    return Colors.blue;
  }
}

使用YSColorTheme使得切换暗黑和普通模式的时候系统会rebuild,这样我们可以修改isDark字段,原理是InheritedWidget

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        brightness: Brightness.light,
        textTheme: const TextTheme(
          subtitle1: TextStyle(
            color: Colors.blue
          )
        )
      ),
      darkTheme: ThemeData(
        brightness: Brightness.dark,
          textTheme: const TextTheme(
            subtitle1: TextStyle(
              color: Colors.red
            )
          )
        // textTheme:
      ),
    // 关键点
      home: const YSColorTheme(child: MyHomePage(title: 'Flutter Demo Home Page')),
    );
  }
}
Text( '普通模式下是蓝色,暗盒下是红色',style: TextStyle(color: YSColor.brandColor),),

效果和上面是一样的

Flutter暗黑图片适配方案

纯色图片可以利用上面的颜色方案,设置不同模式下得颜色

 Image(image: const AssetImage("abc.png"),color: YSColor.brandColor,)

非纯色图片的适配其实和上面是一样的,代码如下

class YSImage {
  static ImageProvider get brandImage  {
    if(isDark) {
      return const AssetImage("dark.png");
    }
    return const AssetImage("normal.png");
  }
}

这样就可以随意定义自己的一套暗黑系统,原理的话,就是context(也就是Element)会被InheritedWidget保存,主题被保存在一个就是InheritedWidget子类_InheritedTheme中,切换暗黑的时候,会将该类所依赖的所有context就行rebuild,但是我们的YSColorTheme会被首先rebuild,这样isDark就会被修改了,child重新rebuild的时候,拿到的数据就是对应主题的颜色和图片

相关文章

  • 暗黑模式开发

    iOS13暗黑模式适配(项目开发版) iOS 13 DarkMode 暗黑模式 IOS 暗黑模式适配---基础适配

  • flutter项目关闭暗黑模式

    写了个flutter项目,小米手机夜晚会自动进入暗黑模式,自己的app没有适配暗黑模式,导致显示和UI设计出入很大...

  • Flutter 暗黑模式适配

    业务需求 处理暗黑模式下Flutter模式的适配工作 业务背景 混合开发,原生嵌套Flutter,原生已经有一套成...

  • iOS 暗黑模式适配(项目实战篇)

    通过上面两篇文章iOS 暗黑模式适配(方法介绍篇)iOS 暗黑模式适配(叨叨篇)我们知道了暗黑模式怎么去适配,那么...

  • iOS 开发之关闭暗黑模式

    对于现在很多应用不想适配暗黑模式或者来不及适配的,可以关闭暗黑模式。 全局关闭暗黑模式: 在 Info.plist...

  • iOS 暗黑模式适配

    DarkModeAdapter 简介 iOS 暗黑模式适配懒人版 普通模式(light)下: 暗黑模式(dark)...

  • iOS:暗黑模式适配

    简介:iOS13苹果推出的暗黑模式,在去年苹果已经声明必须适配暗黑模式否则会下架。网上有很多好的文章来适配暗黑模式...

  • Xcode 升级11 适配 ⚠️记录~

    1、关闭暗黑模式 ,如果没有适配暗黑模式,在暗黑模式下会很丑 2、 报错 library not found fo...

  • 百度APP iOS暗黑模式适配的完美解决方案

    百度APP iOS暗黑模式适配的完美解决方案百度APP iOS暗黑模式适配的完美解决方案

  • uni-app做iOS的夜间模式

    iOS13适配暗黑模式/夜间模式/深色模式/暗黑主题(DarkMode)问题:1.监听Android深色或浅色模式...

网友评论

      本文标题:Flutter 暗黑模式适配

      本文链接:https://www.haomeiwen.com/subject/jhmhaltx.html