main.dart 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. import 'package:clean/data/consts/constants.dart';
  2. import 'package:clean/resource/colors.gen.dart';
  3. import 'package:clean/resource/string.gen.dart';
  4. import 'package:clean/resource/string_source.dart';
  5. import 'package:clean/router/app_pages.dart';
  6. import 'package:clean/utils/app_info_util.dart';
  7. import 'package:clean/utils/mmkv_util.dart';
  8. import 'package:flutter/material.dart';
  9. import 'package:flutter_localizations/flutter_localizations.dart';
  10. import 'package:flutter_screenutil/flutter_screenutil.dart';
  11. import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
  12. import 'package:get/get_navigation/src/root/get_material_app.dart';
  13. import 'package:pull_to_refresh/pull_to_refresh.dart';
  14. import 'device/device_info_util.dart';
  15. Future<void> main() async {
  16. await KVUtil.init();
  17. //初始化
  18. await initAfterGrant();
  19. runApp(const MyApp());
  20. }
  21. Future<void> initAfterGrant() async {
  22. if (!isAgreePrivacyPolicy()) {
  23. return;
  24. }
  25. //获取包信息
  26. await appInfoUtil.init();
  27. //获取设备信息
  28. await deviceInfoUtil.init();
  29. }
  30. class MyApp extends StatelessWidget {
  31. const MyApp({super.key});
  32. @override
  33. Widget build(BuildContext context) {
  34. return ScreenUtilInit(
  35. designSize: const Size(360, 800),
  36. builder: (_, child) {
  37. return _buildMaterialApp();
  38. },
  39. );
  40. }
  41. _buildMaterialApp() {
  42. return RefreshConfiguration(
  43. headerBuilder: () =>
  44. const MaterialClassicHeader(color: ColorName.colorPrimary),
  45. // footerBuilder: () => ClassicFooter(
  46. // canLoadingText: StringName.loadingMore,
  47. // idleText: StringName.loadPullUp,
  48. // loadingText: StringName.loadingTxt,
  49. // noDataText: StringName.loadNoData,
  50. // failedText: StringName.loadFailed,
  51. // ),
  52. child: GetMaterialApp(
  53. onGenerateTitle: (_) => StringName.appName,
  54. getPages: AppPage.pages,
  55. initialRoute: RoutePath.splash,
  56. initialBinding: AppBinding(),
  57. theme: ThemeData(
  58. useMaterial3: true,
  59. textSelectionTheme: const TextSelectionThemeData(
  60. cursorColor: ColorName.colorPrimary, // 设置默认光标颜色
  61. selectionHandleColor: ColorName.colorPrimary, // 设置光标下面水滴的颜色
  62. ),
  63. ),
  64. navigatorObservers: [FlutterSmartDialog.observer],
  65. builder: FlutterSmartDialog.init(),
  66. translations: StringResource(),
  67. localizationsDelegates: const [
  68. GlobalMaterialLocalizations.delegate,
  69. //是Flutter的一个本地化委托,用于提供Material组件库的本地化支持
  70. GlobalWidgetsLocalizations.delegate,
  71. //用于提供通用部件(Widgets)的本地化支持
  72. GlobalCupertinoLocalizations.delegate,
  73. //用于提供Cupertino风格的组件的本地化支持
  74. ],
  75. supportedLocales: const [
  76. Locale('zh', 'CN'), // 支持的语言和地区
  77. ],
  78. // 你的翻译
  79. locale: const Locale('zh', 'CN'),
  80. // 将会按照此处指定的语言翻译 添加一个回调语言选项,以备上面指定的语言翻译不存在
  81. fallbackLocale: const Locale('zh', 'CN'),
  82. ),
  83. );
  84. }
  85. }