diff options
author | Vasilij Schneidermann <mail@vasilij.de> | 2020-08-13 10:21:51 +0200 |
---|---|---|
committer | Vasilij Schneidermann <mail@vasilij.de> | 2020-08-13 10:21:51 +0200 |
commit | 6cfd80124038504038bcb5d4cf2e8b037c36841a (patch) | |
tree | c3fe7265b4b594be099d5c84d4ec51c5d3e6bcc0 /nov.el | |
parent | 3d32aac0f895c8605e254c8b7f246537816744f5 (diff) |
Use native scaling if available
Diffstat (limited to 'nov.el')
-rw-r--r-- | nov.el | 42 |
1 files changed, 21 insertions, 21 deletions
@@ -439,30 +439,30 @@ Each alist item consists of the identifier and full path." (setq url (url-generic-parse-url url)) (mapcar 'nov-urldecode (list (url-filename url) (url-target url)))) +;; adapted from `shr-rescale-image' (defun nov-insert-image (path alt) "Insert an image for PATH at point, falling back to ALT. This function honors `shr-max-image-proportion' if possible." - (cond - ((not (display-graphic-p)) - (insert alt)) - ;; TODO: add native resizing support once it's official - ((fboundp 'imagemagick-types) - ;; adapted from `shr-rescale-image' - (-let [(x1 y1 x2 y2) (window-inside-pixel-edges - (get-buffer-window (current-buffer)))] - (insert-image - (create-image path 'imagemagick nil - :ascent 100 - :max-width (truncate (* shr-max-image-proportion - (- x2 x1))) - :max-height (truncate (* shr-max-image-proportion - (- y2 y1))))))) - (t - ;; `create-image' errors out for unsupported image types - (let ((image (ignore-errors (create-image path nil nil :ascent 100)))) - (if image - (insert-image image) - (insert alt)))))) + (let ((type (if (or (and (fboundp 'image-transforms-p) (image-transforms-p)) + (not (fboundp 'imagemagick-types))) + nil + 'imagemagick))) + (if (not (display-graphic-p)) + (insert alt) + (-let* (((x1 y1 x2 y2) (window-inside-pixel-edges + (get-buffer-window (current-buffer)))) + (image + ;; `create-image' errors out for unsupported image types + (ignore-errors + (create-image path type nil + :ascent 100 + :max-width (truncate (* shr-max-image-proportion + (- x2 x1))) + :max-height (truncate (* shr-max-image-proportion + (- y2 y1))))))) + (if image + (insert-image image) + (insert alt)))))) (defvar nov-original-shr-tag-img-function (symbol-function 'shr-tag-img)) |