Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1438)

Unified Diff: Source/modules/vr/HMDVRDevice.cpp

Issue 848053002: Adding WebVR interface to Blink (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Fixed compiler warning treated as an error on Windows Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/modules/vr/HMDVRDevice.cpp
diff --git a/Source/modules/vr/HMDVRDevice.cpp b/Source/modules/vr/HMDVRDevice.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..2aa73e15e568b9bb06e1312d5e3d2e31a17390ae
--- /dev/null
+++ b/Source/modules/vr/HMDVRDevice.cpp
@@ -0,0 +1,97 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "config.h"
+#include "modules/vr/HMDVRDevice.h"
+
+#include "modules/vr/VRFieldOfView.h"
+#include "public/platform/Platform.h"
+#include "public/platform/WebSize.h"
+
+namespace blink {
+
+HMDVRDevice::HMDVRDevice(VRHardwareUnit* hardwareUnit)
+ : VRDevice(hardwareUnit)
+ , m_dirtyFov(true)
+{
+ m_eyeParametersLeft = VREyeParameters::create();
+ m_eyeParametersRight = VREyeParameters::create();
+}
+
+VREye HMDVRDevice::StringToVREye(const String& whichEye)
+{
+ if (whichEye == "left")
+ return VREyeLeft;
+ if (whichEye == "right")
+ return VREyeRight;
+ return VREyeNone;
+}
+
+void HMDVRDevice::updateFromWebVRDevice(const WebVRDevice& device)
+{
+ VRDevice::updateFromWebVRDevice(device);
+ const blink::WebVRHMDInfo &hmdInfo = device.hmdInfo;
+
+ m_eyeParametersLeft->setFromWebVREyeParameters(hmdInfo.leftEye);
+ m_eyeParametersRight->setFromWebVREyeParameters(hmdInfo.rightEye);
+}
+
+VREyeParameters* HMDVRDevice::getEyeParameters(const String& whichEye)
+{
+ // If we have updated the field of view since the last call recompute the render rects.
+ if (m_dirtyFov) {
+ blink::WebVRVector4 leftRect, rightRect;
+ blink::Platform::current()->getVRRenderTargetRects(index(),
+ m_eyeParametersLeft->currentFieldOfView()->toWebVRFieldOfView(),
+ m_eyeParametersRight->currentFieldOfView()->toWebVRFieldOfView(),
+ &leftRect,
+ &rightRect);
+
+ m_eyeParametersLeft->setRenderRect(leftRect.x, leftRect.y, leftRect.z, leftRect.w);
+ m_eyeParametersRight->setRenderRect(rightRect.x, rightRect.y, rightRect.z, rightRect.w);
+
+ m_dirtyFov = false;
+ }
+
+ switch (StringToVREye(whichEye)) {
+ case VREyeLeft:
+ return m_eyeParametersLeft;
+ case VREyeRight:
+ return m_eyeParametersRight;
+ default:
+ return nullptr;
+ }
+}
+
+void HMDVRDevice::setFieldOfView(VRFieldOfView* leftFov, VRFieldOfView* rightFov)
+{
+ m_dirtyFov = true;
+
+ // FIXME: Clamp to maxFOV
+ if (leftFov) {
+ hardwareUnit()->setFieldOfView(VREyeLeft, leftFov);
+ m_eyeParametersLeft->setCurrentFieldOfView(leftFov);
+ } else {
+ hardwareUnit()->setFieldOfView(VREyeLeft, m_eyeParametersLeft->recommendedFieldOfView());
+ m_eyeParametersLeft->setCurrentFieldOfView(m_eyeParametersLeft->recommendedFieldOfView());
+ }
+
+ if (rightFov) {
+ hardwareUnit()->setFieldOfView(VREyeRight, rightFov);
+ m_eyeParametersLeft->setCurrentFieldOfView(rightFov);
+ } else {
+ hardwareUnit()->setFieldOfView(VREyeRight, m_eyeParametersRight->recommendedFieldOfView());
+ m_eyeParametersRight->setCurrentFieldOfView(m_eyeParametersRight->recommendedFieldOfView());
+ }
+}
+
+void HMDVRDevice::trace(Visitor* visitor)
+{
+ visitor->trace(m_eyeParametersLeft);
+ visitor->trace(m_eyeParametersRight);
+
+ VRDevice::trace(visitor);
+}
+
+} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698