首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于系统暗淡模式的动态主题切换

基于系统暗淡模式的动态主题切换
EN

Stack Overflow用户
提问于 2020-05-03 22:06:14
回答 1查看 583关注 0票数 1

我一直在研究flutter中的动态暗模式和亮模式功能。

当我从系统设置中更改移动系统的暗/亮模式时,我想将应用程序的主题更改为暗主题或亮主题。

但是,我无法根据移动系统的亮或暗模式来更改应用程序的暗或亮模式。

我使用了下面的代码。

main.dart

代码语言:javascript
复制
    import 'package:flutter/material.dart';
    import 'package:flutterrookieapp/provider/ThemeProvider.dart';
    import 'package:flutterrookieapp/utils/AppTheme.dart';
    import 'package:provider/provider.dart';

    void main() => runApp(MyApp());

    class MyApp extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return MultiProvider(
          providers: [
            ChangeNotifierProvider(
              create: (context) => ThemeProvider(
                  MediaQuery.of(context).platformBrightness == Brightness.dark
                      ? darkTheme
                      : lightTheme),
            )
          ],
          child: Consumer<ThemeProvider>(
            builder: (temp, theme, _) {
              return MaterialApp(
                debugShowCheckedModeBanner: false,
                title: 'Flutter Sample',
                theme: MediaQuery.platformBrightnessOf(context) == Brightness.dark
                    ? darkTheme
                    : lightTheme,
                home: HomePage(),
              );
            },
          ),
        );
      }
    }
  }

ThemeProvider.dart

代码语言:javascript
复制
import 'package:flutter/material.dart';

class ThemeProvider with ChangeNotifier {
  ThemeData _themeData;

  ThemeProvider(this._themeData);

  ThemeData getTheme() => _themeData;

  setTheme(ThemeData themeData) async {
    this._themeData = themeData;
    notifyListeners();
  }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-04 12:07:52

您可以在MaterialApp中使用darkThemetheme,它始终来自移动系统设置

代码语言:javascript
复制
MaterialApp(
  debugShowCheckedModeBanner: false,
  title: 'Flutter Sample',
  darkTheme: darkTheme,
  theme: lightTheme,
  home: HomePage(),
),
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61575776

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档