wip: fix issues.
This commit is contained in:
+1
-1
@@ -18,7 +18,7 @@ class Test {
|
|||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
2. `app` 项目目录下执行 `flutter packages pub run build_runner build`
|
2. `app` 项目目录下执行 `flutter packages pub get && flutter packages pub run build_runner build --delete-conflicting-outputs`
|
||||||
|
|
||||||
3. 将在 `lib/models/test.provider.dart` 生成如下代码:
|
3. 将在 `lib/models/test.provider.dart` 生成如下代码:
|
||||||
```dart
|
```dart
|
||||||
|
|||||||
@@ -0,0 +1,3 @@
|
|||||||
|
class SPKeys {
|
||||||
|
static final String brightnessMode = 'BRIGHTNESS_MODE';
|
||||||
|
}
|
||||||
+53
-10
@@ -1,3 +1,5 @@
|
|||||||
|
import 'package:dde_gesture_manager/models/configs.dart';
|
||||||
|
import 'package:dde_gesture_manager/models/configs.provider.dart';
|
||||||
import 'package:dde_gesture_manager/models/settings.provider.dart';
|
import 'package:dde_gesture_manager/models/settings.provider.dart';
|
||||||
import 'package:dde_gesture_manager/utils/init.dart';
|
import 'package:dde_gesture_manager/utils/init.dart';
|
||||||
import 'package:flutter/foundation.dart';
|
import 'package:flutter/foundation.dart';
|
||||||
@@ -17,17 +19,25 @@ class MyApp extends StatelessWidget {
|
|||||||
return MultiProvider(
|
return MultiProvider(
|
||||||
providers: [
|
providers: [
|
||||||
ChangeNotifierProvider(create: (context) => SettingsProvider()),
|
ChangeNotifierProvider(create: (context) => SettingsProvider()),
|
||||||
|
ChangeNotifierProvider(create: (context) => ConfigsProvider()),
|
||||||
],
|
],
|
||||||
builder: (context, child) {
|
builder: (context, child) {
|
||||||
var isDarkMode = context.watch<SettingsProvider>().isDarkMode;
|
var isDarkMode = context.watch<SettingsProvider>().isDarkMode;
|
||||||
|
var brightnessMode = context.watch<ConfigsProvider>().brightnessMode;
|
||||||
|
late bool showDarkMode;
|
||||||
|
if (brightnessMode == BrightnessMode.system) {
|
||||||
|
showDarkMode = isDarkMode ?? false;
|
||||||
|
} else {
|
||||||
|
showDarkMode = brightnessMode == BrightnessMode.dark;
|
||||||
|
}
|
||||||
return MaterialApp(
|
return MaterialApp(
|
||||||
title: 'Flutter Demo',
|
title: 'Flutter Demo',
|
||||||
theme: ThemeData(
|
theme: ThemeData(
|
||||||
primarySwatch: isDarkMode == true ? Colors.blue : Colors.blue,
|
primarySwatch: showDarkMode ? Colors.blue : Colors.blue,
|
||||||
brightness: isDarkMode == true ? Brightness.dark : Brightness.light,
|
brightness: showDarkMode ? Brightness.dark : Brightness.light,
|
||||||
),
|
),
|
||||||
home: AnimatedCrossFade(
|
home: AnimatedCrossFade(
|
||||||
crossFadeState: isDarkMode != null ? CrossFadeState.showFirst : CrossFadeState.showSecond,
|
crossFadeState: isDarkMode != null ? CrossFadeState.showSecond : CrossFadeState.showFirst,
|
||||||
alignment: Alignment.center,
|
alignment: Alignment.center,
|
||||||
layoutBuilder: (topChild, topChildKey, bottomChild, bottomChildKey) => Stack(
|
layoutBuilder: (topChild, topChildKey, bottomChild, bottomChildKey) => Stack(
|
||||||
clipBehavior: Clip.none,
|
clipBehavior: Clip.none,
|
||||||
@@ -37,14 +47,12 @@ class MyApp extends StatelessWidget {
|
|||||||
Positioned(key: topChildKey, child: topChild),
|
Positioned(key: topChildKey, child: topChild),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
firstChild: MyHomePage(title: 'Flutter Demo Home Page'),
|
firstChild: Builder(builder: (context) {
|
||||||
secondChild: Builder(builder: (context) {
|
Future.microtask(() => initEvents(context));
|
||||||
initEvents(context);
|
return Container();
|
||||||
return Center(
|
|
||||||
child: CircularProgressIndicator(),
|
|
||||||
);
|
|
||||||
}),
|
}),
|
||||||
duration: Duration(seconds: 1),
|
secondChild: MyHomePage(title: 'Flutter Demo Home Page'),
|
||||||
|
duration: Duration(milliseconds: 500),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
@@ -72,6 +80,7 @@ class _MyHomePageState extends State<MyHomePage> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
var brightnessMode = context.watch<ConfigsProvider>().brightnessMode;
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
appBar: AppBar(
|
appBar: AppBar(
|
||||||
title: Text(widget.title),
|
title: Text(widget.title),
|
||||||
@@ -87,6 +96,40 @@ class _MyHomePageState extends State<MyHomePage> {
|
|||||||
'$_counter',
|
'$_counter',
|
||||||
style: Theme.of(context).textTheme.headline4,
|
style: Theme.of(context).textTheme.headline4,
|
||||||
),
|
),
|
||||||
|
ListTile(
|
||||||
|
title: const Text('System'),
|
||||||
|
leading: Radio<BrightnessMode>(
|
||||||
|
value: BrightnessMode.system,
|
||||||
|
groupValue: brightnessMode,
|
||||||
|
onChanged: (BrightnessMode? value) {
|
||||||
|
context.read<ConfigsProvider>().setProps(brightnessMode: value);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
ListTile(
|
||||||
|
title: const Text('Light'),
|
||||||
|
leading: Radio<BrightnessMode>(
|
||||||
|
value: BrightnessMode.light,
|
||||||
|
groupValue: brightnessMode,
|
||||||
|
onChanged: (BrightnessMode? value) {
|
||||||
|
setState(() {
|
||||||
|
context.read<ConfigsProvider>().setProps(brightnessMode: value);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
ListTile(
|
||||||
|
title: const Text('Dark'),
|
||||||
|
leading: Radio<BrightnessMode>(
|
||||||
|
value: BrightnessMode.dark,
|
||||||
|
groupValue: brightnessMode,
|
||||||
|
onChanged: (BrightnessMode? value) {
|
||||||
|
setState(() {
|
||||||
|
context.read<ConfigsProvider>().setProps(brightnessMode: value);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -0,0 +1,19 @@
|
|||||||
|
import 'package:dde_gesture_manager/builder/provider_annotation.dart';
|
||||||
|
import 'package:dde_gesture_manager/constants/sp_keys.dart';
|
||||||
|
import 'package:dde_gesture_manager/utils/helper.dart';
|
||||||
|
|
||||||
|
enum BrightnessMode {
|
||||||
|
system,
|
||||||
|
light,
|
||||||
|
dark,
|
||||||
|
}
|
||||||
|
|
||||||
|
@ProviderModel()
|
||||||
|
class Configs {
|
||||||
|
@ProviderModelProp()
|
||||||
|
BrightnessMode? brightnessMode;
|
||||||
|
|
||||||
|
Configs() {
|
||||||
|
this.brightnessMode = BrightnessMode.values[H().sp.getInt(SPKeys.brightnessMode)?.clamp(0, 2) ?? 0];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -4,7 +4,4 @@ import 'package:dde_gesture_manager/builder/provider_annotation.dart';
|
|||||||
class Settings {
|
class Settings {
|
||||||
@ProviderModelProp()
|
@ProviderModelProp()
|
||||||
bool? isDarkMode;
|
bool? isDarkMode;
|
||||||
|
|
||||||
@ProviderModelProp()
|
|
||||||
String? name;
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
import 'package:dde_gesture_manager/utils/helper.dart';
|
import 'package:dde_gesture_manager/utils/helper.dart';
|
||||||
import 'package:flutter/foundation.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:gsettings/gsettings.dart';
|
import 'package:gsettings/gsettings.dart';
|
||||||
import 'package:provider/provider.dart';
|
import 'package:provider/provider.dart';
|
||||||
@@ -12,18 +11,23 @@ Future<void> initEvents(BuildContext context) async {
|
|||||||
context.read<SettingsProvider>().setProps(isDarkMode: isDark);
|
context.read<SettingsProvider>().setProps(isDarkMode: isDark);
|
||||||
} else {
|
} else {
|
||||||
var xsettings = GSettings('com.deepin.xsettings');
|
var xsettings = GSettings('com.deepin.xsettings');
|
||||||
xsettings.get('theme-name').then((value) {
|
String? themeName;
|
||||||
Future.delayed(
|
try {
|
||||||
Duration(seconds: 1),
|
themeName = (await xsettings.get('theme-name')).toString();
|
||||||
() => context.read<SettingsProvider>().setProps(isDarkMode: value.toString().contains('dark')),
|
} catch (e) {
|
||||||
);
|
print(e);
|
||||||
});
|
context.read<SettingsProvider>().setProps(isDarkMode: false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (themeName != null) {
|
||||||
|
context.read<SettingsProvider>().setProps(isDarkMode: themeName.contains('dark'));
|
||||||
xsettings.keysChanged.listen((event) {
|
xsettings.keysChanged.listen((event) {
|
||||||
xsettings.get('theme-name').then((value) {
|
xsettings.get('theme-name').then((value) {
|
||||||
context.read<SettingsProvider>().setProps(isDarkMode: value.toString().contains('dark'));
|
context.read<SettingsProvider>().setProps(isDarkMode: value.toString().contains('dark'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> initConfigs() async {
|
Future<void> initConfigs() async {
|
||||||
|
|||||||
Reference in New Issue
Block a user