mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
opt: theme type
Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
@@ -33,13 +33,13 @@ class _HomePageState extends State<HomePage>
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
super.build(context);
|
||||
Brightness currentBrightness = MediaQuery.of(context).platformBrightness;
|
||||
// Brightness currentBrightness = MediaQuery.of(context).platformBrightness;
|
||||
// 设置状态栏图标的亮度
|
||||
SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle(
|
||||
statusBarIconBrightness: currentBrightness == Brightness.light
|
||||
? Brightness.dark
|
||||
: Brightness.light,
|
||||
));
|
||||
// SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle(
|
||||
// statusBarIconBrightness: currentBrightness == Brightness.light
|
||||
// ? Brightness.dark
|
||||
// : Brightness.light,
|
||||
// ));
|
||||
return Scaffold(
|
||||
appBar: AppBar(toolbarHeight: 0),
|
||||
body: Column(
|
||||
|
||||
@@ -1,3 +1,5 @@
|
||||
import 'dart:ui';
|
||||
|
||||
import 'package:PiliPalaX/common/widgets/network_img_layer.dart';
|
||||
import 'package:PiliPalaX/models/space/card.dart' as space;
|
||||
import 'package:PiliPalaX/models/space/images.dart' as space;
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
import 'package:PiliPalaX/utils/global_data.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
||||
import 'package:get/get.dart';
|
||||
@@ -21,6 +22,9 @@ class MineController extends GetxController {
|
||||
static bool anonymity =
|
||||
GStorage.setting.get(SettingBoxKey.anonymity, defaultValue: false);
|
||||
|
||||
ThemeType get nextThemeType =>
|
||||
ThemeType.values[(themeType.value.index + 1) % ThemeType.values.length];
|
||||
|
||||
@override
|
||||
onInit() {
|
||||
super.onInit();
|
||||
@@ -30,8 +34,7 @@ class MineController extends GetxController {
|
||||
userLogin.value = true;
|
||||
}
|
||||
|
||||
themeType.value = ThemeType.values[setting.get(SettingBoxKey.themeMode,
|
||||
defaultValue: ThemeType.system.code)];
|
||||
// themeType.value = ThemeType.values[GlobalData().themeMode];
|
||||
// anonymity = setting.get(SettingBoxKey.anonymity, defaultValue: false);
|
||||
}
|
||||
|
||||
@@ -190,44 +193,9 @@ class MineController extends GetxController {
|
||||
}
|
||||
|
||||
onChangeTheme() {
|
||||
ThemeType currentTheme = themeType.value;
|
||||
//system -> dark -> light -> system
|
||||
switch (currentTheme) {
|
||||
case ThemeType.system:
|
||||
setting.put(SettingBoxKey.themeMode, ThemeType.dark.code);
|
||||
themeType.value = ThemeType.dark;
|
||||
break;
|
||||
case ThemeType.dark:
|
||||
setting.put(SettingBoxKey.themeMode, ThemeType.light.code);
|
||||
themeType.value = ThemeType.light;
|
||||
break;
|
||||
case ThemeType.light:
|
||||
setting.put(SettingBoxKey.themeMode, ThemeType.system.code);
|
||||
themeType.value = ThemeType.system;
|
||||
break;
|
||||
}
|
||||
// Brightness currentBrightness =
|
||||
// MediaQuery.of(Get.context!).platformBrightness;
|
||||
// switch (currentTheme) {
|
||||
// case ThemeType.dark:
|
||||
// setting.put(SettingBoxKey.themeMode, ThemeType.light.code);
|
||||
// themeType.value = ThemeType.light;
|
||||
// break;
|
||||
// case ThemeType.light:
|
||||
// setting.put(SettingBoxKey.themeMode, ThemeType.dark.code);
|
||||
// themeType.value = ThemeType.dark;
|
||||
// break;
|
||||
// case ThemeType.system:
|
||||
// // 判断当前的颜色模式
|
||||
// if (currentBrightness == Brightness.light) {
|
||||
// setting.put(SettingBoxKey.themeMode, ThemeType.dark.code);
|
||||
// themeType.value = ThemeType.dark;
|
||||
// } else {
|
||||
// setting.put(SettingBoxKey.themeMode, ThemeType.light.code);
|
||||
// themeType.value = ThemeType.light;
|
||||
// }
|
||||
// break;
|
||||
// }
|
||||
themeType.value = nextThemeType;
|
||||
setting.put(SettingBoxKey.themeMode, themeType.value.code);
|
||||
GlobalData().themeMode = themeType.value.code;
|
||||
Get.forceAppUpdate();
|
||||
}
|
||||
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
// ignore_for_file: no_leading_underscores_for_local_identifiers
|
||||
|
||||
import 'package:PiliPalaX/utils/global_data.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:get/get.dart';
|
||||
import 'package:PiliPalaX/common/constants.dart';
|
||||
@@ -17,7 +18,8 @@ class MinePage extends StatefulWidget {
|
||||
}
|
||||
|
||||
class _MinePageState extends State<MinePage> {
|
||||
final MineController mineController = Get.put(MineController());
|
||||
final MineController mineController = Get.put(MineController())
|
||||
..themeType.value = ThemeType.values[GlobalData().themeMode];
|
||||
late Future _futureBuilderFuture;
|
||||
|
||||
@override
|
||||
@@ -86,19 +88,18 @@ class _MinePageState extends State<MinePage> {
|
||||
tapTargetSize:
|
||||
MaterialTapTargetSize.shrinkWrap, // the '2023' part
|
||||
),
|
||||
//system -> dark -> light -> system
|
||||
tooltip:
|
||||
'切换至${mineController.themeType.value == ThemeType.system ? '深色' : (mineController.themeType.value == ThemeType.dark ? '浅色' : '跟随系统')}主题',
|
||||
onPressed: () {
|
||||
mineController.onChangeTheme();
|
||||
setState(() {});
|
||||
},
|
||||
tooltip: '切换至${switch (mineController.nextThemeType) {
|
||||
ThemeType.light => '浅色',
|
||||
ThemeType.dark => '深色',
|
||||
ThemeType.system => '跟随系统',
|
||||
}}主题',
|
||||
onPressed: mineController.onChangeTheme,
|
||||
icon: Icon(
|
||||
mineController.themeType.value == ThemeType.system
|
||||
? MdiIcons.themeLightDark
|
||||
: mineController.themeType.value == ThemeType.light
|
||||
? MdiIcons.weatherSunny
|
||||
: MdiIcons.weatherNight,
|
||||
switch (mineController.themeType.value) {
|
||||
ThemeType.light => MdiIcons.weatherSunny,
|
||||
ThemeType.dark => MdiIcons.weatherNight,
|
||||
ThemeType.system => MdiIcons.themeLightDark,
|
||||
},
|
||||
size: 24,
|
||||
),
|
||||
),
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
import 'package:PiliPalaX/utils/global_data.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_inappwebview/flutter_inappwebview.dart';
|
||||
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
||||
@@ -43,8 +44,7 @@ class SettingController extends GetxController {
|
||||
setting.get(SettingBoxKey.defaultToastOp, defaultValue: 1.0);
|
||||
picQuality.value =
|
||||
setting.get(SettingBoxKey.defaultPicQa, defaultValue: 10);
|
||||
themeType.value = ThemeType.values[setting.get(SettingBoxKey.themeMode,
|
||||
defaultValue: ThemeType.system.code)];
|
||||
themeType.value = ThemeType.values[GlobalData().themeMode];
|
||||
dynamicBadgeType.value = DynamicBadgeMode.values[setting.get(
|
||||
SettingBoxKey.dynamicBadgeMode,
|
||||
defaultValue: DynamicBadgeMode.number.code)];
|
||||
|
||||
@@ -308,6 +308,7 @@ class _StyleSettingState extends State<StyleSetting> {
|
||||
_tempThemeValue = result;
|
||||
settingController.themeType.value = result;
|
||||
setting.put(SettingBoxKey.themeMode, result.index);
|
||||
GlobalData().themeMode = result.index;
|
||||
Get.forceAppUpdate();
|
||||
}
|
||||
},
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
import 'dart:async';
|
||||
import 'dart:math';
|
||||
|
||||
import 'package:PiliPalaX/grpc/grpc_repo.dart';
|
||||
import 'package:PiliPalaX/http/loading_state.dart';
|
||||
import 'package:PiliPalaX/utils/utils.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
Reference in New Issue
Block a user