'exif-parse-file' and 'exif-parse-buffer' are the main interface
functions.
+*** 'image-mode' now uses this library to automatically rotate images
+according to the orientation in the Exif data, if any.
+
*** New library image-converter.
If you need to view exotic image formats for which Emacs doesn't have
native support, customize the new user option
GraphicsMagick, ImageMagick or 'ffmpeg' installed, they will then be
used to convert images automatically before displaying them.
-*** 'image-mode' now uses this library to automatically rotate images
-according to the orientation in the Exif data, if any.
+*** 'auto-mode-alist' now includes many of the types typically
+supported by the external image converters, like WEPB, BMP and ICO.
+These now default to using 'image-mode'.
*** 'imagemagick-types-inhibit' disables using ImageMagick by default.
'image-mode' started using ImageMagick by default for all images
;; The following should come after the ChangeLog pattern
;; for the sake of ChangeLog.1, etc.
;; and after the .scm.[0-9] and CVS' <file>.<rev> patterns too.
- ("\\.[1-9]\\'" . nroff-mode)))
+ ("\\.[1-9]\\'" . nroff-mode)
+ ;; Image file types probably supported by `image-convert'.
+ ("\\.art\\'" . image-mode)
+ ("\\.avs\\'" . image-mode)
+ ("\\.bmp\\'" . image-mode)
+ ("\\.cmyk\\'" . image-mode)
+ ("\\.cmyka\\'" . image-mode)
+ ("\\.crw\\'" . image-mode)
+ ("\\.dcr\\'" . image-mode)
+ ("\\.dcx\\'" . image-mode)
+ ("\\.dng\\'" . image-mode)
+ ("\\.dpx\\'" . image-mode)
+ ("\\.fax\\'" . image-mode)
+ ("\\.hrz\\'" . image-mode)
+ ("\\.icb\\'" . image-mode)
+ ("\\.icc\\'" . image-mode)
+ ("\\.icm\\'" . image-mode)
+ ("\\.ico\\'" . image-mode)
+ ("\\.icon\\'" . image-mode)
+ ("\\.jbg\\'" . image-mode)
+ ("\\.jbig\\'" . image-mode)
+ ("\\.jng\\'" . image-mode)
+ ("\\.jnx\\'" . image-mode)
+ ("\\.miff\\'" . image-mode)
+ ("\\.mng\\'" . image-mode)
+ ("\\.mvg\\'" . image-mode)
+ ("\\.otb\\'" . image-mode)
+ ("\\.p7\\'" . image-mode)
+ ("\\.pcx\\'" . image-mode)
+ ("\\.pdb\\'" . image-mode)
+ ("\\.pfa\\'" . image-mode)
+ ("\\.pfb\\'" . image-mode)
+ ("\\.picon\\'" . image-mode)
+ ("\\.pict\\'" . image-mode)
+ ("\\.rgb\\'" . image-mode)
+ ("\\.rgba\\'" . image-mode)
+ ("\\.tga\\'" . image-mode)
+ ("\\.wbmp\\'" . image-mode)
+ ("\\.webp\\'" . image-mode)
+ ("\\.wmf\\'" . image-mode)
+ ("\\.wpg\\'" . image-mode)
+ ("\\.xcf\\'" . image-mode)
+ ("\\.xmp\\'" . image-mode)
+ ("\\.xwd\\'" . image-mode)
+ ("\\.yuv\\'" . image-mode)))
"Alist of filename patterns vs corresponding major mode functions.
Each element looks like (REGEXP . FUNCTION) or (REGEXP FUNCTION NON-NIL).
\(NON-NIL stands for anything that is not nil; the value does not matter.)
Key bindings:
\\{image-mode-map}"
(interactive)
- (condition-case err
+ (unless (display-images-p)
+ (error "Display does not support images"))
+
+ (major-mode-suspend)
+ (setq major-mode 'image-mode)
+
+ (if (not (image-get-display-property))
(progn
- (unless (display-images-p)
- (error "Display does not support images"))
-
- (major-mode-suspend)
- (setq major-mode 'image-mode)
-
- (if (not (image-get-display-property))
- (progn
- (image-toggle-display-image)
- ;; If attempt to display the image fails.
- (if (not (image-get-display-property))
- (error "Invalid image")))
- ;; Set next vars when image is already displayed but local
- ;; variables were cleared by kill-all-local-variables
- (setq cursor-type nil truncate-lines t
- image-type (plist-get (cdr (image-get-display-property)) :type)))
-
- (setq mode-name (if image-type (format "Image[%s]" image-type) "Image"))
- (use-local-map image-mode-map)
-
- ;; Use our own bookmarking function for images.
- (setq-local bookmark-make-record-function
- #'image-bookmark-make-record)
-
- ;; Keep track of [vh]scroll when switching buffers
- (image-mode-setup-winprops)
-
- (add-hook 'change-major-mode-hook #'image-toggle-display-text nil t)
- (add-hook 'after-revert-hook #'image-after-revert-hook nil t)
- (run-mode-hooks 'image-mode-hook)
- (let ((image (image-get-display-property))
- (msg1 (substitute-command-keys
- "Type \\[image-toggle-display] or \\[image-toggle-hex-display] to view the image as "))
- animated)
- (cond
- ((null image)
- (message "%s" (concat msg1 "an image.")))
- ((setq animated (image-multi-frame-p image))
- (setq image-multi-frame t
- mode-line-process
- `(:eval
- (concat " "
- (propertize
- (format "[%s/%s]"
- (1+ (image-current-frame ',image))
- ,(car animated))
- 'help-echo "Frames
-mouse-1: Next frame
-mouse-3: Previous frame"
- 'mouse-face 'mode-line-highlight
- 'local-map
- '(keymap
- (mode-line
- keymap
- (down-mouse-1 . image-next-frame)
- (down-mouse-3 . image-previous-frame)))))))
- (message "%s"
- (concat msg1 "text. This image has multiple frames.")))
-;;; (substitute-command-keys
-;;; "\\[image-toggle-animation] to animate."))))
- (t
- (message "%s" (concat msg1 "text or hex."))))))
-
- (error
- (image-mode-as-text)
- (funcall
- (if (called-interactively-p 'any) 'error 'message)
- "Cannot display image: %s" (cdr err)))))
+ (when (condition-case err
+ (progn
+ (image-toggle-display-image)
+ t)
+ (unknown-image-type
+ (image-mode-as-text)
+ (funcall
+ (if (called-interactively-p 'any) 'error 'message)
+ "Unknown image type; consider switching `image-use-external-converter' on")
+ nil)
+ (error
+ (image-mode-as-text)
+ (funcall
+ (if (called-interactively-p 'any) 'error 'message)
+ "Cannot display image: %s" (cdr err))
+ nil))
+ ;; If attempt to display the image fails.
+ (if (not (image-get-display-property))
+ (error "Invalid image"))
+ (image-mode--setup-mode)))
+ ;; Set next vars when image is already displayed but local
+ ;; variables were cleared by kill-all-local-variables
+ (setq cursor-type nil truncate-lines t
+ image-type (plist-get (cdr (image-get-display-property)) :type))
+ (image-mode--setup-mode)))
+
+(defun image-mode--setup-mode ()
+ (setq mode-name (if image-type (format "Image[%s]" image-type) "Image"))
+ (use-local-map image-mode-map)
+
+ ;; Use our own bookmarking function for images.
+ (setq-local bookmark-make-record-function
+ #'image-bookmark-make-record)
+
+ ;; Keep track of [vh]scroll when switching buffers
+ (image-mode-setup-winprops)
+
+ (add-hook 'change-major-mode-hook #'image-toggle-display-text nil t)
+ (add-hook 'after-revert-hook #'image-after-revert-hook nil t)
+ (run-mode-hooks 'image-mode-hook)
+ (let ((image (image-get-display-property))
+ (msg1 (substitute-command-keys
+ "Type \\[image-toggle-display] or \\[image-toggle-hex-display] to view the image as "))
+ animated)
+ (cond
+ ((null image)
+ (message "%s" (concat msg1 "an image.")))
+ ((setq animated (image-multi-frame-p image))
+ (setq image-multi-frame t
+ mode-line-process
+ `(:eval
+ (concat " "
+ (propertize
+ (format "[%s/%s]"
+ (1+ (image-current-frame ',image))
+ ,(car animated))
+ 'help-echo "Frames\nmouse-1: Next frame\nmouse-3: Previous frame"
+ 'mouse-face 'mode-line-highlight
+ 'local-map
+ '(keymap
+ (mode-line
+ keymap
+ (down-mouse-1 . image-next-frame)
+ (down-mouse-3 . image-previous-frame)))))))
+ (message "%s"
+ (concat msg1 "text. This image has multiple frames.")))
+ (t
+ (message "%s" (concat msg1 "text or hex."))))))
;;;###autoload
(define-minor-mode image-minor-mode