main.dart 2.7 KB

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