From 3e47cb1df7ea039a04fa9efe8f56852a9c627f48 Mon Sep 17 00:00:00 2001 From: Imanol Fernandez Date: Tue, 9 Apr 2019 22:36:02 +0200 Subject: [PATCH] Add UI texture scaling (#790) --- .../mozilla/vrbrowser/VRBrowserActivity.java | 19 +++++++++++++------ .../vrbrowser/ui/widgets/TrayWidget.java | 1 + .../vrbrowser/ui/widgets/WidgetPlacement.java | 2 ++ .../vrbrowser/ui/widgets/WindowWidget.java | 1 + app/src/main/cpp/BrowserWorld.cpp | 7 +++---- app/src/main/cpp/Widget.cpp | 4 ++-- app/src/main/cpp/WidgetPlacement.cpp | 11 +++++++++++ app/src/main/cpp/WidgetPlacement.h | 4 ++++ 8 files changed, 37 insertions(+), 12 deletions(-) diff --git a/app/src/common/shared/org/mozilla/vrbrowser/VRBrowserActivity.java b/app/src/common/shared/org/mozilla/vrbrowser/VRBrowserActivity.java index 4885c7fac..6e9b44f4a 100644 --- a/app/src/common/shared/org/mozilla/vrbrowser/VRBrowserActivity.java +++ b/app/src/common/shared/org/mozilla/vrbrowser/VRBrowserActivity.java @@ -475,8 +475,10 @@ public void onFrameAvailable(SurfaceTexture surfaceTexture) { } widget.setSurfaceTexture(aTexture, aWidth, aHeight); // Add widget to a virtual display for invalidation - if (((View)widget).getParent() == null) { - mWidgetContainer.addView((View) widget, new FrameLayout.LayoutParams(aWidth, aHeight)); + View view = (View) widget; + if (view.getParent() == null) { + float scale = widget.getPlacement().textureScale; + mWidgetContainer.addView(view, new FrameLayout.LayoutParams((int) Math.ceil(aWidth / scale), (int) Math.ceil(aHeight / scale))); } }); } @@ -507,7 +509,8 @@ void dispatchCreateWidgetLayer(final int aHandle, final Surface aSurface, final View view = (View) widget; // Add widget to a virtual display for invalidation if (aSurface != null && view.getParent() == null) { - mWidgetContainer.addView(view, new FrameLayout.LayoutParams(aWidth, aHeight)); + float scale = widget.getPlacement().textureScale; + mWidgetContainer.addView(view, new FrameLayout.LayoutParams((int) Math.ceil(aWidth / scale), (int) Math.ceil(aHeight / scale))); } else if (aSurface == null && view.getParent() != null) { mWidgetContainer.removeView(view); } @@ -520,13 +523,17 @@ void dispatchCreateWidgetLayer(final int aHandle, final Surface aSurface, final void handleMotionEvent(final int aHandle, final int aDevice, final boolean aPressed, final float aX, final float aY) { runOnUiThread(() -> { Widget widget = mWidgets.get(aHandle); + float scale = widget != null ? widget.getPlacement().textureScale : 1.0f; + final float x = aX / scale; + final float y = aY / scale; + if (widget == null) { - MotionEventGenerator.dispatch(mRootWidget, aDevice, aPressed, aX, aY); + MotionEventGenerator.dispatch(mRootWidget, aDevice, aPressed, x, y); } else if (widget == mWindowWidget && mWindowWidget.getBorderWidth() > 0) { final int border = mWindowWidget.getBorderWidth(); - MotionEventGenerator.dispatch(widget, aDevice, aPressed, aX - border, aY - border); + MotionEventGenerator.dispatch(widget, aDevice, aPressed, x - border, y - border); } else { - MotionEventGenerator.dispatch(widget, aDevice, aPressed, aX, aY); + MotionEventGenerator.dispatch(widget, aDevice, aPressed, x, y); } }); } diff --git a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/TrayWidget.java b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/TrayWidget.java index b941c123c..9210c8e23 100644 --- a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/TrayWidget.java +++ b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/TrayWidget.java @@ -203,6 +203,7 @@ protected void initializeWidgetPlacement(WidgetPlacement aPlacement) { aPlacement.rotation = (float)Math.toRadians(-45); aPlacement.opaque = false; aPlacement.cylinder = false; + aPlacement.textureScale = 1.0f; } @Override diff --git a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WidgetPlacement.java b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WidgetPlacement.java index d07cd8dec..19b4900d8 100644 --- a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WidgetPlacement.java +++ b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WidgetPlacement.java @@ -40,6 +40,7 @@ public WidgetPlacement(Context aContext) { public boolean firstDraw = false; public boolean layer = true; public boolean cylinder = true; + public float textureScale = 0.7f; public WidgetPlacement clone() { WidgetPlacement w = new WidgetPlacement(); @@ -70,6 +71,7 @@ public void copyFrom(WidgetPlacement w) { this.firstDraw = w.firstDraw; this.layer = w.layer; this.cylinder = w.cylinder; + this.textureScale = w.textureScale; } public int textureWidth() { diff --git a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WindowWidget.java b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WindowWidget.java index 8fb90ee58..87fca6af8 100644 --- a/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WindowWidget.java +++ b/app/src/common/shared/org/mozilla/vrbrowser/ui/widgets/WindowWidget.java @@ -96,6 +96,7 @@ protected void initializeWidgetPlacement(WidgetPlacement aPlacement) { aPlacement.anchorY = 0.0f; aPlacement.visible = true; aPlacement.cylinder = true; + aPlacement.textureScale = 1.0f; } @Override diff --git a/app/src/main/cpp/BrowserWorld.cpp b/app/src/main/cpp/BrowserWorld.cpp index be913cb15..61a247894 100644 --- a/app/src/main/cpp/BrowserWorld.cpp +++ b/app/src/main/cpp/BrowserWorld.cpp @@ -713,8 +713,8 @@ BrowserWorld::AddWidget(int32_t aHandle, const WidgetPlacementPtr& aPlacement) { worldWidth = aPlacement->width * kWorldDPIRatio; } - int32_t textureWidth = (int32_t)(ceilf(aPlacement->width * aPlacement->density)); - int32_t textureHeight = (int32_t)(ceilf(aPlacement->height * aPlacement->density)); + const int32_t textureWidth = aPlacement->GetTextureWidth(); + const int32_t textureHeight = aPlacement->GetTextureHeight(); const float aspect = (float)textureWidth / (float)textureHeight; const float worldHeight = worldWidth / aspect; @@ -765,8 +765,7 @@ BrowserWorld::UpdateWidget(int32_t aHandle, const WidgetPlacementPtr& aPlacement widget->SetPlacement(aPlacement); widget->SetCylinderDensity(m.cylinderDensity); widget->ToggleWidget(aPlacement->visible); - widget->SetSurfaceTextureSize((int32_t)(ceilf(aPlacement->width * aPlacement->density)), - (int32_t)(ceilf(aPlacement->height * aPlacement->density))); + widget->SetSurfaceTextureSize(aPlacement->GetTextureWidth(), aPlacement->GetTextureHeight()); float worldWidth = 0.0f, worldHeight = 0.0f; widget->GetWorldSize(worldWidth, worldHeight); diff --git a/app/src/main/cpp/Widget.cpp b/app/src/main/cpp/Widget.cpp index bdc4e4a37..06355caf5 100644 --- a/app/src/main/cpp/Widget.cpp +++ b/app/src/main/cpp/Widget.cpp @@ -130,8 +130,8 @@ struct Widget::State { cylinder->GetTextureSize(textureWidth, textureHeight); const float radius = cylinder->GetCylinderRadius(); - const float surfaceWidth = (float)textureWidth / placement->density; - const float surfaceHeight = (float)textureHeight / placement->density; + const float surfaceWidth = (float)textureWidth / placement->density * placement->textureScale; + const float surfaceHeight = (float)textureHeight / placement->density * placement->textureScale; // Cylinder density measures the pixels for a 360 cylinder // Oculus recommends 4680px density, which is 13 pixels per degree. const float theta = (float)M_PI * surfaceWidth / (cylinderDensity * 0.5f); diff --git a/app/src/main/cpp/WidgetPlacement.cpp b/app/src/main/cpp/WidgetPlacement.cpp index 128b1b8fe..f3ebaf29d 100644 --- a/app/src/main/cpp/WidgetPlacement.cpp +++ b/app/src/main/cpp/WidgetPlacement.cpp @@ -54,8 +54,19 @@ WidgetPlacement::FromJava(JNIEnv* aEnv, jobject& aObject) { GET_BOOLEAN_FIELD(firstDraw); GET_BOOLEAN_FIELD(layer); GET_BOOLEAN_FIELD(cylinder); + GET_FLOAT_FIELD(textureScale, "textureScale"); return result; } +int32_t +WidgetPlacement::GetTextureWidth() const{ + return (int32_t)ceilf(width * density * textureScale); +} + +int32_t +WidgetPlacement::GetTextureHeight() const { + return (int32_t)ceilf(height * density * textureScale); +} + } \ No newline at end of file diff --git a/app/src/main/cpp/WidgetPlacement.h b/app/src/main/cpp/WidgetPlacement.h index 7a8b37315..d18e08caa 100644 --- a/app/src/main/cpp/WidgetPlacement.h +++ b/app/src/main/cpp/WidgetPlacement.h @@ -32,6 +32,10 @@ struct WidgetPlacement { bool firstDraw; bool layer; bool cylinder; + float textureScale; + + int32_t GetTextureWidth() const; + int32_t GetTextureHeight() const; static WidgetPlacementPtr FromJava(JNIEnv* aEnv, jobject& aObject); private: