led_bt_jl_ota 0.0.34
led_bt_jl_ota: ^0.0.34 copied to clipboard
杰理ota的封装
example/lib/main.dart
import 'dart:io';
import 'package:bot_toast/bot_toast.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter/services.dart';
import 'package:led_bt_jl_ota/led_bt_jl_ota.dart';
import 'package:led_bt_jl_ota_example/testled/AutoConnectTask.dart';
import 'package:led_bt_jl_ota_example/testled/ConnectUtil.dart';
import 'package:led_bt_jl_ota_example/testled/task/RGBTaskBean.dart';
import 'package:led_bt_jl_ota_example/ui/ExecPage.dart';
import 'package:led_bt_jl_ota_example/ui/SettingPage.dart';
import 'package:led_bt_jl_ota_example/ui/delay/DelayTestPage.dart';
import 'package:led_bt_jl_ota_example/utils/AppUpdateUtil.dart';
import 'package:led_bt_jl_ota_example/utils/ParseBleDataUtil.dart';
import 'package:oktoast/oktoast.dart';
import 'BleDevicePage.dart';
import 'ble/utils/ToastUtil.dart';
import 'eyesui/EyesIndexPage.dart';
import 'hatui/HatIndexPage.dart';
import 'miniui/MiniIndexPage.dart';
import 'ui/rgb/RgbTestPage.dart';
import 'ui/text/TextTestPage.dart';
import 'ble/permission/PermisionUtil.dart';
import 'ble/utils/SPUtils.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await SPUtils.init();
ParseBleDataUtil.setSupportAll();
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
@override
void initState() {
super.initState();
initPlatformState();
}
// Platform messages are asynchronous, so we initialize in an async method.
Future<void> initPlatformState() async {
// If the widget was removed from the tree while the asynchronous platform
// message was in flight, we want to discard the reply rather than calling
// setState to update our non-existent appearance.
if (!mounted) return;
if (Platform.isAndroid) {
SystemChrome.setSystemUIOverlayStyle(
const SystemUiOverlayStyle(
statusBarColor: Colors.transparent, // 设置透明状态栏
statusBarBrightness: Brightness.dark, // 设置状态栏文本颜色,基于亮度
systemNavigationBarColor: Colors.grey, // 设置底部导航栏颜色
statusBarIconBrightness: Brightness.dark, // 可选,直接设置状态栏文本颜色
),
);
} else {
SystemChrome.setSystemUIOverlayStyle(
const SystemUiOverlayStyle(
systemStatusBarContrastEnforced: true,
// Enforce contrast for status bar text and icons
statusBarColor: Colors.transparent, // Make the status bar transparent
),
);
}
}
@override
Widget build(BuildContext context) {
return OKToast(
child: MaterialApp(
builder: BotToastInit(),
navigatorObservers: [BotToastNavigatorObserver()],
debugShowCheckedModeBanner: false,
home: const HomePage(),
),
);
}
}
class HomePage extends StatelessWidget {
const HomePage({super.key});
openPage(BuildContext context, Widget widget) {
return Navigator.of(context).push(CupertinoPageRoute(builder: (BuildContext context) {
return widget;
}));
}
@override
Widget build(BuildContext context) {
AppUpdateUtil.appHasUpdate().then((value) {
if (value) {
AppUpdateUtil.showUpdateDialog(context);
}
});
return Scaffold(
body: SafeArea(
child: WillPopScope(
onWillPop: () async {
return false;
},
child: Center(
child: Column(children: [
Row(mainAxisAlignment: MainAxisAlignment.spaceAround, children: [
ElevatedButton(
onPressed: () async {
bool flag = await PermissionUtil.instance.checkPermission(context);
if (flag) {
Navigator.of(context).push(CupertinoPageRoute(builder: (BuildContext context) {
return const BleDevicePage();
}));
}
//ConnectUtil.instance.start();
},
child: Text("连接")),
GestureDetector(
onTap: () {
Navigator.of(context).push(CupertinoPageRoute(builder: (BuildContext context) {
return const SettingPage();
}));
},
child: const Icon(size: 50, Icons.settings_outlined))
]),
Expanded(
child: Column(mainAxisAlignment: MainAxisAlignment.center, children: [
ElevatedButton(
onPressed: () => openPage(context, const EyesIndexPage()), child: const Text("eyes 系列")),
const SizedBox(height: 20),
ElevatedButton(
onPressed: () => openPage(context, const MiniIndexPage()), child: const Text("mini 系列")),
const SizedBox(height: 20),
ElevatedButton(onPressed: () => openPage(context, const HatIndexPage()), child: const Text("帽子屏")),
const SizedBox(height: 20),
ElevatedButton(onPressed: () => openPage(context, const DelayTestPage()), child: const Text("延迟测试"))
]))
])))));
}
}