mirror of
https://github.com/JulianGro/overte.git
synced 2025-05-06 02:48:03 +02:00
124 lines
3.6 KiB
QML
124 lines
3.6 KiB
QML
//
|
|
// highlight.qml
|
|
// developer/utilities/render
|
|
//
|
|
// Olivier Prat, created on 08/08/2017.
|
|
// Copyright 2017 High Fidelity, Inc.
|
|
//
|
|
// Distributed under the Apache License, Version 2.0.
|
|
// See the accompanying file LICENSE or https://www.apache.org/licenses/LICENSE-2.0.html
|
|
//
|
|
import QtQuick 2.7
|
|
import QtQuick.Controls 1.4
|
|
import QtQuick.Layouts 1.3
|
|
|
|
import "qrc:///qml/styles-uit"
|
|
import "qrc:///qml/controls-uit" as HifiControls
|
|
import "configSlider"
|
|
import "../lib/plotperf"
|
|
import "highlight"
|
|
|
|
Item {
|
|
id: root
|
|
HifiConstants { id: hifi;}
|
|
anchors.margins: 0
|
|
property var listName: "contextOverlayHighlightList"
|
|
|
|
property var styleList: Selection.getHighlightedListNames()
|
|
|
|
signal sendToScript(var message);
|
|
|
|
Component.onCompleted: {
|
|
}
|
|
|
|
|
|
Column {
|
|
id: col
|
|
spacing: 5
|
|
anchors.left: root.left
|
|
anchors.right: root.right
|
|
anchors.margins: hifi.dimensions.contentMargin.x
|
|
|
|
Row {
|
|
id: controlbar
|
|
spacing: 10
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
height: 24
|
|
|
|
HifiControls.Button {
|
|
id: debug
|
|
text: "Refresh"
|
|
height: 24
|
|
onClicked: {
|
|
print("list of highlight styles")
|
|
root.styleList = Selection.getHighlightedListNames()
|
|
|
|
print(root.styleList)
|
|
styleSelectorLoader.sourceComponent = undefined;
|
|
styleSelectorLoader.sourceComponent = selectorWidget;
|
|
}
|
|
}
|
|
|
|
Loader {
|
|
id: styleSelectorLoader
|
|
sourceComponent: selectorWidget
|
|
width: 350
|
|
anchors.right: parent.right
|
|
}
|
|
Component {
|
|
id: selectorWidget
|
|
HifiControls.ComboBox {
|
|
id: box
|
|
z: 999
|
|
editable: true
|
|
colorScheme: hifi.colorSchemes.dark
|
|
model: root.styleList
|
|
label: ""
|
|
|
|
Timer {
|
|
id: postpone
|
|
interval: 100; running: false; repeat: false
|
|
onTriggered: { styleWidgetLoader.sourceComponent = styleWidget }
|
|
}
|
|
onCurrentIndexChanged: {
|
|
root.listName = model[currentIndex];
|
|
// sendToScript("highlight "+currentIndex)
|
|
// This is a hack to be sure the widgets below properly reflect the change of category: delete the Component
|
|
// by setting the loader source to Null and then recreate it 100ms later
|
|
styleWidgetLoader.sourceComponent = undefined;
|
|
postpone.interval = 100
|
|
postpone.start()
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
}
|
|
|
|
Separator {}
|
|
Loader {
|
|
id: styleWidgetLoader
|
|
sourceComponent: styleWidget
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: styleWidget
|
|
|
|
HighlightStyle {
|
|
id: highlightStyle
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
highlightStyle: Selection.getListHighlightStyle(root.listName)
|
|
|
|
onNewStyle: {
|
|
var style = getStyle()
|
|
// print("new style " + JSON.stringify(style) )
|
|
Selection.enableListHighlight(root.listName, style)
|
|
}
|
|
}
|
|
}
|
|
}
|