fb69b791a1
Summary: When windows get added some effects grab the window and want to be the only one animating this window. For this the grab roles exists. An effect being notified later on evaluates the grab state and does not start the animation. This process failed due to being dependent on the order the effects are loaded. Window Added/Closed are signals emitted by EffectsHandler, thus first come, first serve. The requested effect order does not play into it. Due to that it could happen that an Effect which should not animate, started to animate as the grab was still there. This change adds the possibility to be notified whenever the window data changes. A new signal is added to EffectsHandler which is emitted whenever the windowData changes. The interested effects connect to it and cancel their (just started) animation for the window. Adjusted effects are: * ScaleIn * Fade * WobblyWindows In case of WobblyWindows an additional logical error was fixed that the animations were only run when an effect grabbed instead of the other way around. BUG: 336866 FIXED-IN: 5.8.4 Reviewers: #kwin, #plasma, broulik Subscribers: plasma-devel, kwin Tags: #kwin Differential Revision: https://phabricator.kde.org/D3211
77 lines
2.7 KiB
JavaScript
77 lines
2.7 KiB
JavaScript
/********************************************************************
|
|
KWin - the KDE window manager
|
|
This file is part of the KDE project.
|
|
|
|
Copyright (C) 2013 Kai Uwe Broulik <kde@privat.broulik.de>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*********************************************************************/
|
|
/*global effect, effects, animate, animationTime, Effect, QEasingCurve */
|
|
var scaleInEffect = {
|
|
duration: animationTime(150),
|
|
loadConfig: function () {
|
|
"use strict";
|
|
scaleInEffect.duration = animationTime(150);
|
|
},
|
|
isScaleWindow: function (window) {
|
|
"use strict";
|
|
if (window.popupMenu || window.specialWindow || window.utility || window.minimized ||
|
|
effect.isGrabbed(window, Effect.WindowAddedGrabRole)) {
|
|
return false;
|
|
}
|
|
return true;
|
|
},
|
|
scaleIn: function (window) {
|
|
"use strict";
|
|
window.scaleInWindowTypeAnimation = animate({
|
|
window: window,
|
|
duration: scaleInEffect.duration,
|
|
curve: QEasingCurve.InOutQuad,
|
|
animations: [{
|
|
type: Effect.Opacity,
|
|
from: 0.0,
|
|
to: 1.0
|
|
}, {
|
|
type: Effect.Scale,
|
|
from: 0.75,
|
|
to: 1.0
|
|
}]
|
|
});
|
|
},
|
|
added: function (window) {
|
|
"use strict";
|
|
if (!scaleInEffect.isScaleWindow(window)) {
|
|
return;
|
|
}
|
|
scaleInEffect.scaleIn(window);
|
|
},
|
|
dataChanged: function (window, role) {
|
|
"use strict";
|
|
if (role == Effect.WindowAddedGrabRole) {
|
|
if (effect.isGrabbed(window, Effect.WindowAddedGrabRole)) {
|
|
if (window.scaleInWindowTypeAnimation !== undefined) {
|
|
cancel(window.scaleInWindowTypeAnimation);
|
|
window.scaleInWindowTypeAnimation = undefined;
|
|
}
|
|
}
|
|
}
|
|
},
|
|
init: function () {
|
|
"use strict";
|
|
effect.configChanged.connect(scaleInEffect.loadConfig);
|
|
effects.windowAdded.connect(scaleInEffect.added);
|
|
effects.windowDataChanged.connect(scaleInEffect.dataChanged);
|
|
}
|
|
};
|
|
scaleInEffect.init();
|