annotate lisp/modes/image-mode.el @ 169:15872534500d r20-3b11

Import from CVS: tag r20-3b11
author cvs
date Mon, 13 Aug 2007 09:46:53 +0200
parents 85ec50267440
children 78f53ef88e17
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
1 ;;; image-mode.el --- Major mode for navigate images
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
2
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
3 ;; Copyright (C) 1997 MORIOKA Tomohiko
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
4
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
5 ;; Author: MORIOKA Tomohiko <morioka@jaist.ac.jp>
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
6 ;; Created: 1997/6/27
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
7 ;; Version: image-mode.el,v 20.3.1.2 1997/07/01 17:29:44 morioka Exp
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
8 ;; Keywords: image, graphics
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
9
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
10 ;; This file is part of XEmacs.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
11
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
12 ;; XEmacs is free software; you can redistribute it and/or modify it
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
13 ;; under the terms of the GNU General Public License as published by
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
14 ;; the Free Software Foundation; either version 2, or (at your option)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
15 ;; any later version.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
16
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
17 ;; XEmacs is distributed in the hope that it will be useful, but
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
18 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
20 ;; General Public License for more details.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
21
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
22 ;; You should have received a copy of the GNU General Public License
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
23 ;; along with XEmacs; see the file COPYING. If not, write to the Free
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
24 ;; Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
25 ;; 02111-1307, USA.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
26
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
27 ;;; Code:
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
28
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
29 (defvar buffer-image-format nil)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
30 (make-variable-buffer-local 'buffer-image-format)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
31
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
32 (defsubst image-decode (start end type)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
33 "Decode the image between START and END which is encoded in TYPE."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
34 (save-excursion
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
35 (let ((image (make-image-instance
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
36 (vector type :data (buffer-string)) nil nil 'no-error)))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
37 (delete-region start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
38 (if image
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
39 (let ((glyph (make-glyph image)))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
40 (set-extent-begin-glyph (make-extent start start) glyph)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
41 (setq buffer-read-only t)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
42 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
43 (insert (format "%s is not supported!\n" type))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
44 (let ((overriding-local-map image-mode-map))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
45 (insert
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
46 (substitute-command-keys
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
47 "
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
48 Please type `\\[image-toggle-decoding]' if you would like to display
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
49 raw data.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
50 Please type `\\[image-enter-hexl-mode]' if you would like to edit hex
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
51 data.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
52 Please type `\\[image-start-external-viewer]' if you would like to
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
53 display contents of this buffer by external viewer.\n")))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
54 (call-interactively 'fill-paragraph)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
55 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
56 start)))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
57
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
58 (defvar image-mode-map (make-keymap))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
59 (suppress-keymap image-mode-map)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
60 (define-key image-mode-map "v" 'image-start-external-viewer)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
61 (define-key image-mode-map "t" 'image-toggle-decoding)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
62 (define-key image-mode-map "h" 'image-enter-hexl-mode)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
63 (define-key image-mode-map "q" 'image-mode-quit)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
64
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
65 (defvar image-external-viewer
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
66 (cond ((exec-installed-p "display") "display") ; ImageMagic
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
67 ((exec-installed-p "xv") "xv") ; xv
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
68 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
69 "*External viewer for image-mode.")
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
70
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
71 (defun image-start-external-viewer ()
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
72 "Start external image viewer for current-buffer.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
73 It uses `image-external-viewer' as external image viewer."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
74 (interactive)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
75 (start-process "external image viewer" nil
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
76 image-external-viewer buffer-file-name)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
77 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
78
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
79 (defun image-toggle-decoding ()
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
80 "Toggle image display mode in current buffer."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
81 (interactive)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
82 (if buffer-file-format
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
83 (progn
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
84 (setq buffer-read-only nil)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
85 (erase-buffer)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
86 (map-extents (function
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
87 (lambda (extent maparg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
88 (delete-extent extent)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
89 )) nil (point-min)(point-min))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
90 (setq buffer-file-format nil)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
91 (insert-file-contents-literally buffer-file-name)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
92 (set-buffer-modified-p nil)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
93 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
94 (format-decode-buffer buffer-image-format)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
95 ))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
96
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
97 (defun image-exit-hexl-mode-function ()
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
98 (format-decode-buffer)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
99 (remove-hook 'hexl-mode-exit-hook 'image-exit-hexl-mode-function)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
100 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
101
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
102 (defun image-enter-hexl-mode ()
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
103 "Enter to hexl-mode."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
104 (interactive)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
105 (when buffer-file-format
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
106 (setq buffer-read-only nil)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
107 (erase-buffer)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
108 (map-extents (function
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
109 (lambda (extent maparg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
110 (delete-extent extent)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
111 )) nil (point-min)(point-min))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
112 (setq buffer-file-format nil)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
113 (insert-file-contents-literally buffer-file-name)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
114 (set-buffer-modified-p nil)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
115 (add-hook 'hexl-mode-exit-hook 'image-exit-hexl-mode-function)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
116 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
117 (hexl-mode)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
118 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
119
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
120 (defun image-mode-quit ()
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
121 "Exit image-mode."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
122 (interactive)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
123 (kill-buffer (current-buffer))
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
124 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
125
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
126 (defun image-maybe-restore ()
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
127 "Restore buffer from file if it is decoded as `buffer-file-format'."
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
128 (when (and buffer-file-format
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
129 buffer-file-name)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
130 (setq buffer-read-only nil)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
131 (erase-buffer)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
132 (map-extents (function
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
133 (lambda (extent maparg)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
134 (delete-extent extent)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
135 )) nil (point-min)(point-min))
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
136 (setq buffer-file-format nil)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
137 (insert-file-contents-literally buffer-file-name)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
138 (set-buffer-modified-p nil)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
139 ))
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
140
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
141 (add-hook 'change-major-mode-hook 'image-maybe-restore)
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
142
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
143
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
144 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
145 (defun image-mode (&optional arg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
146 "\\{image-mode-map}"
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
147 (interactive)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
148 (setq major-mode 'image-mode)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
149 (setq mode-name "Image")
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
150 (use-local-map image-mode-map)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
151 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
152
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
153 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
154 (defun image-decode-jpeg (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
155 "Decode JPEG image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
156 (setq buffer-image-format 'image/jpeg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
157 (image-decode start end 'jpeg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
158 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
159
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
160 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
161 (defun image-decode-gif (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
162 "Decode GIF image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
163 (setq buffer-image-format 'image/gif)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
164 (image-decode start end 'gif)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
165 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
166
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
167 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
168 (defun image-decode-png (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
169 "Decode PNG image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
170 (setq buffer-image-format 'image/png)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
171 (image-decode start end 'png)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
172 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
173
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
174 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
175 (defun image-decode-xpm (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
176 "Decode XPM image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
177 (setq buffer-image-format 'image/x-xpm)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
178 (image-decode start end 'xpm)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
179 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
180
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
181 (provide 'image-mode)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
182
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
183 ;;; image-mode.el ends here