icon优化

This commit is contained in:
Developer
2026-04-02 17:31:53 +08:00
parent 954d173329
commit 09fee0694c
34 changed files with 754 additions and 194 deletions

View File

@@ -2,8 +2,10 @@ import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter/foundation.dart' show kIsWeb;
import 'package:share_plus/share_plus.dart';
import 'package:get/get.dart';
import '../../../constants/app_constants.dart';
import '../../../services/isweb/wakelock_service.dart';
import '../../../services/get/theme_controller.dart';
import '../guide/beginner_page.dart';
import 'dart:io' as io;
@@ -14,7 +16,7 @@ class PopMenu extends StatelessWidget {
final VoidCallback? onDarkMode;
final VoidCallback? onSettings;
const PopMenu({
PopMenu({
super.key,
this.onRefresh,
this.onEdit,
@@ -23,6 +25,8 @@ class PopMenu extends StatelessWidget {
this.onSettings,
});
final ThemeController _themeController = Get.find<ThemeController>();
static Future<void> shareApp(BuildContext context) async {
try {
const String shareText = '情景诗词App - 一款优雅的诗词学习应用,包含丰富的诗词内容和答题功能';
@@ -124,42 +128,78 @@ class PopMenu extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Container(
decoration: const BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.vertical(top: Radius.circular(20)),
),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
// 顶部拖拽条
Container(
width: 40,
height: 4,
margin: const EdgeInsets.only(top: 8),
decoration: BoxDecoration(
color: Colors.grey[300]!,
borderRadius: BorderRadius.circular(2),
return Obx(() {
final isDark = _themeController.isDarkMode;
return Container(
width: double.infinity,
decoration: BoxDecoration(
color: isDark ? const Color(0xFF2A2A2A) : Colors.white,
borderRadius: const BorderRadius.vertical(top: Radius.circular(20)),
boxShadow: [
BoxShadow(
color: Colors.black.withAlpha(isDark ? 76 : 26),
blurRadius: 10,
offset: const Offset(0, -2),
),
],
),
child: Material(
color: Colors.transparent,
child: InkWell(
onTap: () {
SystemNavigator.pop();
},
child: Container(
width: double.infinity,
padding: const EdgeInsets.symmetric(vertical: 20),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
// 顶部拖拽条
Container(
width: 40,
height: 4,
margin: const EdgeInsets.only(top: 8),
decoration: BoxDecoration(
color: isDark ? Colors.grey[600]! : Colors.grey[300]!,
borderRadius: BorderRadius.circular(2),
),
),
// 选项列表
_buildBottomSheetItem(
context,
'刷新数据',
Icons.refresh,
onRefresh,
),
_buildBottomSheetItem(context, '分享软件', Icons.share, () {
shareApp(context);
}),
_buildBottomSheetItem(context, '使用教程', Icons.menu_book, () {
Navigator.of(context).push(
MaterialPageRoute<void>(
builder: (_) => const BeginnerPage(),
),
);
}),
_buildBottomSheetItem(
context,
'取消',
Icons.settings,
onSettings,
),
const SizedBox(height: 20),
_buildBottomSheetItem(context, '返回桌面', Icons.exit_to_app, () {
SystemNavigator.pop();
}),
],
),
),
),
// 选项列表
_buildBottomSheetItem(context, '刷新数据', Icons.refresh, onRefresh),
_buildBottomSheetItem(context, '分享软件', Icons.share, () {
shareApp(context);
}),
_buildBottomSheetItem(context, '使用教程', Icons.menu_book, () {
Navigator.of(context).push(
MaterialPageRoute<void>(builder: (_) => const BeginnerPage()),
);
}),
_buildBottomSheetItem(context, '取消', Icons.settings, onSettings),
const SizedBox(height: 20),
_buildBottomSheetItem(context, '返回桌面', Icons.exit_to_app, () {
SystemNavigator.pop();
}),
],
),
);
),
);
});
}
Widget _buildBottomSheetItem(
@@ -168,9 +208,17 @@ class PopMenu extends StatelessWidget {
IconData icon,
VoidCallback? onTap,
) {
final isDark = _themeController.isDarkMode;
return ListTile(
leading: Icon(icon, color: AppConstants.primaryColor),
title: Text(title),
leading: Icon(
icon,
color: isDark ? Colors.white70 : AppConstants.primaryColor,
),
title: Text(
title,
style: TextStyle(color: isDark ? Colors.white70 : Colors.black87),
),
onTap: () {
Navigator.pop(context);
HapticFeedback.lightImpact();