poppler 2.2.4-x64-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/README +35 -0
- data/Rakefile +75 -0
- data/ext/poppler/depend +6 -0
- data/ext/poppler/extconf.rb +70 -0
- data/ext/poppler/poppler.def +2 -0
- data/ext/poppler/rbpoppler-action.c +372 -0
- data/ext/poppler/rbpoppler-annotation-callout-line.c +127 -0
- data/ext/poppler/rbpoppler-annotation-free-text.c +46 -0
- data/ext/poppler/rbpoppler-annotation-mapping.c +72 -0
- data/ext/poppler/rbpoppler-annotation-markup.c +98 -0
- data/ext/poppler/rbpoppler-annotation-text.c +53 -0
- data/ext/poppler/rbpoppler-annotation.c +74 -0
- data/ext/poppler/rbpoppler-attachment.c +124 -0
- data/ext/poppler/rbpoppler-button-field.c +56 -0
- data/ext/poppler/rbpoppler-choice-field.c +131 -0
- data/ext/poppler/rbpoppler-color.c +107 -0
- data/ext/poppler/rbpoppler-document.c +224 -0
- data/ext/poppler/rbpoppler-font-info.c +59 -0
- data/ext/poppler/rbpoppler-fonts-iter.c +127 -0
- data/ext/poppler/rbpoppler-form-field-mapping.c +44 -0
- data/ext/poppler/rbpoppler-form-field.c +98 -0
- data/ext/poppler/rbpoppler-image-mapping.c +48 -0
- data/ext/poppler/rbpoppler-index-iter.c +128 -0
- data/ext/poppler/rbpoppler-link-mapping.c +47 -0
- data/ext/poppler/rbpoppler-page-transition.c +59 -0
- data/ext/poppler/rbpoppler-page.c +322 -0
- data/ext/poppler/rbpoppler-private.h +77 -0
- data/ext/poppler/rbpoppler-ps-file.c +66 -0
- data/ext/poppler/rbpoppler-rectangle.c +92 -0
- data/ext/poppler/rbpoppler-text-field.c +91 -0
- data/ext/poppler/rbpoppler.c +111 -0
- data/ext/poppler/rbpoppler.h +61 -0
- data/ext/poppler/rbpopplerconversions.h +105 -0
- data/extconf.rb +49 -0
- data/lib/2.0/poppler.so +0 -0
- data/lib/2.1/poppler.so +0 -0
- data/lib/2.2/poppler.so +0 -0
- data/lib/poppler.rb +105 -0
- data/sample/number-pdf.rb +32 -0
- data/sample/pdf2.rb +132 -0
- data/sample/pdf2svg.rb +26 -0
- data/sample/pdf2text.rb +16 -0
- data/sample/pdfcrop.rb +32 -0
- data/sample/pdfdiv.rb +36 -0
- data/test/fixtures/image.pdf +0 -0
- data/test/fixtures/image.png +0 -0
- data/test/poppler-test-utils.rb +58 -0
- data/test/run-test.rb +32 -0
- data/test/test_annotation.rb +86 -0
- data/test/test_color.rb +26 -0
- data/test/test_constants.rb +30 -0
- data/test/test_document.rb +41 -0
- data/test/test_page.rb +42 -0
- data/vendor/local/bin/cjpeg.exe +0 -0
- data/vendor/local/bin/djpeg.exe +0 -0
- data/vendor/local/bin/jpegtran.exe +0 -0
- data/vendor/local/bin/libjpeg-9.dll +0 -0
- data/vendor/local/bin/libpoppler-48.dll +0 -0
- data/vendor/local/bin/libpoppler-cpp-0.dll +0 -0
- data/vendor/local/bin/libpoppler-glib-8.dll +0 -0
- data/vendor/local/bin/libsqlite3-0.dll +0 -0
- data/vendor/local/bin/pdfdetach.exe +0 -0
- data/vendor/local/bin/pdffonts.exe +0 -0
- data/vendor/local/bin/pdfimages.exe +0 -0
- data/vendor/local/bin/pdfinfo.exe +0 -0
- data/vendor/local/bin/pdfseparate.exe +0 -0
- data/vendor/local/bin/pdftocairo.exe +0 -0
- data/vendor/local/bin/pdftohtml.exe +0 -0
- data/vendor/local/bin/pdftoppm.exe +0 -0
- data/vendor/local/bin/pdftops.exe +0 -0
- data/vendor/local/bin/pdftotext.exe +0 -0
- data/vendor/local/bin/pdfunite.exe +0 -0
- data/vendor/local/bin/rdjpgcom.exe +0 -0
- data/vendor/local/bin/sqlite3.exe +0 -0
- data/vendor/local/bin/wrjpgcom.exe +0 -0
- data/vendor/local/include/jconfig.h +60 -0
- data/vendor/local/include/jerror.h +304 -0
- data/vendor/local/include/jmorecfg.h +446 -0
- data/vendor/local/include/jpeglib.h +1180 -0
- data/vendor/local/include/poppler/cpp/poppler-document.h +104 -0
- data/vendor/local/include/poppler/cpp/poppler-embedded-file.h +55 -0
- data/vendor/local/include/poppler/cpp/poppler-font.h +91 -0
- data/vendor/local/include/poppler/cpp/poppler-global.h +111 -0
- data/vendor/local/include/poppler/cpp/poppler-image.h +71 -0
- data/vendor/local/include/poppler/cpp/poppler-page-renderer.h +66 -0
- data/vendor/local/include/poppler/cpp/poppler-page-transition.h +82 -0
- data/vendor/local/include/poppler/cpp/poppler-page.h +76 -0
- data/vendor/local/include/poppler/cpp/poppler-rectangle.h +84 -0
- data/vendor/local/include/poppler/cpp/poppler-toc.h +74 -0
- data/vendor/local/include/poppler/cpp/poppler-version.h +39 -0
- data/vendor/local/include/poppler/glib/poppler-action.h +316 -0
- data/vendor/local/include/poppler/glib/poppler-annot.h +296 -0
- data/vendor/local/include/poppler/glib/poppler-attachment.h +87 -0
- data/vendor/local/include/poppler/glib/poppler-date.h +30 -0
- data/vendor/local/include/poppler/glib/poppler-document.h +299 -0
- data/vendor/local/include/poppler/glib/poppler-enums.h +116 -0
- data/vendor/local/include/poppler/glib/poppler-features.h +88 -0
- data/vendor/local/include/poppler/glib/poppler-form-field.h +111 -0
- data/vendor/local/include/poppler/glib/poppler-layer.h +43 -0
- data/vendor/local/include/poppler/glib/poppler-media.h +73 -0
- data/vendor/local/include/poppler/glib/poppler-movie.h +42 -0
- data/vendor/local/include/poppler/glib/poppler-page.h +377 -0
- data/vendor/local/include/poppler/glib/poppler-structure-element.h +357 -0
- data/vendor/local/include/poppler/glib/poppler.h +250 -0
- data/vendor/local/include/sqlite3.h +7494 -0
- data/vendor/local/include/sqlite3ext.h +487 -0
- data/vendor/local/lib/girepository-1.0/Poppler-0.18.typelib +0 -0
- data/vendor/local/lib/libjpeg.a +0 -0
- data/vendor/local/lib/libjpeg.dll.a +0 -0
- data/vendor/local/lib/libjpeg.la +41 -0
- data/vendor/local/lib/libpoppler-cpp.a +0 -0
- data/vendor/local/lib/libpoppler-cpp.dll.a +0 -0
- data/vendor/local/lib/libpoppler-cpp.la +41 -0
- data/vendor/local/lib/libpoppler-glib.a +0 -0
- data/vendor/local/lib/libpoppler-glib.dll.a +0 -0
- data/vendor/local/lib/libpoppler-glib.la +41 -0
- data/vendor/local/lib/libpoppler.a +0 -0
- data/vendor/local/lib/libpoppler.dll.a +0 -0
- data/vendor/local/lib/libpoppler.la +41 -0
- data/vendor/local/lib/libsqlite3.a +0 -0
- data/vendor/local/lib/libsqlite3.dll.a +0 -0
- data/vendor/local/lib/libsqlite3.la +41 -0
- data/vendor/local/lib/pkgconfig/poppler-cairo.pc +9 -0
- data/vendor/local/lib/pkgconfig/poppler-cpp.pc +13 -0
- data/vendor/local/lib/pkgconfig/poppler-glib.pc +13 -0
- data/vendor/local/lib/pkgconfig/poppler-splash.pc +9 -0
- data/vendor/local/lib/pkgconfig/poppler.pc +11 -0
- data/vendor/local/lib/pkgconfig/sqlite3.pc +13 -0
- data/vendor/local/share/gir-1.0/Poppler-0.18.gir +8281 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerAnnot.html +3221 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerAttachment.html +267 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerDocument.html +3328 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerFormField.html +1403 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerLayer.html +307 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerMedia.html +381 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerMovie.html +197 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerPage.html +3002 -0
- data/vendor/local/share/gtk-doc/html/poppler/PopplerStructureElement.html +3781 -0
- data/vendor/local/share/gtk-doc/html/poppler/annotation-glossary.html +63 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-12.html +123 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-14.html +102 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-16.html +180 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-18.html +72 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-20.html +39 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-0-22.html +64 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-deprecated.html +39 -0
- data/vendor/local/share/gtk-doc/html/poppler/api-index-full.html +1830 -0
- data/vendor/local/share/gtk-doc/html/poppler/ch01.html +74 -0
- data/vendor/local/share/gtk-doc/html/poppler/home.png +0 -0
- data/vendor/local/share/gtk-doc/html/poppler/index.html +85 -0
- data/vendor/local/share/gtk-doc/html/poppler/index.sgml +557 -0
- data/vendor/local/share/gtk-doc/html/poppler/left-insensitive.png +0 -0
- data/vendor/local/share/gtk-doc/html/poppler/left.png +0 -0
- data/vendor/local/share/gtk-doc/html/poppler/poppler-PDF-Utility-functions.html +107 -0
- data/vendor/local/share/gtk-doc/html/poppler/poppler-PopplerAction.html +796 -0
- data/vendor/local/share/gtk-doc/html/poppler/poppler-PopplerColor.html +201 -0
- data/vendor/local/share/gtk-doc/html/poppler/poppler-Version-and-Features-Information.html +254 -0
- data/vendor/local/share/gtk-doc/html/poppler/poppler-poppler.html +169 -0
- data/vendor/local/share/gtk-doc/html/poppler/poppler.devhelp2 +470 -0
- data/vendor/local/share/gtk-doc/html/poppler/right-insensitive.png +0 -0
- data/vendor/local/share/gtk-doc/html/poppler/right.png +0 -0
- data/vendor/local/share/gtk-doc/html/poppler/style.css +476 -0
- data/vendor/local/share/gtk-doc/html/poppler/up-insensitive.png +0 -0
- data/vendor/local/share/gtk-doc/html/poppler/up.png +0 -0
- data/vendor/local/share/license/poppler/AUTHORS +5 -0
- data/vendor/local/share/license/poppler/COPYING +339 -0
- data/vendor/local/share/man/man1/cjpeg.1 +387 -0
- data/vendor/local/share/man/man1/djpeg.1 +252 -0
- data/vendor/local/share/man/man1/jpegtran.1 +293 -0
- data/vendor/local/share/man/man1/pdfdetach.1 +86 -0
- data/vendor/local/share/man/man1/pdffonts.1 +119 -0
- data/vendor/local/share/man/man1/pdfimages.1 +260 -0
- data/vendor/local/share/man/man1/pdfinfo.1 +152 -0
- data/vendor/local/share/man/man1/pdfseparate.1 +49 -0
- data/vendor/local/share/man/man1/pdftocairo.1 +295 -0
- data/vendor/local/share/man/man1/pdftohtml.1 +107 -0
- data/vendor/local/share/man/man1/pdftoppm.1 +170 -0
- data/vendor/local/share/man/man1/pdftops.1 +217 -0
- data/vendor/local/share/man/man1/pdftotext.1 +137 -0
- data/vendor/local/share/man/man1/pdfunite.1 +33 -0
- data/vendor/local/share/man/man1/rdjpgcom.1 +63 -0
- data/vendor/local/share/man/man1/sqlite3.1 +279 -0
- data/vendor/local/share/man/man1/wrjpgcom.1 +103 -0
- metadata +254 -0
@@ -0,0 +1,252 @@
|
|
1
|
+
.TH DJPEG 1 "23 November 2013"
|
2
|
+
.SH NAME
|
3
|
+
djpeg \- decompress a JPEG file to an image file
|
4
|
+
.SH SYNOPSIS
|
5
|
+
.B djpeg
|
6
|
+
[
|
7
|
+
.I options
|
8
|
+
]
|
9
|
+
[
|
10
|
+
.I filename
|
11
|
+
]
|
12
|
+
.LP
|
13
|
+
.SH DESCRIPTION
|
14
|
+
.LP
|
15
|
+
.B djpeg
|
16
|
+
decompresses the named JPEG file, or the standard input if no file is named,
|
17
|
+
and produces an image file on the standard output. PBMPLUS (PPM/PGM), BMP,
|
18
|
+
GIF, Targa, or RLE (Utah Raster Toolkit) output format can be selected.
|
19
|
+
(RLE is supported only if the URT library is available.)
|
20
|
+
.SH OPTIONS
|
21
|
+
All switch names may be abbreviated; for example,
|
22
|
+
.B \-grayscale
|
23
|
+
may be written
|
24
|
+
.B \-gray
|
25
|
+
or
|
26
|
+
.BR \-gr .
|
27
|
+
Most of the "basic" switches can be abbreviated to as little as one letter.
|
28
|
+
Upper and lower case are equivalent (thus
|
29
|
+
.B \-BMP
|
30
|
+
is the same as
|
31
|
+
.BR \-bmp ).
|
32
|
+
British spellings are also accepted (e.g.,
|
33
|
+
.BR \-greyscale ),
|
34
|
+
though for brevity these are not mentioned below.
|
35
|
+
.PP
|
36
|
+
The basic switches are:
|
37
|
+
.TP
|
38
|
+
.BI \-colors " N"
|
39
|
+
Reduce image to at most N colors. This reduces the number of colors used in
|
40
|
+
the output image, so that it can be displayed on a colormapped display or
|
41
|
+
stored in a colormapped file format. For example, if you have an 8-bit
|
42
|
+
display, you'd need to reduce to 256 or fewer colors.
|
43
|
+
.TP
|
44
|
+
.BI \-quantize " N"
|
45
|
+
Same as
|
46
|
+
.BR \-colors .
|
47
|
+
.B \-colors
|
48
|
+
is the recommended name,
|
49
|
+
.B \-quantize
|
50
|
+
is provided only for backwards compatibility.
|
51
|
+
.TP
|
52
|
+
.B \-fast
|
53
|
+
Select recommended processing options for fast, low quality output. (The
|
54
|
+
default options are chosen for highest quality output.) Currently, this is
|
55
|
+
equivalent to \fB\-dct fast \-nosmooth \-onepass \-dither ordered\fR.
|
56
|
+
.TP
|
57
|
+
.B \-grayscale
|
58
|
+
Force gray-scale output even if JPEG file is color. Useful for viewing on
|
59
|
+
monochrome displays; also,
|
60
|
+
.B djpeg
|
61
|
+
runs noticeably faster in this mode.
|
62
|
+
.TP
|
63
|
+
.BI \-scale " M/N"
|
64
|
+
Scale the output image by a factor M/N. Currently supported scale factors are
|
65
|
+
M/N with all M from 1 to 16, where N is the source DCT size, which is 8 for
|
66
|
+
baseline JPEG. If the /N part is omitted, then M specifies the DCT scaled
|
67
|
+
size to be applied on the given input. For baseline JPEG this is equivalent
|
68
|
+
to M/8 scaling, since the source DCT size for baseline JPEG is 8.
|
69
|
+
Scaling is handy if the image is larger than your screen; also,
|
70
|
+
.B djpeg
|
71
|
+
runs much faster when scaling down the output.
|
72
|
+
.TP
|
73
|
+
.B \-bmp
|
74
|
+
Select BMP output format (Windows flavor). 8-bit colormapped format is
|
75
|
+
emitted if
|
76
|
+
.B \-colors
|
77
|
+
or
|
78
|
+
.B \-grayscale
|
79
|
+
is specified, or if the JPEG file is gray-scale; otherwise, 24-bit full-color
|
80
|
+
format is emitted.
|
81
|
+
.TP
|
82
|
+
.B \-gif
|
83
|
+
Select GIF output format. Since GIF does not support more than 256 colors,
|
84
|
+
.B \-colors 256
|
85
|
+
is assumed (unless you specify a smaller number of colors).
|
86
|
+
.TP
|
87
|
+
.B \-os2
|
88
|
+
Select BMP output format (OS/2 1.x flavor). 8-bit colormapped format is
|
89
|
+
emitted if
|
90
|
+
.B \-colors
|
91
|
+
or
|
92
|
+
.B \-grayscale
|
93
|
+
is specified, or if the JPEG file is gray-scale; otherwise, 24-bit full-color
|
94
|
+
format is emitted.
|
95
|
+
.TP
|
96
|
+
.B \-pnm
|
97
|
+
Select PBMPLUS (PPM/PGM) output format (this is the default format).
|
98
|
+
PGM is emitted if the JPEG file is gray-scale or if
|
99
|
+
.B \-grayscale
|
100
|
+
is specified; otherwise PPM is emitted.
|
101
|
+
.TP
|
102
|
+
.B \-rle
|
103
|
+
Select RLE output format. (Requires URT library.)
|
104
|
+
.TP
|
105
|
+
.B \-targa
|
106
|
+
Select Targa output format. Gray-scale format is emitted if the JPEG file is
|
107
|
+
gray-scale or if
|
108
|
+
.B \-grayscale
|
109
|
+
is specified; otherwise, colormapped format is emitted if
|
110
|
+
.B \-colors
|
111
|
+
is specified; otherwise, 24-bit full-color format is emitted.
|
112
|
+
.PP
|
113
|
+
Switches for advanced users:
|
114
|
+
.TP
|
115
|
+
.B \-dct int
|
116
|
+
Use integer DCT method (default).
|
117
|
+
.TP
|
118
|
+
.B \-dct fast
|
119
|
+
Use fast integer DCT (less accurate).
|
120
|
+
.TP
|
121
|
+
.B \-dct float
|
122
|
+
Use floating-point DCT method.
|
123
|
+
The float method is very slightly more accurate than the int method, but is
|
124
|
+
much slower unless your machine has very fast floating-point hardware. Also
|
125
|
+
note that results of the floating-point method may vary slightly across
|
126
|
+
machines, while the integer methods should give the same results everywhere.
|
127
|
+
The fast integer method is much less accurate than the other two.
|
128
|
+
.TP
|
129
|
+
.B \-dither fs
|
130
|
+
Use Floyd-Steinberg dithering in color quantization.
|
131
|
+
.TP
|
132
|
+
.B \-dither ordered
|
133
|
+
Use ordered dithering in color quantization.
|
134
|
+
.TP
|
135
|
+
.B \-dither none
|
136
|
+
Do not use dithering in color quantization.
|
137
|
+
By default, Floyd-Steinberg dithering is applied when quantizing colors; this
|
138
|
+
is slow but usually produces the best results. Ordered dither is a compromise
|
139
|
+
between speed and quality; no dithering is fast but usually looks awful. Note
|
140
|
+
that these switches have no effect unless color quantization is being done.
|
141
|
+
Ordered dither is only available in
|
142
|
+
.B \-onepass
|
143
|
+
mode.
|
144
|
+
.TP
|
145
|
+
.BI \-map " file"
|
146
|
+
Quantize to the colors used in the specified image file. This is useful for
|
147
|
+
producing multiple files with identical color maps, or for forcing a
|
148
|
+
predefined set of colors to be used. The
|
149
|
+
.I file
|
150
|
+
must be a GIF or PPM file. This option overrides
|
151
|
+
.B \-colors
|
152
|
+
and
|
153
|
+
.BR \-onepass .
|
154
|
+
.TP
|
155
|
+
.B \-nosmooth
|
156
|
+
Don't use high-quality upsampling.
|
157
|
+
.TP
|
158
|
+
.B \-onepass
|
159
|
+
Use one-pass instead of two-pass color quantization. The one-pass method is
|
160
|
+
faster and needs less memory, but it produces a lower-quality image.
|
161
|
+
.B \-onepass
|
162
|
+
is ignored unless you also say
|
163
|
+
.B \-colors
|
164
|
+
.IR N .
|
165
|
+
Also, the one-pass method is always used for gray-scale output (the two-pass
|
166
|
+
method is no improvement then).
|
167
|
+
.TP
|
168
|
+
.BI \-maxmemory " N"
|
169
|
+
Set limit for amount of memory to use in processing large images. Value is
|
170
|
+
in thousands of bytes, or millions of bytes if "M" is attached to the
|
171
|
+
number. For example,
|
172
|
+
.B \-max 4m
|
173
|
+
selects 4000000 bytes. If more space is needed, temporary files will be used.
|
174
|
+
.TP
|
175
|
+
.BI \-outfile " name"
|
176
|
+
Send output image to the named file, not to standard output.
|
177
|
+
.TP
|
178
|
+
.B \-verbose
|
179
|
+
Enable debug printout. More
|
180
|
+
.BR \-v 's
|
181
|
+
give more output. Also, version information is printed at startup.
|
182
|
+
.TP
|
183
|
+
.B \-debug
|
184
|
+
Same as
|
185
|
+
.BR \-verbose .
|
186
|
+
.SH EXAMPLES
|
187
|
+
.LP
|
188
|
+
This example decompresses the JPEG file foo.jpg, quantizes it to
|
189
|
+
256 colors, and saves the output in 8-bit BMP format in foo.bmp:
|
190
|
+
.IP
|
191
|
+
.B djpeg \-colors 256 \-bmp
|
192
|
+
.I foo.jpg
|
193
|
+
.B >
|
194
|
+
.I foo.bmp
|
195
|
+
.SH HINTS
|
196
|
+
To get a quick preview of an image, use the
|
197
|
+
.B \-grayscale
|
198
|
+
and/or
|
199
|
+
.B \-scale
|
200
|
+
switches.
|
201
|
+
.B \-grayscale \-scale 1/8
|
202
|
+
is the fastest case.
|
203
|
+
.PP
|
204
|
+
Several options are available that trade off image quality to gain speed.
|
205
|
+
.B \-fast
|
206
|
+
turns on the recommended settings.
|
207
|
+
.PP
|
208
|
+
.B \-dct fast
|
209
|
+
and/or
|
210
|
+
.B \-nosmooth
|
211
|
+
gain speed at a small sacrifice in quality.
|
212
|
+
When producing a color-quantized image,
|
213
|
+
.B \-onepass \-dither ordered
|
214
|
+
is fast but much lower quality than the default behavior.
|
215
|
+
.B \-dither none
|
216
|
+
may give acceptable results in two-pass mode, but is seldom tolerable in
|
217
|
+
one-pass mode.
|
218
|
+
.PP
|
219
|
+
If you are fortunate enough to have very fast floating point hardware,
|
220
|
+
\fB\-dct float\fR may be even faster than \fB\-dct fast\fR. But on most
|
221
|
+
machines \fB\-dct float\fR is slower than \fB\-dct int\fR; in this case it is
|
222
|
+
not worth using, because its theoretical accuracy advantage is too small to be
|
223
|
+
significant in practice.
|
224
|
+
.SH ENVIRONMENT
|
225
|
+
.TP
|
226
|
+
.B JPEGMEM
|
227
|
+
If this environment variable is set, its value is the default memory limit.
|
228
|
+
The value is specified as described for the
|
229
|
+
.B \-maxmemory
|
230
|
+
switch.
|
231
|
+
.B JPEGMEM
|
232
|
+
overrides the default value specified when the program was compiled, and
|
233
|
+
itself is overridden by an explicit
|
234
|
+
.BR \-maxmemory .
|
235
|
+
.SH SEE ALSO
|
236
|
+
.BR cjpeg (1),
|
237
|
+
.BR jpegtran (1),
|
238
|
+
.BR rdjpgcom (1),
|
239
|
+
.BR wrjpgcom (1)
|
240
|
+
.br
|
241
|
+
.BR ppm (5),
|
242
|
+
.BR pgm (5)
|
243
|
+
.br
|
244
|
+
Wallace, Gregory K. "The JPEG Still Picture Compression Standard",
|
245
|
+
Communications of the ACM, April 1991 (vol. 34, no. 4), pp. 30-44.
|
246
|
+
.SH AUTHOR
|
247
|
+
Independent JPEG Group
|
248
|
+
.SH BUGS
|
249
|
+
To avoid the Unisys LZW patent (now expired),
|
250
|
+
.B djpeg
|
251
|
+
produces uncompressed GIF files. These are larger than they should be, but
|
252
|
+
are readable by standard GIF decoders.
|
@@ -0,0 +1,293 @@
|
|
1
|
+
.TH JPEGTRAN 1 "13 September 2013"
|
2
|
+
.SH NAME
|
3
|
+
jpegtran \- lossless transformation of JPEG files
|
4
|
+
.SH SYNOPSIS
|
5
|
+
.B jpegtran
|
6
|
+
[
|
7
|
+
.I options
|
8
|
+
]
|
9
|
+
[
|
10
|
+
.I filename
|
11
|
+
]
|
12
|
+
.LP
|
13
|
+
.SH DESCRIPTION
|
14
|
+
.LP
|
15
|
+
.B jpegtran
|
16
|
+
performs various useful transformations of JPEG files.
|
17
|
+
It can translate the coded representation from one variant of JPEG to another,
|
18
|
+
for example from baseline JPEG to progressive JPEG or vice versa. It can also
|
19
|
+
perform some rearrangements of the image data, for example turning an image
|
20
|
+
from landscape to portrait format by rotation.
|
21
|
+
.PP
|
22
|
+
.B jpegtran
|
23
|
+
works by rearranging the compressed data (DCT coefficients), without
|
24
|
+
ever fully decoding the image. Therefore, its transformations are lossless:
|
25
|
+
there is no image degradation at all, which would not be true if you used
|
26
|
+
.B djpeg
|
27
|
+
followed by
|
28
|
+
.B cjpeg
|
29
|
+
to accomplish the same conversion. But by the same token,
|
30
|
+
.B jpegtran
|
31
|
+
cannot perform lossy operations such as changing the image quality.
|
32
|
+
.PP
|
33
|
+
.B jpegtran
|
34
|
+
reads the named JPEG/JFIF file, or the standard input if no file is
|
35
|
+
named, and produces a JPEG/JFIF file on the standard output.
|
36
|
+
.SH OPTIONS
|
37
|
+
All switch names may be abbreviated; for example,
|
38
|
+
.B \-optimize
|
39
|
+
may be written
|
40
|
+
.B \-opt
|
41
|
+
or
|
42
|
+
.BR \-o .
|
43
|
+
Upper and lower case are equivalent.
|
44
|
+
British spellings are also accepted (e.g.,
|
45
|
+
.BR \-optimise ),
|
46
|
+
though for brevity these are not mentioned below.
|
47
|
+
.PP
|
48
|
+
To specify the coded JPEG representation used in the output file,
|
49
|
+
.B jpegtran
|
50
|
+
accepts a subset of the switches recognized by
|
51
|
+
.BR cjpeg :
|
52
|
+
.TP
|
53
|
+
.B \-optimize
|
54
|
+
Perform optimization of entropy encoding parameters.
|
55
|
+
.TP
|
56
|
+
.B \-progressive
|
57
|
+
Create progressive JPEG file.
|
58
|
+
.TP
|
59
|
+
.BI \-restart " N"
|
60
|
+
Emit a JPEG restart marker every N MCU rows, or every N MCU blocks if "B" is
|
61
|
+
attached to the number.
|
62
|
+
.TP
|
63
|
+
.B \-arithmetic
|
64
|
+
Use arithmetic coding.
|
65
|
+
.TP
|
66
|
+
.BI \-scans " file"
|
67
|
+
Use the scan script given in the specified text file.
|
68
|
+
.PP
|
69
|
+
See
|
70
|
+
.BR cjpeg (1)
|
71
|
+
for more details about these switches.
|
72
|
+
If you specify none of these switches, you get a plain baseline-JPEG output
|
73
|
+
file. The quality setting and so forth are determined by the input file.
|
74
|
+
.PP
|
75
|
+
The image can be losslessly transformed by giving one of these switches:
|
76
|
+
.TP
|
77
|
+
.B \-flip horizontal
|
78
|
+
Mirror image horizontally (left-right).
|
79
|
+
.TP
|
80
|
+
.B \-flip vertical
|
81
|
+
Mirror image vertically (top-bottom).
|
82
|
+
.TP
|
83
|
+
.B \-rotate 90
|
84
|
+
Rotate image 90 degrees clockwise.
|
85
|
+
.TP
|
86
|
+
.B \-rotate 180
|
87
|
+
Rotate image 180 degrees.
|
88
|
+
.TP
|
89
|
+
.B \-rotate 270
|
90
|
+
Rotate image 270 degrees clockwise (or 90 ccw).
|
91
|
+
.TP
|
92
|
+
.B \-transpose
|
93
|
+
Transpose image (across UL-to-LR axis).
|
94
|
+
.TP
|
95
|
+
.B \-transverse
|
96
|
+
Transverse transpose (across UR-to-LL axis).
|
97
|
+
.IP
|
98
|
+
The transpose transformation has no restrictions regarding image dimensions.
|
99
|
+
The other transformations operate rather oddly if the image dimensions are not
|
100
|
+
a multiple of the iMCU size (usually 8 or 16 pixels), because they can only
|
101
|
+
transform complete blocks of DCT coefficient data in the desired way.
|
102
|
+
.IP
|
103
|
+
.BR jpegtran 's
|
104
|
+
default behavior when transforming an odd-size image is designed
|
105
|
+
to preserve exact reversibility and mathematical consistency of the
|
106
|
+
transformation set. As stated, transpose is able to flip the entire image
|
107
|
+
area. Horizontal mirroring leaves any partial iMCU column at the right edge
|
108
|
+
untouched, but is able to flip all rows of the image. Similarly, vertical
|
109
|
+
mirroring leaves any partial iMCU row at the bottom edge untouched, but is
|
110
|
+
able to flip all columns. The other transforms can be built up as sequences
|
111
|
+
of transpose and flip operations; for consistency, their actions on edge
|
112
|
+
pixels are defined to be the same as the end result of the corresponding
|
113
|
+
transpose-and-flip sequence.
|
114
|
+
.IP
|
115
|
+
For practical use, you may prefer to discard any untransformable edge pixels
|
116
|
+
rather than having a strange-looking strip along the right and/or bottom edges
|
117
|
+
of a transformed image. To do this, add the
|
118
|
+
.B \-trim
|
119
|
+
switch:
|
120
|
+
.TP
|
121
|
+
.B \-trim
|
122
|
+
Drop non-transformable edge blocks.
|
123
|
+
.IP
|
124
|
+
Obviously, a transformation with
|
125
|
+
.B \-trim
|
126
|
+
is not reversible, so strictly speaking
|
127
|
+
.B jpegtran
|
128
|
+
with this switch is not lossless. Also, the expected mathematical
|
129
|
+
equivalences between the transformations no longer hold. For example,
|
130
|
+
.B \-rot 270 -trim
|
131
|
+
trims only the bottom edge, but
|
132
|
+
.B \-rot 90 -trim
|
133
|
+
followed by
|
134
|
+
.B \-rot 180 -trim
|
135
|
+
trims both edges.
|
136
|
+
.IP
|
137
|
+
If you are only interested in perfect transformation, add the
|
138
|
+
.B \-perfect
|
139
|
+
switch:
|
140
|
+
.TP
|
141
|
+
.B \-perfect
|
142
|
+
Fails with an error if the transformation is not perfect.
|
143
|
+
.IP
|
144
|
+
For example you may want to do
|
145
|
+
.IP
|
146
|
+
.B (jpegtran \-rot 90 -perfect
|
147
|
+
.I foo.jpg
|
148
|
+
.B || djpeg
|
149
|
+
.I foo.jpg
|
150
|
+
.B | pnmflip \-r90 | cjpeg)
|
151
|
+
.IP
|
152
|
+
to do a perfect rotation if available or an approximated one if not.
|
153
|
+
.PP
|
154
|
+
We also offer a lossless-crop option, which discards data outside a given
|
155
|
+
image region but losslessly preserves what is inside. Like the rotate and
|
156
|
+
flip transforms, lossless crop is restricted by the current JPEG format: the
|
157
|
+
upper left corner of the selected region must fall on an iMCU boundary. If
|
158
|
+
this does not hold for the given crop parameters, we silently move the upper
|
159
|
+
left corner up and/or left to make it so, simultaneously increasing the
|
160
|
+
region dimensions to keep the lower right crop corner unchanged. (Thus, the
|
161
|
+
output image covers at least the requested region, but may cover more.)
|
162
|
+
The adjustment of the region dimensions may be optionally disabled.
|
163
|
+
|
164
|
+
The image can be losslessly cropped by giving the switch:
|
165
|
+
.TP
|
166
|
+
.B \-crop WxH+X+Y
|
167
|
+
Crop to a rectangular subarea of width W, height H starting at point X,Y.
|
168
|
+
.PP
|
169
|
+
A complementary lossless-wipe option is provided to discard (gray out) data
|
170
|
+
inside a given image region while losslessly preserving what is outside:
|
171
|
+
.TP
|
172
|
+
.B \-wipe WxH+X+Y
|
173
|
+
Wipe (gray out) a rectangular subarea of width W, height H starting at point
|
174
|
+
X,Y.
|
175
|
+
.PP
|
176
|
+
Other not-strictly-lossless transformation switches are:
|
177
|
+
.TP
|
178
|
+
.B \-grayscale
|
179
|
+
Force grayscale output.
|
180
|
+
.IP
|
181
|
+
This option discards the chrominance channels if the input image is YCbCr
|
182
|
+
(ie, a standard color JPEG), resulting in a grayscale JPEG file. The
|
183
|
+
luminance channel is preserved exactly, so this is a better method of reducing
|
184
|
+
to grayscale than decompression, conversion, and recompression. This switch
|
185
|
+
is particularly handy for fixing a monochrome picture that was mistakenly
|
186
|
+
encoded as a color JPEG. (In such a case, the space savings from getting rid
|
187
|
+
of the near-empty chroma channels won't be large; but the decoding time for
|
188
|
+
a grayscale JPEG is substantially less than that for a color JPEG.)
|
189
|
+
.TP
|
190
|
+
.BI \-scale " M/N"
|
191
|
+
Scale the output image by a factor M/N.
|
192
|
+
.IP
|
193
|
+
Currently supported scale factors are M/N with all M from 1 to 16, where N is
|
194
|
+
the source DCT size, which is 8 for baseline JPEG. If the /N part is omitted,
|
195
|
+
then M specifies the DCT scaled size to be applied on the given input. For
|
196
|
+
baseline JPEG this is equivalent to M/8 scaling, since the source DCT size
|
197
|
+
for baseline JPEG is 8.
|
198
|
+
.B Caution:
|
199
|
+
An implementation of the JPEG SmartScale extension is required for this
|
200
|
+
feature. SmartScale enabled JPEG is not yet widely implemented, so many
|
201
|
+
decoders will be unable to view a SmartScale extended JPEG file at all.
|
202
|
+
.PP
|
203
|
+
.B jpegtran
|
204
|
+
also recognizes these switches that control what to do with "extra" markers,
|
205
|
+
such as comment blocks:
|
206
|
+
.TP
|
207
|
+
.B \-copy none
|
208
|
+
Copy no extra markers from source file. This setting suppresses all
|
209
|
+
comments and other excess baggage present in the source file.
|
210
|
+
.TP
|
211
|
+
.B \-copy comments
|
212
|
+
Copy only comment markers. This setting copies comments from the source file,
|
213
|
+
but discards any other inessential (for image display) data.
|
214
|
+
.TP
|
215
|
+
.B \-copy all
|
216
|
+
Copy all extra markers. This setting preserves miscellaneous markers
|
217
|
+
found in the source file, such as JFIF thumbnails, Exif data, and Photoshop
|
218
|
+
settings. In some files these extra markers can be sizable.
|
219
|
+
.IP
|
220
|
+
The default behavior is
|
221
|
+
.BR "\-copy comments" .
|
222
|
+
(Note: in IJG releases v6 and v6a,
|
223
|
+
.B jpegtran
|
224
|
+
always did the equivalent of
|
225
|
+
.BR "\-copy none" .)
|
226
|
+
.PP
|
227
|
+
Additional switches recognized by jpegtran are:
|
228
|
+
.TP
|
229
|
+
.BI \-maxmemory " N"
|
230
|
+
Set limit for amount of memory to use in processing large images. Value is
|
231
|
+
in thousands of bytes, or millions of bytes if "M" is attached to the
|
232
|
+
number. For example,
|
233
|
+
.B \-max 4m
|
234
|
+
selects 4000000 bytes. If more space is needed, temporary files will be used.
|
235
|
+
.TP
|
236
|
+
.BI \-outfile " name"
|
237
|
+
Send output image to the named file, not to standard output.
|
238
|
+
.TP
|
239
|
+
.B \-verbose
|
240
|
+
Enable debug printout. More
|
241
|
+
.BR \-v 's
|
242
|
+
give more output. Also, version information is printed at startup.
|
243
|
+
.TP
|
244
|
+
.B \-debug
|
245
|
+
Same as
|
246
|
+
.BR \-verbose .
|
247
|
+
.SH EXAMPLES
|
248
|
+
.LP
|
249
|
+
This example converts a baseline JPEG file to progressive form:
|
250
|
+
.IP
|
251
|
+
.B jpegtran \-progressive
|
252
|
+
.I foo.jpg
|
253
|
+
.B >
|
254
|
+
.I fooprog.jpg
|
255
|
+
.PP
|
256
|
+
This example rotates an image 90 degrees clockwise, discarding any
|
257
|
+
unrotatable edge pixels:
|
258
|
+
.IP
|
259
|
+
.B jpegtran \-rot 90 -trim
|
260
|
+
.I foo.jpg
|
261
|
+
.B >
|
262
|
+
.I foo90.jpg
|
263
|
+
.SH ENVIRONMENT
|
264
|
+
.TP
|
265
|
+
.B JPEGMEM
|
266
|
+
If this environment variable is set, its value is the default memory limit.
|
267
|
+
The value is specified as described for the
|
268
|
+
.B \-maxmemory
|
269
|
+
switch.
|
270
|
+
.B JPEGMEM
|
271
|
+
overrides the default value specified when the program was compiled, and
|
272
|
+
itself is overridden by an explicit
|
273
|
+
.BR \-maxmemory .
|
274
|
+
.SH SEE ALSO
|
275
|
+
.BR cjpeg (1),
|
276
|
+
.BR djpeg (1),
|
277
|
+
.BR rdjpgcom (1),
|
278
|
+
.BR wrjpgcom (1)
|
279
|
+
.br
|
280
|
+
Wallace, Gregory K. "The JPEG Still Picture Compression Standard",
|
281
|
+
Communications of the ACM, April 1991 (vol. 34, no. 4), pp. 30-44.
|
282
|
+
.SH AUTHOR
|
283
|
+
Independent JPEG Group
|
284
|
+
.SH BUGS
|
285
|
+
The transform options can't transform odd-size images perfectly. Use
|
286
|
+
.B \-trim
|
287
|
+
or
|
288
|
+
.B \-perfect
|
289
|
+
if you don't like the results.
|
290
|
+
.PP
|
291
|
+
The entire image is read into memory and then written out again, even in
|
292
|
+
cases where this isn't really necessary. Expect swapping on large images,
|
293
|
+
especially when using the more complex transform options.
|