MediaStreamTrack

Baseline Widely available *

This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2017.

* Some parts of this feature may have varying levels of support.

摘要

MediaStreamTrack 接口在 User Agent 中表示一段媒体源,比如音轨或视频。

属性

MediaStreamTrack.enabled

布尔值,为 true 时表示轨道有效,并且可以被渲染。为 false 时表示轨道失效,只能被渲染为静音或黑屏。如果该轨道连接中断,该值还是可以被改变但不会有任何效果了。

MediaStreamTrack.id 只读

返回一个由浏览器产生的DOMString类型的 GUID 值,作为这个轨道的唯一标识值。

MediaStreamTrack.kind 只读

返回一个DOMString类型的值。如果为“audio”表示轨道为音频轨道,为“video”则为视频轨道。如果该轨道从它的源上分离,这个值也不会改变。

MediaStreamTrack.label 只读

返回一个DOMString类型。内容为一个用户代理指定的标签,来标识该轨道的来源,比如“internal microphone”。该字符串可以为空,并且在没有源与这个轨道连接的情况下会一直为空。当该轨道从它的源上分离时,这个值也不会改变。

MediaStreamTrack.muted 只读

返回一个布尔类型的值,为 true 时表示轨道是静音,其他为 false。

MediaStreamTrack.readonly 只读

返回一个布尔类型的值,为 true 时表示该轨道是只读的,比如视频文件源或一个被设置为不能修改的摄像头源,或则为 false。

MediaStreamTrack.readyState 只读

返回枚举类型的值,表示轨道的当前状态。该枚举值为以下中的一个:

  • "live"表示当前输入已经连接并且在尽力提供实时数据。在这种情况下,输出数据可以通过操作 MediaStreamTrack.enabled 属性进行开关。
  • “ended”表示这个输出连接没有更多的数据了,而且也不会提供更多的数据了。
MediaStreamTrack.remote 只读

返回布尔值类型,当为 true 时表示数据是通过RTCPeerConnection提供的,否则为 false。

事件处理

MediaStreamTrack.onstarted

这是 started 事件在这个对象上被触发时调用的事件处理器,这时一个新的 MediaStreamTrack 对象被添加到轨道源上。

MediaStreamTrack.onmute

这是 mute 事件在这个对象被触发时调用的事件处理器,这时这个流被中断。

MediaStreamTrack.onunmute

这是 unmute 事件在这个对象上被触发时调用的事件处理器,未实现。

MediaStreamTrack.onoverconstrained

这是 overconstrained 事件在这个对象上被触发时调用的事件处理器,未实现。

MediaStreamTrack.oneended

这是 ended 事件在这个对象被触发时调用的事件处理器,未实现。

方法

MediaStreamTrack.getConstraints()

TBD

MediaStreamTrack.applyConstraints()

TBD

MediaStreamTrack.getSettings()

TBD

MediaStreamTrack.getCapabilities()

TBD

MediaStreamTrack.clone()

TBD

MediaStreamTrack.stop()

停止播放轨道对应的源,源与轨道将脱离关联,同时轨道状态将设为“ended”。

规范

Specification
Media Capture and Streams
# mediastreamtrack

浏览器兼容性

BCD tables only load in the browser

参见