mirror of
https://invent.kde.org/marcoa/shift-shell.git
synced 2026-04-26 14:23:09 +00:00
slide zoom too
This commit is contained in:
parent
59b57b5e74
commit
9acba2675d
1 changed files with 40 additions and 14 deletions
|
|
@ -43,7 +43,7 @@ Rectangle {
|
|||
Item {
|
||||
id: mainContent
|
||||
width: parent.width
|
||||
height: flow.y + flow.height
|
||||
height: flow.y + flow.height + root.height
|
||||
Flow {
|
||||
id: flow
|
||||
anchors {
|
||||
|
|
@ -87,31 +87,41 @@ Rectangle {
|
|||
MouseArea {
|
||||
anchors.fill: parent
|
||||
property int oldY
|
||||
property real startY
|
||||
onClicked: {
|
||||
root.state = "switcher"
|
||||
}
|
||||
onPressed: {
|
||||
if (root.state == "app") {
|
||||
return;
|
||||
}
|
||||
root.state = "dragging";
|
||||
root.state = "zooming";
|
||||
} else {
|
||||
root.state = "dragging";
|
||||
}
|
||||
oldY = mouse.y;
|
||||
startY = mouse.y;
|
||||
}
|
||||
onPositionChanged: {
|
||||
if (root.state == "app") {
|
||||
return;
|
||||
if (root.state == "app" || root.state == "zooming") {
|
||||
mainFlickable.scale = (1 - (startY - mouse.y) / root.height);
|
||||
// mainFlickable.contentY -= oldY - mouse.y;
|
||||
} else {
|
||||
mainFlickable.contentY += oldY - mouse.y;
|
||||
}
|
||||
mainFlickable.contentY += oldY - mouse.y;
|
||||
oldY = mouse.y;
|
||||
}
|
||||
onReleased: {
|
||||
if (root.state == "app") {
|
||||
return;
|
||||
}
|
||||
if (mainFlickable.contentY < root.height) {
|
||||
root.state = "homescreen"
|
||||
if (root.state == "app" || root.state == "zooming") {
|
||||
if (mainFlickable.scale < 0.7) {
|
||||
root.state = "switcher"
|
||||
} else {
|
||||
root.state = "app"
|
||||
}
|
||||
} else {
|
||||
root.state = "switcher"
|
||||
if (mainFlickable.contentY < root.height) {
|
||||
root.state = "homescreen"
|
||||
} else {
|
||||
root.state = "switcher"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -125,7 +135,7 @@ Rectangle {
|
|||
x: -root.width / 2
|
||||
y: -root.height / 2
|
||||
interactive: true
|
||||
contentY: root.height*2
|
||||
contentY: root.height*2 + (root.currentApp ? root.currentApp.y : 0)
|
||||
visible: true
|
||||
}
|
||||
},
|
||||
|
|
@ -141,6 +151,18 @@ Rectangle {
|
|||
visible: true
|
||||
}
|
||||
},
|
||||
State {
|
||||
name: "zooming"
|
||||
PropertyChanges {
|
||||
target: mainFlickable
|
||||
scale: scale
|
||||
x: (-root.currentApp.x * (mainFlickable.scale/0.5 - 1) ) + (2 - mainFlickable.scale/0.5) * (-root.width / 2)
|
||||
y: (-root.height / 2) * (2 - mainFlickable.scale/0.5)
|
||||
interactive: true
|
||||
contentY: (root.height*2 + (root.currentApp ? root.currentApp.y : 0)) * (2 - mainFlickable.scale/0.5) + (root.height*2 + root.currentApp.y) * (mainFlickable.scale/0.5 - 1)
|
||||
visible: true
|
||||
}
|
||||
},
|
||||
State {
|
||||
name: "app"
|
||||
PropertyChanges {
|
||||
|
|
@ -170,6 +192,9 @@ Rectangle {
|
|||
Transition {
|
||||
to: "dragging"
|
||||
},
|
||||
Transition {
|
||||
to: "zooming"
|
||||
},
|
||||
Transition {
|
||||
SequentialAnimation {
|
||||
ScriptAction {
|
||||
|
|
@ -189,6 +214,7 @@ Rectangle {
|
|||
script: {
|
||||
if (root.state == "homescreen") {
|
||||
mainFlickable.visible = false;
|
||||
root.currentApp = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in a new issue