main.dart 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. import 'dart:io';
  2. import 'package:atmob_logging/atmob_logging.dart';
  3. import 'package:flutter/material.dart';
  4. import 'package:flutter_localizations/flutter_localizations.dart';
  5. import 'package:flutter_screenutil/flutter_screenutil.dart';
  6. import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
  7. import 'package:get/get.dart';
  8. import 'package:keyboard/plugins/keyboard_android_platform.dart';
  9. import 'package:keyboard/resource/colors.gen.dart';
  10. import 'package:keyboard/resource/string.gen.dart';
  11. import 'package:keyboard/resource/string_source.dart';
  12. import 'package:keyboard/router/app_pages.dart';
  13. import 'package:keyboard/utils/app_info_util.dart';
  14. import 'package:keyboard/utils/atmob_log.dart';
  15. import 'package:keyboard/utils/channel_util.dart';
  16. import 'package:keyboard/utils/mmkv_util.dart';
  17. import 'package:keyboard/utils/privacy_compliance.dart';
  18. import 'package:keyboard/utils/toast_util.dart';
  19. import 'data/consts/build_config.dart';
  20. import 'data/consts/constants.dart';
  21. import 'device/device_info_util.dart';
  22. import 'di/get_it.dart';
  23. void main() async {
  24. WidgetsFlutterBinding.ensureInitialized();
  25. await initRequired();
  26. //非隐私相关
  27. initCommon();
  28. //隐私相关:系统参数&第三方sdk初始化
  29. await PrivacyCompliance.ensurePolicyGranted(AppInitTask());
  30. if (Platform.isAndroid) {
  31. //键盘
  32. KeyboardAndroidPlatform.init();
  33. }
  34. runApp(const MyApp());
  35. //檢查地址
  36. checkEnv();
  37. }
  38. Future<void> initRequired() async {
  39. //存储
  40. await KVUtil.init();
  41. //getit
  42. configureDependencies();
  43. }
  44. void initCommon() {
  45. smartConfig();
  46. AtmobLog.setLogLevel(BuildConfig.isDebug ? LogLevel.verbose : LogLevel.none);
  47. //渠道(仅Android)
  48. ChannelUtil.initChannel();
  49. }
  50. void checkEnv() {
  51. if (!Constants.isProdEnv() && !BuildConfig.isDebug) {
  52. ToastUtil.show('不是正式环境!!!', addPostFrame: true);
  53. }
  54. }
  55. /// 隐私相关初始化
  56. class AppInitTask implements EnsurePolicyGrant {
  57. @override
  58. Future<void> onPolicyGrant() async {
  59. //初始化基础信息
  60. await appInfoUtil.init();
  61. await deviceInfoUtil.init();
  62. //初始化其他sdk
  63. }
  64. }
  65. void smartConfig() {
  66. SmartDialog.config.custom = SmartConfigCustom(
  67. animationType: SmartAnimationType.fade,
  68. );
  69. }
  70. class MyApp extends StatelessWidget {
  71. const MyApp({super.key});
  72. @override
  73. Widget build(BuildContext context) {
  74. return ScreenUtilInit(
  75. designSize: const Size(360, 800),
  76. builder: (_, child) {
  77. return buildApp();
  78. },
  79. );
  80. }
  81. buildApp() {
  82. return Platform.isAndroid ? _buildMaterialApp() : _buildIosApp();
  83. }
  84. _buildMaterialApp() {
  85. return GetMaterialApp(
  86. onGenerateTitle: AppCommonConfig.appName,
  87. getPages: AppCommonConfig.getPages,
  88. initialRoute: AppCommonConfig.initialRoute,
  89. initialBinding: AppCommonConfig.initialBinding,
  90. theme: ThemeData(
  91. useMaterial3: true,
  92. textSelectionTheme: const TextSelectionThemeData(
  93. cursorColor: ColorName.colorPrimary, // 设置默认光标颜色
  94. selectionHandleColor: ColorName.colorPrimary, // 设置光标下面水滴的颜色
  95. ),
  96. ),
  97. navigatorObservers: AppCommonConfig.navigatorObservers,
  98. builder: AppCommonConfig.builder,
  99. translations: AppCommonConfig.localizationsTranslations,
  100. localizationsDelegates: AppCommonConfig.localizations.delegates,
  101. locale: AppCommonConfig.localizations.locale,
  102. fallbackLocale: AppCommonConfig.localizations.fallbackLocale,
  103. );
  104. }
  105. _buildIosApp() {
  106. return GetCupertinoApp(
  107. onGenerateTitle: AppCommonConfig.appName,
  108. getPages: AppCommonConfig.getPages,
  109. initialRoute: AppCommonConfig.initialRoute,
  110. initialBinding: AppCommonConfig.initialBinding,
  111. navigatorObservers: AppCommonConfig.navigatorObservers,
  112. builder: AppCommonConfig.builder,
  113. translations: AppCommonConfig.localizationsTranslations,
  114. localizationsDelegates: AppCommonConfig.localizations.delegates,
  115. supportedLocales: AppCommonConfig.localizations.supportedLocales,
  116. locale: AppCommonConfig.localizations.locale,
  117. fallbackLocale: AppCommonConfig.localizations.fallbackLocale,
  118. );
  119. }
  120. }
  121. class AppCommonConfig {
  122. static GenerateAppTitle appName = (_) => StringName.appName;
  123. // 路由配置
  124. static List<GetPage>? getPages = AppPage.pages;
  125. static const initialRoute = RoutePath.splash;
  126. // 初始化绑定
  127. static Bindings initialBinding = AppBinding();
  128. // 导航观察者
  129. static List<NavigatorObserver> navigatorObservers = [
  130. FlutterSmartDialog.observer,
  131. ];
  132. // 弹窗初始化
  133. static final builder = FlutterSmartDialog.init();
  134. // 本地化配置
  135. static const localizations = (
  136. delegates: [
  137. GlobalMaterialLocalizations.delegate,
  138. GlobalWidgetsLocalizations.delegate,
  139. GlobalCupertinoLocalizations.delegate,
  140. ],
  141. supportedLocales: [Locale('zh', 'CN')],
  142. locale: Locale('zh', 'CN'),
  143. fallbackLocale: Locale('zh', 'CN'),
  144. );
  145. // 多语言配置
  146. static Translations localizationsTranslations = StringResource();
  147. }