--- title: WebVR API slug: Web/API/WebVR_API translation_of: Web/API/WebVR_API ---
{{SeeCompatTable}}{{APIRef("WebVR API")}}

WebVR обеспечивает поддержку для использования устройств виртуальной реальности — например, шлемы виртуальной реальности, таких как Oculus Rift или HTC Vive — для веб-приложений, позволяя разработчикам передавать  информацию о местоположении и движения с дисплея в движение вокруг 3D-сцены. Это имеет множество интересных приложений, от виртуальных туров продукта и интерактивных обучающих приложений до захватывающих игр от первого лица.

Концепция и использование

Любые VR-устройства, подключенные к вашему компьютеру, будут возвращены методом {{domxref("Navigator.getVRDisplays()")}}; каждое из которых будет представлено  {{domxref("VRDisplay")}} объектом.

Sketch of a person in a chair with wearing goggles labelled "Head mounted display (HMD)" facing a monitor with a webcam labelled "Position sensor"

{{domxref("VRDisplay")}} является центральным интерфейсом в API WebVR - с помощью его свойств и методов вы получить доступ к функциям:

Типичное (простое) WebVR приложение будет работать так:

  1. {{domxref("Navigator.getVRDisplays()")}} используется для получения ссылки на ваш VR-дисплей.
  2. {{domxref("VRDisplay.requestPresent()")}} используется для начала представления на дисплей VR.
  3. Выделенный {{domxref("VRDisplay.requestAnimationFrame()")}}  WebVR's используется для запуска цикла рендеринга приложения с правильной частотой обновления для отображения.
  4. Внутри цикла рендеринга берутся данные, необходимые для отображения текущего кадра  ({{domxref("VRDisplay.getFrameData()")}}), дважды нарисуйте отображаемую сцену - один раз для просмотра в каждом глазу, затем отправьте отображаемый вид на дисплей, чтобы показать пользователю ({{domxref("VRDisplay.submitFrame()")}}).

Кроме того, WebVR 1.1 добавляет ряд событий {{domxref("Window")}} объекту, чтобы JavaScript мог реагировать на изменения состояния дисплея.

Примечание: Вы можете найти намного больше о том, как работает API в Using the WebVR API и WebVR Concepts статьях.

Использование контроллеров: Объединение WebVR с API-интерфейсом геймпада

Многие аппаратные настройки WebVR оснащены контроллерами, которые сочетаются с гарнитурой. Они могут быть использованы в WebVR приложениях через Gamepad API, и, в частности, Gamepad расширения API, которые добавляют API функции для доступа к позе контроллера, haptic actuators, и многое другое.

Примечание: Наша Using VR controllers with WebVR статья объясняет основы использования VR-контроллеров в приложениях WebVR.

WebVR Интерфейс

{{domxref("VRDisplay")}}
Представляет любое устройство VR, поддерживаемое этим API. VRDisplay включает в себя общую информацию, такую как идентификаторы устройств и  описания, а также методы для начала представления сцены VR, получения параметров глаз и возможностей отображения и других важных функций.
{{domxref("VRDisplayCapabilities")}}
описывает возможности {{domxref("VRDisplay")}} — его функции могут использоваться для тестирования возможностей устройства VR, например, может ли он возвращать информацию о местоположении.
{{domxref("VRDisplayEvent")}}
Возвращает объект события (event) связанного с WebVR-событием (см. {{anch("Window", "window object extensions")}} , перечисленных ниже).
{{domxref("VRFrameData")}}
Представляет всю информацию, необходимую для создания одного кадра сцены VR; созданный от  {{domxref("VRDisplay.getFrameData()")}}.
{{domxref("VRPose")}}
Представляет состояние позиции на заданной временной отметке (которая включает в себя ориентацию, положение, скорость и ускорение).
{{domxref("VREyeParameters")}}
Предоставляет доступ ко все информации, необходимой для корректного отображения сцены для каждого заднего глаза, включая информацию о поле зрения.
{{domxref("VRFieldOfView")}}
Представляет поле зрения, определенное четырьмя различными значениями степени, описывающими представление из центральной точки.
{{domxref("VRLayerInit")}}
Представляет слой, который должен быть представлен в {{domxref("VRDisplay")}}.
{{domxref("VRStageParameters")}}
Представляет значения, описывающие область сцены для устройств, поддерживающих опыт в помещении.

Расширения для других интерфейсов

WebVR API расширяет следующие API, добавляя перечисленные функции.

Геймпад

{{domxref("Gamepad.displayId")}} {{readonlyInline}}
Возвращает {{domxref("VRDisplay.displayId")}} связанного с  {{domxref("VRDisplay")}} — VRDisplay , которым геймпад управляет отображаемой сценой.

Навигатор

{{domxref("Navigator.activeVRDisplays")}} {{readonlyInline}}
Возвращает массив, содержащий каждый {{domxref("VRDisplay")}} объект, который в настоящее время отображается ({{domxref("VRDisplay.ispresenting")}} является true).
{{domxref("Navigator.getVRDisplays()")}}
Возвращает обещание, которое преобразуется в массив {{domxref("VRDisplay")}} объектов,  представляющих любые доступные VR-дисплеи, подключенные к компьютеру.

Window события

{{domxref("Window.onvrdisplaypresentchange")}}
Представляет обработчик событий, который будет выполняться, при изменении состояния отображения VR-дисплея — т.е. идёт от отображения до неотображения, или наоборот (когда {{event("vrdisplaypresentchange")}} событие срабатывает).
{{domxref("Window.onvrdisplayconnect")}}
Представляет обработчик событий, который будет запускаться, когда к компьютеру подключен совместимый VR-дисплей (когда {{event("vrdisplayconnect")}} событие срабатывает).
{{domxref("Window.onvrdisplaydisconnect")}}
Представляет обработчик событий, который будет запускаться, когда совместимый VR-дисплей был отключён от компьютера (когда {{event("vrdisplaydisconnect")}} событие срабатывает).
{{domxref("Window.onvrdisplayactivate")}}
Представляет обработчик событий, который будет выполняться, когда дисплей может быть представлен (когда {{event("vrdisplayactivate")}}событие срабатывает), например, HMD (Head Mounted Display) был перемещён, чтобы вывести его из режима ожидания, или проснулся, будучи перемещенным.
{{domxref("Window.onvrdisplaydeactivate")}}
Представляет обработчик событий, который будет запускаться, когда дисплей больше не будет отображаться (когда {{event("vrdisplaydeactivate")}} событие срабатывает), например, HMD (Head Mounted Display) перешёл в режим ожидания или спящий режим из-за периода бездействия.

Невыполненные window события

Следующие события перечислены в спецификации, but do not currently seem to be implemented anywhere as yet.

{{domxref("Window.onvrdisplayblur")}}
Представляет обработчик событий, который будет выполняться, когда презентация на дисплей была приостановлена по какой-то причине в браузере, ОС или оборудованием VR (когда  {{event("vrdisplayblur")}} событие срабатывает) — например, в то время как пользователь взаимодействует с системным меню или браузером, чтобы предотвратить отслеживание или потерю опыта.
{{domxref("Window.onvrdisplayfocus")}}
Представляет обработчик событий, который будет выполняться, когда презентация на дисплей возобновляется после потери фокуса (когда {{event("vrdisplayfocus")}} событие срабатывает).

Примеры

Вы можете найти несколько примеров в этих местах:

Спецификация

Спецификация Статус Комментарий
{{SpecName("GamepadExtensions")}} {{Spec2("GamepadExtensions")}}

Определяет Experimental Gamepad extensions.

{{SpecName('WebVR 1.1')}} {{Spec2('WebVR 1.1')}} Первоначальное определение

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

{{CompatibilityTable}}

Feature Chrome Edge Firefox (Gecko) Internet Explorer Opera Safari (WebKit)
Basic support {{CompatNo}}[1] {{CompatVersionUnknown}} {{CompatGeckoDesktop(55)}}[2] {{CompatNo}} {{CompatNo}} {{CompatNo}}
Gamepad extensions {{CompatNo}} {{CompatNo}} {{CompatNo}}[3] {{CompatNo}} {{CompatNo}} {{CompatNo}}
Feature Android Webview Chrome for Android Edge Firefox Mobile (Gecko) IE Phone Opera Mobile Safari Mobile Samsung Internet for GearVR
Basic support {{CompatNo}} {{CompatNo}}[1] {{CompatNo}} {{CompatNo}} {{CompatNo}} {{CompatNo}} {{CompatNo}} {{CompatVersionUnknown}}
 
Gamepad extensions {{CompatNo}} {{CompatNo}} {{CompatNo}} {{CompatNo}}[3] {{CompatNo}} {{CompatNo}} {{CompatNo}} {{CompatNo}}

[1] Origin trials only.

[2] В настоящее время только в Windows и Mac OSX поддержка включена по умолчанию.

[3] Включено в Firefox Nightly и Beta, версии 55 и выше. Включено / отключено с помощью  dom.gamepad-extensions.enabled pref.

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