HIDDevice: sendReport()-Methode

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Sicherer Kontext: Diese Funktion ist nur in sicheren Kontexten (HTTPS) in einigen oder allen unterstützenden Browsern verfügbar.

Experimentell: Dies ist eine experimentelle Technologie
Überprüfen Sie die Browser-Kompatibilitätstabelle sorgfältig vor der Verwendung auf produktiven Webseiten.

Hinweis: This feature is available in Web Workers, except for Shared Web Workers.

Die sendReport()-Methode des HIDDevice-Interfaces sendet einen Ausgabereport an das HID-Gerät.

Die reportId für jedes der von diesem Gerät unterstützten Reportformate kann aus HIDDevice.collections abgerufen werden.

Syntax

js
sendReport(reportId, data)

Parameter

reportId

Eine 8-Bit-Report-ID. Falls das HID-Gerät keine Report-IDs verwendet, senden Sie 0.

data

Bytes als ArrayBuffer, ein TypedArray oder ein DataView.

Rückgabewert

Ein Promise, das auf undefined aufgelöst wird, sobald der Report gesendet wurde.

Ausnahmen

NotAllowedError DOMException

Wird ausgelöst, wenn das Senden des Reports aus irgendeinem Grund fehlschlägt.

Beispiele

Das folgende Beispiel zeigt, wie man ein Joy-Con-Gerät mit Hilfe von Ausgabereports zum Vibrieren bringt. Sie können weitere Beispiele und Live-Demos im Artikel Verbindung mit ungewöhnlichen HID-Geräten sehen.

js
// First, send a command to enable vibration.
// Magical bytes come from https://github.com/mzyy94/joycon-toolweb
const enableVibrationData = [1, 0, 1, 64, 64, 0, 1, 64, 64, 0x48, 0x01];
await device.sendReport(0x01, new Uint8Array(enableVibrationData));

// Then, send a command to make the Joy-Con device rumble.
// Actual bytes are available in the sample.
const rumbleData = [
  /* … */
];
await device.sendReport(0x10, new Uint8Array(rumbleData));

Spezifikationen

Specification
WebHID API
# dom-hiddevice-sendreport

Browser-Kompatibilität

Report problems with this compatibility data on GitHub
desktopmobile
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
sendReport
Experimental

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support
No support
No support
Experimental. Expect behavior to change in the future.