diff options
author | Po Lu <luangruo@yahoo.com> | 2021-12-27 09:02:20 +0800 |
---|---|---|
committer | Po Lu <luangruo@yahoo.com> | 2021-12-27 09:02:20 +0800 |
commit | 736bf3aaa72e8fdd1c37bb9c8d003b17ffb612f9 (patch) | |
tree | 6ba25eceedef3cbe0e34eafd9334d138a7c247dc | |
parent | d4353da0ad969a492c75bae130aed33ab204ed32 (diff) | |
download | emacs-736bf3aaa72e8fdd1c37bb9c8d003b17ffb612f9.tar.gz emacs-736bf3aaa72e8fdd1c37bb9c8d003b17ffb612f9.tar.bz2 emacs-736bf3aaa72e8fdd1c37bb9c8d003b17ffb612f9.zip |
Store sign separately when accumulating precision scroll momentum
* lisp/pixel-scroll.el (pixel-scroll-kinetic-state): Return
vector in new format.
(pixel-scroll-accumulate-velocity): Use new sign field.
-rw-r--r-- | lisp/pixel-scroll.el | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/lisp/pixel-scroll.el b/lisp/pixel-scroll.el index 3abd4b2a723..e3a17295217 100644 --- a/lisp/pixel-scroll.el +++ b/lisp/pixel-scroll.el @@ -680,10 +680,10 @@ wheel." (defun pixel-scroll-kinetic-state () "Return the kinetic scroll state of the current window. -It is a vector of the form [ VELOCITY TIME ]." +It is a vector of the form [ VELOCITY TIME SIGN ]." (or (window-parameter nil 'kinetic-state) (set-window-parameter nil 'kinetic-state - (vector (make-ring 10) nil)))) + (vector (make-ring 10) nil nil)))) (defun pixel-scroll-accumulate-velocity (delta) "Accumulate DELTA into the current window's kinetic scroll state." @@ -693,9 +693,9 @@ It is a vector of the form [ VELOCITY TIME ]." (when (or (and time (> (- (float-time) time) 0.5)) (and (not (ring-empty-p ring)) (not (eq (< delta 0) - (< (cdr (ring-ref ring 0)) - 0))))) + (aref state 2))))) (aset state 0 (make-ring 10))) + (aset state 2 (< delta 0)) (ring-insert (aref state 0) (cons (aset state 1 (float-time)) delta)))) |