main.dart 2.8 KB

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