mirror of
https://github.com/alicevision/Meshroom.git
synced 2025-04-29 02:08:08 +02:00
141 lines
4.1 KiB
QML
141 lines
4.1 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 bool isGridDisplayed : false;
|
|
property string channelModeString : "rgba"
|
|
|
|
onIsGridDisplayedChanged: {
|
|
root.displayGrid()
|
|
}
|
|
|
|
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: 20; height: width
|
|
radius: 10
|
|
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 + (20 / 2), rect.y + (20 / 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;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|