RTCRtpSender: getCapabilities() statische Methode
Die statische Methode RTCRtpSender.getCapabilities()
gibt ein Objekt zurück, das die Codec- und Header-Erweiterungen beschreibt, die vom RTCRtpSender
unterstützt werden.
Sie können auf ähnliche Weise die Fähigkeiten von RTCRtpReceiver
-Objekten auf dem Gerät ermitteln, indem Sie die statische Funktion RTCRtpReceiver.getCapabilities()
aufrufen.
Syntax
RTCRtpSender.getCapabilities(kind)
Parameter
kind
-
Ein String, der den Medientyp angibt, für den die Sendefähigkeiten des Browsers abgefragt werden. Die unterstützten Medientypen sind:
audio
undvideo
.
Rückgabewert
Ein neues Objekt, das anzeigt, welche Fähigkeiten der Browser zum Senden des angegebenen Medientyps über eine RTCPeerConnection
hat.
Wenn der Browser keine Unterstützung für den angegebenen Media-kind
hat, ist der zurückgegebene Wert null
.
Das zurückgegebene Objekt hat die folgenden Eigenschaften:
codecs
-
Ein Array von Objekten, die jeweils die grundlegenden Fähigkeiten eines einzelnen Media-Codecs beschreiben, die vom
RTCRtpSender
unterstützt werden.Hinweis: Das Array enthält spezielle Einträge, die die zugrunde liegenden Komponenten des Transports darstellen — diese können ignoriert werden, wenn Sie sich nur für die eigentlichen Codecs interessieren, die für die Medien selbst verwendet werden. Diese werden unten im Abschnitt Das codecs-Array beschrieben.
Jedes Codec-Objekt hat die folgenden Eigenschaften:
channels
Optional-
Ein positiver Ganzzahlwert, der die maximale Anzahl von Kanälen angibt, die vom Codec unterstützt werden; zum Beispiel würde ein Codec, der nur Mono-Sound unterstützt, einen Wert von 1 haben; Stereo-Codecs hätten eine 2 usw.
clockRate
-
Eine positive Ganzzahl, die die Taktfrequenz des Codecs in Hertz (Hz) angibt. Die IANA führt eine Liste von Codecs und deren Parametern, einschließlich ihrer Taktfrequenzen.
mimeType
-
Ein String, der den MIME-Medientyp und den Subtyp des Codecs angibt. Die von RTP verwendeten MIME-Typ-Strings unterscheiden sich von denen, die anderswo verwendet werden. Siehe RFC 3555, Abschnitt 4 für das vollständige IANA-Register dieser Typen. Siehe auch Von WebRTC verwendete Codecs für Details zu potenziellen Codecs, die hier referenziert werden könnten.
sdpFmtpLine
Optional-
Ein String, der das formatspezifische Parameterfeld aus der
a=fmtp
-Zeile in der SDP angibt, das dem Codec entspricht, falls eine solche Zeile existiert. Wenn es kein Parameterfeld gibt, wird diese Eigenschaft weggelassen.
headerExtensions
-
Ein Array von Objekten, die jeweils die URI einer Header-Erweiterung bereitstellen, die für die aktuelle
kind
von Medien unterstützt wird. Jedes Objekt hat die folgende Eigenschaft:
Beschreibung
Als statische Funktion wird diese immer in der Form aufgerufen:
capabilities = RTCRtpSender.getCapabilities("audio");
Der zurückgegebene Satz von Fähigkeiten ist die optimistischste mögliche Liste. Es ist durchaus möglich, dass bestimmte Kombinationen von Optionen nicht funktionieren, wenn Sie versuchen, sie tatsächlich zu verwenden.
Der Aufruf von RTCRtpSender.getCapabilities()
bereitet den Browser in keiner Weise darauf vor, Medien zu handhaben.
Es wird nichts geladen, abgerufen oder auf andere Weise vorbereitet.
Es ist ein Mittel, um festzustellen, was möglicherweise nutzbar ist, bevor Sie versuchen, auf Medien zuzugreifen.
Da der verfügbare Satz an Fähigkeiten dazu neigt, über einen längeren Zeitraum stabil zu sein (Menschen installieren und deinstallieren Codecs und dergleichen nicht sehr oft), können die Medienfähigkeiten ganz oder teilweise eine bereichsübergreifende Methode zur Identifizierung eines Benutzers bereitstellen. Aus diesem Grund kann der Browser in datenschutzsensiblen Kontexten wählen, die Fähigkeiten zu verschleiern; dies könnte zum Beispiel dadurch geschehen, dass selten verwendete Codec-Konfigurationen weggelassen werden.
Das codecs-Array
Das codecs
-Array ist ein Array von Objekten, das einen einzelnen Codec und seine grundlegenden Fähigkeiten beschreibt.
Der Browser meldet nur verschiedene Fähigkeitenskombinationen separat.
Wenn zwei Sätze von Fähigkeiten als einer beschrieben werden können, werden sie es.
Das bedeutet, dass, zum Beispiel, wenn es zwei Einträge für den H.264-Codec (wie durch den mimeType
als "video/H264" identifiziert) gibt, andere Werte in den Fähigkeitsobjekten angeben, wie sie sich in irgendeiner Weise unterscheiden.
Es gibt drei spezielle Einträge, die immer vorhanden sein sollten und die zugrunde liegenden Komponenten des Transports darstellen. Diese Komponenten sind:
- RED (REDundant Audio Data)
-
Der Medientyp eines RED-Eintrags kann variieren, da es mehrere Versionen davon gibt, aber er endet immer mit
red
, wievideo/red
odervideo/fwdred
. Der Basis-RED-Standard kann bei RFC 2198 gefunden werden. Es kann mehrere Einträge für RED geben, wenn verschiedene Formen davon unterstützt werden; in diesem Fall wird jeder einen einzigartigen Medientyp haben. - FEC (Forward Error Correction)
-
Eine FEC-Komponente verarbeitet Fehlerkorrekturdaten; ihr Medientyp kann ebenfalls variieren, da erweiterte Versionen des Standards verfügbar sind, aber er endet immer mit
fec
. Ein möglicher Wert istvideo/ulpfec
(ein generisches Fehlerverbindungsmodell). Es kann auch mehrere FEC-Einträge geben, wenn mehr als eine Form unterstützt wird. - RTX (Retransmission)
-
Diese Komponente ist für die Übertragung von Daten verantwortlich; ihr Medientyp sollte
video/rtx
sein. Es wird nur einen Eintrag für RTX geben, und er wird keinesdpFmtpLine
Eigenschaft haben.
Diese Einträge sollten ignoriert werden, wenn nur Codecs im Zusammenhang mit dem Medium von Interesse sind.
Beispiele
Funktionsunterstützung
Sie können Object.hasOwn()
verwenden, um zu überprüfen, ob RTCRtpSender.getCapabilities()
unterstützt wird:
log.textContent = `RTCRtpSender.getCapabilities() supported: ${Object.hasOwn(
RTCRtpSender,
"getCapabilities",
)}`;
Überprüfung der Unterstützung für einen bestimmten Codec
Die folgende Funktion gibt ein true
oder false
zurück, das anzeigt, ob das Gerät die Übertragung von H.264-Video über einen RTCRtpSender
unterstützt.
Hinweis: Da RTCRtpSender.getCapabilities()
tatsächlich nur wahrscheinliche Unterstützung anzeigt.
Daher könnte die Unterstützung von H.264 trotz eines positiven Ergebnisses dieser Funktion fehlschlagen.
function canSendH264() {
let capabilities = RTCRtpSender.getCapabilities("video");
capabilities.codecs.forEach((codec) => {
if (codec.mimeType === "video/H264") {
return true;
}
});
return false;
}
Abrufen aller Fähigkeiten
Dieses Codebeispiel zeigt, wie wir alle unterstützten Codecs und Header erhalten könnten. Das HTML definiert eine Auswahlliste für die beiden Arten von Fähigkeiten und einen Logbereich.
<select id="kind">
<option value="audio">audio</option>
<option value="video">video</option>
</select>
<textarea rows="40" cols="100" id="log"></textarea>
Das JavaScript definiert eine Funktion, um die Fähigkeiten für ein bestimmtes "kind" zu protokollieren.
Diese wird zunächst mit dem Wert audio
aufgerufen.
Ein Listener aktualisiert den Wert, wenn die Auswahl der Liste kind
geändert wird.
const log = document.querySelector("#log");
const kindSelector = document.querySelector("#kind");
logMediaCapabilities("audio");
kindSelector.addEventListener("click", () => {
log.textContent = "";
logMediaCapabilities(kindSelector.value);
});
function logMediaCapabilities(kind) {
const capabilities = RTCRtpSender.getCapabilities(`${kind}`);
log.textContent += "Headers\n";
capabilities.headerExtensions.forEach((header) => {
log.textContent += ` uri: ${header.uri}\n`;
});
log.textContent += "\nCodecs\n";
capabilities.codecs.forEach((codec) => {
log.textContent += ` mime type: ${codec.mimeType}\n`;
log.textContent += ` channels: ${codec.channels}\n`; // max channels - e.g. 2 is stereo
log.textContent += ` clockRate: ${codec.clockRate}\n`; // clock rate in Hz
log.textContent += ` sdpFmtpLine: ${codec.sdpFmtpLine}\n`; // mime media type and subtype
});
}
Ergebnis
Spezifikationen
Specification |
---|
WebRTC: Real-Time Communication in Browsers # dom-rtcrtpsender-getcapabilities |
Browser-Kompatibilität
BCD tables only load in the browser