mirror of
https://github.com/Armored-Dragon/overte.git
synced 2025-03-11 16:13:16 +01:00
fixed qml font path issue for desktop and tablet
This commit is contained in:
parent
648e8fccac
commit
afd56bbbbe
10 changed files with 358 additions and 34 deletions
342
interface/resources/qml/hifi/dialogs/TabletRunningScripts.qml
Normal file
342
interface/resources/qml/hifi/dialogs/TabletRunningScripts.qml
Normal file
|
@ -0,0 +1,342 @@
|
||||||
|
//
|
||||||
|
// RunningScripts.qml
|
||||||
|
//
|
||||||
|
// Created by Bradley Austin Davis on 12 Jan 2016
|
||||||
|
// Copyright 2016 High Fidelity, Inc.
|
||||||
|
//
|
||||||
|
// Distributed under the Apache License, Version 2.0.
|
||||||
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||||
|
//
|
||||||
|
|
||||||
|
import QtQuick 2.5
|
||||||
|
import QtQuick.Controls 1.4
|
||||||
|
import QtQuick.Dialogs 1.2 as OriginalDialogs
|
||||||
|
import Qt.labs.settings 1.0
|
||||||
|
|
||||||
|
import "../../styles-uit"
|
||||||
|
import "../../controls-uit" as HifiControls
|
||||||
|
import "../../windows"
|
||||||
|
|
||||||
|
Item {
|
||||||
|
id: root
|
||||||
|
objectName: "RunningScripts"
|
||||||
|
HifiConstants { id: hifi }
|
||||||
|
signal sendToScript(var message);
|
||||||
|
property var eventBridge;
|
||||||
|
property var scripts: ScriptDiscoveryService;
|
||||||
|
property var scriptsModel: scripts.scriptsModelFilter
|
||||||
|
property var runningScriptsModel: ListModel { }
|
||||||
|
property bool isHMD: false
|
||||||
|
|
||||||
|
Connections {
|
||||||
|
target: ScriptDiscoveryService
|
||||||
|
onScriptCountChanged: updateRunningScripts();
|
||||||
|
}
|
||||||
|
|
||||||
|
Component.onCompleted: {
|
||||||
|
isHMD = HMD.active;
|
||||||
|
updateRunningScripts();
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateRunningScripts() {
|
||||||
|
var runningScripts = ScriptDiscoveryService.getRunning();
|
||||||
|
runningScriptsModel.clear()
|
||||||
|
for (var i = 0; i < runningScripts.length; ++i) {
|
||||||
|
runningScriptsModel.append(runningScripts[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function loadScript(script) {
|
||||||
|
console.log("Load script " + script);
|
||||||
|
scripts.loadOneScript(script);
|
||||||
|
}
|
||||||
|
|
||||||
|
function reloadScript(script) {
|
||||||
|
console.log("Reload script " + script);
|
||||||
|
scripts.stopScript(script, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
function stopScript(script) {
|
||||||
|
console.log("Stop script " + script);
|
||||||
|
scripts.stopScript(script);
|
||||||
|
}
|
||||||
|
|
||||||
|
function reloadAll() {
|
||||||
|
console.log("Reload all scripts");
|
||||||
|
scripts.reloadAllScripts();
|
||||||
|
}
|
||||||
|
|
||||||
|
function loadDefaults() {
|
||||||
|
console.log("Load default scripts");
|
||||||
|
scripts.loadOneScript(scripts.defaultScriptsPath + "/defaultScripts.js");
|
||||||
|
}
|
||||||
|
|
||||||
|
function stopAll() {
|
||||||
|
console.log("Stop all scripts");
|
||||||
|
scripts.stopAllScripts();
|
||||||
|
}
|
||||||
|
|
||||||
|
Column {
|
||||||
|
width: parent.width
|
||||||
|
HifiControls.TabletContentSection {
|
||||||
|
name: "Currently Running"
|
||||||
|
isFirst: true
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {}
|
||||||
|
|
||||||
|
Row {
|
||||||
|
spacing: hifi.dimensions.contentSpacing.x
|
||||||
|
|
||||||
|
HifiControls.Button {
|
||||||
|
text: "Reload All"
|
||||||
|
color: hifi.buttons.black
|
||||||
|
onClicked: reloadAll()
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.Button {
|
||||||
|
text: "Remove All"
|
||||||
|
color: hifi.buttons.red
|
||||||
|
onClicked: stopAll()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {
|
||||||
|
height: hifi.dimensions.controlInterlineHeight + 2 // Add space for border
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.Table {
|
||||||
|
model: runningScriptsModel
|
||||||
|
id: table
|
||||||
|
height: 185
|
||||||
|
colorScheme: hifi.colorSchemes.dark
|
||||||
|
anchors.left: parent.left
|
||||||
|
anchors.right: parent.right
|
||||||
|
expandSelectedRow: true
|
||||||
|
|
||||||
|
itemDelegate: Item {
|
||||||
|
anchors {
|
||||||
|
left: parent ? parent.left : undefined
|
||||||
|
leftMargin: hifi.dimensions.tablePadding
|
||||||
|
right: parent ? parent.right : undefined
|
||||||
|
rightMargin: hifi.dimensions.tablePadding
|
||||||
|
}
|
||||||
|
|
||||||
|
FiraSansSemiBold {
|
||||||
|
id: textItem
|
||||||
|
text: styleData.value
|
||||||
|
size: hifi.fontSizes.tableText
|
||||||
|
color: table.colorScheme == hifi.colorSchemes.light
|
||||||
|
? (styleData.selected ? hifi.colors.black : hifi.colors.baseGrayHighlight)
|
||||||
|
: (styleData.selected ? hifi.colors.black : hifi.colors.lightGrayText)
|
||||||
|
anchors {
|
||||||
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
top: parent.top
|
||||||
|
topMargin: 3
|
||||||
|
}
|
||||||
|
|
||||||
|
HiFiGlyphs {
|
||||||
|
id: reloadButton
|
||||||
|
text: hifi.glyphs.reloadSmall
|
||||||
|
color: reloadButtonArea.pressed ? hifi.colors.white : parent.color
|
||||||
|
anchors {
|
||||||
|
top: parent.top
|
||||||
|
right: stopButton.left
|
||||||
|
verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
|
MouseArea {
|
||||||
|
id: reloadButtonArea
|
||||||
|
anchors { fill: parent; margins: -2 }
|
||||||
|
onClicked: reloadScript(model.url)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HiFiGlyphs {
|
||||||
|
id: stopButton
|
||||||
|
text: hifi.glyphs.closeSmall
|
||||||
|
color: stopButtonArea.pressed ? hifi.colors.white : parent.color
|
||||||
|
anchors {
|
||||||
|
top: parent.top
|
||||||
|
right: parent.right
|
||||||
|
verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
|
MouseArea {
|
||||||
|
id: stopButtonArea
|
||||||
|
anchors { fill: parent; margins: -2 }
|
||||||
|
onClicked: stopScript(model.url)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
FiraSansSemiBold {
|
||||||
|
text: runningScriptsModel.get(styleData.row) ? runningScriptsModel.get(styleData.row).url : ""
|
||||||
|
elide: Text.ElideMiddle
|
||||||
|
size: hifi.fontSizes.tableText
|
||||||
|
color: table.colorScheme == hifi.colorSchemes.light
|
||||||
|
? (styleData.selected ? hifi.colors.black : hifi.colors.lightGray)
|
||||||
|
: (styleData.selected ? hifi.colors.black : hifi.colors.lightGrayText)
|
||||||
|
anchors {
|
||||||
|
top: textItem.bottom
|
||||||
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
}
|
||||||
|
visible: styleData.selected
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TableViewColumn {
|
||||||
|
role: "name"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {
|
||||||
|
height: hifi.dimensions.controlInterlineHeight + 2 // Add space for border
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.TabletContentSection {
|
||||||
|
name: "Load Scripts"
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {}
|
||||||
|
|
||||||
|
Row {
|
||||||
|
spacing: hifi.dimensions.contentSpacing.x
|
||||||
|
|
||||||
|
HifiControls.Button {
|
||||||
|
text: "from URL"
|
||||||
|
color: hifi.buttons.black
|
||||||
|
height: 26
|
||||||
|
onClicked: fromUrlTimer.running = true
|
||||||
|
|
||||||
|
// For some reason trigginer an API that enters
|
||||||
|
// an internal event loop directly from the button clicked
|
||||||
|
// trigger below causes the appliction to behave oddly.
|
||||||
|
// Most likely because the button onClicked handling is never
|
||||||
|
// completed until the function returns.
|
||||||
|
// FIXME find a better way of handling the input dialogs that
|
||||||
|
// doesn't trigger this.
|
||||||
|
Timer {
|
||||||
|
id: fromUrlTimer
|
||||||
|
interval: 5
|
||||||
|
repeat: false
|
||||||
|
running: false
|
||||||
|
onTriggered: ApplicationInterface.loadScriptURLDialog();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.Button {
|
||||||
|
text: "from Disk"
|
||||||
|
color: hifi.buttons.black
|
||||||
|
height: 26
|
||||||
|
onClicked: fromDiskTimer.running = true
|
||||||
|
|
||||||
|
Timer {
|
||||||
|
id: fromDiskTimer
|
||||||
|
interval: 5
|
||||||
|
repeat: false
|
||||||
|
running: false
|
||||||
|
onTriggered: ApplicationInterface.loadDialog();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.Button {
|
||||||
|
text: "Load Defaults"
|
||||||
|
color: hifi.buttons.black
|
||||||
|
height: 26
|
||||||
|
onClicked: loadDefaults()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {}
|
||||||
|
|
||||||
|
HifiControls.TextField {
|
||||||
|
id: filterEdit
|
||||||
|
isSearchField: true
|
||||||
|
anchors.left: parent.left
|
||||||
|
anchors.right: parent.right
|
||||||
|
colorScheme: hifi.colorSchemes.dark
|
||||||
|
placeholderText: "Filter"
|
||||||
|
onTextChanged: scriptsModel.filterRegExp = new RegExp("^.*" + text + ".*$", "i")
|
||||||
|
Component.onCompleted: scriptsModel.filterRegExp = new RegExp("^.*$", "i")
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {
|
||||||
|
height: hifi.dimensions.controlInterlineHeight + 2 // Add space for border
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.Tree {
|
||||||
|
id: treeView
|
||||||
|
height: 155
|
||||||
|
treeModel: scriptsModel
|
||||||
|
colorScheme: hifi.colorSchemes.dark
|
||||||
|
anchors.left: parent.left
|
||||||
|
anchors.right: parent.right
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {
|
||||||
|
height: hifi.dimensions.controlInterlineHeight + 2 // Add space for border
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.TextField {
|
||||||
|
id: selectedScript
|
||||||
|
anchors.left: parent.left
|
||||||
|
anchors.right: parent.right
|
||||||
|
anchors.rightMargin: loadButton.width + hifi.dimensions.contentSpacing.x
|
||||||
|
|
||||||
|
colorScheme: hifi.colorSchemes.dark
|
||||||
|
readOnly: true
|
||||||
|
|
||||||
|
Connections {
|
||||||
|
target: treeView
|
||||||
|
onCurrentIndexChanged: {
|
||||||
|
var path = scriptsModel.data(treeView.currentIndex, 0x100)
|
||||||
|
if (path) {
|
||||||
|
selectedScript.text = path
|
||||||
|
} else {
|
||||||
|
selectedScript.text = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Item {
|
||||||
|
// Take the loadButton out of the column flow.
|
||||||
|
id: loadButtonContainer
|
||||||
|
anchors.top: selectedScript.top
|
||||||
|
anchors.right: parent.right
|
||||||
|
|
||||||
|
HifiControls.Button {
|
||||||
|
id: loadButton
|
||||||
|
anchors.right: parent.right
|
||||||
|
|
||||||
|
text: "Load"
|
||||||
|
color: hifi.buttons.blue
|
||||||
|
enabled: selectedScript.text != ""
|
||||||
|
onClicked: root.loadScript(selectedScript.text)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {
|
||||||
|
height: hifi.dimensions.controlInterlineHeight - (!isHMD ? 3 : 0)
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.TextAction {
|
||||||
|
id: directoryButton
|
||||||
|
icon: hifi.glyphs.script
|
||||||
|
iconSize: 24
|
||||||
|
text: "Reveal Scripts Folder"
|
||||||
|
onClicked: fileDialogHelper.openDirectory(scripts.defaultScriptsPath)
|
||||||
|
colorScheme: hifi.colorSchemes.dark
|
||||||
|
anchors.left: parent.left
|
||||||
|
visible: !isHMD
|
||||||
|
}
|
||||||
|
|
||||||
|
HifiControls.VerticalSpacer {
|
||||||
|
height: hifi.dimensions.controlInterlineHeight - 3
|
||||||
|
visible: !isHMD
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -110,10 +110,6 @@ FocusScope {
|
||||||
buildMenu();
|
buildMenu();
|
||||||
}
|
}
|
||||||
function buildMenu() {
|
function buildMenu() {
|
||||||
<<<<<<< HEAD
|
|
||||||
<<<<<<< HEAD
|
|
||||||
=======
|
|
||||||
>>>>>>> updated menu stack
|
|
||||||
// Build submenu if specified.
|
// Build submenu if specified.
|
||||||
if (subMenu !== "") {
|
if (subMenu !== "") {
|
||||||
var index = 0;
|
var index = 0;
|
||||||
|
@ -132,13 +128,6 @@ FocusScope {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise build whole menu.
|
// Otherwise build whole menu.
|
||||||
<<<<<<< HEAD
|
|
||||||
menuPopperUpper.popup(tabletMenu, rootMenu.items);
|
|
||||||
=======
|
|
||||||
menuPopperUpper.popup(rootMenu.items);
|
menuPopperUpper.popup(rootMenu.items);
|
||||||
>>>>>>> updating branch with master
|
|
||||||
=======
|
|
||||||
menuPopperUpper.popup(rootMenu.items);
|
|
||||||
>>>>>>> updated menu stack
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,16 +17,6 @@ Item {
|
||||||
id: root
|
id: root
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
objectName: "tabletMenuHandlerItem"
|
objectName: "tabletMenuHandlerItem"
|
||||||
|
|
||||||
MouseArea {
|
|
||||||
id: menuRoot;
|
|
||||||
objectName: "tabletMenuHandlerMouseArea"
|
|
||||||
anchors.fill: parent
|
|
||||||
enabled: d.topMenu !== null
|
|
||||||
onClicked: {
|
|
||||||
d.clearMenus();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
StackView {
|
StackView {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
|
@ -61,9 +51,11 @@ Item {
|
||||||
d.push(Qt.resolvedUrl(path));
|
d.push(Qt.resolvedUrl(path));
|
||||||
d.currentItem.eventBridge = tabletMenu.eventBridge
|
d.currentItem.eventBridge = tabletMenu.eventBridge
|
||||||
d.currentItem.sendToScript.connect(tabletMenu.sendToScript);
|
d.currentItem.sendToScript.connect(tabletMenu.sendToScript);
|
||||||
|
breadcrumbText.text = d.currentItem.objectName;
|
||||||
}
|
}
|
||||||
|
|
||||||
function popSource() {
|
function popSource() {
|
||||||
|
console.log("trying to pop page");
|
||||||
d.pop();
|
d.pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,7 +82,9 @@ Item {
|
||||||
}
|
}
|
||||||
|
|
||||||
function popMenu() {
|
function popMenu() {
|
||||||
|
console.log("the depth of the stack " + d.depth);
|
||||||
if (d.depth) {
|
if (d.depth) {
|
||||||
|
console.log("trying to pop page from stack");
|
||||||
d.pop();
|
d.pop();
|
||||||
}
|
}
|
||||||
if (d.depth) {
|
if (d.depth) {
|
||||||
|
|
|
@ -14,7 +14,7 @@ import QtQuick.Controls.Styles 1.4
|
||||||
|
|
||||||
Text {
|
Text {
|
||||||
id: root
|
id: root
|
||||||
FontLoader { id: firaSansSemiBold; source: "../../fonts/FiraSans-SemiBold.ttf"; }
|
FontLoader { id: firaSansSemiBold; source: pathToFonts + "fonts/FiraSans-SemiBold.ttf"; }
|
||||||
property real size: 32
|
property real size: 32
|
||||||
font.pixelSize: size
|
font.pixelSize: size
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
|
|
@ -14,7 +14,7 @@ import QtQuick.Controls.Styles 1.4
|
||||||
|
|
||||||
Text {
|
Text {
|
||||||
id: root
|
id: root
|
||||||
FontLoader { id: hiFiGlyphs; source: "../../fonts/hifi-glyphs.ttf"; }
|
FontLoader { id: hiFiGlyphs; source: pathToFonts + "fonts/hifi-glyphs.ttf"; }
|
||||||
property int size: 32
|
property int size: 32
|
||||||
font.pixelSize: size
|
font.pixelSize: size
|
||||||
width: size
|
width: size
|
||||||
|
|
|
@ -14,7 +14,7 @@ import QtQuick.Controls.Styles 1.4
|
||||||
|
|
||||||
Text {
|
Text {
|
||||||
id: root
|
id: root
|
||||||
FontLoader { id: ralewayBold; source: "../../fonts/Raleway-Bold.ttf"; }
|
FontLoader { id: ralewayBold; source: pathToFonts + "fonts/Raleway-Bold.ttf"; }
|
||||||
property real size: 32
|
property real size: 32
|
||||||
font.pixelSize: size
|
font.pixelSize: size
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
|
|
@ -14,7 +14,7 @@ import QtQuick.Controls.Styles 1.4
|
||||||
|
|
||||||
Text {
|
Text {
|
||||||
id: root
|
id: root
|
||||||
FontLoader { id: ralewayRegular; source: "../../fonts/Raleway-Regular.ttf"; }
|
FontLoader { id: ralewayRegular; source: pathToFonts + "fonts/Raleway-Regular.ttf"; }
|
||||||
property real size: 32
|
property real size: 32
|
||||||
font.pixelSize: size
|
font.pixelSize: size
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
|
|
@ -14,7 +14,7 @@ import QtQuick.Controls.Styles 1.4
|
||||||
|
|
||||||
Text {
|
Text {
|
||||||
id: root
|
id: root
|
||||||
FontLoader { id: ralewaySemiBold; source: "../../fonts/Raleway-SemiBold.ttf"; }
|
FontLoader { id: ralewaySemiBold; source: pathToFonts + "fonts/Raleway-SemiBold.ttf"; }
|
||||||
property real size: 32
|
property real size: 32
|
||||||
font.pixelSize: size
|
font.pixelSize: size
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
|
|
@ -1940,6 +1940,7 @@ void Application::initializeUi() {
|
||||||
rootContext->setContextProperty("AddressManager", DependencyManager::get<AddressManager>().data());
|
rootContext->setContextProperty("AddressManager", DependencyManager::get<AddressManager>().data());
|
||||||
rootContext->setContextProperty("FrameTimings", &_frameTimingsScriptingInterface);
|
rootContext->setContextProperty("FrameTimings", &_frameTimingsScriptingInterface);
|
||||||
rootContext->setContextProperty("Rates", new RatesScriptingInterface(this));
|
rootContext->setContextProperty("Rates", new RatesScriptingInterface(this));
|
||||||
|
rootContext->setContextProperty("pathToFonts", "../../");
|
||||||
|
|
||||||
rootContext->setContextProperty("TREE_SCALE", TREE_SCALE);
|
rootContext->setContextProperty("TREE_SCALE", TREE_SCALE);
|
||||||
rootContext->setContextProperty("Quat", new Quat());
|
rootContext->setContextProperty("Quat", new Quat());
|
||||||
|
@ -5743,14 +5744,8 @@ bool Application::displayAvatarAttachmentConfirmationDialog(const QString& name)
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::toggleRunningScriptsWidget() const {
|
void Application::toggleRunningScriptsWidget() const {
|
||||||
auto tabletScriptingInterface = DependencyManager::get<TabletScriptingInterface>();
|
DependencyManager::get<OffscreenUi>()->show(url, "RunningScripts");
|
||||||
static const QUrl url("hifi/dialogs/RunningScripts.qml");
|
|
||||||
if (true) {
|
|
||||||
auto tablet = dynamic_cast<TabletProxy*>(tabletScriptingInterface->getTablet("com.highfidelity.interface.tablet.system"));
|
|
||||||
tablet->pushOntoStack("../..//hifi/dialogs/RunningScripts.qml");
|
|
||||||
} else {
|
|
||||||
DependencyManager::get<OffscreenUi>()->show(url, "RunningScripts");
|
|
||||||
}
|
|
||||||
//if (_runningScriptsWidget->isVisible()) {
|
//if (_runningScriptsWidget->isVisible()) {
|
||||||
// if (_runningScriptsWidget->hasFocus()) {
|
// if (_runningScriptsWidget->hasFocus()) {
|
||||||
// _runningScriptsWidget->hide();
|
// _runningScriptsWidget->hide();
|
||||||
|
|
|
@ -38,8 +38,10 @@
|
||||||
#include "scripting/AccountScriptingInterface.h"
|
#include "scripting/AccountScriptingInterface.h"
|
||||||
#include "scripting/HMDScriptingInterface.h"
|
#include "scripting/HMDScriptingInterface.h"
|
||||||
#include <Preferences.h>
|
#include <Preferences.h>
|
||||||
|
#include <ScriptEngines.h>
|
||||||
#include "FileDialogHelper.h"
|
#include "FileDialogHelper.h"
|
||||||
|
|
||||||
|
|
||||||
static const float DPI = 30.47f;
|
static const float DPI = 30.47f;
|
||||||
static const float INCHES_TO_METERS = 1.0f / 39.3701f;
|
static const float INCHES_TO_METERS = 1.0f / 39.3701f;
|
||||||
static const float METERS_TO_INCHES = 39.3701f;
|
static const float METERS_TO_INCHES = 39.3701f;
|
||||||
|
@ -170,6 +172,8 @@ void Web3DOverlay::loadSourceURL() {
|
||||||
_webSurface->getRootContext()->setContextProperty("Account", AccountScriptingInterface::getInstance());
|
_webSurface->getRootContext()->setContextProperty("Account", AccountScriptingInterface::getInstance());
|
||||||
_webSurface->getRootContext()->setContextProperty("HMD", DependencyManager::get<HMDScriptingInterface>().data());
|
_webSurface->getRootContext()->setContextProperty("HMD", DependencyManager::get<HMDScriptingInterface>().data());
|
||||||
_webSurface->getRootContext()->setContextProperty("fileDialogHelper", new FileDialogHelper());
|
_webSurface->getRootContext()->setContextProperty("fileDialogHelper", new FileDialogHelper());
|
||||||
|
_webSurface->getRootContext()->setContextProperty("ScriptDiscoveryService", DependencyManager::get<ScriptEngines>().data());
|
||||||
|
_webSurface->getRootContext()->setContextProperty("pathToFonts", "../../../");
|
||||||
tabletScriptingInterface->setQmlTabletRoot("com.highfidelity.interface.tablet.system", _webSurface->getRootItem(), _webSurface.data());
|
tabletScriptingInterface->setQmlTabletRoot("com.highfidelity.interface.tablet.system", _webSurface->getRootItem(), _webSurface.data());
|
||||||
|
|
||||||
// Override min fps for tablet UI, for silky smooth scrolling
|
// Override min fps for tablet UI, for silky smooth scrolling
|
||||||
|
|
Loading…
Reference in a new issue