summaryrefslogtreecommitdiffstats
path: root/gfx/vr/VRDisplayPresentation.cpp
diff options
context:
space:
mode:
authorwolfbeast <mcwerewolf@wolfbeast.com>2019-01-06 15:14:54 +0100
committerwolfbeast <mcwerewolf@wolfbeast.com>2019-01-06 15:14:54 +0100
commitcc6a935ce54b573c1efd7533aff00e7bf0a9959c (patch)
treec8ad266edb7ea1e7b93aaaaa98847cf662373668 /gfx/vr/VRDisplayPresentation.cpp
parentd129c900c9f943adb69c1fb20ba1a029fdd95cff (diff)
parent9f4afc2552a67cc675b8b8af2ecb8ebc04a473a7 (diff)
downloadUXP-cc6a935ce54b573c1efd7533aff00e7bf0a9959c.tar
UXP-cc6a935ce54b573c1efd7533aff00e7bf0a9959c.tar.gz
UXP-cc6a935ce54b573c1efd7533aff00e7bf0a9959c.tar.lz
UXP-cc6a935ce54b573c1efd7533aff00e7bf0a9959c.tar.xz
UXP-cc6a935ce54b573c1efd7533aff00e7bf0a9959c.zip
Merge branch 'master' into Pale_Moon-release
# Conflicts: # application/palemoon/components/feeds/FeedWriter.js # application/palemoon/config/version.txt # security/manager/ssl/nsSTSPreloadList.errors # security/manager/ssl/nsSTSPreloadList.inc
Diffstat (limited to 'gfx/vr/VRDisplayPresentation.cpp')
-rw-r--r--gfx/vr/VRDisplayPresentation.cpp112
1 files changed, 0 insertions, 112 deletions
diff --git a/gfx/vr/VRDisplayPresentation.cpp b/gfx/vr/VRDisplayPresentation.cpp
deleted file mode 100644
index ba528ae7c..000000000
--- a/gfx/vr/VRDisplayPresentation.cpp
+++ /dev/null
@@ -1,112 +0,0 @@
-/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-* This Source Code Form is subject to the terms of the Mozilla Public
-* License, v. 2.0. If a copy of the MPL was not distributed with this
-* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-
-#include "VRDisplayPresentation.h"
-
-#include "mozilla/Unused.h"
-#include "VRDisplayClient.h"
-#include "VRLayerChild.h"
-
-using namespace mozilla;
-using namespace mozilla::gfx;
-
-VRDisplayPresentation::VRDisplayPresentation(VRDisplayClient *aDisplayClient,
- const nsTArray<mozilla::dom::VRLayer>& aLayers)
- : mDisplayClient(aDisplayClient)
- , mDOMLayers(aLayers)
-{
- CreateLayers();
-}
-
-void
-VRDisplayPresentation::CreateLayers()
-{
- if (mLayers.Length()) {
- return;
- }
-
- for (dom::VRLayer& layer : mDOMLayers) {
- dom::HTMLCanvasElement* canvasElement = layer.mSource;
- if (!canvasElement) {
- /// XXX In the future we will support WebVR in WebWorkers here
- continue;
- }
-
- Rect leftBounds(0.0, 0.0, 0.5, 1.0);
- if (layer.mLeftBounds.Length() == 4) {
- leftBounds.x = layer.mLeftBounds[0];
- leftBounds.y = layer.mLeftBounds[1];
- leftBounds.width = layer.mLeftBounds[2];
- leftBounds.height = layer.mLeftBounds[3];
- } else if (layer.mLeftBounds.Length() != 0) {
- /**
- * We ignore layers with an incorrect number of values.
- * In the future, VRDisplay.requestPresent may throw in
- * this case. See https://github.com/w3c/webvr/issues/71
- */
- continue;
- }
-
- Rect rightBounds(0.5, 0.0, 0.5, 1.0);
- if (layer.mRightBounds.Length() == 4) {
- rightBounds.x = layer.mRightBounds[0];
- rightBounds.y = layer.mRightBounds[1];
- rightBounds.width = layer.mRightBounds[2];
- rightBounds.height = layer.mRightBounds[3];
- } else if (layer.mRightBounds.Length() != 0) {
- /**
- * We ignore layers with an incorrect number of values.
- * In the future, VRDisplay.requestPresent may throw in
- * this case. See https://github.com/w3c/webvr/issues/71
- */
- continue;
- }
-
- VRManagerChild *manager = VRManagerChild::Get();
- if (!manager) {
- NS_WARNING("VRManagerChild::Get returned null!");
- continue;
- }
-
- RefPtr<VRLayerChild> vrLayer = static_cast<VRLayerChild*>(manager->CreateVRLayer(mDisplayClient->GetDisplayInfo().GetDisplayID(), leftBounds, rightBounds));
- if (!vrLayer) {
- NS_WARNING("CreateVRLayer returned null!");
- continue;
- }
-
- vrLayer->Initialize(canvasElement);
-
- mLayers.AppendElement(vrLayer);
- }
-}
-
-void
-VRDisplayPresentation::DestroyLayers()
-{
- for (VRLayerChild* layer : mLayers) {
- Unused << layer->SendDestroy();
- }
- mLayers.Clear();
-}
-
-void
-VRDisplayPresentation::GetDOMLayers(nsTArray<dom::VRLayer>& result)
-{
- result = mDOMLayers;
-}
-
-VRDisplayPresentation::~VRDisplayPresentation()
-{
- DestroyLayers();
- mDisplayClient->PresentationDestroyed();
-}
-
-void VRDisplayPresentation::SubmitFrame()
-{
- for (VRLayerChild *layer : mLayers) {
- layer->SubmitFrame();
- break; // Currently only one layer supported, submit only the first
- }
-}