Limited support 一部のブラウザのみ対応。使用時はサポート状況を確認すること。

対応ブラウザ

機能 デスクトップ モバイル
Chrome
Edge
Firefox
Safari
Chrome Android
Safari iOS
109
109

CaptureController コンストラクターは、新しい CaptureController オブジェクト インスタンスを作成します。

109
109

CaptureController インターフェイスの setFocusBehavior() メソッドは、関連付けられた MediaDevices.getDisplayMedia() Promise が満たされたときにキャプチャされたタブまたはウィンドウにフォーカスするかどうか、またはキャプチャ アプリを含むタブにフォーカスを維持するかどうかを制御します。

109
109

getDisplayMedia() は MediaDevices インターフェイスのメソッドで、ディスプレイまたはその一部(ウィンドウなど)の内容を MediaStream としてキャプチャする許可を選択し、許可するようユーザーに促します。

72
79
66
13

音声の共有が必要なプロジェクトを開始する前に、getDisplayMedia()のブラウザ互換性を確認し、互換性を希望するブラウザがキャプチャした画面ストリームで音声をサポートしているかどうかを確認してください。

74
79
getDisplayMedia (controller option)
実験的

controller`オプション

109
109
getDisplayMedia (monitorTypeSurfaces option)
実験的

monitorTypeSurfaces`オプション

119
119
getDisplayMedia (selfBrowserSurface option)
実験的

selfBrowserSurface`オプション

112
112
getDisplayMedia (surfaceSwitching option)
実験的

surfaceSwitching`オプション

107
107
getDisplayMedia (systemAudio option)
実験的

systemAudio`オプション

105
105

MediaTrackConstraints辞書のdisplaySurfaceプロパティは、MediaTrackSettings.displaySurface制約可能プロパティの優先値を記述したConstrainDOMStringです。

107
107
11.1
107
11.3

MediaTrackConstraints辞書のlogicalSurfaceプロパティは、MediaTrackSettings.logicalSurface制約可能プロパティの値に要求された、または必須の制約を記述するConstrainDOMStringである。

11.1
11.3

MediaTrackConstraints ディクショナリの [suppressLocalAudioPlayback] プロパティは、MediaTrackSettings.suppressLocalAudioPlayback 制約可能プロパティの値に適用される要求された制約または必須の制約を記述する ConstrainBoolean です。 このプロパティは、タブで再生されているオーディオをユーザーのローカル環境から引き続き再生するかどうかを制御します。

109
109
109
その他
html.elements.iframe.allow.display-capture
94
94
74
13
94

HTTP の Permissions-Policy ヘッダーにおける display-capture ディレクティブは、現在の文書が画面キャプチャ API、すなわち MediaDevices.getDisplayMedia を使用して画面の内容をキャプチャすることを許可するかどうかを制御します。

94
94
94
1+対応 (バージョン) 未対応 注釈あり サブ機能の解説は MDN Web Docs (CC BY-SA 2.5)
注釈 3件
制限事項
  • このブラウザでは部分的にしか実装されていません
削除済み
  • このバージョンで機能が削除されました (79)
実装メモ
  • MediaDevices`の代わりに`Navigator`のメンバとして利用できる。
注釈 2件
削除済み
  • このバージョンで機能が削除されました (66)
実装メモ
  • Firefox 33 以降では、`mediaSource` と呼ばれる `video` 制約を使用して、`getUserMedia()` を使用して画面データをキャプチャできます。52 以前は、クライアントが設定可能な許可サイトのリストに依存していました。
注釈 1件
実装メモ
  • Chrome Android 72から88まで、このメソッドは公開されていたが、常に`NotAllowedError`で失敗していた。バグ 40418135 を参照。
注釈 1件
実装メモ
  • WindowsとChromeOSでは、画面全体を共有する場合、システム全体の音声をキャプチャできます。LinuxとmacOSでは、タブの音声のみをキャプチャできます。
注釈 1件
実装メモ
  • WindowsとChromeOSでは、画面全体を共有する場合、システム全体の音声をキャプチャできます。LinuxとmacOSでは、タブの音声のみをキャプチャできます。
注釈 1件
実装メモ
  • デフォルト値 = `include`
注釈 1件
実装メモ
  • デフォルト値 = `include`
注釈 3件
実装メモ
  • デフォルト値 = `exclude`
  • デフォルト値 = `include`
削除済み
  • このバージョンで機能が削除されました (111)
注釈 3件
実装メモ
  • デフォルト値 = `exclude`
  • デフォルト値 = `include`
削除済み
  • このバージョンで機能が削除されました (111)
注釈 1件
実装メモ
  • デフォルト値 = `exclude`
注釈 1件
実装メモ
  • デフォルト値 = `exclude`
注釈 1件
実装メモ
  • デフォルト値 = `include`
注釈 1件
実装メモ
  • デフォルト値 = `include`

基本構文

JAVASCRIPT
const stream = await navigator.mediaDevices.getDisplayMedia({
  video: { displaySurface: 'monitor' },
  audio: true
});
const video = document.querySelector('video');
video.srcObject = stream;

実務での使いどころ

  • Screen capture の活用

    実験的機能: これは実験的な技術です

注意点

  • 一部のブラウザでのみ対応。使用前にブラウザサポートを確認すること。

アクセシビリティ

  • スクリーンリーダーでの読み上げを確認すること。