--- title: MediaDevices slug: Web/API/MediaDevices tags: - API - Devices - Interface - Media - Media Capture and Streams API - Media Streams API - MediaDevices - NeedsTranslation - Reference - TopicStub - WebRTC translation_of: Web/API/MediaDevices ---
Интерфейс MediaDevices предоставляет доступ к подключённым медиа-устройствам ввода, таким как камера, микрофон, а также к совместному использованию экрана. В сущности, он позволяет получать доступ к любому устройству медиа-данных.
Наследует свойство родителя {{domxref("EventTarget")}}.
MediaDevices когда медиа-устройство ввода или вывода подключается или отключается на компьютере пользователя.Наследуемый метод родителя {{domxref("EventTarget")}}.
'use strict';
// Помещаем переменные в глобальную область видимости, чтобы сделать их доступными для консоли браузера
var video = document.querySelector('video');
var constraints = window.constraints = {
audio: false,
video: true
};
var errorElement = document.querySelector('#errorMsg');
navigator.mediaDevices.getUserMedia(constraints)
.then(function(stream) {
var videoTracks = stream.getVideoTracks();
console.log('Получил поток с ограничениями:', constraints);
console.log('Использую видео-устройство: ' + videoTracks[0].label);
stream.onended = function() {
console.log('Трансляция закончилась');
};
window.stream = stream; // Делаем переменную доступной для консоли браузера
video.srcObject = stream;
})
.catch(function(error) {
if (error.name === 'ConstraintNotSatisfiedError') {
errorMsg('Разрешение ' + constraints.video.width.exact + 'x' +
constraints.video.height.exact + ' px не поддерживается устройством.');
} else if (error.name === 'PermissionDeniedError') {
errorMsg('Разрешения на использование камеры и микрофона не были предоставлены. ' +
'Вам нужно разрешить странице доступ к вашим устройствам,' +
' чтобы демо-версия работала.');
}
errorMsg('getUserMedia error: ' + error.name, error);
});
function errorMsg(msg, error) {
errorElement.innerHTML += '<p>' + msg + '</p>';
if (typeof error !== 'undefined') {
console.error(error);
}
}
| Спецификация | Статус | Комментарий |
|---|---|---|
| {{SpecName('Media Capture', '#mediadevices', 'MediaDevices')}} | {{Spec2('Media Capture')}} | Основная спецификация |
| Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Microsoft Edge | Opera | Safari (WebKit) |
|---|---|---|---|---|---|---|---|
| Basic support | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatGeckoDesktop("36.0")}} | {{CompatNo}} | {{CompatUnknown}} | {{CompatNo}} | {{CompatNo}} |
enumerateDevices() |
{{CompatChrome(51.0)}} | {{CompatUnknown}} | {{CompatUnknown}} | {{CompatNo}} | {{CompatUnknown}} | {{CompatNo}} | {{CompatNo}} |
getSupportedConstraints() |
{{CompatVersionUnknown}} | {{CompatUnknown}} | {{CompatGeckoDesktop(50)}} | {{CompatNo}} | {{CompatUnknown}} | {{CompatNo}} | {{CompatNo}} |
ondevicechange and devicechange events |
{{CompatVersionUnknown}} | {{CompatUnknown}} | {{CompatGeckoDesktop(51)}}[1] | {{CompatNo}} | {{CompatUnknown}} | {{CompatNo}} | {{CompatNo}} |
| Feature | Android | Android Webview | Edge | Firefox Mobile (Gecko) | Firefox OS | IE Mobile | Opera Mobile | Safari Mobile | Chrome for Android |
|---|---|---|---|---|---|---|---|---|---|
| Basic support | {{CompatNo}} | {{CompatNo}} | {{CompatVersionUnknown}} | {{CompatGeckoMobile("36.0")}} | 2.2 | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
enumerateDevices() |
{{CompatNo}} | {{CompatNo}} | {{CompatUnknown}} | {{CompatUnknown}} | {{CompatUnknown}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
getSupportedConstraints() |
{{CompatNo}} | {{CompatNo}} | {{CompatUnknown}} | {{CompatGeckoMobile(50)}} | {{CompatUnknown}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
[1] Поддержка события devicechange и {{domxref("MediaDevices.ondevicechange")}} появилась Firefox 51, но только для Mac и по умолчанию отключена. Её можно включить, установив параметру media.ondevicechange.enabled значение ИСТИНА. Для Linux и Windows поддержка добавлена и включена по умолчанию с Firefox 52.
MediaDevices, который можно использовать для доступа к устройствам.MediaDevices и MediaStream Recording API (исходный код на GitHub)