1.首先
在连接 USB 设备成功后,可以使用 WebUSB API 提供的 transferIn() 和 transferOut() 方法来发送和接收数据。这两个方法都返回一个 Promise 对象,可以使用 async/await 或者 Promise.then() 方法来处理结果。
下面是一个示例代码,演示了如何使用 WebUSB API 连接到 USB 设备,并向设备发送和接收数据:
<!-- index.html -->
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>WebUSB Example</title>
</head>
<body>
<button id="connect">Connect to USB Device</button>
<script>
const connectButton = document.querySelector('#connect');
connectButton.addEventListener('click', async () => {
try {
const device = await navigator.usb.requestDevice({ filters: [{ vendorId: 0x1234 }] });
console.log('USB Device:', device);
await device.open();
await device.selectConfiguration(1);
await device.claimInterface(2);
console.log('Interface claimed');
const data = new Uint8Array([0x01, 0x02, 0x03, 0x04]);
const result = await device.transferOut(2, data);
console.log('Data sent:', result);
const response = await device.transferIn(1, 4);
console.log('Data received:', response.data);
} catch (error) {
console.error(error);
}
});
</script>
</body>
</html>
在上面的示例中,我们使用 device.open() 方法打开设备连接,使用 device.selectConfiguration() 方法选择设备的配置,使用 device.claimInterface() 方法来获取设备接口的访问权限。
2.然后
我们创建一个 Uint8Array 类型的数组,作为要发送的数据,使用 device.transferOut() 方法将数据发送到设备。这个方法接受两个参数,第一个参数是要发送数据的端点地址(Endpoint Address),在这个例子中是 2,第二个参数是一个 Uint8Array 类型的数据。
3.接下来
我们使用 device.transferIn() 方法来从设备接收数据。这个方法也接受两个参数,第一个参数是要接收数据的端点地址(Endpoint Address),在这个例子中是 1,第二个参数是要接收的数据长度,这里我们指定为 4。
当数据发送和接收完成后,我们可以在控制台中查看结果。
4.需要注意的是
具体的数据传输方式和数据格式需要根据 USB 设备的协议来进行编写。