首页 > 解决方案 > flutter : 开启Changed Dark Theme & Light Theme

问题描述

我想在布尔更改时更改主题,我已经更改了布尔的值但是为什么主题没有改变

切换前

切换后

输出打印

false
true
true
false
false
true

布尔值已经改变,但主题没有改变

这是我的 Synxtax,有什么解决方案或替代方案吗?

main.dart

import 'global.dart' as global;

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      ....
      theme: global.modetheme
          ? ThemeData(primaryColor: Colors.white)
          : ThemeData.dark(),
      ....
    );
  }
}

全球飞镖

library myproject.global;

bool modetheme = false;

抽屉.dart

import 'global.dart' as global;

SwitchListTile(
  value: global.modetheme,
    onChanged: (bool value) {
      setState(() {
        global.modetheme = value;
        print(global.modetheme);
         });
       },
     )

标签: flutterflutter-layout

解决方案


推荐阅读