js-apis-usb.md 17.3 KB
Newer Older
Z
zengyawen 已提交
1 2
# USB管理

G
ge-yafang 已提交
3
>  **说明:**
Z
zengyawen 已提交
4 5 6 7
> 本模块首批接口从API version 8开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

## 导入模块

G
ge-yafang 已提交
8
```js
Z
zengyawen 已提交
9 10 11 12 13
import usb from "@ohos.usb";
```

## usb.getDevices

Y
YOUR_NAME 已提交
14
getDevices(): Array<Readonly<USBDevice>>
Z
zengyawen 已提交
15 16 17

获取USB设备列表。

G
ge-yafang 已提交
18
**系统能力:**  SystemCapability.USB.USBManager
19

G
ge-yafang 已提交
20
**返回值:**
G
ge-yafang 已提交
21

Z
zengyawen 已提交
22 23 24 25
  | 类型 | 说明 |
  | -------- | -------- |
  | Array<Readonly<[USBDevice](#usbdevice)>> | 设备信息列表。 |

G
ge-yafang 已提交
26 27
**示例:**
  ```js
Z
zengyawen 已提交
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
  let devicesList = usb.getDevices();
  console.log(`devicesList = ${JSON.stringify(devicesList)}`);
  //devicesList  返回的数据结构
  //此处提供一个简单的示例,如下
  [
    {
      name: "1-1",
      serial: "",
      manufacturerName: "",
      productName: "",
      version: "",
      vendorId: 7531,
      productId: 2,
      clazz: 9,
      subclass: 0,
      protocol: 1,
      devAddress: 1,
      busNum: 1,
      configs: [
        {
          id: 1,
          attributes: 224,
          isRemoteWakeup: true,
          isSelfPowered: true,
          maxPower: 0,
          name: "1-1",
          interfaces: [
            {
              id: 0,
              protocol: 0,
              clazz: 9,
              subclass: 0,
              alternateSetting: 0,
              name: "1-1",
              endpoints: [
                {
                  address: 129,
                  attributes: 3,
                  interval: 12,
                  maxPacketSize: 4,
                  direction: 128,
                  number: 1,
                  type: 3,
                  interfaceId: 0,
                },
              ],
            },
          ],
        },
      ],
    },
  ]
  ```


## usb.connectDevice

Y
YOUR_NAME 已提交
85
connectDevice(device: USBDevice): Readonly<USBDevicePipe>
Z
zengyawen 已提交
86 87 88 89 90

打开USB设备。

需要调用[usb.getDevices](#usbgetdevices)获取设备信息以及device;再调用[usb.requestRight](#usbrequestright)获取设备请求权限。

G
ge-yafang 已提交
91
**系统能力:**  SystemCapability.USB.USBManager
92

G
ge-yafang 已提交
93
**参数:**
Z
zengyawen 已提交
94 95 96 97
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | device | [USBDevice](#usbdevice) | 是 | USB设备信息。 |

G
ge-yafang 已提交
98
**返回值:**
Z
zengyawen 已提交
99 100 101 102
  | 类型 | 说明 |
  | -------- | -------- |
  | Readonly<[USBDevicePipe](#usbdevicepipe)> | 指定的传输通道对象。 |

G
ge-yafang 已提交
103 104
**示例:**
  ```js
Z
zengyawen 已提交
105 106 107 108 109 110 111
  let devicepipe= usb.connectDevice(device);
  console.log(`devicepipe = ${JSON.stringify(devicepipe)}`);
  ```


## usb.hasRight

Y
YOUR_NAME 已提交
112
hasRight(deviceName: string): boolean
Z
zengyawen 已提交
113 114 115

判断是否有权访问该设备。

G
ge-yafang 已提交
116
**系统能力:**  SystemCapability.USB.USBManager
117

G
ge-yafang 已提交
118
**参数:**
Z
zengyawen 已提交
119 120 121 122
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | deviceName | string | 是 | 设备名称。 |

G
ge-yafang 已提交
123
**返回值:**
Z
zengyawen 已提交
124 125 126 127
  | 类型 | 说明 |
  | -------- | -------- |
  | boolean | true表示有访问设备的权限,false表示没有访问设备的权限。 |

G
ge-yafang 已提交
128 129
**示例:**
  ```js
Z
zengyawen 已提交
130 131 132 133 134 135 136 137
  let divicesName="1-1";
  let bool = usb.hasRight(divicesName);
  console.log(bool);
  ```


## usb.requestRight

Y
YOUR_NAME 已提交
138
requestRight(deviceName: string): Promise<boolean>
Z
zengyawen 已提交
139 140 141

请求软件包的临时权限以访问设备。

G
ge-yafang 已提交
142
**系统能力:**  SystemCapability.USB.USBManager
143

G
ge-yafang 已提交
144
**参数:**
Z
zengyawen 已提交
145 146 147 148
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | deviceName | string | 是 | 设备名称。 |

G
ge-yafang 已提交
149
**返回值:**
Z
zengyawen 已提交
150 151 152 153
  | 类型 | 说明 |
  | -------- | -------- |
  | Promise<boolean> | 获取到true则表示软件包的临时权限已访问成功, 获取到false则表示软件包的临时权限已访问失败。 |

G
ge-yafang 已提交
154 155
**示例:**
  ```js
Z
zengyawen 已提交
156 157 158 159 160 161 162 163 164
  let divicesName="1-1";
  usb.requestRight(divicesName).then((ret) => {
    console.log(`requestRight = ${JSON.stringify(ret)}`);
  });
  ```


## usb.claimInterface

Y
YOUR_NAME 已提交
165
claimInterface(pipe: USBDevicePipe, iface: USBInterface, force?: boolean): number
Z
zengyawen 已提交
166 167 168 169 170

注册通信接口。

需要调用[usb.getDevices](#usbgetdevices)获取设备信息以及interfaces;调用[usb.requestRight](#usbrequestright)获取设备请求权限;调用[usb.connectDevice](#usbconnectdevice)接口得到devicepipe作为参数。

G
ge-yafang 已提交
171
**系统能力:**  SystemCapability.USB.USBManager
172

G
ge-yafang 已提交
173
**参数:**
Z
zengyawen 已提交
174 175 176 177 178 179
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定总线号和设备地址。 |
  | iface | [USBInterface](#usbinterface) | 是 | 用于确定需要获取接口的索引。 |
  | force | boolean | 否 | 可选参数,是否强制获取。默认值false ,表示不强制获取。 |

G
ge-yafang 已提交
180
**返回值:**
Z
zengyawen 已提交
181 182 183 184
  | 类型 | 说明 |
  | -------- | -------- |
  | number | 注册通信接口成功返回0;注册通信接口失败返回其他错误码。 |

G
ge-yafang 已提交
185 186
**示例:**
  ```js
Z
zengyawen 已提交
187 188 189 190 191 192 193
  let ret = usb.claimInterface(devicepipe, interfaces);
  console.log(`claimInterface = ${ret}`);
  ```


## usb.releaseInterface

Y
YOUR_NAME 已提交
194
releaseInterface(pipe: USBDevicePipe, iface: USBInterface): number
Z
zengyawen 已提交
195 196 197 198 199

释放注册过的通信接口。

需要调用[usb.claimInterface](#usbclaiminterface)先获取接口,才能使用此方法释放接口。

G
ge-yafang 已提交
200
**系统能力:**  SystemCapability.USB.USBManager
201

G
ge-yafang 已提交
202
**参数:**
Z
zengyawen 已提交
203 204 205 206 207
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定总线号和设备地址。 |
  | iface | [USBInterface](#usbinterface) | 是 | 用于确定需要释放接口的索引。 |

G
ge-yafang 已提交
208
**返回值:**
Z
zengyawen 已提交
209 210 211 212
  | 类型 | 说明 |
  | -------- | -------- |
  | number | 释放接口成功返回0;释放接口失败返回其他错误码。 |

G
ge-yafang 已提交
213 214
**示例:**
  ```js
Z
zengyawen 已提交
215 216 217 218 219 220 221
  let ret = usb.releaseInterface(devicepipe, interfaces);
  console.log(`releaseInterface = ${ret}`);
  ```


## usb.setConfiguration

Y
YOUR_NAME 已提交
222
setConfiguration(pipe: USBDevicePipe, config: USBConfig): number
Z
zengyawen 已提交
223 224 225 226 227

设置设备配置。

需要调用[usb.getDevices](#usbgetdevices)获取设备信息以及config;调用[usb.requestRight](#usbrequestright)获取设备请求权限;调用[usb.connectDevice](#usbconnectdevice)得到devicepipe作为参数。

G
ge-yafang 已提交
228
**系统能力:**  SystemCapability.USB.USBManager
229

G
ge-yafang 已提交
230
**参数:**
Z
zengyawen 已提交
231 232 233 234 235
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定总线号和设备地址。 |
  | config | [USBConfig](#usbconfig) | 是 | 用于确定需要设置的配置。 |

G
ge-yafang 已提交
236
**返回值:**
Z
zengyawen 已提交
237 238 239 240
  | 类型 | 说明 |
  | -------- | -------- |
  | number | 设置设备配置成功返回0;设置设备配置失败返回其他错误码。 |

G
ge-yafang 已提交
241 242
**示例:**
  ```js
Z
zengyawen 已提交
243 244 245 246 247 248 249
  let ret = usb.setConfiguration(devicepipe, config);
  console.log(`setConfiguration = ${ret}`);
  ```


## usb.setInterface

Y
YOUR_NAME 已提交
250
setInterface(pipe: USBDevicePipe, iface: USBInterface): number
Z
zengyawen 已提交
251 252 253

设置设备接口。

254
需要调用[usb.getDevices](#usbgetdevices)获取设备列表以及interfaces;调用[usb.requestRight](#usbrequestright)获取设备请求权限;调用[usb.connectDevice](#usbconnectdevice)得到devicepipe作为参数。
Z
zengyawen 已提交
255

G
ge-yafang 已提交
256
**系统能力:**  SystemCapability.USB.USBManager
257

G
ge-yafang 已提交
258
**参数:**
Z
zengyawen 已提交
259 260 261 262 263
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定总线号和设备地址。 |
  | iface | [USBInterface](#usbinterface) | 是 | 用于确定需要设置的接口。 |

G
ge-yafang 已提交
264
**返回值:**
Z
zengyawen 已提交
265 266 267 268
  | 类型 | 说明 |
  | -------- | -------- |
  | number | 设置设备接口成功返回0;设置设备接口失败返回其他错误码。 |

G
ge-yafang 已提交
269 270
**示例:**
  ```js
Z
zengyawen 已提交
271 272 273 274 275 276 277
  let ret = usb.setInterface(devicepipe, interfaces);
  console.log(`setInterface = ${ret}`);
  ```


## usb.getRawDescriptor

Y
YOUR_NAME 已提交
278
getRawDescriptor(pipe: USBDevicePipe): Uint8Array
Z
zengyawen 已提交
279 280 281 282 283

获取原始的USB描述符。

需要调用[usb.getDevices](#usbgetdevices)获取设备列表;调用[usb.requestRight](#usbrequestright)获取设备请求权限;调用[usb.connectDevice](#usbconnectdevice)接口得到devicepipe作为参数。

G
ge-yafang 已提交
284
**系统能力:**  SystemCapability.USB.USBManager
285

G
ge-yafang 已提交
286
**参数:**
Z
zengyawen 已提交
287 288 289 290
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定总线号和设备地址。 |

G
ge-yafang 已提交
291
**返回值:**
Z
zengyawen 已提交
292 293 294 295
  | 类型 | 说明 |
  | -------- | -------- |
  | Uint8Array | 返回获取的原始数据。 |

G
ge-yafang 已提交
296 297
**示例:**
  ```js
Z
zengyawen 已提交
298 299 300 301 302 303
  let ret = usb.getRawDescriptor(devicepipe);
  ```


## usb.getFileDescriptor

Y
YOUR_NAME 已提交
304
getFileDescriptor(pipe: USBDevicePipe): number
Z
zengyawen 已提交
305 306 307 308 309

获取文件描述符。

需要调用[usb.getDevices](#usbgetdevices)获取设备列表;调用[usb.requestRight](#usbrequestright)获取设备请求权限;调用[usb.connectDevice](#usbconnectdevice)接口得到devicepipe作为参数。

G
ge-yafang 已提交
310
**系统能力:**  SystemCapability.USB.USBManager
311

G
ge-yafang 已提交
312
**参数:**
Z
zengyawen 已提交
313 314 315 316
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定总线号和设备地址。 |

G
ge-yafang 已提交
317 318 319 320 321
**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| number | 返回设备对应的文件描述符。 |
Z
zengyawen 已提交
322

G
ge-yafang 已提交
323 324
**示例:**
  ```js
Z
zengyawen 已提交
325 326 327 328 329 330
  let ret = usb.getFileDescriptor(devicepipe);
  ```


## usb.controlTransfer

Y
YOUR_NAME 已提交
331
controlTransfer(pipe: USBDevicePipe, contrlparam: USBControlParams, timeout?: number): Promise<number>
Z
zengyawen 已提交
332 333 334 335 336

控制传输。

需要调用[usb.getDevices](#usbgetdevices)获取设备列表;调用[usb.requestRight](#usbrequestright)获取设备请求权限;调用[usb.connectDevice](#usbconnectdevice)接口得到devicepipe作为参数。

G
ge-yafang 已提交
337
**系统能力:**  SystemCapability.USB.USBManager
338

G
ge-yafang 已提交
339
**参数:**
Z
zengyawen 已提交
340 341 342 343 344 345
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定设备。 |
  | contrlparam | [USBControlParams](#usbcontrolparams) | 是 | 控制传输参数。 |
  | timeout | number | 否 | 超时时间,可选参数,默认为0不超时。 |

G
ge-yafang 已提交
346
**返回值:**
Z
zengyawen 已提交
347 348 349 350
  | 类型 | 说明 |
  | -------- | -------- |
  | Promise<number> | 获取传输或接收到的数据块大小, 获取到-1则表示异常。 |

G
ge-yafang 已提交
351 352
**示例:**
  ```js
Z
zengyawen 已提交
353 354 355 356 357 358 359 360
  usb.controlTransfer(devicepipe, USBControlParams).then((ret) => {
   console.log(`controlTransfer = ${JSON.stringify(ret)}`);
  })
  ```


## usb.bulkTransfer

Y
YOUR_NAME 已提交
361
bulkTransfer(pipe: USBDevicePipe, endpoint: USBEndpoint, buffer: Uint8Array, timeout?: number): Promise<number>
Z
zengyawen 已提交
362 363 364 365 366

批量传输。

需要调用[usb.getDevices](#usbgetdevices)获取设备信息列表以及endpoint;再调用[usb.requestRight](#usbrequestright)获取设备请求权限;然后调用[usb.connectDevice](#usbconnectdevice)接口得到返回数据devicepipe之后,再次获取接口[usb.claimInterface](#usbclaiminterface);再调用usb.bulkTransfer接口。

G
ge-yafang 已提交
367
**系统能力:**  SystemCapability.USB.USBManager
368

G
ge-yafang 已提交
369
**参数:**
Z
zengyawen 已提交
370 371 372 373 374 375 376
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定设备。 |
  | endpoint | [USBEndpoint](#usbendpoint) | 是 | 用于确定传输的端口。 |
  | buffer | Uint8Array | 是 | 用于写入或读取的缓冲区。 |
  | timeout | number | 否 | 超时时间,可选参数,默认为0不超时。 |

G
ge-yafang 已提交
377
**返回值:**
Z
zengyawen 已提交
378 379 380 381
  | 类型 | 说明 |
  | -------- | -------- |
  | Promise<number> | 获取传输或接收到的数据块大小, 获取到-1则表示异常。 |

G
ge-yafang 已提交
382 383
**示例:**
  ```js
Z
zengyawen 已提交
384 385 386 387 388 389 390 391 392 393 394
  //usb.getDevices 接口返回数据集合,取其中一个设备对象,并获取权限 。
  //把获取到的设备对象作为参数传入usb.connectDevice;当usb.connectDevice接口成功返回之后;
  //才可以调用第三个接口usb.claimInterface.当usb.claimInterface 调用成功以后,再调用该接口。
  usb.bulkTransfer(devicepipe, endpoint, buffer).then((ret) => {
   console.log(`bulkTransfer = ${JSON.stringify(ret)}`);
  });
  ```


## usb.closePipe

Y
YOUR_NAME 已提交
395
closePipe(pipe: USBDevicePipe): number
Z
zengyawen 已提交
396 397 398 399 400

关闭设备消息控制通道。

需要调用[usb.getDevices](#usbgetdevices)获取设备列表;调用[usb.requestRight](#usbrequestright)获取设备请求权限;调用[usb.connectDevice](#usbconnectdevice)得到devicepipe作为参数。

G
ge-yafang 已提交
401
**系统能力:**  SystemCapability.USB.USBManager
402

G
ge-yafang 已提交
403
**参数:**
Z
zengyawen 已提交
404 405 406 407
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pipe | [USBDevicePipe](#usbdevicepipe) | 是 | 用于确定USB设备消息控制通道。 |

G
ge-yafang 已提交
408
**返回值:**
Z
zengyawen 已提交
409 410 411 412
  | 类型 | 说明 |
  | -------- | -------- |
  | number | 关闭设备消息控制通道成功返回0;关闭设备消息控制通道失败返回其他错误码。 |

G
ge-yafang 已提交
413 414
**示例:**
  ```js
Z
zengyawen 已提交
415 416 417 418 419 420 421 422 423
  let ret = usb.closePipe(devicepipe);
  console.log(`closePipe = ${ret}`);
  ```


## USBEndpoint

通过USB发送和接收数据的端口。通过[USBInterface](#usbinterface)获取。

424 425
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
426 427
| 名称 | 参数类型 | 说明 |
| -------- | -------- | -------- |
428 429 430 431 432 433 434 435
| address | number | 端点地址。|
| attributes | number | 端点属性。|
| interval | number | 端点间隔。|
| maxPacketSize | number | 端点最大数据包大小。|
| direction | [USBRequestDirection](#usbrequestdirection) | 端点的方向。|
| number | number | 端点号。|
| type | number | 端点类型。|
| interfaceId | number | 端点所属的接口的唯一标识。|
Z
zengyawen 已提交
436 437 438 439 440 441


## USBInterface

一个[USBConfig](#usbconfig)中可以含有多个USBInterface,每个USBInterface提供一个功能。

442 443
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
444 445
| 名称 | 参数类型 | 说明 |
| -------- | -------- | -------- |
446 447 448 449 450 451 452
| id | number | 接口的唯一标识。|
| protocol | number | 接口的协议。|
| clazz | number | 设备类型。|
| subClass | number | 设备子类。|
| alternateSetting | number | 在同一个接口中的多个描述符中进行切换设置。|
| name | string | 接口名称。|
| endpoints | Array<[USBEndpoint](#usbendpoint)> | 当前接口所包含的端点。|
Z
zengyawen 已提交
453 454 455 456 457 458


## USBConfig

USB配置,一个[USBDevice](#usbdevice)中可以含有多个配置。

459 460
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
461 462
| 名称 | 参数类型 | 说明 |
| -------- | -------- | -------- |
463 464 465 466 467 468 469
| id | number | 配置的唯一标识。|
| attributes | number | 配置的属性。|
| maxPower | number | 最大功耗,以毫安为单位。|
| name | string | 配置的名称,可以为空。|
| isRemoteWakeup | boolean | 检查当前配置是否支持远程唤醒。|
| isSelfPowered | boolean | 检查当前配置是否支持独立电源。|
| interfaces | Array <[USBInterface](#usbinterface)> | 配置支持的接口属性。|
Z
zengyawen 已提交
470 471 472 473 474 475


## USBDevice

USB设备信息。

476 477
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
478 479
| 名称 | 参数类型 | 说明 |
| -------- | -------- | -------- |
480 481 482 483 484 485 486 487 488 489 490 491 492
| busNum | number | 总线地址。|
| devAddress | number | 设备地址。|
| serial | string | 序列号。|
| name | string | 设备名字。|
| manufacturerName | string | 产商信息。|
| productName | string | 产品信息。|
| version | string | 版本。|
| vendorId | number | 厂商ID。|
| productId | number | 产品ID。|
| clazz | number | 设备类。|
| subClass | number | 设备子类。|
| protocol | number | 设备协议码。|
| configs | Array<[USBConfig](#usbconfig)> | 设备配置描述符信息。|
Z
zengyawen 已提交
493 494 495 496 497 498


## USBDevicePipe

USB设备消息传输通道,用于确定设备。

499 500
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
501 502
| 名称 | 参数类型 | 说明 |
| -------- | -------- | -------- |
503 504
| busNum | number | 总线地址。|
| devAddress | number | 设备地址。|
Z
zengyawen 已提交
505 506 507 508 509 510


## USBControlParams

控制传输参数。

511 512
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
513 514 515
| 名称 | 参数类型 | 说明 |
| -------- | -------- | -------- |
| request | number | 请求类型。 |
516 517 518 519 520
| target | [USBRequestTargetType](#usbrequesttargettype) | 请求目标类型。|
| reqType | [USBControlRequestType](#usbcontrolrequesttype) | 请求控制类型。|
| value | number | 请求参数。|
| index | number | 请求参数value对应的索引值。|
| data | Uint8Array | 用于写入或读取的缓冲区。|
Z
zengyawen 已提交
521 522 523 524 525 526


## USBRequestTargetType

请求目标类型。

527
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。
Z
zengyawen 已提交
528 529 530

| 名称 | 默认值 | 说明 |
| -------- | -------- | -------- |
531 532 533 534
| USB_REQUEST_TARGET_DEVICE | 0 | 设备。|
| USB_REQUEST_TARGET_INTERFACE | 1 | 接口。|
| USB_REQUEST_TARGET_ENDPOINT | 2 | 端点。|
| USB_REQUEST_TARGET_OTHER | 3 | 其他。|
Z
zengyawen 已提交
535 536 537 538 539 540


## USBControlRequestType

控制请求类型。

541 542
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
543 544
| 名称 | 默认值 | 说明 |
| -------- | -------- | -------- |
545 546 547
| USB_REQUEST_TYPE_STANDARD | 0 | 标准。|
| USB_REQUEST_TYPE_CLASS | 1 | 类。|
| USB_REQUEST_TYPE_VENDOR | 2 | 厂商。|
Z
zengyawen 已提交
548 549 550 551 552 553


## USBRequestDirection

请求方向。

554 555
**系统能力**:以下各项对应的系统能力均为 SystemCapability.USB.USBManager。

Z
zengyawen 已提交
556 557
| 名称 | 默认值 | 说明 |
| -------- | -------- | -------- |
558 559
| USB_REQUEST_DIR_TO_DEVICE | 0 | 写数据,主设备往从设备。|
| USB_REQUEST_DIR_FROM_DEVICE | 0x80 | 读数据,从设备往主设备。|