--- 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 ---
{{APIRef("Media Capture and Streams")}}{{SeeCompatTable}}

Интерфейс MediaDevices предоставляет доступ к подключенным медиа-устройствам ввода, таким как камера, микрофон, а также к совместному использованию экрана. В сущности, он позволяет получать доступ к любому устройству медиа-данных.

Свойства

Наследует свойство родителя {{domxref("EventTarget")}}.

Обработчики событий

{{ domxref("MediaDevices.ondevicechange") }}
Это обработчик события {{event("devicechange")}}. Это событие доставляется в объек MediaDevices когда медиа-устройство ввода или вывода подключается или отключается на компьютере пользователя.

Методы

Наследуемый метод родителя {{domxref("EventTarget")}}.

{{ domxref("EventTarget.addEventListener()") }}
Регистрирует обработчик событий для определенного типа событий.
{{ domxref("MediaDevices.enumerateDevices()") }}
Получает массив информации о медиа-устройстве ввода-вывода.
{{domxref("MediaDevices.getSupportedConstraints()")}}
Возвращает объект, соответствующий {{domxref("MediaTrackSupportedConstraints")}}, указывающий, какие ограничительные свойства поддерживаются в интерфейсе {{domxref("MediaStreamTrack")}}. Смотри {{SectionOnPage("/en-US/docs/Web/API/Media_Streams_API", "Capabilities and constraints")}}, чтобы узнать больше об ограничениях и их использовании.
{{ domxref("MediaDevices.getUserMedia()") }}
С разрешения пользователя (у пользователя будет запрошено разрешение) включает камеру, микрофон или общий доступ к экрану и предоставляет {{domxref("MediaStream")}}, содержащий входящую видео- и/или звуковую дорожку. 
{{ domxref("EventTarget.removeEventListener()") }}
Удаляет обработчик событий.

Пример

'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')}} Основная спецификация

Совместимость с браузерами

{{CompatibilityTable}}
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.

Смотрите также