Flutter怎么实现自定义themes

其他教程   发布日期:2023年07月28日   浏览次数:444

这篇“Flutter怎么实现自定义themes”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Flutter怎么实现自定义themes”文章吧。

MaterialApp中的themes

MaterialApp也是一种StatefulWidget,在MaterialApp中跟theme相关的属性有这样几个:

  1. final ThemeData? theme;
  2. final ThemeData? darkTheme;
  3. final ThemeData? highContrastTheme;
  4. final ThemeData? highContrastDarkTheme;
  5. final ThemeMode? themeMode;

先来看下ThemeMode的定义:

  1. enum ThemeMode {
  2. system,
  3. light,
  4. dark,
  5. }

ThemeMode是一个枚举类,里面有三个枚举值,分别是system,light和dark。

我们都知道现在手机有一个暗黑模式,ThemeMode的这三种模式就是为了适应暗黑模式而生的。

system表示是系统默认的模式,light是明亮模式,dark是暗黑模式。

而ThemeData则定义了主题中各种组件或者行动的配色。

那么如果我们想要实现自定义themes的功能,就可以利用这个ThemeData类来重写其中要重写的颜色。

ThemeData中还有专门为color变化定义的ColorScheme,还有为Text变化设置的TextTheme,这两个theme实际上是一系列的color集合。

除了ThemeData,flutter中还有一个类叫做Theme。

Theme是一个StatelessWidget,这个widget中包含了ThemeData,它提供了一个Theme.of方法来让子widget获得最近的ThemeData数据。

这就意味着,在flutter中,子widget可以使用和父widget不同的主题,非常的棒。

自定义themes的使用

那么如何使用自定义themes呢?有两种方式。

第一种就是在使用MaterialApp的时候传入自定义的themes,如下所示:

  1. Widget build(BuildContext context) {
  2. return MaterialApp(
  3. title: 'Flutter Demo',
  4. theme: ThemeData(
  5. primarySwatch: Colors.blue,
  6. ),
  7. home: const MyHomePage(title: 'Flutter Demo Home Page'),
  8. );
  9. }
  10. }

但是这种操作实际是传入了一个全新的ThemeData,假如我们只想修改部分ThemeData中的数据应该如何处理呢?

我们可以使用Theme.of方法从当前的Theme中拷贝一份,然后再调用copyWith方法,传入要修改的自定义属性即可。

如下所示:

  1. Widget build(BuildContext context) {
  2. return MaterialApp(
  3. title: 'Flutter Demo',
  4. theme: Theme.of(context).copyWith(useMaterial3: true),
  5. home: const MyHomePage(title: 'Flutter Demo Home Page'),
  6. );
  7. }
  8. }

前面我们提到了Theme这个widget,我们还可以将要自定义Theme的widget用Theme包裹起来,理论上我们可以将任何widget都用Theme来进行包装。

比如之前的floatingActionButton的实现是直接返回一个FloatingActionButton:

  1. floatingActionButton: FloatingActionButton(
  2. onPressed: _incrementCounter,
  3. tooltip: 'Increment',
  4. child: const Icon(Icons.add),
  5. )

然后我们可以把FloatingActionButton用Theme包装起来,如下所示:

  1. floatingActionButton: Theme(
  2. data: Theme.of(context).copyWith(focusColor: Colors.yellow),
  3. child: FloatingActionButton(
  4. onPressed: _incrementCounter,
  5. tooltip: 'Increment',
  6. child: const Icon(Icons.add),
  7. ),
  8. )

这样不同的组件就拥有了不同的theme。

以上就是Flutter怎么实现自定义themes的详细内容,更多关于Flutter怎么实现自定义themes的资料请关注九品源码其它相关文章!