Rescale images along with text in eww with `C-x C-+'
authorLars Ingebrigtsen <larsi@gnus.org>
Mon, 26 Sep 2022 11:53:10 +0000 (13:53 +0200)
committerLars Ingebrigtsen <larsi@gnus.org>
Mon, 26 Sep 2022 11:53:10 +0000 (13:53 +0200)
* lisp/net/eww.el (eww--rescale-images): Also rescale images when
using `C-x C-+' etc (bug#58047).

lisp/net/eww.el

index af938e3c1921b763db2992cbf9da74a29d800e75..2a511333de1e57ffb39ba1dd8e05aa4dbecbab24 100644 (file)
@@ -1179,8 +1179,28 @@ the like."
   (setq-local bookmark-make-record-function #'eww-bookmark-make-record)
   (buffer-disable-undo)
   (setq-local shr-url-transformer #'eww--transform-url)
+  ;; Also rescale images when rescaling the text.
+  (add-hook 'text-scale-mode-hook #'eww--rescale-images nil t)
   (setq buffer-read-only t))
 
+(defvar text-scale-mode)
+(defvar text-scale-mode-amount)
+(defun eww--rescale-images ()
+  (let ((scaling (if text-scale-mode
+                     (+ 1 (* text-scale-mode-amount 0.1))
+                   1))
+        match)
+    (save-excursion
+      (goto-char (point-min))
+      (while (setq match (text-property-search-forward 'display))
+        (let ((image (prop-match-value match)))
+          (when (imagep image)
+            (unless (image-property image :original-scale)
+              (setf (image-property image :original-scale)
+                    (or (image-property image :scale) 1)))
+            (setf (image-property image :scale)
+                  (* (image-property image :original-scale) scaling))))))))
+
 (defun eww--url-at-point ()
   "`thing-at-point' provider function."
   (get-text-property (point) 'shr-url))