[gnome-shell] Screen Shield: animate manual locking
- From: Giovanni Campagna <gcampagna src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell] Screen Shield: animate manual locking
- Date: Sat, 21 Jul 2012 13:42:49 +0000 (UTC)
commit 0e4171a87ca7926acc2e5c9f5a80a13ce71697ee
Author: Giovanni Campagna <gcampagna src gnome org>
Date: Sun Jun 3 00:10:23 2012 +0200
Screen Shield: animate manual locking
When the screen shield is activated from the user menu, animate
it instead of showing it abruptly. Also, ensure that the animation
had time to finish before calling UPower to suspend, to avoid
showing it when resuming.
https://bugzilla.gnome.org/show_bug.cgi?id=619955
js/ui/screenShield.js | 38 +++++++++++++++++++++++++++++++-------
js/ui/userMenu.js | 13 +++++++++----
2 files changed, 40 insertions(+), 11 deletions(-)
---
diff --git a/js/ui/screenShield.js b/js/ui/screenShield.js
index 7a8bd34..fcc079d 100644
--- a/js/ui/screenShield.js
+++ b/js/ui/screenShield.js
@@ -24,6 +24,12 @@ const ARROW_DRAG_TRESHOLD = 0.4;
const SUMMARY_ICON_SIZE = 48;
+// Lightbox fading times
+// STANDARD_FADE_TIME is used when the session goes idle, while
+// SHORT_FADE_TIME is used when requesting lock explicitly from the user menu
+const STANDARD_FADE_TIME = 10;
+const SHORT_FADE_TIME = 2;
+
const Clock = new Lang.Class({
Name: 'ScreenShieldClock',
@@ -318,7 +324,9 @@ const ScreenShield = new Lang.Class({
this._hasLockScreen = false;
this._lightbox = new Lightbox.Lightbox(Main.uiGroup,
- { inhibitEvents: true, fadeInTime: 10, fadeFactor: 1 });
+ { inhibitEvents: true,
+ fadeInTime: STANDARD_FADE_TIME,
+ fadeFactor: 1 });
},
_onLockScreenKeyRelease: function(actor, event) {
@@ -390,7 +398,7 @@ const ScreenShield = new Lang.Class({
let shouldLock = lightboxWasShown && this._settings.get_boolean(LOCK_ENABLED_KEY);
if (shouldLock || this._isLocked) {
- this.lock();
+ this.lock(false);
} else if (this._isModal) {
this.unlock();
}
@@ -398,7 +406,7 @@ const ScreenShield = new Lang.Class({
},
showDialog: function() {
- this.lock();
+ this.lock(true);
this._showUnlockDialog(false);
},
@@ -452,7 +460,7 @@ const ScreenShield = new Lang.Class({
this._dialog.destroy();
this._dialog = null;
- this._resetLockScreen();
+ this._resetLockScreen(false);
},
_onUnlockSucceded: function() {
@@ -464,7 +472,23 @@ const ScreenShield = new Lang.Class({
this._lockScreenGroup.hide();
},
- _resetLockScreen: function() {
+ _resetLockScreen: function(animate) {
+ if (animate) {
+ this.actor.opacity = 0;
+ Tweener.removeTweens(this.actor);
+ Tweener.addTween(this.actor,
+ { opacity: 255,
+ time: SHORT_FADE_TIME,
+ transition: 'easeOutQuad',
+ onComplete: function() {
+ this.emit('lock-screen-shown');
+ },
+ onCompleteScope: this
+ });
+ } else {
+ this.emit('lock-screen-shown');
+ }
+
this._lockScreenGroup.fixed_position_set = false;
this._lockScreenGroup.show();
this._arrow.show();
@@ -542,7 +566,7 @@ const ScreenShield = new Lang.Class({
this.emit('lock-status-changed', false);
},
- lock: function() {
+ lock: function(animate) {
if (!this._hasLockScreen)
this._prepareLockScreen();
@@ -553,7 +577,7 @@ const ScreenShield = new Lang.Class({
this._isLocked = true;
this.actor.show();
- this._resetLockScreen();
+ this._resetLockScreen(animate);
this.emit('lock-status-changed', true);
},
diff --git a/js/ui/userMenu.js b/js/ui/userMenu.js
index ed6f9f7..7f8d544 100644
--- a/js/ui/userMenu.js
+++ b/js/ui/userMenu.js
@@ -767,12 +767,12 @@ const UserMenuButton = new Lang.Class({
_onLockScreenActivate: function() {
Main.overview.hide();
- Main.screenShield.lock();
+ Main.screenShield.lock(true);
},
_onLoginScreenActivate: function() {
Main.overview.hide();
- Main.screenShield.lock();
+ Main.screenShield.lock(false);
this._userManager.goto_login_session();
},
@@ -795,8 +795,13 @@ const UserMenuButton = new Lang.Class({
this._suspendOrPowerOffItem.state == PopupMenu.PopupAlternatingMenuItemState.DEFAULT) {
this._session.ShutdownRemote();
} else {
- Main.screenShield.lock();
- this._upClient.suspend_sync(null);
+ let tmpId = Main.screenShield.connect('lock-screen-shown', Lang.bind(this, function() {
+ Main.screenShield.disconnect(tmpId);
+
+ this._upClient.suspend_sync(null);
+ }));
+
+ Main.screenShield.lock(true);
}
}
});
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]