- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个连接了 HC-06 蓝牙模块的微 Controller 。我想构建一个 flutter 应用程序,它可以与微 Controller 通信以通过蓝牙发送整数值,然后也从微 Controller 接收整数值。另一端的代码是用C编程写的。在我这边,我开始用 flutter 构建应用程序。我正在使用 flutter_bluetooth_serial 包。对于蓝牙连接,我使用了官方包github上示例中的一些代码。 https://github.com/edufolly/flutter_bluetooth_serial . (我将名为:BluetoothDeviceListEntry 的文件复制到我的项目中)。
接下来,我创建了应用程序的主页和蓝牙连接编码。这是我的 main.dart 文件:
void main(){
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: HomePage() ,
debugShowCheckedModeBanner: false,
);
}
}
class HomePage extends StatefulWidget{
@override
State<HomePage> createState() => _HomePageState();
}
class _HomePageState extends State<HomePage> with WidgetsBindingObserver {
BluetoothState _bluetoothState = BluetoothState.UNKNOWN;
List<BluetoothDevice> devices = <BluetoothDevice>[];
@override
void initState() {
super.initState();
_getBTState();
_stateChangeListener();
_listBondedDevices();
_stateChangeListener();
}
@override
void dispose(){
WidgetsBinding.instance!.removeObserver(this);
super.dispose();
@override
void disChangeAppLifeCycleState(AppLifecycleState state){
if(state.index == 0){
//resume
if(_bluetoothState.isEnabled){
_listBondedDevices();
}
}
}
}
_getBTState(){
FlutterBluetoothSerial.instance.state.then((state){
_bluetoothState = state;
if(_bluetoothState.isEnabled){
_listBondedDevices();
}
setState(() {});
});
}
_stateChangeListener(){
FlutterBluetoothSerial.instance.onStateChanged().listen((BluetoothState state) {
_bluetoothState = state;
if(_bluetoothState.isEnabled){
_listBondedDevices();
}else{
devices.clear();
}
print("State isEnabled: ${state.isEnabled}");
setState(() {});
});
}
_listBondedDevices(){
FlutterBluetoothSerial.instance.getBondedDevices().then((List<BluetoothDevice> bondedDevices){
devices = bondedDevices;
setState(() {});
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text("Bluetooth Scanner"),),
body: Container(
child: Column(children: <Widget>[
SwitchListTile(
title: Text('Enable Bluetooth'),
value: _bluetoothState.isEnabled,
onChanged: (bool value){
future() async{
if(value){
await FlutterBluetoothSerial.instance.requestEnable();
}else{
await FlutterBluetoothSerial.instance.requestDisable();
}
future().then((_){
setState(() {});
});
}
},
),
ListTile(
title: Text("Bluetooth Status"),
subtitle: Text(_bluetoothState.toString()),
trailing: RaisedButton(child: Text("Settings"), onPressed: (){
FlutterBluetoothSerial.instance.openSettings();
},
),
),
// adaptor code
Expanded(
child: ListView(
children: devices
.map((_device)=> BluetoothDeviceListEntry(
device: _device,
enabled: true,
onTap: (){
print("item");
_startDataCollection(context, _device);
},
))
.toList(),
),
),
// discovery code
],
),
),
);
}
void _startDataCollection(BuildContext context, BluetoothDevice server){
Navigator.of(context).push(MaterialPageRoute(builder: (context){
return DetailPage(server: server);
}));
}
}
当我按下配对设备时,函数 _startDataCollection 被触发,我转到另一个文件 (detailpage.dart),这就是我开始痛苦的地方......
这里是详细页面的编码:
class DetailPage extends StatefulWidget {
final BluetoothDevice server;
DetailPage({required this.server});
@override
State<DetailPage> createState() => _DetailPageState();
}
class _DetailPageState extends State<DetailPage> {
late BluetoothConnection connection;
bool isConnecting = true;
bool get isConnected => connection.isConnected;
bool isDisconnecting = false;
int _selectedvalue =0;
int chunks = 0;
int rcvdData = 0;
int contentLength =0;
late Uint8List _bytes;
@override
void initState() {
super.initState();
_getBTConnection();
}
@override
void dispose() {
if(isConnected){
isDisconnecting = true;
connection.dispose();
}
super.dispose();
}
_getBTConnection(){
BluetoothConnection.toAddress(widget.server.address).then((_connection){
connection = _connection;
isConnecting = false;
isDisconnecting = false;
setState(() {});
connection.input?.listen(_onDataReceived).onDone(() {
if(isDisconnecting){
print("Disconnecting locally");
}else{
print("Disconnecting remotely");
}
if(mounted){
setState(() {});
}
Navigator.of(context).pop();
});
}).catchError((error){
Navigator.of(context).pop();
});
}
_onDataReceived(int data){
if(data != null && data.bitLength > 0){
chunks.add(data);
}
}
Future<void> _sendMessageString() async {
connection.output.add(ascii.encode('Hello!'));
await connection.output.allSent;
print('ok send message');
}
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Colors.grey,
appBar: AppBar(title: (isConnecting ? Text('Connecting to ${widget.server.name} ...')
: isConnected ? Text ('Connected with ${widget.server.name}') : Text(
'Disconnected with ${widget.server.name}')),),
body: SafeArea(child: isConnected
? Column(
children: <Widget>[
submitButton()
],
)
: const Center(
child: Text(
"Connecting ...",
style: TextStyle(
fontSize: 24,
fontWeight: FontWeight.bold,
color: Colors.white),
),
),
));
}
Widget submitButton(){
return Container(
padding: const EdgeInsets.all(16),
child: ElevatedButton(
onPressed: () {
print (chunks);
},
child: const Padding(
padding: EdgeInsets.all(8),
child: Text("show value", style: TextStyle(fontSize: 24),
),
),
),
);
}
}
我想做的是,当我按下按钮(显示值)时,我想在编译器中打印接收到的数据,但出现 2 个错误。第一个是关于 _getBTConnection 函数:
"connection.input?.listen(_onDataReceived).onDone(()"
The argument type 'dynamic Function(int)' can't be assigned to the parameter type 'void Function(Uint8List)?'.
另一个是关于 (_onDataReceived) 函数:
The method 'add' isn't defined for the type 'int'.
我也尝试制作一些函数来发送整数,但似乎没有一个也能正常工作。如果有人可以帮我解决这个问题,因为我是 flutter 的新手
非常感谢
最佳答案
查看您提供的链接中的示例。传入数据的类型是 Uint8List
而不是 int
。
try {
BluetoothConnection connection = await BluetoothConnection.toAddress(address);
print('Connected to the device');
connection.input.listen((Uint8List data) {
print('Data incoming: ${ascii.decode(data)}');
...
}).onDone(() {
print('Disconnected by remote request');
});
}
catch (exception) {
print('Cannot connect, exception occured');
}
使用ByteData从 data
中读取值。
final byteData = ByteData.sublistView(data);
final value = byteData.getFloat32(0);
关于Flutter蓝牙串口通信,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72388235/
是否可以识别我周围启用了蓝牙的设备?我不需要与他们交流,只知道他们就在那里。 我正在寻找类似于 android 的 BluetouthDevice.startDiscovery() 的东西 这样的事情
蓝牙的 HTTP 代理服务是否允许我将 BLE 设备视为 HTTP 服务器,例如以便与设备对话的应用可以向其发送 GET/POST/PUT 请求? 或者这个操作是相反的方向,BLE 设备通过应用程序向
我正在与BlueZ库一起在Linux下管理蓝牙堆栈。我正在尝试打开一个套接字,该套接字应与已知UUID的特定服务连接。我已成功尝试按照以下示例在服务器和客户端之间打开套接字: http://peopl
有谁知道蓝牙设备如何获取范围内可发现设备的设备 ID? 理想情况下,我正在寻找涉及蓝牙协议(protocol)最小实现的最简单解决方案。 一个起点会很好,我只是想创建一个设备,它可以以最小的功耗存储附
蓝牙双模设备是否可以在与 BT LE 设备配对的同时被经典蓝牙发现?如果设备不能同时运行这两种模式也没关系,但我真的应该在这些模式之间切换芯片吗?我只是在 BT 4 Core 规范中找不到答案 最佳答
我目前正在开展一个涉及乐高 Mindstorms 套件的项目。砖 block 是 NXT,我对蓝牙 ping 速率很好奇。 我对其进行了 100 次 ping 测试,得到了一些有趣的结果。延迟似乎分为
我正在启动一个通过蓝牙进行无线 MIDI 连接的项目。据我所知,BT规范中没有定义MIDI配置文件。 我想知道你们中的一些人是否有兴趣分享有关通过 BT 使用 MIDI 的最佳方式的经验,特别是关于延
Closed. This question is off-topic。它当前不接受答案。
我想通过蓝牙将我的摩托罗拉机器人连接到 OBDKey。我以 BluetoothChat 为例连接蓝牙,使用 KWP 作为协议(protocol) 然后我写byte[]命令 command[0]=ra
几个月前,我用 C# 编写了一个 Messenger 程序,可以让许多客户端连接到服务器并进行聊天。 现在,我想为 android 编写相同的程序。在阅读了 Android Developers 中的
我目前正在制作一个与蓝牙相关的 Android 实用程序,我需要更改我的设备的设备发现范围.. 我有办法这样做吗?我目前正在考虑使用 TPL 来执行此操作,但我不太确定.. Android 应用程序或
我正在为两个玩家构建 tic tac,需要蓝牙连接来交换一些数据,我可以启用蓝牙,启用发现能力,但我不知道“BluetoothServerSocket”和客户端“BluetoothSocket”中的问
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visi
我正在 Microsoft visual studio express 2012,C++ 中制作一个程序,以便与具有此 mac 地址的设备建立简单的蓝牙连接:“00:12:08:24:15:50”,
我正在为 python import bluetooth 使用蓝牙模块,我相信它是 PyBluez 包。我能够从 bluetooth.BluetoothSocket 类进行连接、发送和接收,但我的应用
我正在为 python import bluetooth 使用蓝牙模块,我相信它是 PyBluez 包。我能够从 bluetooth.BluetoothSocket 类进行连接、发送和接收,但我的应用
我尝试通过以下命令来做到这一点: ./configure -developer-build -opensource -nomake examples -nomake tests make module
我有一个服务,理论上可以在没有关联 Activity 的情况下工作(因为“服务”适用于 Android 平台)。 此服务使用蓝牙,特别是注册一个具有给定名称的蓝牙服务来监听通信。当然,它必须启用蓝牙才
谁知道是否可以制作一个应用程序通过蓝牙模拟触摸屏鼠标或触控板? 如何让 PC(或 MAC)知道我是鼠标设备? 问候, 胡安 最佳答案 您应该看看蓝牙 HID 规范。这可能是可能的,具体取决于您用来模拟
我的问题很简单。我想知道什么是我的应用程序的最佳实践,以便它可以“防打瞌睡”。随着 Android N 将在更多情况下应用 Doze,这变得更加相关。 阅读时Doze Documentation有一部
我是一名优秀的程序员,十分优秀!