Flutter网页浏览插件web_blue的使用
Flutter网页浏览插件web_blue的使用
Dart包装器通过dart:js
实现对Web Bluetooth API的支持。
特性
canUseBlue
getAvailability
subscribeAvailabilitychanged/unsubscribeAvailabilitychanged
getDevices/requestDevice
connect/disconnect
getPrimaryService/getCharacteristic
startNotifications/stopNotifications
subscribeValueChanged/unsubscribeValueChanged
readValue/writeValueWithResponse
使用方法
canUseBlue
bool canUse = canUseBlue();
print('canUse $canUse');
getAvailability
bool availability = await blue.getAvailability();
print('availability $availability');
subscribeAvailabilitychanged/unsubscribeAvailabilitychanged
final EventListener _handleAvailabilitychanged = allowInterop((Event event) {});
...
blue.subscribeAvailabilitychanged(_handleAvailabilitychanged);
...
blue.unsubscribeAvailabilitychanged(_handleAvailabilitychanged);
getDevices/requestDevice
getDevices
List<BlueDevice> getDevices = await blue.getDevices();
_device = getDevices[0];
requestDevice
BlueDevice requestDevice = await blue.requestDevice(RequestOptions(
optionalServices: [BlueUUID.getService(WOODEMI_SERV__COMMAND)],
acceptAllDevices: true,
));
_device = requestDevice;
connect/disconnect
connect
_device?.gatt.connect().then((value) {
print('device.gatt.connect success');
}).catchError((error) {
print('device.gatt.connect $error');
});
disconnect
_device?.gatt.disconnect();
getPrimaryService/getCharacteristic
getPrimaryService
_service = await _device!.gatt.getPrimaryService(BlueUUID.getService(WOODEMI_SERV__COMMAND));
getCharacteristic
_characteristic = await _service!.getCharacteristic(BlueUUID.getCharacteristic(WOODEMI_CHAR__COMMAND_REQUEST));
startNotifications/stopNotifications
startNotifications
await _characteristic!.startNotifications();
stopNotifications
await _characteristic!.stopNotifications();
subscribeValueChanged/unsubscribeValueChanged
subscribeValueChanged
final EventListener _handleValueChanged = allowInterop((event) {});
...
_characteristic!.subscribeValueChanged(_handleValueChanged);
...
_characteristic!.unsubscribeValueChanged(_handleValueChanged);
readValue/writeValueWithResponse
readValue
var byteData = await _characteristic!.readValue();
writeValueWithResponse
_characteristic!.writeValueWithResponse(Uint8List.fromList([0x01, 0x0A, 0x00, 0x00, 0x00, 0x01]));
示例代码
// ignore_for_file: avoid_print, avoid_web_libraries_in_flutter
import 'dart:html' show Event, EventListener;
import 'dart:js' show allowInterop;
import 'dart:js_util' show getProperty;
import 'package:flutter/material.dart';
import 'package:web_blue/web_blue.dart';
import 'woodemi_notepad_page.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const MyHomePage(),
);
}
}
class MyHomePage extends StatelessWidget {
const MyHomePage({Key? key}) : super(key: key);
[@override](/user/override)
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('web_blue example'),
),
body: Center(
child: Column(
children: [
ElevatedButton(
child: const Text('canUse'),
onPressed: () {
bool canUse = canUseBlue();
print('canUse $canUse');
},
),
ElevatedButton(
child: const Text('getAvailability'),
onPressed: () async {
bool availability = await blue.getAvailability();
print('availability $availability');
},
),
ElevatedButton(
child: const Text('subscribeAvailabilitychanged'),
onPressed: () async {
blue.subscribeAvailabilitychanged(_handleAvailabilitychanged);
print('subscribeAvailabilitychanged success');
},
),
ElevatedButton(
child: const Text('unsubscribeAvailabilitychanged'),
onPressed: () async {
blue.unsubscribeAvailabilitychanged(_handleAvailabilitychanged);
print('unsubscribeAvailabilitychanged success');
},
),
ElevatedButton(
child: const Text('Woodemi Notepad'),
onPressed: () {
var route = MaterialPageRoute(builder: (context) {
return const WoodemiNotepadPage();
});
Navigator.of(context).push(route);
},
),
],
),
),
);
}
}
final EventListener _handleAvailabilitychanged = allowInterop((Event event) {
print('_handleAvailabilitychanged $event');
bool available = getProperty(event, 'value');
print('available $available');
});
更多关于Flutter网页浏览插件web_blue的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter网页浏览插件web_blue的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
关于Flutter中的web_blue
插件(假设这里指的是用于网页浏览的某个Flutter插件,因为实际上web_blue
并不是一个广为人知的Flutter插件名称,但我会基于你的要求模拟一个类似的场景),通常这类插件会提供一个WebView组件来嵌入和显示网页内容。以下是一个基于Flutter的WebView插件(例如webview_flutter
,这是Flutter官方提供的插件)的使用示例代码。虽然这不是web_blue
,但原理是相似的。
首先,确保你已经在pubspec.yaml
文件中添加了相应的依赖:
dependencies:
flutter:
sdk: flutter
webview_flutter: ^3.0.4 # 使用时请检查最新版本
然后运行flutter pub get
来获取依赖。
接下来是示例代码,展示如何在Flutter应用中使用WebView:
import 'package:flutter/material.dart';
import 'package:webview_flutter/webview_flutter.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: WebViewExample(),
);
}
}
class WebViewExample extends StatefulWidget {
@override
_WebViewExampleState createState() => _WebViewExampleState();
}
class _WebViewExampleState extends State<WebViewExample> {
late WebViewController _controller;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('WebView Example'),
),
body: WebView(
initialUrl: 'https://www.example.com', // 初始加载的URL
javascriptMode: JavascriptMode.unrestricted, // 允许JavaScript执行
onWebViewCreated: (WebViewController webViewController) {
_controller = webViewController;
// 可以在这里执行更多WebView控制操作,比如加载本地HTML文件
// _controller.loadUrl(Uri.dataFromString(
// '<html><body><h1>Hello, world!</h1></body></html>',
// mimeType: 'text/html', encoding: Encoding.getByName('utf-8'))
// .toString());
},
onPageFinished: (String url) {
print('Page finished loading: $url');
},
navigationDelegate: (NavigationRequest request) {
if (request.url.startsWith('https://www.unwanted-site.com')) {
// 阻止导航到某些URL
return NavigationDecision.prevent;
}
return NavigationDecision.navigate;
},
),
floatingActionButton: FloatingActionButton(
onPressed: () async {
// 示例:在WebView中执行JavaScript代码
String result = await _controller.evaluateJavascript('document.title');
print('Page title is $result');
},
tooltip: 'Execute JS',
child: Icon(Icons.code),
),
);
}
}
这个示例展示了如何使用webview_flutter
插件来创建一个简单的WebView应用。你可以加载一个初始URL,控制JavaScript的执行,监听页面加载完成事件,以及通过navigationDelegate
来拦截和处理导航请求。
如果你使用的确实是web_blue
插件(尽管这不是一个标准或广为人知的插件名),那么你应该查阅该插件的官方文档或GitHub仓库以获取具体的用法和API参考。通常,这类插件的使用方式大同小异,主要差异在于API的细节和可用的配置选项。