annotate lisp/modes/image-mode.el @ 167:85ec50267440 r20-3b10

Import from CVS: tag r20-3b10
author cvs
date Mon, 13 Aug 2007 09:45:46 +0200
parents
children 15872534500d
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
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
7 ;; Version: $Id: image-mode.el,v 1.1 1997/06/29 23:12:55 steve Exp $
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
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
126 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
127 (defun image-mode (&optional arg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
128 "\\{image-mode-map}"
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
129 (interactive)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
130 (setq major-mode 'image-mode)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
131 (setq mode-name "Image")
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
132 (use-local-map image-mode-map)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
133 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
134
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
135 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
136 (defun image-decode-jpeg (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
137 "Decode JPEG image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
138 (setq buffer-image-format 'image/jpeg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
139 (image-decode start end 'jpeg)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
140 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
141
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
142 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
143 (defun image-decode-gif (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
144 "Decode GIF image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
145 (setq buffer-image-format 'image/gif)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
146 (image-decode start end 'gif)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
147 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
148
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
149 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
150 (defun image-decode-png (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
151 "Decode PNG image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
152 (setq buffer-image-format 'image/png)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
153 (image-decode start end 'png)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
154 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
155
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
156 ;;;###autoload
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
157 (defun image-decode-xpm (start end)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
158 "Decode XPM image between START and END."
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
159 (setq buffer-image-format 'image/x-xpm)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
160 (image-decode start end 'xpm)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
161 )
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
162
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
163 (provide 'image-mode)
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
164
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents:
diff changeset
165 ;;; image-mode.el ends here