1
0
mirror of https://github.com/KDE/latte-dock.git synced 2025-01-24 18:03:53 +03:00

enable smooth animation when changing alignments

This commit is contained in:
Michail Vourlakos 2018-02-12 23:07:47 +02:00
parent c2e72b7f67
commit 976494ed09
4 changed files with 73 additions and 91 deletions

View File

@ -351,6 +351,13 @@ Item{
onShownAppletsChanged: HeuristicTools.updateSizeForAppletsInFill();
onSizeWithNoFillAppletsChanged: HeuristicTools.updateSizeForAppletsInFill();
transitions: Transition {
enabled: editModeVisual.plasmaEditMode
AnchorAnimation {
duration: 0.8 * root.animationTime
easing.type: Easing.OutCubic
}
}
//////////////////////////BEGIN states
//user set Panel Positions

View File

@ -416,6 +416,14 @@ Item{
}
}
transitions: Transition {
enabled: editModeVisual.plasmaEditMode
AnchorAnimation {
duration: 0.8 * root.animationTime
easing.type: Easing.OutCubic
}
}
//BEGIN states
//user set Panel Positions
//0-Center, 1-Left, 2-Right, 3-Top, 4-Bottom

View File

@ -36,6 +36,8 @@ Item{
opacity: root.editMode ? 1 : 0
property int rulerAnimationTime: 0.8 * root.animationTime
x: {
if (root.isHorizontal) {
return xL;
@ -61,12 +63,42 @@ Item{
}
property int length: root.maxLength/* root.isHorizontal ? (root.behaveAsPlasmaPanel ? root.width - root.maxIconSize/4 : root.maxLength):
(root.behaveAsPlasmaPanel ? root.height - root.maxIconSize/4 : root.maxLength)*/
property int length: root.maxLength
property int rMargin: 3
property int xL: 0
property int yL: 0
property int xL: {
if (root.isHorizontal) {
if (plasmoid.configuration.panelPosition === Latte.Dock.Justify) {
return root.width/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Left) {
return root.offset;
} else if (root.panelAlignment === Latte.Dock.Center) {
return root.width/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Right) {
return root.width - rulerItem.length - root.offset;
}
} else {
return ;
}
}
property int yL: {
if (root.isVertical) {
if (plasmoid.configuration.panelPosition === Latte.Dock.Justify) {
return root.height/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Top) {
return root.offset;
} else if (root.panelAlignment === Latte.Dock.Center) {
return root.height/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Bottom) {
return root.height - rulerItem.length - root.offset;
}
} else {
return;
}
}
property int foregroundTextShadow: {
if ((editModeVisual.layoutColor === "gold")
@ -106,73 +138,38 @@ Item{
}
}
Connections{
target: plasmoid
onLocationChanged: initializeEditPosition();
}
Connections{
target: root
onMaxIconSizeChanged: initializeEditPosition();
onPanelAlignmentChanged: initializeEditPosition();
onOffsetChanged: initializeEditPosition();
onMaxLengthChanged: initializeEditPosition();
onEditModeChanged: {
if (editMode) {
initializeEditPosition();
}
}
}
Connections{
target: editModeVisual
onRootThicknessChanged: {
rulerItem.initializeEditPosition();
}
onThicknessChanged: {
rulerItem.initializeEditPosition();
}
}
Behavior on width {
NumberAnimation {
duration: 250
id: horizontalAnimation
duration: rulerAnimationTime
easing.type: Easing.OutCubic
}
}
Behavior on height {
NumberAnimation {
duration: 250
id: verticalAnimation
duration: rulerAnimationTime
easing.type: Easing.OutCubic
}
}
Behavior on x {
enabled: root.isHorizontal
enabled: root.isHorizontal && !offsetAnimation.running
NumberAnimation {
duration: 250
duration: rulerAnimationTime
easing.type: Easing.OutCubic
}
}
Behavior on y {
enabled: root.isVertical
enabled: root.isVertical && !offsetAnimation.running
NumberAnimation {
duration: 250
duration: rulerAnimationTime
easing.type: Easing.OutCubic
}
}
/* Behavior on opacity {
NumberAnimation {
duration: 250
easing.type: Easing.OutCubic
}
}*/
Grid{
id: rulerGrid
width: root.isHorizontal ? parent.width : undefined
@ -316,41 +313,4 @@ Item{
color: foregroundColor
}
}
function initializeEditPosition() {
if (root.editMode) {
/* if (plasmoid.location === PlasmaCore.Types.LeftEdge){
x = 0;
} else if (plasmoid.location === PlasmaCore.Types.TopEdge) {
y =editModeVisual.thickness - 1.5 *theme.defaultFont.pixelSize;
} else if (plasmoid.location === PlasmaCore.Types.BottomEdge) {
y = editModeVisual.rootThickness - editModeVisual.thickness + 0.5 * theme.defaultFont.pixelSize;
} else if (plasmoid.location === PlasmaCore.Types.RightEdge) {
x = editModeVisual.rootThickness - editModeVisual.thickness + 0.5 * theme.defaultFont.pixelSize;
}*/
if (root.isHorizontal) {
if (plasmoid.configuration.panelPosition === Latte.Dock.Justify) {
xL = root.width/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Left) {
xL = root.offset;
} else if (root.panelAlignment === Latte.Dock.Center) {
xL = root.width/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Right) {
xL = root.width - rulerItem.length - root.offset;
}
} else if (root.isVertical) {
if (plasmoid.configuration.panelPosition === Latte.Dock.Justify) {
yL = root.height/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Top) {
yL = root.offset;
} else if (root.panelAlignment === Latte.Dock.Center) {
yL = root.height/2 - rulerItem.length/2 + root.offset;
} else if (root.panelAlignment === Latte.Dock.Bottom) {
yL = root.height - rulerItem.length - root.offset;
}
}
}
}
}

View File

@ -74,7 +74,7 @@ DragDrop.DropArea {
}
property bool blurEnabled: plasmoid.configuration.blurEnabled && !root.forceTransparentPanel
|| (hasExpandedApplet && zoomFactor===1 && plasmoid.configuration.panelSize===100)
|| (hasExpandedApplet && zoomFactor===1 && plasmoid.configuration.panelSize===100)
property bool confirmedDragEntered: false
property bool containsOnlyPlasmaTasks: false //this is flag to indicate when from tasks only a plasma based one is found
@ -387,9 +387,6 @@ DragDrop.DropArea {
////////////////END properties
//// BEGIN OF Behaviors
Behavior on iconSize {
enabled: !(root.editMode && root.behaveAsPlasmaPanel)
@ -403,6 +400,16 @@ DragDrop.DropArea {
}
}
}
Behavior on offset {
enabled: editModeVisual.plasmaEditMode
NumberAnimation {
id: offsetAnimation
duration: 0.8 * root.animationTime
easing.type: Easing.OutCubic
}
}
//// END OF Behaviors
//////////////START OF CONNECTIONS
@ -1108,7 +1115,7 @@ DragDrop.DropArea {
if (dockContainsMouse && !rootMouseArea.containsMouse) {
root.globalDirectRender = true;
} else {
// console.log("direct render true ignored...");
// console.log("direct render true ignored...");
}
} else {
root.globalDirectRender = false;
@ -1479,7 +1486,7 @@ DragDrop.DropArea {
EditModeVisual{
id:editModeVisual
// z: root.behaveAsPlasmaPanel ? 1 : 0
// z: root.behaveAsPlasmaPanel ? 1 : 0
}
Ruler{id: ruler}
@ -1488,7 +1495,7 @@ DragDrop.DropArea {
id: panelBox
anchors.fill:layoutsContainer
// z: root.behaveAsPlasmaPanel ? 0 : 1
// z: root.behaveAsPlasmaPanel ? 0 : 1
PanelBox{}
}