Flutter智能手表连接插件releep_watch_connect的使用

Flutter智能手表连接插件releep_watch_connect的使用

releep_watch_connect

这是一个用于连接releep手表的新Flutter插件。

插件版本

获取开始

本项目是一个用于Flutter的插件包起点,它包含针对Android和/或iOS平台的特定实现代码。

要开始使用Flutter,请查看我们的在线文档,其中提供了教程、示例、移动开发指导以及完整的API参考。

示例代码

以下是一个完整的示例代码,演示如何使用releep_watch_connect插件来连接和同步数据到智能手表。

import 'dart:convert';
import 'dart:io';

import 'package:flutter/material.dart';
import 'dart:async';

import 'package:flutter/services.dart';
import 'package:releep_watch_connect/releep_watch_connect.dart';
import 'package:releep_watch_connect/util_releep_watch.dart';

void main() {
  runApp(
    MaterialApp(
      home: MyApp(),
      routes: <String, WidgetBuilder>{
        '/Fitness': (BuildContext context) => new FitnessPage(),
      },
    ),
  );
}

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  [@override](/user/override)
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  String _platformVersion = 'Unknown';
  late StreamSubscription _ReleepWatchScanSubscription;
  var _listWatch = [];
  final TextEditingController _resReleepWatch = TextEditingController();

  [@override](/user/override)
  void initState() {
    super.initState();
    initPlatformState();
    _resReleepWatch.text = "no response";
  }

  // 平台消息是异步的,因此我们在异步方法中初始化。
  Future<void> initPlatformState() async {
    String platformVersion;
    // 平台消息可能失败,所以我们使用一个带有try/catch的PlatformException。
    // 我们还处理了消息可能返回null的情况。
    try {
      platformVersion = await ReleepWatchConnect.platformVersion ?? 'Unknown platform version';
    } on PlatformException {
      platformVersion = 'Failed to get platform version.';
    }

    // 如果在异步平台消息飞行时小部件从树中被移除,我们希望丢弃回复而不是调用setState来更新我们的非存在的外观。
    if (!mounted) return;

    setState(() {
      _platformVersion = platformVersion;
    });
  }

  Future<Null> _connectReleepWatch(watchMac, uuidStr) async {
    int code = await ReleepWatchConnect.connectWatch(watchMac, uuidString: uuidStr);
    _cancelWatchScan();
    debugPrint("connect Res ${code}");
    setState(() {
      _resReleepWatch.text = code.toString();
    });
  }

  Future<Null> _disconnectReleepWatch() async {
    int code = await ReleepWatchConnect.disconectReleepWatch();
    debugPrint("disconnect Res ${code}");
    setState(() {
      _resReleepWatch.text = code.toString();
    });
  }

  Future<Null> _syncDataReleepWatch() async {
    var res = await ReleepWatchConnect.syncHealthAll();
    debugPrint("syncHealthAll --> HealthAll ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthStep() async {
    var res = await ReleepWatchConnect.syncHealthStep();
    debugPrint("_syncHealthStep --> Step ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  // 运动
  Future<Null> _syncSportRun() async {
    var res = await ReleepWatchConnect.syncRUN();
    debugPrint("_syncHealthStep --> Run ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncSportFitness() async {
    var res = await ReleepWatchConnect.syncFitness();
    debugPrint("_syncHealthStep --> Fitness ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthHR() async {
    var res = await ReleepWatchConnect.syncHealthHeartRate();
    debugPrint("_syncHealthHR --> HR ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthTemp() async {
    var res = await ReleepWatchConnect.syncHealthTemp();
    debugPrint("_syncHealthTemp --> Temp ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthSPO2() async {
    var res = await ReleepWatchConnect.syncHealthSPO2();
    debugPrint("_syncHealthSPO2 --> SPO2 ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthBloodPresure() async {
    var res = await ReleepWatchConnect.syncHealthBlood();
    debugPrint("_syncHealthBloodPresure --> BloodPresure ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthSport() async {
    var res = await ReleepWatchConnect.syncHealthSport();
    debugPrint("_syncHealthSport --> Sport ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthSleep() async {
    var res = await ReleepWatchConnect.syncHealthSleep();
    debugPrint("_syncHealthSleep --> Sleep ${res.toString()}");
    setState(() {
      _resReleepWatch.text = res.toString();
    });
  }

  Future<Null> _syncHealthECG() async {
    var res = await ReleepWatchConnect.syncHealthSleep();
    debugPrint("_syncHealthECG --> ECG ${res.toString()}");
    setState(() {
      setState(() {
        _resReleepWatch.text = res.toString();
      });
    });
  }

  Future<Null> _deleteHealthAll() async {
    var res = await ReleepWatchConnect.deleteHealthAll();
    debugPrint("deleteHealthAll --> HR ${res.toString()}");
    setState(() {
      setState(() {
        _resReleepWatch.text = res.toString();
      });
    });
  }

  Future<Null> _disableNotification() async {
    var res = await ReleepWatchConnect.disbleWatchNotification();
    debugPrint("disbleWatchNotification -->  ${res.toString()}");
    setState(() {
      setState(() {
        _resReleepWatch.text = res.toString();
      });
    });
  }

  Future<Null> _settingLangReleepWatch(lang) async {
    int code = await ReleepWatchConnect.settingLanguage(lang);
    debugPrint("_settingLangReleepWatch Res ${code}");
    setState(() {
      _resReleepWatch.text = "_settingLangReleepWatch :" + code.toString();
    });
  }

  Future<Null> _settingBloodOxygenAlarm(value) async {
    int code = await ReleepWatchConnect.settingBloodOxygenAlarm(value);
    debugPrint("_settingBloodOxygenAlarm Res ${code}");
    setState(() {
      _resReleepWatch.text = "_settingBloodOxygenAlarm :" + code.toString();
    });
  }

  Future<Null> _settingTemperatureAlarm(value, minValue) async {
    int code = await ReleepWatchConnect.settingTemperatureAlarm(value, minValue);
    debugPrint("settingTemperatureAlarm Res ${code}");
    setState(() {
      _resReleepWatch.text = "settingTemperatureAlarm :" + code.toString();
    });
  }

  Future<Null> _settingHeartAlarm(highValue, lowValue) async {
    int code = await ReleepWatchConnect.settingHeartAlarm(highValue, lowValue);
    debugPrint("settingHeartAlarm Res ${code}");
    setState(() {
      _resReleepWatch.text = "settingHeartAlarm :" + code.toString();
    });
  }

  Future<Null> _settingWorkingMode(mode) async {
    int code = await ReleepWatchConnect.settingWorkingMode(mode);
    debugPrint("_settingWorkingMode Res ${code}");
    setState(() {
      _resReleepWatch.text = "_settingWorkingMode :" + code.toString();
    });
  }

  Future<Null> _settingHeartMonitor(mode) async {
    int code = await ReleepWatchConnect.settingHeartMonitor(mode);
    debugPrint("_settingHeartMonitor Res ${code}");
    setState(() {
      _resReleepWatch.text = "_settingHeartMonitor :" + code.toString();
    });
  }

  Future<Null> _settingTemperatureMonitor(mode) async {
    int code = await ReleepWatchConnect.settingTemperatureMonitor(mode);
    debugPrint("_settingTemperatureMonitor Res ${code}");
    setState(() {
      _resReleepWatch.text = "_settingTemperatureMonitor :" + code.toString();
    });
  }

  Future<Null> _settingBloodOxygenModeMonitor(mode) async {
    int code = await ReleepWatchConnect.settingBloodOxygenModeMonitor(mode);
    debugPrint("_settingBloodOxygenModeMonitor Res ${code}");
    setState(() {
      _resReleepWatch.text = "_settingBloodOxygenModeMonitor :" + code.toString();
    });
  }

  //_getConnectState
  Future<Null> _getConnectState() async {
    int code = await ReleepWatchConnect.getConnectionState();
    debugPrint("getConnectionState Res ${code}");
    setState(() {
      _resReleepWatch.text = "getConnectionState :" + UtilReleepWatch.getStatusName(code);
    });
  }

  void _startWatchScan() {
    setState(() {
      _listWatch = [];
    });
    debugPrint("_startWatchScan");
    _ReleepWatchScanSubscription =
        ReleepWatchConnect.scanReleepWatch.listen((event) => {
              setState(() {
                var json = jsonDecode(event);
                _listWatch = json;
              })
            });
  }

  void _cancelWatchScan() {
    _ReleepWatchScanSubscription.cancel();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
          appBar: AppBar(
            title: const Text('Releep Watch Connect'),
          ),
          body: SingleChildScrollView(
            physics: const ScrollPhysics(),
            child: Column(
              children: [
                Wrap(
                  spacing: 10.0,
                  children: <Widget>[
                    ElevatedButton(
                        onPressed: _syncDataReleepWatch,
                        child: const Text("Sync Data")),
                    ElevatedButton(
                        onPressed: _syncHealthHR,
                        child: const Text("Sync HR")),
                    ElevatedButton(
                        onPressed: _syncHealthBloodPresure,
                        child: const Text("Sync BP")),
                    ElevatedButton(
                        onPressed: _syncHealthSPO2,
                        child: const Text("Sync SPO2")),
                    ElevatedButton(
                        onPressed: _syncHealthSport,
                        child: const Text("Sync Sport")),
                    ElevatedButton(
                        onPressed: _syncHealthSleep,
                        child: const Text("Sync Sleep")),
                    ElevatedButton(
                        onPressed: _syncHealthECG,
                        child: const Text("Sync ECG")),
                    ElevatedButton(
                        onPressed: _syncHealthTemp,
                        child: const Text("Sync Temp")),
                    ElevatedButton(
                        onPressed: _syncHealthStep,
                        child: const Text("Sync Step")),
                    ElevatedButton(
                        onPressed: _deleteHealthAll,
                        child: const Text("Delete Health All")),
                    ElevatedButton(
                        onPressed: () => _settingLangReleepWatch(0x00),
                        child: const Text("Setting Lang EN")),
                    ElevatedButton(
                        onPressed: () => _settingLangReleepWatch(0x01),
                        child: const Text("Setting Lang CN")),
                    ElevatedButton(
                        onPressed: () => _settingLangReleepWatch(0x0D),
                        child: const Text("Setting Lang TH")),
                    ElevatedButton(
                        onPressed: () => _settingTemperatureAlarm(38, 20),
                        child: const Text("Setting Temp 38")),
                    ElevatedButton(
                        onPressed: () => _settingBloodOxygenAlarm(95),
                        child: const Text("Setting Spo2 95")),
                    ElevatedButton(
                        onPressed: () => _settingHeartAlarm(100, 45),
                        child: const Text("Setting HR 100,45")),
                    ElevatedButton(
                        onPressed: () => _settingWorkingMode(0x00),
                        child: const Text("Setting Mode normal")),
                    ElevatedButton(
                        onPressed: () => _settingWorkingMode(0x01),
                        child: const Text("Setting Mode care")),
                    ElevatedButton(
                        onPressed: () => _settingWorkingMode(0x02),
                        child: const Text("Setting Mode Save Power")),
                    ElevatedButton(
                        onPressed: () => _settingHeartMonitor(5),
                        child: const Text("Setting Heart Monitor 5m")),
                    ElevatedButton(
                        onPressed: () => _disableNotification(),
                        child: const Text("Disable Push Notification")),
                    ElevatedButton(
                        onPressed: () => _getConnectState(),
                        child: const Text("Connect State")),
                    ElevatedButton(
                        onPressed: () => _connectReleepWatch(
                            "C0:AB:61:18:5B:22",
                            "CCEE2AF2-36D8-8DE2-8F2F-34F11801250B"),
                        child: const Text("Connect E66")),
                    ElevatedButton(
                        onPressed: () => _disconnectReleepWatch(),
                        child: const Text("Disconnect")),
                    ElevatedButton(
                        onPressed: () => ReleepWatchConnect.startForegroundTask(),
                        child: const Text("startTask")),
                    ElevatedButton(
                        onPressed: () => ReleepWatchConnect.stopForegroundTask(),
                        child: const Text("stopTask")),
                    ElevatedButton(
                        onPressed: () => ReleepWatchConnect.syncFitness(),
                        child: const Text("syncFitness")),
                    ElevatedButton(
                        onPressed: () => ReleepWatchConnect.syncRUN(),
                        child: const Text("syncRUN")),
                    ElevatedButton(
                        onPressed: () => ReleepWatchConnect.syncRunIndoors(),
                        child: const Text("syncRunIndoors")),
                    ElevatedButton(
                        onPressed: () => ReleepWatchConnect.syncRunOutSide(),
                        child: const Text("syncRunOutSide")),
                    ElevatedButton(
                        onPressed: () => Navigator.of(context).pushNamed('/Fitness'),
                        child: const Text("ไปยังหน้าออกกำลังกาย")),
                  ],
                ),
                Wrap(
                  children: [
                    Text("res :"),
                  ],
                ),
                TextField(
                  maxLines: null,
                  keyboardType: TextInputType.multiline,
                  controller: _resReleepWatch,
                ),
                ListView.builder(
                  shrinkWrap: true,
                  itemCount: _listWatch.length,
                  itemBuilder: (context, index) {
                    return ListTile(
                      title: Text('${_listWatch[index]['DeviceName']}' +
                          ' | ' +
                          '${_listWatch[index]['MacAddress']}' +
                          ' ' +
                          '${_listWatch[index]['UUIDString'] ?? ""}'),
                      onTap: () => {
                        _connectReleepWatch(
                            '${_listWatch[index]['MacAddress']}',
                            '${_listWatch[index]['UUIDString'] ?? ""}'),
                      },
                    );
                  },
                ),
              ],
            ),
          ),
          floatingActionButton: FloatingActionButton(
            backgroundColor: Colors.green,
            onPressed: _startWatchScan,
            child: const Icon(Icons.search),
          )),
    );
  }
}

class FitnessPage extends StatefulWidget {
  FitnessPage({Key? key}) : super(key: key);

  [@override](/user/override)
  State<FitnessPage> createState() => _FitnessPageState();
}

class _FitnessPageState extends State<FitnessPage> {
  bool isStart = false;
  String text = "";

  late StreamSubscription _ReleepWatchSportubscription;
  late StreamSubscription _ReleepWatchTodeviceSportubscription;

  [@override](/user/override)
  void initState() {
    // TODO: implement initState
    super.initState();

    // callBackDevice();
  }

  callBackDevice() {
    _ReleepWatchTodeviceSportubscription =
        ReleepWatchConnect.deviceToAppSport.listen((event) {
          if (event == 0) {
            // _cancelWatchSport();
            setState(() {
              text = "";
            });
          }
        });
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text("ออกกำลังกาย"),
        ),
        body: Text(text),
        floatingActionButton: SizedBox(
          width: 90,
          height: 90,
          child: FloatingActionButton(
            backgroundColor: Colors.green,
            onPressed: () async {
              if (!isStart) {
                setState(() {
                  isStart = true;
                  text = "";
                });
                var res = ReleepWatchConnect.startSport(
                    typeSport:
                        Platform.isIOS ? YCDeviceSportType.run : SportType.RUN);
                _ReleepWatchSportubscription =
                    ReleepWatchConnect.sportStartResponse.listen((event) => {
                          setState(() {
                            text = event.toString();
                            print(text);
                          })
                        });

                // if (res != null) {
                //   text = res.toString();
                //   setState(() {
                //     isStart = false;
                //   });
                // }
              } else {
                _cancelWatchSport();
                setState(() {
                  isStart = false;
                });
                ReleepWatchConnect.stopSport(
                    typeSport:
                        Platform.isIOS ? YCDeviceSportType.run : SportType.RUN);
              }
            },
            child: Icon(isStart ? Icons.stop : Icons.play_arrow, size: 60),
          ),
        ));
  }

  void _cancelWatchSport() {
    _ReleepWatchSportubscription.cancel();
    // _ReleepWatchTodeviceSportubscription.cancel();
  }
}

class SportType {
  static const int RESERVED = 0;
  static const int RUN = 1;
  static const int SWIMMING = 2;
  static const int RIDE = 3;
  static const int FITNESS = 4;
  static const int SCRAP = 5;
  static const int SKIPPING_ROPE = 6;
  static const int BASKETBALL = 7;
  static const int WALKING = 8;
  static const int BADMINTON = 9;
  static const int FOOTBALL = 10;
  static const int MOUNTAINEERING = 11;
  static const int PING_PONG = 12;
  static const int FREE_MODE = 13;
  static const int RUN_INDOORS = 14;
  static const int RUN_OUTSIDE = 15;
  static const int WALK_OUTDOOR = 16;
  static const int WALK_INDOOR = 17;
  static const int WALK_AND_RUN = 18;
  static const int INDOOR_CYCLING = 19;
  static const int STEPPER = 20;
  static const int ROWING_MACHINE = 21;
  static const int REAL_TIME_MODE = 22;
  static const int SIT_UPS = 23;
  static const int LEAPING_MOTION = 24;
  static const int WEIGHT_TRAINING = 25;
  static const int YOGA = 26;
  static const int ONFOOT = 27;
  static const int VOLLEYBALL = 28;
  static const int KAYAK = 29;
  static const int ROLLER_SKATING = 30;
  static const int TENNIS = 31;
  static const int GOLF = 32;
  static const int ELLIPTICAL_MACHINE = 33;
  static const int DANCE = 34;
  static const int ROCK_CLIMBING = 35;
  static const int AEROBICS = 36;
  static const int OTHERSPORTS = 37;
}

class YCDeviceSportType {
  static const int none = 0x00;
  static const int run = 0x01;
  static const int swimming = 0x02;
  static const int riding = 0x03;
  static const int fitness = 0x04;
  static const int ropeskipping = 0x06;
  static const int playball = 0x07;
  static const int walk = 0x08;
  static const int badminton = 0x09;
  static const int football = 0x0A;
  static const int mountaineering = 0x0B;
  static const int pingPang = 0x0C;
  static const int freeMode = 0x0D;
  static const int indoorRunning = 0x0E;
  static const int outdoorRunning = 0x0F;
  static const int outdoorWalking = 0x10;
  static const int indoorWalking = 0x11;
  static const int runMode = 0x12;
  static const int indoorRiding = 0x13;
  static const int stepper = 0x14;
  static const int rowingMachine = 0x15;
  static const int realTimeMonitoring = 0x16;
  static const int situps = 0x17;
  static const int jumping = 0x18;
  static const int weightTraining = 0x19;
  static const int yoga = 0x1A;
  static const int onfoot = 0x1B;
  static const int volleyball = 0x1C;
  static const int kayak = 0x1D;
  static const int rollerSkating = 0x1E;
  static const int tennis = 0x1F;
  static const int golf = 0x20;
  static const int ellipticalMachine = 0x21;
  static const int dance = 0x22;
  static const int rockClimbing = 0x23;
  static const int aerobics = 0x24;
  static const int otherSports = 0x25;
}

更多关于Flutter智能手表连接插件releep_watch_connect的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter智能手表连接插件releep_watch_connect的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


releep_watch_connect 是一个用于连接智能手表的 Flutter 插件。它允许 Flutter 应用程序与特定的智能手表设备进行通信,通常用于健康数据同步、通知推送等功能。以下是使用 releep_watch_connect 插件的基本步骤:

1. 添加依赖

首先,在 pubspec.yaml 文件中添加 releep_watch_connect 插件的依赖:

dependencies:
  flutter:
    sdk: flutter
  releep_watch_connect: ^1.0.0  # 请使用最新版本

然后运行 flutter pub get 来获取依赖。

2. 导入插件

在你的 Dart 文件中导入插件:

import 'package:releep_watch_connect/releep_watch_connect.dart';

3. 初始化插件

在使用插件之前,需要初始化它。通常可以在 initState 方法中进行初始化:

class MyApp extends StatefulWidget {
  [@override](/user/override)
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  ReleepWatchConnect _watchConnect;

  [@override](/user/override)
  void initState() {
    super.initState();
    _watchConnect = ReleepWatchConnect();
    _watchConnect.initialize();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('Releep Watch Connect'),
        ),
        body: Center(
          child: Text('Hello, World!'),
        ),
      ),
    );
  }
}

4. 连接设备

使用 connect 方法来尝试连接智能手表设备:

void _connectToWatch() async {
  bool isConnected = await _watchConnect.connect();
  if (isConnected) {
    print('Connected to watch');
  } else {
    print('Failed to connect to watch');
  }
}

5. 发送和接收数据

你可以使用 sendMessage 方法向手表发送数据,并通过监听 onMessageReceived 来接收来自手表的消息。

void _sendMessageToWatch() async {
  await _watchConnect.sendMessage({'command': 'start_workout'});
}

void _listenToWatchMessages() {
  _watchConnect.onMessageReceived.listen((message) {
    print('Received message from watch: $message');
  });
}

6. 断开连接

当不再需要连接时,可以使用 disconnect 方法断开连接:

void _disconnectFromWatch() async {
  await _watchConnect.disconnect();
}

7. 处理错误

在处理连接和数据传输时,可能会遇到错误。你可以通过监听 onError 来处理这些错误:

void _listenToErrors() {
  _watchConnect.onError.listen((error) {
    print('Error occurred: $error');
  });
}

8. 示例代码

以下是一个完整的示例代码,展示了如何使用 releep_watch_connect 插件:

import 'package:flutter/material.dart';
import 'package:releep_watch_connect/releep_watch_connect.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatefulWidget {
  [@override](/user/override)
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  ReleepWatchConnect _watchConnect;

  [@override](/user/override)
  void initState() {
    super.initState();
    _watchConnect = ReleepWatchConnect();
    _watchConnect.initialize();
    _listenToWatchMessages();
    _listenToErrors();
  }

  void _connectToWatch() async {
    bool isConnected = await _watchConnect.connect();
    if (isConnected) {
      print('Connected to watch');
    } else {
      print('Failed to connect to watch');
    }
  }

  void _sendMessageToWatch() async {
    await _watchConnect.sendMessage({'command': 'start_workout'});
  }

  void _listenToWatchMessages() {
    _watchConnect.onMessageReceived.listen((message) {
      print('Received message from watch: $message');
    });
  }

  void _listenToErrors() {
    _watchConnect.onError.listen((error) {
      print('Error occurred: $error');
    });
  }

  void _disconnectFromWatch() async {
    await _watchConnect.disconnect();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('Releep Watch Connect'),
        ),
        body: Center(
          child: Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: [
              ElevatedButton(
                onPressed: _connectToWatch,
                child: Text('Connect to Watch'),
              ),
              ElevatedButton(
                onPressed: _sendMessageToWatch,
                child: Text('Send Message to Watch'),
              ),
              ElevatedButton(
                onPressed: _disconnectFromWatch,
                child: Text('Disconnect from Watch'),
              ),
            ],
          ),
        ),
      ),
    );
  }
}
回到顶部