aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/api/mediastream
diff options
context:
space:
mode:
Diffstat (limited to 'files/zh-cn/web/api/mediastream')
-rw-r--r--files/zh-cn/web/api/mediastream/active/index.html59
-rw-r--r--files/zh-cn/web/api/mediastream/clone/index.html43
-rw-r--r--files/zh-cn/web/api/mediastream/getaudiotracks/index.html78
-rw-r--r--files/zh-cn/web/api/mediastream/gettracks/index.html65
-rw-r--r--files/zh-cn/web/api/mediastream/id/index.html99
-rw-r--r--files/zh-cn/web/api/mediastream/index.html101
-rw-r--r--files/zh-cn/web/api/mediastream/mediastream/index.html59
7 files changed, 504 insertions, 0 deletions
diff --git a/files/zh-cn/web/api/mediastream/active/index.html b/files/zh-cn/web/api/mediastream/active/index.html
new file mode 100644
index 0000000000..904001fd9c
--- /dev/null
+++ b/files/zh-cn/web/api/mediastream/active/index.html
@@ -0,0 +1,59 @@
+---
+title: active
+slug: Web/API/MediaStream/active
+tags:
+ - 参考
+ - 媒体流
+ - 属性
+ - 接口
+ - 活动
+translation_of: Web/API/MediaStream/active
+---
+<p>{{APIRef("Media Capture and Streams")}}</p>
+
+<p><strong><code>active</code></strong> 是 {{domxref("MediaStream")}} 接口的只读属性,返回布尔值,如果媒体流当前为活动状态时,返回 <code>true</code> ,否则返回 <code>false</code>。 至少有一条 {{domxref("MediaStreamTrack")}} 的媒体流不是{{domxref("MediaStreamTrack.ended")}} 状态时才认为是 <strong>活动的</strong> 。当所有轨道关闭时,媒体流的属性置为 <code>false。</code></p>
+
+<h2 id="语法">语法</h2>
+
+<pre class="syntaxbox">var <em>isActive</em> = <em>MediaStream</em>.active;</pre>
+
+<h3 id="Value">Value</h3>
+
+<p>布尔值,当媒体流当前为活动状态时为 <code>true</code> ; 否则为 <code>false</code>.</p>
+
+<h2 id="样例">样例</h2>
+
+<p>在这个例子中,使用{{domxref("MediaDevices.getUserMedia", "getUserMedia()")}}请求源为用户本地摄像机和麦克风的一条新流,当流可用时(即满足返回的{{jsxref("Promise")}}),根据该流当前是否处于活动状态来更新页面上的按钮。</p>
+
+<pre class="brush: js">var promise = navigator.mediaDevices.getUserMedia({
+  audio: true,
+  video: true
+});
+
+promise.then(function(stream) {
+ var startBtn = document.querySelector('#startBtn');
+  startBtn.disabled = stream.active;
+};)</pre>
+
+<h2 id="规格">规格</h2>
+
+<table class="standard-table">
+ <tbody>
+ <tr>
+ <th scope="col">Specification</th>
+ <th scope="col">Status</th>
+ <th scope="col">Comment</th>
+ </tr>
+ <tr>
+ <td>{{SpecName('Media Capture', '#dom-mediastream-active', 'active')}}</td>
+ <td>{{Spec2('Media Capture')}}</td>
+ <td>Initial definition.</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="浏览器兼容">浏览器兼容</h2>
+
+
+
+<p>{{Compat("api.MediaStream.active")}}</p>
diff --git a/files/zh-cn/web/api/mediastream/clone/index.html b/files/zh-cn/web/api/mediastream/clone/index.html
new file mode 100644
index 0000000000..664ea6ffc6
--- /dev/null
+++ b/files/zh-cn/web/api/mediastream/clone/index.html
@@ -0,0 +1,43 @@
+---
+title: MediaStream.clone()
+slug: Web/API/MediaStream/clone
+translation_of: Web/API/MediaStream/clone
+---
+<p>{{APIRef("Media Capture and Streams")}}</p>
+
+<p>The <strong><code>clone()</code></strong> method of the {{domxref("MediaStream")}} interface creates a duplicate of the <code>MediaStream</code>. This new <code>MediaStream</code> object has a new unique {{domxref("MediaStream.id", "id")}} and contains clones of every {{domxref("MediaStreamTrack")}} contained by the <code>MediaStream</code> on which <code>clone()</code> was called.</p>
+
+<h2 id="Syntax">Syntax</h2>
+
+<pre class="syntaxbox">var <em>stream</em> = <em>MediaStream</em>.clone();</pre>
+
+<h3 id="Parameters">Parameters</h3>
+
+<p>None.</p>
+
+<h3 id="Return_value">Return value</h3>
+
+<p>A new {{domxref("MediaStream")}} instance which has a new unique ID and contains clones of every {{domxref("MediaStreamTrack")}} contained by the <code>MediaStream</code> on which <code>clone()</code> was called.</p>
+
+<h2 id="Specifications">Specifications</h2>
+
+<table class="standard-table">
+ <tbody>
+ <tr>
+ <th scope="col">Specification</th>
+ <th scope="col">Status</th>
+ <th scope="col">Comment</th>
+ </tr>
+ <tr>
+ <td>{{SpecName('Media Capture', '#widl-MediaStream-clone-MediaStream', 'MediaStream.clone()')}}</td>
+ <td>{{Spec2('Media Capture')}}</td>
+ <td>Initial definition.</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="Browser_compatibility">Browser compatibility</h2>
+
+
+
+<p>{{Compat("api.MediaStream.clone")}}</p>
diff --git a/files/zh-cn/web/api/mediastream/getaudiotracks/index.html b/files/zh-cn/web/api/mediastream/getaudiotracks/index.html
new file mode 100644
index 0000000000..4c7bb6dad1
--- /dev/null
+++ b/files/zh-cn/web/api/mediastream/getaudiotracks/index.html
@@ -0,0 +1,78 @@
+---
+title: MediaStream.getAudioTracks()
+slug: Web/API/MediaStream/getAudioTracks
+tags:
+ - API
+ - getAudioTracks
+ - 媒体
+ - 媒体流
+ - 媒体流 API
+ - 媒体流轨道
+ - 方法
+ - 轨道
+ - 音频
+translation_of: Web/API/MediaStream/getAudioTracks
+---
+<p>{{APIRef("Media Capture and Streams")}}</p>
+
+<p>{{domxref("MediaStream")}} 接口下的 <strong><dfn><code>getAudioTracks()</code></dfn></strong> 方法会返回一个包含 <code><a href="https://www.w3.org/TR/mediacapture-streams/#track-set">track set</a></code> 流中所有 {{domxref("MediaStreamTrack.kind")}} 为 <code>audio</code> 的 {{domxref("MediaStreamTrack")}} 对象序列。</p>
+
+<h2 id="语法">语法</h2>
+
+<pre class="syntaxbox">var <em>mediaStreamTracks</em> = <em>mediaStream</em>.getAudioTracks()</pre>
+
+<h3 id="参数">参数</h3>
+
+<p>无</p>
+
+<h3 id="返回值">返回值</h3>
+
+<p>{{domxref("MediaStreamTrack")}} 对象数组,包含流中所有的音轨。音轨的 {{domxref("MediaStreamTrack.kind", "kind")}} 值为 <code>audio</code> 。如果流中不包含音轨,则数组为空。</p>
+
+<div class="note">
+<p><strong>注意</strong>:数组中返回的顺序并不是由规范定义的,事实上,每次调用 <code>getAudioTracks()</code> 的结果都可能有所不同。</p>
+</div>
+
+<p>更早版本的本API中,包含一个用做列表中每个音频类型的 <code>AudioStreamTrack</code> 接口;现在已被合并至 {{domxref("MediaStreamTrack")}} 主接口中。</p>
+
+<h2 id="示例">示例</h2>
+
+<p><font><font>本示例使用 </font></font>{{domxref("MediaDevices.getUserMedia", "getUserMedia()")}} <font><font>获取视频流中的网络摄像机的音频和视频,并将媒体流绑定到 </font></font>{{HTMLElement("video")}} <font><font>元素,然后设置一个计时器,计时器到期时会停止在该媒体流中找到的第一个音轨。</font></font></p>
+
+<pre class="brush: js">navigator.mediaDevices.getUserMedia({audio: true, video: true})
+.then(mediaStream =&gt; {
+ document.querySelector('video').srcObject = mediaStream;
+ // Stop the audio stream after 5 seconds
+ setTimeout(() =&gt; {
+ const tracks = mediaStream.getAudioTracks()
+ tracks[0].stop()
+ }, 5000)
+})
+</pre>
+
+<h2 id="说明">说明</h2>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">说明</th>
+ <th scope="col">状态</th>
+ <th scope="col">评论</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>{{SpecName('Media Capture','#dom-mediastream-getaudiotracks','getAudioTracks()')}}</td>
+ <td>{{Spec2('Media Capture')}}</td>
+ <td>Initial definition.</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="浏览器兼容性">浏览器兼容性</h2>
+
+<div class="hidden">
+<p>The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p>
+</div>
+
+<p>{{Compat("api.MediaStream.getAudioTracks")}}</p>
diff --git a/files/zh-cn/web/api/mediastream/gettracks/index.html b/files/zh-cn/web/api/mediastream/gettracks/index.html
new file mode 100644
index 0000000000..c47d48473b
--- /dev/null
+++ b/files/zh-cn/web/api/mediastream/gettracks/index.html
@@ -0,0 +1,65 @@
+---
+title: MediaStream.getTracks()
+slug: Web/API/MediaStream/getTracks
+tags:
+ - 参考
+ - 媒体流
+ - 媒体流 API
+ - 媒体轨道
+ - 方法
+translation_of: Web/API/MediaStream/getTracks
+---
+<p>{{APIRef("Media Capture and Streams")}}{{SeeCompatTable}}</p>
+
+<p>{{domxref("MediaStream")}} 接口的<strong><dfn><code>getTracks()</code></dfn></strong> 方法会返回一个包含  <code><a href="https://www.w3.org/TR/mediacapture-streams/#track-set">track set</a></code> 流中所有 {{domxref("MediaStreamTrack")}}  对象的序列, 序列内容与{{domxref("MediaStreamTrack.kind")}} 无关。</p>
+
+<h2 id="语法">语法</h2>
+
+<pre class="syntaxbox">var <em>mediaStreamTracks</em> = <em>mediaStream</em>.getTracks()</pre>
+
+<h3 id="参数">参数</h3>
+
+<p>无</p>
+
+<h3 id="返回值">返回值</h3>
+
+<p>{{domxref("MediaStreamTrack")}} 对象的数组</p>
+
+<h2 id="示例">示例</h2>
+
+<pre class="brush: js">navigator.mediaDevices.getUserMedia({audio: false, video: true})
+.then(mediaStream =&gt; {
+ document.querySelector('video').srcObject = mediaStream;
+ // Stop the stream after 5 seconds
+ setTimeout(() =&gt; {
+ const tracks = mediaStream.getTracks()
+ tracks[0].stop()
+ }, 5000)
+})</pre>
+
+<h2 id="说明">说明</h2>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">说明</th>
+ <th scope="col">状态</th>
+ <th scope="col">评论</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>{{SpecName('Media Capture','#dom-mediastream-gettracks','getTracks()')}}</td>
+ <td>{{Spec2('Media Capture')}}</td>
+ <td>Initial definition.</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="浏览器支持情况">浏览器支持情况</h2>
+
+<div class="hidden">
+<p>The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p>
+</div>
+
+<p>{{Compat("api.MediaStream.getTracks")}}</p>
diff --git a/files/zh-cn/web/api/mediastream/id/index.html b/files/zh-cn/web/api/mediastream/id/index.html
new file mode 100644
index 0000000000..ef5d47c56c
--- /dev/null
+++ b/files/zh-cn/web/api/mediastream/id/index.html
@@ -0,0 +1,99 @@
+---
+title: MediaStream.id
+slug: Web/API/MediaStream/id
+translation_of: Web/API/MediaStream/id
+---
+<p>{{APIRef("WebRTC")}}</p>
+
+<p><code><strong>MediaStream.id</strong></code> 只读属性,一个包含36个字符的 {{domxref("DOMString")}} ,用来作为这个对象的唯一标识符 (GUID) 。</p>
+
+<h2 id="Syntax" name="Syntax">语法</h2>
+
+<pre class="syntaxbox">var <em>id</em> = <em>mediaStream</em>.id;
+</pre>
+
+<h2 id="示例">示例</h2>
+
+<pre class="brush: js"><code class="language-html">var p = navigator.mediaDevices.getUserMedia({ audio: true, video: true });
+
+p.then(function(stream) {
+ console.log(stream.id);
+};)
+</code></pre>
+
+<h2 id="规范">规范</h2>
+
+<table class="standard-table">
+ <tbody>
+ <tr>
+ <th scope="col">Specification</th>
+ <th scope="col">Status</th>
+ <th scope="col">Comment</th>
+ </tr>
+ <tr>
+ <td>{{SpecName('Media Capture', '#widl-MediaStream-id', 'MediaStream.id')}}</td>
+ <td>{{Spec2('Media Capture')}}</td>
+ <td>Initial definition.</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="Browser_compatibility" name="Browser_compatibility">浏览器兼容性</h2>
+
+<p>{{ CompatibilityTable() }}</p>
+
+<div id="compat-desktop">
+<table class="compat-table">
+ <tbody>
+ <tr>
+ <th>Feature</th>
+ <th>Chrome</th>
+ <th>Edge</th>
+ <th>Firefox (Gecko)</th>
+ <th>Internet Explorer</th>
+ <th>Opera</th>
+ <th>Safari</th>
+ </tr>
+ <tr>
+ <td>Basic support</td>
+ <td>{{ CompatUnknown() }}</td>
+ <td>{{CompatVersionUnknown}}</td>
+ <td>{{ CompatGeckoDesktop(41) }}</td>
+ <td>{{ CompatUnknown() }}</td>
+ <td>{{ CompatUnknown() }}</td>
+ <td>{{ CompatUnknown() }}</td>
+ </tr>
+ </tbody>
+</table>
+</div>
+
+<div id="compat-mobile">
+<table class="compat-table">
+ <tbody>
+ <tr>
+ <th>Feature</th>
+ <th>Android</th>
+ <th>Edge</th>
+ <th>Firefox Mobile (Gecko)</th>
+ <th>IE Mobile</th>
+ <th>Opera Mobile</th>
+ <th>Safari Mobile</th>
+ </tr>
+ <tr>
+ <td>Basic support</td>
+ <td>{{ CompatUnknown() }}</td>
+ <td>{{CompatVersionUnknown}}</td>
+ <td>{{ CompatGeckoMobile(41) }}</td>
+ <td>{{ CompatUnknown() }}</td>
+ <td>{{ CompatUnknown() }}</td>
+ <td>{{ CompatUnknown() }}</td>
+ </tr>
+ </tbody>
+</table>
+</div>
+
+<h2 id="相关链接">相关链接</h2>
+
+<ul>
+ <li>{{domxref("MediaStream")}},包含该属性的接口。</li>
+</ul>
diff --git a/files/zh-cn/web/api/mediastream/index.html b/files/zh-cn/web/api/mediastream/index.html
new file mode 100644
index 0000000000..049ea4a3f9
--- /dev/null
+++ b/files/zh-cn/web/api/mediastream/index.html
@@ -0,0 +1,101 @@
+---
+title: 媒体流(MediaStream)
+slug: Web/API/MediaStream
+translation_of: Web/API/MediaStream
+---
+<div>{{APIRef("Media Capture and Streams")}}</div>
+
+<div><span class="seoSummary"><strong><code>MediaStream</code></strong><strong> </strong>接口是一个媒体内容的流.。一个流包含几个<em>轨道</em>,比如视频和音频轨道。</span></div>
+
+<h2 id="属性">属性</h2>
+
+<dl>
+</dl>
+
+<dl>
+ <dt>{{domxref("MediaStream.active")}} {{readonlyinline}}</dt>
+ <dd>布尔型。如果这个流处于活动状态值为true,反之为false</dd>
+ <dt>{{domxref("MediaStream.ended")}} {{readonlyInline}}{{obsolete_inline()}}</dt>
+ <dd>布尔型。如果 {{event("ended (MediaStream)", "ended")}} 事件在这个对象上触发了,也就是说这个流已经被完全读取,值为true。 如果还没有到达这个流的尾部,值为false。</dd>
+</dl>
+
+<dl>
+ <dt>{{domxref("MediaStream.id")}} {{readonlyInline}}</dt>
+ <dd>这是一个包含36个字符的 {{domxref("DOMString")}} ,用来作为这个对象的唯一标识符 (GUID) 。</dd>
+</dl>
+
+<h3 id="事件处理">事件处理</h3>
+
+<dl>
+ <dt>{{domxref("MediaStream.onaddtrack")}}</dt>
+ <dd>这是{{event("addtrack")}}事件在这个对象上触发时调用的事件处理器[{{domxref("EventHandler")}}],这时一个{{domxref("MediaStreamTrack")}}对象被添加到这个流。</dd>
+ <dt>{{domxref("MediaStream.onended")}}</dt>
+ <dd>这是当流终止[{{event("ended (MediaStream)","ended")}}]时触发的事件。</dd>
+ <dt>{{domxref("MediaStream.onremovetrack")}}</dt>
+ <dd>这是{{event("removetrack")}}事件在这个对象上触发事调用的事件处理器[{{domxref("EventHandler")}}],这时一个对象从流上移除。</dd>
+</dl>
+
+<h2 id="方法">方法</h2>
+
+<dl>
+ <dt>{{domxref("MediaStream.addTrack()")}}</dt>
+ <dd>存储传入参数 {{domxref("MediaStreamTrack")}} 的一个副本。如果这个轨道已经被添加到了这个媒体流,什么也不会发生; 如果目标轨道为“完成”状态(也就是已经到尾部了),一个<span style="font-family: consolas,monaco,andale mono,monospace;">INVALID_STATE_RAISE异常会产生。</span></dd>
+</dl>
+
+<dl>
+ <dt>{{domxref("MediaStream.clone()")}}</dt>
+ <dd>返回这个<code style="font-style: normal;">MediaStream对象的克隆版本。返回的版本会有一个新的ID。</code></dd>
+ <dd>返回给定ID的轨道。如果没有参数或者没有指定ID的轨道,将返回null。如果有几个轨道有同一个ID,将返回第一个。</dd>
+</dl>
+
+<dl>
+ <dt>{{domxref("MediaStream.getTracks()")}}</dt>
+ <dd>返回流中所有的{{domxref("MediaStreamTrack")}}列表。</dd>
+</dl>
+
+<dl>
+ <dt><span style="line-height: 1.572;">{{domxref("MediaStream.getAudioTracks()")}}</span></dt>
+ <dd>返回流中kind属性为"audio"的{{domxref("MediaStreamTrack")}}列表。顺序是不确定的,不同浏览器间会有不同,每次调用也有可能不同。</dd>
+</dl>
+
+<dl>
+ <dt>{{domxref("MediaStream.getTrackById()")}}</dt>
+ <dd>返回给定ID的轨道。如果没有参数或者没有指定ID的轨道,将返回null。如果有几个轨道有同一个ID,将返回第一个。</dd>
+</dl>
+
+<dl>
+ <dt>{{domxref("MediaStream.getVideoTracks()")}}</dt>
+ <dd>返回流中kind属性为"video"的{{domxref("MediaStreamTrack")}}列表。顺序是不确定的,不同浏览器间会有不同,每次调用也有可能不同。</dd>
+</dl>
+
+<dl>
+ <dt>{{domxref("MediaStream.removeTrack()")}}</dt>
+ <dd>移除作为参数传入的 {{domxref("MediaStreamTrack")}}。 如果这个轨道不在<code style="font-size: 14px;">MediaStream对象中什么也不会发生;</code> 如果目标轨道为“完成”状态,一个<span style="font-family: consolas,monaco,andale mono,monospace;">INVALID_STATE_RAISE异常会产生。</span></dd>
+</dl>
+
+<h2 id="说明">说明</h2>
+
+<table class="standard-table">
+ <tbody>
+ <tr>
+ <th scope="col">说明</th>
+ <th scope="col">状态</th>
+ <th scope="col">评论</th>
+ </tr>
+ <tr>
+ <td>{{SpecName('Media Capture', '#mediastream', 'MediaStream')}}</td>
+ <td>{{Spec2('Media Capture')}}</td>
+ <td></td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="浏览器支持情况">浏览器支持情况</h2>
+
+<div>{{Compat("api.MediaStream")}}</div>
+
+<h2 id="相关内容">相关内容</h2>
+
+<ul>
+ <li>Using the MediaStream API</li>
+</ul>
diff --git a/files/zh-cn/web/api/mediastream/mediastream/index.html b/files/zh-cn/web/api/mediastream/mediastream/index.html
new file mode 100644
index 0000000000..1775c27fbb
--- /dev/null
+++ b/files/zh-cn/web/api/mediastream/mediastream/index.html
@@ -0,0 +1,59 @@
+---
+title: MediaStream()
+slug: Web/API/MediaStream/MediaStream
+translation_of: Web/API/MediaStream/MediaStream
+---
+<div>{{APIRef("Media Capture and Streams")}}</div>
+
+<p><span class="seoSummary"> 构造函数<strong><code>MediaStream()</code></strong> 返回新建的 {{domxref("MediaStream")}} 实例,该实例作为媒体流的内容的集合载体,其可能包含多个媒体数据轨,每个数据轨则由一个 {{domxref("MediaStreamTrack")}} 对象表示。如果给出相应参数,在指定的数据轨则被添加到新的流中。否则,该流中不包含任何数据轨。</span></p>
+
+<h2 id="语法">语法</h2>
+
+<pre class="syntaxbox"><var>newStream</var> = new MediaStream();
+<var>newStream</var> = new MediaStream(<var>stream</var>);
+<var>newStream</var> = new MediaStream(<var>tracks[]</var>);
+</pre>
+
+<h3 id="参数">参数</h3>
+
+<dl>
+ <dt><code><var>stream</var></code></dt>
+ <dd>这是另一个 {{domxref("MediaStream")}} 对象,其数据轨会被自动添加到新建的流中。且这些数据轨不会从原流中移除,即变成了两条流共享的数据。</dd>
+ <dt><code><var>tracks</var></code></dt>
+ <dd>这是 {{domxref("MediaStreamTrack")}} 对象的 {{jsxref("Array")}} 类型的成员,代表了每一个添加到流中的数据轨。</dd>
+</dl>
+
+<h3 id="返回值">返回值</h3>
+
+<p>新建的 {{domxref("MediaStream")}} 对象,会包含创建时已给的数据轨内容,若没有给定任何数据轨则内容为空。</p>
+
+<h2 id="参数类别">参数类别</h2>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">Specification</th>
+ <th scope="col">Status</th>
+ <th scope="col">Comment</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>{{SpecName('Media Capture', '#mediastream', 'MediaStream')}}</td>
+ <td>{{Spec2('Media Capture')}}</td>
+ <td></td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="浏览器兼容性">浏览器兼容性</h2>
+
+<div class="hidden">该页面的兼容性列表是由结构化数据生成的。如果你希望完善此数据,请拉取git仓库 <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> 完善内容后向我们发起推送请求</div>
+
+<p>{{Compat("api.MediaStream.MediaStream")}}</p>
+
+<h2 id="也可参考">也可参考</h2>
+
+<ul>
+ <li>{{domxref("MediaStream")}}</li>
+</ul>