根据 Flutter 中 Provider 值的变化在屏幕之间导航
Navigating between screens based on the Provider value change in Flutter
我有一个带有 BLE 通信的 flutter 应用程序。我已经将 BLE 相关的变量和函数放在 Provider class 中。我的屏幕结构如下:
Home -> ModeSelect -> NormalMode -> NormalDataShow
|
-> CustomMode -> CustomModeShow
我们控制的设备也有按钮。因此,无论何时用户按下按钮,BLE 数据都应该被丢弃,应用程序应该转到 ModeSelect 屏幕。
因此,如果我们处于 NormalDataShow 或 CustomMode 屏幕,例如,用户按下按钮,这些屏幕应该关闭,应用程序必须自动返回到 ModeSelect。
用户每次按下按钮时,设备都会发送一个数据包。我目前收到这个数据包并且可以在 Provider class.
中处理它的值变化
我的问题是:发生此类事件后如何在屏幕之间导航?
我试过了,但一切都搞砸了,_Failed assertion: line 1995 pos 12: '!debugLocked' 发生错误:
@override
Widget build(BuildContext context) {
final _bleProvider = Provider.of<BLEProvider>(context, listen: true);
if (_bleProvider.modeChanged == true) {
_bleProvider.modeChanged = false;
_bleProvider.resetScore();
Navigator.of(context).popAndPushNamed('mode');
return Container();
} else
return ... // The page main scaffold
我会采用类似于 Flutter 团队 BottomNavigationBar example 的方法。
基本上,有一个 Scaffold
可以根据您的提供商的价值更改其属性(主要是 body
)。
例如:
enum Page { a, b ,c }
/// This is the private State class that goes with MyStatefulWidget.
class BleApp extends StatelessWidget {
final Map<Page, Widget> _widgets = {
Page.a: Text('a'),
Page.b: Text('b'),
Page.c: Text('c'),
};
@override
Widget build(BuildContext context) {
final _bleProvider = Provider.of<BLEProvider>(context, listen: true);
// Determine what page to show
final page = Page.a;
return Scaffold(
appBar: AppBar(
title: const Text('BLE App'),
),
body: _widgets[page],
);
}
}
这是一个简化的示例,但应该可以帮助您入门。
我有一个带有 BLE 通信的 flutter 应用程序。我已经将 BLE 相关的变量和函数放在 Provider class 中。我的屏幕结构如下:
Home -> ModeSelect -> NormalMode -> NormalDataShow
|
-> CustomMode -> CustomModeShow
我们控制的设备也有按钮。因此,无论何时用户按下按钮,BLE 数据都应该被丢弃,应用程序应该转到 ModeSelect 屏幕。
因此,如果我们处于 NormalDataShow 或 CustomMode 屏幕,例如,用户按下按钮,这些屏幕应该关闭,应用程序必须自动返回到 ModeSelect。
用户每次按下按钮时,设备都会发送一个数据包。我目前收到这个数据包并且可以在 Provider class.
中处理它的值变化我的问题是:发生此类事件后如何在屏幕之间导航?
我试过了,但一切都搞砸了,_Failed assertion: line 1995 pos 12: '!debugLocked' 发生错误:
@override
Widget build(BuildContext context) {
final _bleProvider = Provider.of<BLEProvider>(context, listen: true);
if (_bleProvider.modeChanged == true) {
_bleProvider.modeChanged = false;
_bleProvider.resetScore();
Navigator.of(context).popAndPushNamed('mode');
return Container();
} else
return ... // The page main scaffold
我会采用类似于 Flutter 团队 BottomNavigationBar example 的方法。
基本上,有一个 Scaffold
可以根据您的提供商的价值更改其属性(主要是 body
)。
例如:
enum Page { a, b ,c }
/// This is the private State class that goes with MyStatefulWidget.
class BleApp extends StatelessWidget {
final Map<Page, Widget> _widgets = {
Page.a: Text('a'),
Page.b: Text('b'),
Page.c: Text('c'),
};
@override
Widget build(BuildContext context) {
final _bleProvider = Provider.of<BLEProvider>(context, listen: true);
// Determine what page to show
final page = Page.a;
return Scaffold(
appBar: AppBar(
title: const Text('BLE App'),
),
body: _widgets[page],
);
}
}
这是一个简化的示例,但应该可以帮助您入门。