mirror of
https://gitgud.io/wackyideas/aerothemeplasma.git
synced 2024-08-15 00:43:43 +00:00
Very early KDE 6 release.
This commit is contained in:
parent
7cc4ccabbc
commit
686046d4f7
6272 changed files with 140920 additions and 529657 deletions
196
kwin/effects/squash/contents/code/main.js
Normal file
196
kwin/effects/squash/contents/code/main.js
Normal file
|
@ -0,0 +1,196 @@
|
|||
/*
|
||||
This file is part of the KDE project.
|
||||
|
||||
SPDX-FileCopyrightText: 2018 Vlad Zahorodnii <vlad.zahorodnii@kde.org>
|
||||
|
||||
SPDX-License-Identifier: GPL-2.0-or-later
|
||||
*/
|
||||
|
||||
"use strict";
|
||||
|
||||
var squashEffect = { // 300 ms
|
||||
duration: animationTime(250),
|
||||
loadConfig: function () {
|
||||
squashEffect.duration = animationTime(250);
|
||||
},
|
||||
slotWindowMinimized: function (window) {
|
||||
if (effects.hasActiveFullScreenEffect) {
|
||||
return;
|
||||
}
|
||||
|
||||
// If the window doesn't have an icon in the task manager,
|
||||
// don't animate it.
|
||||
var iconRect = window.iconGeometry;
|
||||
if (iconRect.width == 0 || iconRect.height == 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (window.unminimizeAnimation) {
|
||||
if (redirect(window.unminimizeAnimation, Effect.Backward)) {
|
||||
return;
|
||||
}
|
||||
cancel(window.unminimizeAnimation);
|
||||
delete window.unminimizeAnimation;
|
||||
}
|
||||
|
||||
if (window.minimizeAnimation) {
|
||||
if (redirect(window.minimizeAnimation, Effect.Forward)) {
|
||||
return;
|
||||
}
|
||||
cancel(window.minimizeAnimation);
|
||||
}
|
||||
|
||||
var windowRect = window.geometry;
|
||||
|
||||
window.minimizeAnimation = animate({
|
||||
window: window,
|
||||
curve: QEasingCurve.Linear,
|
||||
duration: squashEffect.duration*1.1,
|
||||
animations: [
|
||||
{
|
||||
type: Effect.Size,
|
||||
from: {
|
||||
value1: windowRect.width,
|
||||
value2: windowRect.height
|
||||
},
|
||||
to: {
|
||||
value1: iconRect.width,
|
||||
value2: iconRect.height
|
||||
}
|
||||
},
|
||||
{
|
||||
type: Effect.Translation,
|
||||
from: {
|
||||
value1: 0.0,
|
||||
value2: 0.0
|
||||
},
|
||||
to: {
|
||||
value1: iconRect.x - windowRect.x -
|
||||
(windowRect.width - iconRect.width) / 2,
|
||||
value2: iconRect.y - windowRect.y -
|
||||
(windowRect.height - iconRect.height) / 2,
|
||||
}
|
||||
},
|
||||
{
|
||||
type: Effect.Opacity,
|
||||
from: 0.9,
|
||||
to: 0.0
|
||||
},
|
||||
/*{
|
||||
type: Effect.Rotation,
|
||||
meta: {
|
||||
axis: 1
|
||||
},
|
||||
from: 0,
|
||||
to: 0.262
|
||||
},
|
||||
{
|
||||
type: Effect.Rotation,
|
||||
meta: {
|
||||
axis: 2
|
||||
},
|
||||
from: 0,
|
||||
to: 0.262
|
||||
}*/
|
||||
|
||||
]
|
||||
});
|
||||
},
|
||||
slotWindowUnminimized: function (window) {
|
||||
if (effects.hasActiveFullScreenEffect) {
|
||||
return;
|
||||
}
|
||||
|
||||
// If the window doesn't have an icon in the task manager,
|
||||
// don't animate it.
|
||||
var iconRect = window.iconGeometry;
|
||||
if (iconRect.width == 0 || iconRect.height == 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (window.minimizeAnimation) {
|
||||
if (redirect(window.minimizeAnimation, Effect.Backward)) {
|
||||
return;
|
||||
}
|
||||
cancel(window.minimizeAnimation);
|
||||
delete window.minimizeAnimation;
|
||||
}
|
||||
|
||||
if (window.unminimizeAnimation) {
|
||||
if (redirect(window.unminimizeAnimation, Effect.Forward)) {
|
||||
return;
|
||||
}
|
||||
cancel(window.unminimizeAnimation);
|
||||
}
|
||||
|
||||
window.setData(Effect.WindowForceBlurRole, true);
|
||||
|
||||
var windowRect = window.geometry;
|
||||
|
||||
window.unminimizeAnimation = animate({
|
||||
window: window,
|
||||
curve: QEasingCurve.Linear,
|
||||
duration: squashEffect.duration,
|
||||
animations: [
|
||||
|
||||
/*{
|
||||
type: Effect.Rotation,
|
||||
axis: 0,
|
||||
sourceAnchor: 0,
|
||||
targetAnchor: 1,
|
||||
from: 1,
|
||||
to: 0.5
|
||||
},*/
|
||||
{
|
||||
type: Effect.Size,
|
||||
from: {
|
||||
value1: iconRect.width,
|
||||
value2: iconRect.height
|
||||
},
|
||||
to: {
|
||||
value1: windowRect.width,
|
||||
value2: windowRect.height
|
||||
}
|
||||
},
|
||||
{
|
||||
type: Effect.Translation,
|
||||
from: {
|
||||
value1: iconRect.x - windowRect.x -
|
||||
(windowRect.width - iconRect.width) / 2,
|
||||
value2: iconRect.y - windowRect.y -
|
||||
(windowRect.height - iconRect.height) / 2,
|
||||
},
|
||||
to: {
|
||||
value1: 0.0,
|
||||
value2: 0.0
|
||||
}
|
||||
},
|
||||
{
|
||||
type: Effect.Opacity,
|
||||
from: 0.0,
|
||||
to: 1.0
|
||||
}
|
||||
|
||||
]
|
||||
});
|
||||
},
|
||||
slotWindowAdded: function (window) {
|
||||
window.minimizedChanged.connect(() => {
|
||||
if (window.minimized) {
|
||||
squashEffect.slotWindowMinimized(window);
|
||||
} else {
|
||||
squashEffect.slotWindowUnminimized(window);
|
||||
}
|
||||
});
|
||||
},
|
||||
init: function () {
|
||||
effect.configChanged.connect(squashEffect.loadConfig);
|
||||
|
||||
effects.windowAdded.connect(squashEffect.slotWindowAdded);
|
||||
for (const window of effects.stackingOrder) {
|
||||
squashEffect.slotWindowAdded(window);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
squashEffect.init();
|
Loading…
Add table
Add a link
Reference in a new issue