]> git.eshelyaron.com Git - emacs.git/commitdiff
* lisp/image-mode.el: Resize image on window resizing (bug#32672)
authorJuri Linkov <juri@linkov.net>
Wed, 27 Nov 2019 21:52:29 +0000 (23:52 +0200)
committerJuri Linkov <juri@linkov.net>
Wed, 27 Nov 2019 21:52:29 +0000 (23:52 +0200)
* lisp/image-mode.el (image--window-change): New function.
(image--window-change-function): New variable.
(image-mode--setup-mode): Add buffer-local hook image--window-change
to window-size-change-functions, window-state-change-functions,
window-selection-change-functions.

etc/NEWS
lisp/image-mode.el

index 8233328fa3c3ab5e33833e6705fea61ce3fba0f9..db304508886dc3d8d2fb29141e6692b1080793a2 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -2623,6 +2623,9 @@ pointer is over.  To change this behaviour, you can customize the user
 option 'mouse-wheel-follow-mouse'.  Note that this will also affect
 scrolling.
 
+** Mouse scroll up and down with control key modifier also works on images
+where it scales the image under the mouse pointer.
+
 ---
 ** help-follow-symbol now signals 'user-error' if point (or the
 position pointed to by the argument POS) is not in a symbol.
index db6864649d098cffcf76c37dd815085382d47065..09d7828047e7b039ce35d52396e28fc4a014e03d 100644 (file)
@@ -599,6 +599,10 @@ Key bindings:
 
   (add-hook 'change-major-mode-hook #'image-toggle-display-text nil t)
   (add-hook 'after-revert-hook #'image-after-revert-hook nil t)
+  (add-hook 'window-size-change-functions #'image--window-change nil t)
+  (add-hook 'window-state-change-functions #'image--window-change nil t)
+  (add-hook 'window-selection-change-functions #'image--window-change nil t)
+
   (run-mode-hooks 'image-mode-hook)
   (let ((image (image-get-display-property))
        (msg1 (substitute-command-keys
@@ -856,6 +860,27 @@ Otherwise, display the image by calling `image-mode'."
           (get-buffer-window-list (current-buffer) 'nomini 'visible))
     (image-toggle-display-image)))
 
+(defvar image--window-change-function
+  (debounce 1.0
+    (lambda (window)
+      (when (window-live-p window)
+        (with-current-buffer (window-buffer)
+          (when (derived-mode-p 'image-mode)
+            (let ((spec (image-get-display-property)))
+              (when (eq (car-safe spec) 'image)
+                (let* ((image-width  (plist-get (cdr spec) :max-width))
+                       (image-height (plist-get (cdr spec) :max-height))
+                       (edges (window-inside-pixel-edges window))
+                       (window-width  (- (nth 2 edges) (nth 0 edges)))
+                       (window-height (- (nth 3 edges) (nth 1 edges))))
+                  (when (and image-width image-height
+                             (or (not (= image-width  window-width))
+                                 (not (= image-height window-height))))
+                    (image-toggle-display-image)))))))))))
+
+(defun image--window-change (window)
+  (funcall image--window-change-function window))
+
 \f
 ;;; Animated images