Meshroom/meshroom/ui/qml/Viewer/PanoramaViewer.qml
Landrodie 1fc7cb7844 [PanoramaViewer] add control points display buttons
Added a button to enable or disable the display of the controls points in the panorama viewer
2021-09-14 18:06:40 +02:00

153 lines
4.4 KiB
QML

import QtQuick 2.11
import Utils 1.0
import AliceVision 1.0 as AliceVision
/**
* FloatImage displays an Image with gamma / offset / channel controls
* Requires QtAliceVision plugin.
*/
AliceVision.PanoramaViewer {
id: root
width: textureSize.width
height: textureSize.height
visible: (status === Image.Ready)
// paintedWidth / paintedHeight / status for compatibility with standard Image
property int paintedWidth: textureSize.width
property int paintedHeight: textureSize.height
property var status: {
if(root.loading)
return Image.Loading;
else if((root.source === "") ||
(root.sourceSize.height <= 0) ||
(root.sourceSize.width <= 0))
return Image.Null;
root.defaultControlPoints();
return Image.Ready;
}
property string channelModeString : "rgba"
property bool isCtrlPointsDisplayed : true;
property bool isGridDisplayed : false;
property int gridOpacity : 100;
onIsCtrlPointsDisplayedChanged: {
repeater.displayControlPoints()
}
onIsGridDisplayedChanged: {
root.displayGrid()
}
onGridOpacityChanged: {
root.setGridColorQML(Qt.rgba(255, 0, 0, gridOpacity/100));
}
channelMode: {
switch(channelModeString)
{
case "rgb": return AliceVision.FloatImageViewer.EChannelMode.RGB
case "r": return AliceVision.FloatImageViewer.EChannelMode.R
case "g": return AliceVision.FloatImageViewer.EChannelMode.G
case "b": return AliceVision.FloatImageViewer.EChannelMode.B
case "a": return AliceVision.FloatImageViewer.EChannelMode.A
default: return AliceVision.FloatImageViewer.EChannelMode.RGBA
}
}
clearBeforeLoad: true
property alias containsMouse: mouseArea.containsMouse
property alias mouseX: mouseArea.mouseX
property alias mouseY: mouseArea.mouseY
MouseArea {
id: mouseArea
anchors.fill: parent
hoverEnabled: true
// Do not intercept mouse events, only get the mouse over information
acceptedButtons: Qt.NoButton
}
Item {
id: grid
width: root.width
height: root.height
Connections {
target: root
onVerticesChanged : {
if (reinit){
grid.recalculateCP();
grid.generateControlPoints();
}
}
}
function generateControlPoints() {
if(repeater.model === 121){
repeater.model = 0;
}
repeater.model = 121;
}
function recalculateCP() {
if (repeater.model === 0)
return
var width = repeater.itemAt(0).width;
var height = repeater.itemAt(0).height;
for (let i = 0; i < repeater.model; i++) {
repeater.itemAt(i).x = root.getVertex(i).x - (width / 2);
repeater.itemAt(i).y = root.getVertex(i).y - (height / 2);
}
}
Component {
id: rectGrid
Rectangle {
id: rect
width: root.sourceSize.width/100; height: width
radius: width/2
x: root.getVertex(model.index).x - (width / 2)
y: root.getVertex(model.index).y - (height / 2)
color: "yellow"
visible: true
MouseArea {
id: mouseAreaCP
anchors.fill : parent;
acceptedButtons: Qt.LeftButton
drag.target: rect
drag.smoothed: false
drag.axis: Drag.XAndYAxis
onReleased: {
root.setVertex(index, rect.x + (width / 2), rect.y + (height / 2))
}
}
}
}
Repeater {
id: repeater
model: 121
delegate: rectGrid
function displayControlPoints() {
for (let i = 0; i < model; i++) {
if (repeater.itemAt(i).visible) {
repeater.itemAt(i).visible = false;
}
else {
repeater.itemAt(i).visible = true;
}
}
}
}
}
}