From: Juri Linkov <juri@linkov.net>
To: 41222@debbugs.gnu.org
Subject: bug#41222: 27.1; Auto-resizing of images in image-mode
Date: Wed, 13 May 2020 01:57:38 +0300 [thread overview]
Message-ID: <87tv0kkbkl.fsf@mail.linkov.net> (raw)
This is a followup to the emacs-devel thread
https://lists.gnu.org/archive/html/emacs-devel/2020-04/msg00777.html
I noticed that image-mode still lacks one needed command:
some image viewers have a menu item titled “Normal Size C-0” or
“Original Size C-0”. Here's is the patch that implements it:
diff --git a/lisp/image-mode.el b/lisp/image-mode.el
index 480b2e6b26..45007289c8 100644
--- a/lisp/image-mode.el
+++ b/lisp/image-mode.el
@@ -456,6 +456,7 @@ image-mode-map
(define-key map "sb" 'image-transform-fit-both)
(define-key map "ss" 'image-transform-set-scale)
(define-key map "sr" 'image-transform-set-rotation)
+ (define-key map "so" 'image-transform-original)
(define-key map "s0" 'image-transform-reset)
;; Multi-frame keys
@@ -521,6 +522,8 @@ image-mode-map
:help "Rotate the image"]
["Set Rotation..." image-transform-set-rotation
:help "Set rotation angle of the image"]
+ ["Original Size" image-transform-original
+ :help "Reset image to original size"]
["Reset Transformations" image-transform-reset
:help "Reset all image transformations"]
"--"
@@ -1382,6 +1385,13 @@ image-transform-set-rotation
(setq image-transform-rotation (float (mod rotation 360)))
(image-toggle-display-image))
+(defun image-transform-original ()
+ "Display the current image with the original size and rotation."
+ (interactive)
+ (setq image-transform-resize nil
+ image-transform-scale 1)
+ (image-toggle-display-image))
+
(defun image-transform-reset ()
"Display the current image with the default size and rotation."
(interactive)
BTW, like ‘image-auto-resize-on-window-resize’ was added recently to
image-mode.el, is there a need to add a similar option to man.el
to allow customization of auto-resizing of Man buffers as well?
Maybe something like:
diff --git a/lisp/man.el b/lisp/man.el
index 5278a1a84d..a614cac536 100644
--- a/lisp/man.el
+++ b/lisp/man.el
@@ -1579,7 +1579,8 @@ Man-mode
(set (make-local-variable 'outline-level) (lambda () 1))
(set (make-local-variable 'bookmark-make-record-function)
'Man-bookmark-make-record)
- (add-hook 'window-state-change-functions #'Man--window-state-change nil t))
+ (when Man-fit-to-window-on-window-resize
+ (add-hook 'window-state-change-functions #'Man--window-state-change nil t)))
(defun Man-build-section-list ()
"Build the list of manpage sections."
next reply other threads:[~2020-05-12 22:57 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-05-12 22:57 Juri Linkov [this message]
2020-05-14 20:46 ` bug#41222: 27.1; Auto-resizing of images in image-mode Alan Third
2020-05-14 22:39 ` Juri Linkov
2020-05-15 6:28 ` Alan Third
2020-05-19 22:43 ` Juri Linkov
2020-05-20 20:18 ` Alan Third
2020-05-20 22:23 ` Juri Linkov
2020-06-08 0:30 ` Juri Linkov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87tv0kkbkl.fsf@mail.linkov.net \
--to=juri@linkov.net \
--cc=41222@debbugs.gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).