--- title: MediaDevices.getDisplayMedia() slug: Web/API/MediaDevices/getDisplayMedia tags: - API - 会谈 - 分享 - 参考 - 多媒体 - 多媒体设备 - 屏幕 - 屏幕捕捉 - 屏幕捕捉API - 捕捉 - 方法 - 显示 - 获取显示多媒体 - 视频 translation_of: Web/API/MediaDevices/getDisplayMedia ---
这个 {{domxref("MediaDevices")}} 接口的 getDisplayMedia() 方法提示用户去选择和授权捕获展示的内容或部分内容(如一个窗口)在一个
{{domxref("MediaStream")}} 里. 然后,这个媒体流可以通过使用 MediaStream Recording API 被记录或者作为WebRTC 会话的一部分被传输。
去 Using the Screen Capture API 查找更多详情和例子.
var promise = navigator.mediaDevices.getDisplayMedia(constraints);
constraints
{{optional_inline}}getDisplayMedia()
需要视频轨道,所以即使constraints
对象没有明确请求视频轨道,返回的流也会有一个。一个被解析为 {{domxref("MediaStream")}} 的 {{jsxref("Promise")}},其中包含一个视频轨道。视频轨道的内容来自用户选择的屏幕区域以及一个可选的音频轨道。
Note: 浏览器对音频的支持程度各不相同,既取决于是否支持,也取决于音频源. 点击 {{anch("Browser compatibility", "compatibility table")}} 来查看各个浏览器的支持性.
来自返回的promise的拒绝是通过将{{domxref("DOMException")}}错误对象传递给promise的失败处理程序来进行的。可能的错误是:
AbortError
[中止错误]InvalidStateError
[拒绝错误]getDisplayMedia()
的context中的 {{domxref("document")}} 不是完全激活的; 例如,也许它不是最前面的标签。NotAllowedError
[拒绝错误]NotFoundError
[找不到错误]NotReadableError
[无法读取错误]OverconstrainedError
[转换错误]constraints
失效。TypeError
[类型错误]constraints
包括调用 getDisplayMedia()
时不允许的constraints
。 这些不受支持的constraints
是 advanced
的,任何约束又有一个名为 min
或 exact
的成员。在下面的示例中,我们创建了一个 startCapture()
方法,该方法在给定由 displayMediaOptions
参数指定的一组选项的情况下启动屏幕捕获。 选项以 {{domxref("MediaStreamConstraints")}}对象的形式指定,该对象指定首选流配置和从中捕获视频的显示表面
async function startCapture(displayMediaOptions) { let captureStream = null; try { captureStream = await navigator.mediaDevices.getDisplayMedia(displayMediaOptions); } catch(err) { console.error("Error: " + err); } return captureStream; }
这里使用 {{jsxref("await")}} 来进行异步等待 getDisplayMedia()
来进行 {{domxref("MediaStream")}}解析,其中包含指定选项所请求的显示内容。 之后,流被返回给调用者以供其使用,可能是使用 {{domxref("RTCPeerConnection.addTrack()")}}添加到WebRTC调用来从流中添加视频轨道。
规范 | 状态 | 备注 |
---|---|---|
{{SpecName('Screen Capture', '#dom-mediadevices-getdisplaymedia', 'MediaDevices.getDisplayMedia()')}} | {{Spec2('Screen Capture')}} | 初始定义 |
{{Compat("api.MediaDevices.getDisplayMedia")}}