[gnome-shell/wip/exalm/gestures: 11/11] h



commit acc27191bda926fa8b21937b58ab414066c38413
Author: Alexander Mikhaylenko <exalm7659 gmail com>
Date:   Tue Jun 25 21:14:33 2019 +0500

    h

 js/ui/swipeTracker.js  | 114 ++++++++++++++++++++++++++++---------------------
 js/ui/windowManager.js |   8 ++++
 2 files changed, 73 insertions(+), 49 deletions(-)
---
diff --git a/js/ui/swipeTracker.js b/js/ui/swipeTracker.js
index b60c9aae9..b9917edd8 100644
--- a/js/ui/swipeTracker.js
+++ b/js/ui/swipeTracker.js
@@ -29,44 +29,6 @@ function clamp(value, min, max) {
 // TODO: support touch
 // TODO: support horizontal
 
-/*
-//        actor.connect('event', this._handleEvent.bind(this));
-
-    _handleEvent(actor, event) {
-        if (event.type() != Clutter.EventType.TOUCHPAD_SWIPE) // SCROLL
-            return Clutter.EVENT_PROPAGATE;
-
-        if (event.get_touchpad_gesture_finger_count() != 4)
-            return Clutter.EVENT_PROPAGATE;
-
-//        if (event.get_scroll_direction() != Clutter.ScrollDirection.SMOOTH)
-//            return Clutter.EVENT_PROPAGATE;
-
-        if ((this._allowedModes & Main.actionMode) == 0)
-            return Clutter.EVENT_PROPAGATE;
-
-        if (!this._enabled)
-            return Clutter.EVENT_PROPAGATE;
-
-        let time = event.get_time();
-        let [dx, dy] = event.get_gesture_motion_delta(); //event.get_scroll_delta();
-
-        if (event.get_gesture_phase() == Clutter.TouchpadGesturePhase.UPDATE) {
-//        if ((event.get_scroll_finish_flags() & Clutter.ScrollFinishFlags.VERTICAL == 0) || (dx == 0 && dy 
== 0))
-            if(!(this._touchpadSettings.get_boolean('natural-scroll'))) {
-                dx = -dx;
-                dy = -dy;
-            }
-            this._updateGesture(time, -dy / TOUCHPAD_BASE_DISTANCE * SCROLL_MULTIPLIER); // TODO: multiply 
on actor dimen for touch
-        } else if (event.get_gesture_phase() == Clutter.TouchpadGesturePhase.END)
-            this._endGesture(time);
-        else if (event.get_gesture_phase() == Clutter.TouchpadGesturePhase.CANCEL)
-            this._endGesture(time); // TODO: maybe cancel it?
-
-        return Clutter.EVENT_STOP;
-    }
-*/
-
 var TouchpadSwipeGesture = class TouchpadSwipeGesture {
     constructor(actor) {
         this._touchpadSettings = new Gio.Settings({schema_id: 'org.gnome.desktop.peripherals.touchpad'});
@@ -81,6 +43,9 @@ var TouchpadSwipeGesture = class TouchpadSwipeGesture {
         if (event.get_touchpad_gesture_finger_count() != 4)
             return Clutter.EVENT_PROPAGATE;
 
+//        if ((this._allowedModes & Main.actionMode) == 0 || !this._enabled)
+//            return Clutter.EVENT_PROPAGATE;
+
         let time = event.get_time();
         let [dx, dy] = event.get_gesture_motion_delta();
 
@@ -93,28 +58,69 @@ var TouchpadSwipeGesture = class TouchpadSwipeGesture {
         } else if (event.get_gesture_phase() == Clutter.TouchpadGesturePhase.END)
             this.emit('end', time);
         else if (event.get_gesture_phase() == Clutter.TouchpadGesturePhase.CANCEL)
-            this.emit('cancel', time);
+            this.emit('cancel');
 
         return Clutter.EVENT_STOP;
     }
 };
 Signals.addSignalMethods(TouchpadSwipeGesture.prototype);
-/*
+
 var TouchSwipeGesture = GObject.registerClass({
-    Signals: { 'activated': { param_types: [Meta.MotionDirection.$gtype] },
-               'motion':    { param_types: [GObject.TYPE_DOUBLE, GObject.TYPE_DOUBLE] },
-               'cancel':    { param_types: [] }},
+    Signals: { 'update': { param_types: [GObject.TYPE_UINT, GObject.TYPE_DOUBLE] },
+               'end':    { param_types: [GObject.TYPE_UINT] },
+               'cancel': { param_types: [] }},
 }, class TouchSwipeGesture extends Clutter.SwipeAction {
     _init(actor) {
         super._init();
         this.set_n_touch_points(4);
 
+        this._actor = actor;
+
         global.display.connect('grab-op-begin', () => {
             this.cancel();
         });
     }
+
+    _get_time() {
+        let event = this.get_last_event();
+        return event.get_time();
+    }
+
+    vfunc_gesture_prepare(actor) {
+        this._swept = false;
+
+        if (!super.vfunc_gesture_prepare(actor))
+            return false;
+
+        return true; //(this._allowedModes & Main.actionMode) != 0 && this._enabled;
+    }
+
+    vfunc_gesture_progress(actor) {
+        let [dx, dy] = this.get_motion_delta(0);
+        let time = this._get_time();
+
+        this.emit('update', time, -dy / this._actor.height); // TODO: the height isn't always equal to the 
actor height
+        return true;
+    }
+
+    vfunc_swipe(actor, direction) {
+        this._swept = true;
+
+        let time = this._get_time();
+
+        this.emit('end', time);
+    }
+
+    vfunc_gesture_cancel(actor) {
+        if (this._swept)
+            return;
+
+//        let time = this._get_time();
+
+        this.emit('cancel');
+    }
 });
-*/
+
 /*
 var WorkspaceSwitchAction = GObject.registerClass({
     Signals: { 'activated': { param_types: [Meta.MotionDirection.$gtype] },
@@ -161,9 +167,9 @@ var WorkspaceSwitchAction = GObject.registerClass({
             this.emit('cancel');
             return;
         }
-            
+
         let dir;
-            
+
         if (direction & Clutter.SwipeDirection.UP)
             dir = Meta.MotionDirection.DOWN;
         else if (direction & Clutter.SwipeDirection.DOWN)
@@ -172,7 +178,7 @@ var WorkspaceSwitchAction = GObject.registerClass({
             dir = Meta.MotionDirection.RIGHT;
         else if (direction & Clutter.SwipeDirection.RIGHT)
             dir = Meta.MotionDirection.LEFT;
-        
+
         this._swept = true;
         this.emit('activated', dir);
     }
@@ -192,9 +198,14 @@ var SwipeTracker = class {
         let gesture = new TouchpadSwipeGesture(actor);
         gesture.connect('update', this._updateGesture.bind(this));
         gesture.connect('end', this._endGesture.bind(this));
-        gesture.connect('cancel', this._endGesture.bind(this)); // TODO: cancel it without animation
-    }
+        gesture.connect('cancel', this._endGesture.bind(this)); // End the gesture normally for touchpads
 
+        gesture = new TouchSwipeGesture(actor);
+        gesture.connect('update', this._updateGesture.bind(this));
+        gesture.connect('end', this._endGesture.bind(this));
+        gesture.connect('cancel', this._cancelGesture.bind(this));
+        actor.add_action(gesture);
+    }
 
     get enabled() {
         return this._enabled;
@@ -323,6 +334,11 @@ var SwipeTracker = class {
         this._reset();
     }
 
+    _cancelGesture(gesture) {
+        this.emit('cancel', MIN_ANIMATION_DURATION);
+        this._reset();
+    }
+
     continueFrom(progress) {
         this._progress = progress;
         this._velocity = 0;
diff --git a/js/ui/windowManager.js b/js/ui/windowManager.js
index 32a80bc08..13456a2c4 100644
--- a/js/ui/windowManager.js
+++ b/js/ui/windowManager.js
@@ -1085,6 +1085,14 @@ var WindowManager = class {
         if (!this._switchData || this._switchData.inProgress)
             return;
 
+        if (duration == 0) {
+            this._switchData.progress = 0;
+            this._switchData.container.x = 0;
+            this._switchData.container.y = 0;
+            this._finishWorkspaceSwitch(this._switchData);
+            return;
+        }
+
         let switchData = this._switchData;
         Tweener.addTween(switchData,
                          { progress: 0,


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]