Day15 - Flutter - 主题风格

简介: Day15 - Flutter - 主题风格

概述

  • 主题风格
  • 暗黑Theme适配


一、主题风格



Theme分为:全局Theme和局部Theme

主题有两个作用:

  • 设置了主题之后,某些Widget会自动使用主题的样式(比如AppBar的颜色)
  • 将某些样式放到主题中统一管理,在应用程序的其它地方直接引用


  • 1.1. 全局Theme
    全局Theme会影响整个app的颜色和字体样式。
    使用起来非常简单,只需要向MaterialApp构造器传入 ThemeData 即可。
    如果没有设置Theme,Flutter将会使用预设的样式。当然,我们可以对它进行定制。


void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
   @override
   Widget build(BuildContext context) {
        return MaterialApp(
          title: 'FlutterDemo',
          // 正常模式
          theme: ThemeData(
            // 1.亮度: light-dark,一般theme我们设置 light,在darkTheme里面设置dark
            brightness: Brightness.light,
            // 2.primarySwatch: primaryColor/accentColor的结合体
            primarySwatch: Colors.red,
            // 3.主要颜色: 导航/底部TabBar
            primaryColor: Colors.blue,
            // 4.次要颜色: FloatingActionButton/按钮颜色
            accentColor: Colors.brown,
            // 5.卡片主题
            cardTheme: CardTheme(
               color: Colors.greenAccent,
               elevation: 10,
               shape: Border.all(width: 3, color: Colors.red),
               margin: EdgeInsets.all(10)
            ),
            // 6.按钮主题
            buttonTheme: ButtonThemeData(
              minWidth: 0,
              height: 25
            ),
            // 7.文本主题
            textTheme: TextTheme(
              subtitle1: TextStyle(fontSize: 20),
              headline1: TextStyle(fontSize: 10),
            ),
            splashColor: Colors.transparent,
            // 点击的水波纹设置为无色
            highlightColor: Colors.transparent
          ),
          // 暗黑模式
          darkTheme: ThemeData(
          ), 
       );
   }
}


  • 1.2. 局部Theme
    如果某个具体的Widget不希望直接使用全局的Theme,而希望自己来定义,只需要在Widget的父节点包裹一下Theme即可
    创建另外一个新的页面,页面中使用新的主题:在新的页面的Scaffold外,包裹了一个Theme,并且设置data为一个新的ThemeData


class JKSecondPage extends StatelessWidget {
    @override
    Widget build(BuildContext context) {
        return Theme(
           data: ThemeData(),
           child: Scaffold(
           ),
        );
    }
}
  • 但是,我们很多时候并不是想完全使用一个新的主题,而且在之前的主题基础之上进行修改:


class HYSecondPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
       return Theme(
          data: Theme.of(context).copyWith(
              primaryColor: Colors.greenAccent
          ),
          child: Scaffold(
          ),
       );
  }
}
  • 提示一:我们想要自己改的主题的内容可以在 Theme.of(context).copyWith( )里面修改
  • 提示二:注意事项:accentColor 在这里并不会被覆盖, 如果想要修改局部变量的 accentColor 我们可以如下做, secondary 才是修改的颜色,而 accentColor 是无效的


floatingActionButton: Theme(
    data: Theme.of(context).copyWith(
      colorScheme: Theme.of(context).colorScheme.copyWith(
         secondary: Colors.pink,
      )
    ),
    child: FloatingActionButton(
      child: Icon(Icons.add),
      onPressed: () {
      },
    ),
),


二. 暗黑Theme适配



  • 2.1. darkTheme
    目前很多应用程序都需要适配暗黑模式,Flutter中如何做到暗黑模式的适配呢?
    事实上,MaterialApp中有theme和dartTheme两个参数:
    按照下面的写法,我们已经默认适配了暗黑主题


class MyApp extends StatelessWidget {
    // This widget is the root of your application.
    @override
    Widget build(BuildContext context) {
       return MaterialApp(
          title: 'Flutter Demo',
          // 正常的模式
          theme: ThemeData.light(),
          // 暗黑模式
          darkTheme: ThemeData.dark(),
          home: HYHomePage(),
       );
    }
}
  • 2.2. 开发中适配在开发中,为了能适配两种主题(设置是更多的主题),我们可以封装一个AppTheme
  • 1.公共的样式抽取成常量
  • 2.封装一个亮色主题
  • 3.封装一个暗黑主题


import 'package:flutter/material.dart';
class JKAppTheme {
   // 字体的设置
   static const double smallFontSize = 12.0;
   static const double normalFontSize = 16.0;
   static const double largeFontSize = 22.0;
   // 颜色的设置
   // 正常的颜色
   static final Color normalTextColor = Colors.brown;
   // 暗黑模式的字体颜色
   static final Color darkTextColor = Colors.yellow;
   // 正常的模式
   static final ThemeData normalTheme = ThemeData(
        primaryColor: Colors.yellow,
        textTheme: TextTheme(
           subtitle1: TextStyle(
              fontSize: normalFontSize, 
              color: normalTextColor
           )
        )
   );
   // 暗黑模式
   static final ThemeData darkTheme = ThemeData(
       primaryColor: Colors.yellow,
       textTheme: TextTheme(
           subtitle1: TextStyle(
              fontSize: normalFontSize,
              color: darkTextColor
           )
       )
   );
}
  • 在MaterialApp中,可以决定使用哪一个主题:


class MyApp extends StatelessWidget {
    // This widget is the root of your application.
    @override
    Widget build(BuildContext context) {
        return MaterialApp(
            title: 'Flutter Demo',
            theme: AppTheme.lightTheme,
            darkTheme: AppTheme.darkTheme,
            home: HYHomePage(),
        );
    }
}


提示:MaterialApp 里面的title再iOS里面是没啥用的,在安卓了里面是有用的



目录
相关文章
|
7月前
|
Dart
Flutter 中优雅切换应用主题的组件
【Flutter】使用adaptive_theme组件优雅切换应用主题:封装MaterialApp,支持light/dark/system模式,自定义色彩,保存选择,含调试按钮。安装配置、设置主题、监听切换、自定义颜色、读取配置步骤详细。代码示例与学习路径推荐。[查看完整教程](https://flutter.ducafecat.com/blog/flutter-app-theme-switch)
Flutter 中优雅切换应用主题的组件
|
7月前
|
前端开发 UED 开发者
【Flutter前端技术开发专栏】Flutter中的主题与样式主题化
【4月更文挑战第30天】Flutter是一款由谷歌开发的开源移动应用框架,因其高性能和跨平台能力受到开发者青睐。本文聚焦Flutter中的主题与样式主题化,阐述如何通过`ThemeData`定义和设置全局主题,以及如何利用`TextStyle`、`AppBarTheme`和`ButtonTheme`定制文本、AppBar和按钮样式。了解并运用这些知识,能提升应用的统一风格和用户体验,助力Flutter开发。
60 0
【Flutter前端技术开发专栏】Flutter中的主题与样式主题化
|
7月前
|
存储 容器
Flutter 应用服务:主题、暗黑、国际化、本地化-app_service库
Flutter 应用服务:主题、暗黑、国际化、本地化-app_service库
282 0
|
缓存 Dart 定位技术
闲鱼技术2022年度白皮书-Flutter主题-节日献礼:Flutter 图片库重磅开源!(中)
闲鱼技术2022年度白皮书-Flutter主题-节日献礼:Flutter 图片库重磅开源!
199 0
|
Swift Kotlin
闲鱼技术2022年度白皮书-Flutter主题-节日献礼:Flutter 图片库重磅开源!(下)
闲鱼技术2022年度白皮书-Flutter主题-节日献礼:Flutter 图片库重磅开源!
169 0
|
移动开发 JavaScript 测试技术
|
容器
闲鱼技术2022年度白皮书-Flutter主题-打造Flutter高性能富文本编辑器——协议篇(中)
闲鱼技术2022年度白皮书-Flutter主题-打造Flutter高性能富文本编辑器——协议篇
380 0
闲鱼技术2022年度白皮书-Flutter主题-打造Flutter高性能富文本编辑器——协议篇(下)
闲鱼技术2022年度白皮书-Flutter主题-打造Flutter高性能富文本编辑器——协议篇
174 0