From a319a857a633ab2fbcdbae5204eb5cfcdcc1b413 Mon Sep 17 00:00:00 2001 From: Samuel Fadel Date: Tue, 19 Jan 2016 02:30:50 +0100 Subject: Updated options & hacks to change color scales. --- main_view.qml | 410 ++++++++++++++++++++++++++++++++++------------------------ 1 file changed, 239 insertions(+), 171 deletions(-) (limited to 'main_view.qml') diff --git a/main_view.qml b/main_view.qml index 9e02c32..e2f27d9 100644 --- a/main_view.qml +++ b/main_view.qml @@ -10,6 +10,7 @@ ApplicationWindow { id: mainWindow title: "Projection" visible: true + onClosing: Qt.quit() Component.onCompleted: { setX(Screen.width / 2 - width / 2); setY(Screen.height / 2 - height / 2); @@ -143,212 +144,256 @@ ApplicationWindow { } // Options panel - ColumnLayout { + RowLayout { Layout.alignment: Qt.AlignTop | Qt.AlignLeft - GroupBox { - Layout.fillWidth: true - title: "Projection metrics" + ColumnLayout { + Layout.alignment: Qt.AlignTop | Qt.AlignLeft + + GroupBox { + title: "Control points" + checkable: true + __checkbox.onClicked: { + cpPlot.visible = this.checked; + + if (this.checked) { + cpPlot.z = 0; + rpPlot.z = 0; + } else { + cpPlot.z = 0; + rpPlot.z = 1; + } + } - Column { - ExclusiveGroup { id: wrtMetricsGroup } + GridLayout { + columns: 2 + + GroupBox { + Layout.columnSpan: 2 + flat: true + title: "Colors" + + GridLayout { + columns: 2 + + Label { text: "Map to:" } + ComboBox { + id: cpPlotMetricComboBox + model: metricsModel + } + + Label { text: "Color map:" } + ComboBox { + id: cpPlotColormapCombo + model: colormapModel + onActivated: { + Main.setCPPlotColorScale(model.get(index).value); + } + } + } + } - RadioButton { - text: "Current" - exclusiveGroup: wrtMetricsGroup - checked: true - } - RadioButton { - text: "Diff. to previous" - exclusiveGroup: wrtMetricsGroup - } - RadioButton { - text: "Diff. to original" - exclusiveGroup: wrtMetricsGroup - } - } - } + Label { text: "Glyph size:" } + SpinBox { + id: cpGlyphSizeSpinBox + maximumValue: 100 + minimumValue: 6 + value: cpPlot.glyphSize() + decimals: 1 + stepSize: 1 + onValueChanged: cpPlot.setGlyphSize(this.value) + } - GroupBox { - title: "Control points" - checkable: true - __checkbox.onClicked: { - cpPlot.visible = this.checked; - - if (this.checked) { - cpPlot.z = 0; - rpPlot.z = 0; - } else { - cpPlot.z = 0; - rpPlot.z = 1; + Label { text: "Opacity:" } + Slider { + id: cpPlotOpacitySlider + tickmarksEnabled: true + stepSize: 0.1 + maximumValue: 1 + minimumValue: 0 + value: cpPlot.opacity + onValueChanged: cpPlot.opacity = this.value + } } } - GridLayout { - columns: 2 - - GroupBox { - Layout.columnSpan: 2 - flat: true - title: "Colors" - - GridLayout { - columns: 2 - - Label { text: "Map to:" } - ComboBox { - id: cpPlotMetricComboBox - model: metricsModel - } + GroupBox { + title: "Regular points" + checked: false + checkable: true + __checkbox.onClicked: { + rpPlot.visible = this.checked; + } - Label { text: "Color map:" } - ComboBox { - id: cpPlotColormapCombo - model: [ "Categorical", "Continuous", "Divergent", "Rainbow" ] + GridLayout { + columns: 2 + + GroupBox { + Layout.columnSpan: 2 + flat: true + title: "Colors" + + GridLayout { + columns: 2 + + Label { text: "Map to:" } + ComboBox { + id: rpPlotMetricComboBox + model: metricsModel + } + + Label { text: "Color map:" } + ComboBox { + id: rpPlotColormapCombo + model: colormapModel + onActivated: { + Main.setRPPlotColorScale(model.get(index).value); + } + } } } - } - Label { text: "Glyph size:" } - SpinBox { - id: cpGlyphSizeSpinBox - maximumValue: 100 - minimumValue: 6 - value: cpPlot.glyphSize() - decimals: 1 - stepSize: 1 - onValueChanged: cpPlot.setGlyphSize(this.value) - } + Label { text: "Glyph size:" } + SpinBox { + id: rpGlyphSizeSpinBox + maximumValue: 100 + minimumValue: 6 + value: rpPlot.glyphSize() + decimals: 1 + stepSize: 1 + onValueChanged: rpPlot.setGlyphSize(this.value) + } - Label { text: "Opacity:" } - Slider { - id: cpPlotOpacitySlider - tickmarksEnabled: true - stepSize: 0.1 - maximumValue: 1 - minimumValue: 0 - value: cpPlot.opacity - onValueChanged: cpPlot.opacity = this.value + Label { text: "Opacity:" } + Slider { + id: rpPlotOpacitySlider + tickmarksEnabled: true + stepSize: 0.1 + maximumValue: 1 + minimumValue: 0 + value: rpPlot.opacity + onValueChanged: rpPlot.opacity = this.value + } } } } - GroupBox { - title: "Regular points" - checked: false - checkable: true - __checkbox.onClicked: { - rpPlot.visible = this.checked; - } - - GridLayout { - columns: 2 - - GroupBox { - Layout.columnSpan: 2 - flat: true - title: "Colors" + ColumnLayout { + Layout.alignment: Qt.AlignTop | Qt.AlignLeft - GridLayout { - columns: 2 + GroupBox { + title: "Splat" + checkable: true + __checkbox.onClicked: { + splat.visible = this.checked; + colormap.visible = this.checked; + } - Label { text: "Map to:" } - ComboBox { - id: rpPlotMetricComboBox - model: metricsModel + GridLayout { + columns: 2 + + GroupBox { + Layout.columnSpan: 2 + flat: true + title: "Colors" + + GridLayout { + columns: 2 + + Label { text: "Map to:" } + ComboBox { + id: splatMetricComboBox + model: metricsModel + } + + Label { text: "Color map:" } + ComboBox { + id: splatColormapCombo + model: colormapModel + onActivated: { + Main.setColormapColorScale(model.get(index).value); + Main.setSplatColorScale(model.get(index).value); + } + } } + } - Label { text: "Color map:" } - ComboBox { - id: lotColormapCombo - model: [ "Categorical", "Continuous", "Divergent", "Rainbow" ] - } + Label { text: "Alpha:" } + SpinBox { + id: alphaSpinBox + maximumValue: 100 + minimumValue: 1 + value: splat.alpha() + decimals: 2 + stepSize: 1 + onValueChanged: splat.setAlpha(this.value) } - } - Label { text: "Glyph size:" } - SpinBox { - id: rpGlyphSizeSpinBox - maximumValue: 100 - minimumValue: 6 - value: rpPlot.glyphSize() - decimals: 1 - stepSize: 1 - onValueChanged: rpPlot.setGlyphSize(this.value) - } + Label { text: "Beta:" } + SpinBox { + id: betaSpinBox + maximumValue: 100 + minimumValue: 1 + value: splat.beta() + decimals: 2 + stepSize: 1 + onValueChanged: splat.setBeta(this.value) + } - Label { text: "Opacity:" } - Slider { - id: rpPlotOpacitySlider - tickmarksEnabled: true - stepSize: 0.1 - maximumValue: 1 - minimumValue: 0 - value: rpPlot.opacity - onValueChanged: rpPlot.opacity = this.value + Label { text: "Opacity:" } + Slider { + id: splatOpacitySlider + tickmarksEnabled: true + stepSize: 0.1 + maximumValue: 1 + minimumValue: 0 + value: splat.opacity + onValueChanged: splat.opacity = this.value + } } } - } - GroupBox { - title: "Splat" - checkable: true - __checkbox.onClicked: { - splat.visible = this.checked - } - - GridLayout { - columns: 2 - - Label { text: "Alpha:" } - SpinBox { - id: alphaSpinBox - maximumValue: 100 - minimumValue: 1 - value: splat.alpha() - decimals: 2 - stepSize: 1 - onValueChanged: splat.setAlpha(this.value) + GroupBox { + title: "Bar chart" + checkable: true + __checkbox.onClicked: { + bottomView.visible = this.checked } - Label { text: "Beta:" } - SpinBox { - id: betaSpinBox - maximumValue: 100 - minimumValue: 1 - value: splat.beta() - decimals: 2 - stepSize: 1 - onValueChanged: splat.setBeta(this.value) - } + GridLayout { + columns: 2 - Label { text: "Opacity:" } - Slider { - id: splatOpacitySlider - tickmarksEnabled: true - stepSize: 0.1 - maximumValue: 1 - minimumValue: 0 - value: splat.opacity - onValueChanged: splat.opacity = this.value + Label { text: "Color map:" } + ComboBox { + id: barChartColormapCombo + model: colormapModel + onActivated: { + Main.setBarChartColorScale(model.get(index).value); + } + } } } - } - GroupBox { - title: "Bar chart" - checkable: true - __checkbox.onClicked: { - bottomView.visible = this.checked - } + GroupBox { + Layout.fillWidth: true + title: "Projection metrics" - GridLayout { - columns: 2 + Column { + ExclusiveGroup { id: wrtMetricsGroup } - Label { text: "Color map:" } - ComboBox { - id: barChartColormapCombo - model: [ "Categorical", "Continuous", "Divergent", "Rainbow" ] + RadioButton { + text: "Current" + exclusiveGroup: wrtMetricsGroup + checked: true + } + RadioButton { + text: "Diff. to previous" + exclusiveGroup: wrtMetricsGroup + } + RadioButton { + text: "Diff. to original" + exclusiveGroup: wrtMetricsGroup + } } } } @@ -394,4 +439,27 @@ ApplicationWindow { ListElement { text: "CP influence" } ListElement { text: "Stress" } } + + ListModel { + id: colormapModel + + Component.onCompleted: { + this.append({ + "value": Main.ColorScaleContinuous, + "text": "Continuous" + }); + this.append({ + "value": Main.ColorScaleCategorical, + "text": "Categorical" + }); + this.append({ + "value": Main.ColorScaleDivergent, + "text": "Divergent" + }); + this.append({ + "value": Main.ColorScaleRainbow, + "text": "Rainbow" + }); + } + } } -- cgit v1.2.3