New comit of SDL2
[supertux.git] / src / SDL2 / external / tiff-4.0.3 / html / libtiff.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
2 <html lang="en">
3 <head>
4   <title>Using The TIFF Library</title>
5   <meta http-equiv="content-type" content="text/html; charset=ISO-8859-1">
6   <meta http-equiv="content-language" content="en">
7   <style type="text/css">
8   <!--
9     th {text-align: left; vertical-align: top; font-style: italic; font-weight: normal}
10   -->
11   </style>
12 </head>
13 <body lang="en" text="#000000" bgcolor="#ffffff" link="#0000ff" alink="#0000ff" vlink="#0000ff">
14   <table border="0" cellspacing="0" cellpadding="0">
15     <tr>
16       <td style="padding-left: 1em; padding-right: 1em"><img src="images/cat.gif" width="113" height="146" alt=""></td>
17       <td>
18         <h1>Using The TIFF Library</h1>
19         <p>
20           <tt>libtiff</tt> is a set of C functions (a library) that support
21           the manipulation of TIFF image files.
22           The library requires an ANSI C compilation environment for building
23           and presumes an ANSI C environment for use.
24         </p>
25       </td>
26     </tr>
27   </table>
28   <br>
29   <p>
30     <tt>libtiff</tt>
31     provides interfaces to image data at several layers of abstraction (and cost).
32     At the highest level image data can be read into an 8-bit/sample,
33     ABGR pixel raster format without regard for the underlying data organization,
34     colorspace, or compression scheme.  Below this high-level interface
35     the library provides scanline-, strip-, and tile-oriented interfaces that
36     return data decompressed but otherwise untransformed.  These interfaces
37     require that the application first identify the organization of stored
38     data and select either a strip-based or tile-based API for manipulating
39     data.  At the lowest level the library
40     provides access to the raw uncompressed strips or tiles,
41     returning the data exactly as it appears in the file.
42   </p>
43   <p>
44     The material presented in this chapter is a basic introduction
45     to the capabilities of the library; it is not an attempt to describe
46     everything a developer needs to know about the library or about TIFF.
47     Detailed information on the interfaces to the library are given in
48     the <a href="http://www.remotesensing.org/libtiff/man/index.html">UNIX 
49     manual pages</a> that accompany this software.
50   </p>
51   <p>
52     Michael Still has also written a useful introduction to libtiff for the
53     IBM DeveloperWorks site available at
54     <a href="http://www.ibm.com/developerworks/linux/library/l-libtiff">http://www.ibm.com/developerworks/linux/library/l-libtiff</a>.
55   </p>
56   <p>
57     The following sections are found in this chapter:
58   </p>
59   <ul>
60     <li><a href="#version">How to tell which version you have</a></li>
61     <li><a href="#typedefs">Library Datatypes</a></li>
62     <li><a href="#mman">Memory Management</a></li>
63     <li><a href="#errors">Error Handling</a></li>
64     <li><a href="#fio">Basic File Handling</a></li>
65     <li><a href="#dirs">TIFF Directories</a></li>
66     <li><a href="#tags">TIFF Tags</a></li>
67     <li><a href="#compression">TIFF Compression Schemes</a></li>
68     <li><a href="#byteorder">Byte Order</a></li>
69     <li><a href="#dataplacement">Data Placement</a></li>
70     <li><a href="#tiffrgbaimage">TIFFRGBAImage Support</a></li>
71     <li><a href="#scanlines">Scanline-based Image I/O</a></li>
72     <li><a href="#strips">Strip-oriented Image I/O</a></li>
73     <li><a href="#tiles">Tile-oriented Image I/O</a></li>
74     <li><a href="#other">Other Stuff</a></li>
75   </ul>
76   <hr>
77   <h2 id="version">How to tell which version you have</h2>
78   <p>
79     The software version can be found by looking at the file named
80     <tt>VERSION</tt>
81     that is located at the top of the source tree; the precise alpha number
82     is given in the file <tt>dist/tiff.alpha</tt>.
83     If you have need to refer to this
84     specific software, you should identify it as:
85   </p>
86   <p style="margin-left: 40px">
87     <tt>TIFF &lt;<i>version</i>&gt; &lt;<i>alpha</i>&gt;</tt>
88   </p>
89   <p>
90     where <tt>&lt;<i>version</i>&gt;</tt> is whatever you get from
91     <tt>"cat VERSION"</tt> and <tt>&lt;<i>alpha</i>&gt;</tt> is
92     what you get from <tt>"cat dist/tiff.alpha"</tt>.
93   </p>
94   <p>
95     Within an application that uses <tt>libtiff</tt> the <tt>TIFFGetVersion</tt>
96     routine will return a pointer to a string that contains software version
97     information.
98     The library include file <tt>&lt;tiffio.h&gt;</tt> contains a C pre-processor
99     define <tt>TIFFLIB_VERSION</tt> that can be used to check library
100     version compatiblity at compile time.
101   </p>
102   <hr>
103   <h2 id="typedefs">Library Datatypes</h2>
104   <p>
105     <tt>libtiff</tt> defines a portable programming interface through the
106     use of a set of C type definitions.
107     These definitions, defined in in the files <b>tiff.h</b> and
108     <b>tiffio.h</b>,
109     isolate the <tt>libtiff</tt> API from the characteristics
110     of the underlying machine.
111     To insure portable code and correct operation, applications that use
112     <tt>libtiff</tt> should use the typedefs and follow the function
113     prototypes for the library API.
114   </p>
115   <hr>
116   <h2 id="mman">Memory Management</h2>
117   <p>
118     <tt>libtiff</tt> uses a machine-specific set of routines for managing
119     dynamically allocated memory.
120     <tt>_TIFFmalloc</tt>, <tt>_TIFFrealloc</tt>, and <tt>_TIFFfree</tt>
121     mimic the normal ANSI C routines.
122     Any dynamically allocated memory that is to be passed into the library
123     should be allocated using these interfaces in order to insure pointer
124     compatibility on machines with a segmented architecture.
125     (On 32-bit UNIX systems these routines just call the normal <tt>malloc</tt>,
126     <tt>realloc</tt>, and <tt>free</tt> routines in the C library.)
127   </p>
128   <p>
129     To deal with segmented pointer issues <tt>libtiff</tt> also provides
130     <tt>_TIFFmemcpy</tt>, <tt>_TIFFmemset</tt>, and <tt>_TIFFmemmove</tt>
131     routines that mimic the equivalent ANSI C routines, but that are
132     intended for use with memory allocated through <tt>_TIFFmalloc</tt>
133     and <tt>_TIFFrealloc</tt>.
134   </p>
135   <hr>
136   <h2 id="errors">Error Handling</h2>
137   <p>
138     <tt>libtiff</tt> handles most errors by returning an invalid/erroneous
139     value when returning from a function call.
140     Various diagnostic messages may also be generated by the library.
141     All error messages are directed to a single global error handler
142     routine that can be specified with a call to <tt>TIFFSetErrorHandler</tt>.
143     Likewise warning messages are directed to a single handler routine
144     that can be specified with a call to <tt>TIFFSetWarningHandler</tt>
145   </p>
146   <hr>
147   <h2 id="fio">Basic File Handling</h2>
148   <p>
149     The library is modeled after the normal UNIX stdio library.
150     For example, to read from an existing TIFF image the
151     file must first be opened:
152   </p>
153   <p style="margin-left: 40px">
154     <tt>#include "tiffio.h"<br>
155     main()<br>
156     {<br>
157     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("foo.tif", "r");<br>
158     &nbsp;&nbsp;&nbsp;&nbsp;... do stuff ...<br>
159     &nbsp;&nbsp;&nbsp;&nbsp;TIFFClose(tif);<br>
160     }</tt>
161   </p>
162   <p>
163     The handle returned by <tt>TIFFOpen</tt> is <i>opaque</i>, that is
164     the application is not permitted to know about its contents.
165     All subsequent library calls for this file must pass the handle
166     as an argument.
167   </p>
168   <p>
169     To create or overwrite a TIFF image the file is also opened, but with
170     a <tt>"w"</tt> argument:
171   <p>
172   <p style="margin-left: 40px">
173     <tt>#include "tiffio.h"<br>
174     main()<br>
175     {<br>
176     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("foo.tif", "w");<br>
177     &nbsp;&nbsp;&nbsp;&nbsp;... do stuff ...<br>
178     &nbsp;&nbsp;&nbsp;&nbsp;TIFFClose(tif);<br>
179     }</tt>
180   </p>
181   <p>
182     If the file already exists it is first truncated to zero length.
183   </p>
184   <table>
185     <tr>
186       <td valign=top><img src="images/warning.gif" width="40" height="40" alt=""></td>
187       <td><i>Note that unlike the stdio library TIFF image files may not be
188         opened for both reading and writing;
189         there is no support for altering the contents of a TIFF file.</i></td>
190     </tr>
191   </table>
192   <p>
193     <tt>libtiff</tt> buffers much information associated with writing a
194     valid TIFF image.  Consequently, when writing a TIFF image it is necessary
195     to always call <tt>TIFFClose</tt> or <tt>TIFFFlush</tt> to flush any
196     buffered information to a file.  Note that if you call <tt>TIFFClose</tt>
197     you do not need to call <tt>TIFFFlush</tt>.
198   </p>
199   <hr>
200   <h2 id="dirs">TIFF Directories</h2>
201   <p>
202     TIFF supports the storage of multiple images in a single file.
203     Each image has an associated data structure termed a <i>directory</i>
204     that houses all the information about the format and content of the
205     image data.
206     Images in a file are usually related but they do not need to be; it
207     is perfectly alright to store a color image together with a black and
208     white image.
209     Note however that while images may be related their directories are
210     not.
211     That is, each directory stands on its own; their is no need to read
212     an unrelated directory in order to properly interpret the contents
213     of an image.
214   </p>
215   <p>
216     <tt>libtiff</tt> provides several routines for reading and writing
217     directories.  In normal use there is no need to explicitly
218     read or write a directory: the library automatically reads the first
219     directory in a file when opened for reading, and directory information
220     to be written is automatically accumulated and written when writing
221     (assuming <tt>TIFFClose</tt> or <tt>TIFFFlush</tt> are called).
222   </p>
223   <p>
224     For a file open for reading the <tt>TIFFSetDirectory</tt> routine can
225     be used to select an arbitrary directory; directories are referenced by
226     number with the numbering starting at 0.  Otherwise the
227     <tt>TIFFReadDirectory</tt> and <tt>TIFFWriteDirectory</tt> routines can
228     be used for sequential access to directories.
229     For example, to count the number of directories in a file the following
230     code might be used:
231   </p>
232   <p style="margin-left: 40px">
233     <tt>#include "tiffio.h"<br>
234     main(int argc, char* argv[])<br>
235     {<br>
236     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen(argv[1], "r");<br>
237     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
238     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;int dircount = 0;<br>
239     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;do {<br>
240     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dircount++;<br>
241     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;} while (TIFFReadDirectory(tif));<br>
242     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf("%d directories in %s\n", dircount, argv[1]);<br>
243     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFClose(tif);<br>
244     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
245     &nbsp;&nbsp;&nbsp;&nbsp;exit(0);<br>
246     }</tt>
247   </p>
248   <p>
249     Finally, note that there are several routines for querying the
250     directory status of an open file:
251     <tt>TIFFCurrentDirectory</tt> returns the index of the current
252     directory and
253     <tt>TIFFLastDirectory</tt> returns an indication of whether the
254     current directory is the last directory in a file.
255     There is also a routine, <tt>TIFFPrintDirectory</tt>, that can
256     be called to print a formatted description of the contents of
257     the current directory; consult the manual page for complete details.
258   </p>
259   <hr>
260   <h2 id="tags">TIFF Tags</h2>
261   <p>
262     Image-related information such as the image width and height, number
263     of samples, orientation, colorimetric information, etc.
264     are stored in each image
265     directory in <i>fields</i> or <i>tags</i>.
266     Tags are identified by a number that is usually a value registered
267     with the Aldus (now Adobe) Corporation.
268     Beware however that some vendors write
269     TIFF images with tags that are unregistered; in this case interpreting
270     their contents is usually a waste of time.
271   </p>
272   <p>
273     <tt>libtiff</tt> reads the contents of a directory all at once
274     and converts the on-disk information to an appropriate in-memory
275     form.  While the TIFF specification permits an arbitrary set of
276     tags to be defined and used in a file, the library only understands
277     a limited set of tags.
278     Any unknown tags that are encountered in a file are ignored.
279     There is a mechanism to extend the set of tags the library handles
280     without modifying the library itself;
281     this is described <a href="addingtags.html">elsewhere</a>.
282   </p>
283   <p>
284     <tt>libtiff</tt> provides two interfaces for getting and setting tag
285     values: <tt>TIFFGetField</tt> and <tt>TIFFSetField</tt>.
286     These routines use a variable argument list-style interface to pass
287     parameters of different type through a single function interface.
288     The <i>get interface</i> takes one or more pointers to memory locations
289     where the tag values are to be returned and also returns one or
290     zero according to whether the requested tag is defined in the directory.
291     The <i>set interface</i> takes the tag values either by-reference or
292     by-value.
293     The TIFF specification defines
294     <i>default values</i> for some tags.
295     To get the value of a tag, or its default value if it is undefined,
296     the <tt>TIFFGetFieldDefaulted</tt> interface may be used.
297   </p>
298   <p>
299     The manual pages for the tag get and set routines specifiy the exact data types
300     and calling conventions required for each tag supported by the library.
301   </p>
302   <hr>
303   <h2 id="compression">TIFF Compression Schemes</h2>
304   <p>
305     <tt>libtiff</tt> includes support for a wide variety of
306     data compression schemes.
307     In normal operation a compression scheme is automatically used when
308     the TIFF <tt>Compression</tt> tag is set, either by opening a file
309     for reading, or by setting the tag when writing.
310   </p>
311   <p>
312     Compression schemes are implemented by software modules termed <i>codecs</i>
313     that implement decoder and encoder routines that hook into the
314     core library i/o support.
315     Codecs other than those bundled with the library can be registered
316     for use with the <tt>TIFFRegisterCODEC</tt> routine.
317     This interface can also be used to override the core-library
318     implementation for a compression scheme.
319   </p>
320   <hr>
321   <h2 id="byteorder">Byte Order</h2>
322   <p>
323     The TIFF specification says, and has always said, that
324     <em>a correct TIFF
325     reader must handle images in big-endian and little-endian byte order</em>.
326     <tt>libtiff</tt> conforms in this respect.
327     Consequently there is no means to force a specific
328     byte order for the data written to a TIFF image file (data is
329     written in the native order of the host CPU unless appending to
330     an existing file, in which case it is written in the byte order
331     specified in the file).
332   </p>
333   <hr>
334   <h2 id="dataplacement">Data Placement</h2>
335   <p>
336     The TIFF specification requires that all information except an
337     8-byte header can be placed anywhere in a file.
338     In particular, it is perfectly legitimate for directory information
339     to be written after the image data itself.
340     Consequently TIFF is inherently not suitable for passing through a
341     stream-oriented mechanism such as UNIX pipes.
342     Software that require that data be organized in a file in a particular
343     order (e.g. directory information before image data) does not
344     correctly support TIFF.
345     <tt>libtiff</tt> provides no mechanism for controlling the placement
346     of data in a file; image data is typically written before directory
347     information.
348   </p>
349   <hr>
350   <h2 id="tiffrgbaimage">TIFFRGBAImage Support</h2>
351   <p>
352     <tt>libtiff</tt> provides a high-level interface for reading image
353     data from a TIFF file.  This interface handles the details of
354     data organization and format for a wide variety of TIFF files;
355     at least the large majority of those files that one would normally
356     encounter.  Image data is, by default, returned as ABGR
357     pixels packed into 32-bit words (8 bits per sample).  Rectangular
358     rasters can be read or data can be intercepted at an intermediate
359     level and packed into memory in a format more suitable to the
360     application.
361     The library handles all the details of the format of data stored on
362     disk and, in most cases, if any colorspace conversions are required:
363     bilevel to RGB, greyscale to RGB, CMYK to RGB, YCbCr to RGB, 16-bit
364     samples to 8-bit samples, associated/unassociated alpha, etc.
365   </p>
366   <p>
367     There are two ways to read image data using this interface.  If
368     all the data is to be stored in memory and manipulated at once,
369     then the routine <tt>TIFFReadRGBAImage</tt> can be used:
370   </p>
371   <p>
372   <p style="margin-left: 40px">
373     <tt>#include "tiffio.h"<br>
374     main(int argc, char* argv[])<br>
375     {<br>
376     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen(argv[1], "r");<br>
377     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
378     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 w, h;<br>
379     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;size_t npixels;<br>
380     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32* raster;<br>
381     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
382     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_IMAGEWIDTH, &amp;w);<br>
383     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &amp;h);<br>
384     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;npixels = w * h;<br>
385     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;raster = (uint32*) _TIFFmalloc(npixels * sizeof (uint32));<br>
386     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (raster != NULL) {<br>
387     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (TIFFReadRGBAImage(tif, w, h, raster, 0)) {<br>
388     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;...process raster data...<br>
389     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
390     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_TIFFfree(raster);<br>
391     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
392     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFClose(tif);<br>
393     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
394     &nbsp;&nbsp;&nbsp;&nbsp;exit(0);<br>
395     }</tt>
396   </p>
397   <p>
398     Note above that <tt>_TIFFmalloc</tt> is used to allocate memory for
399     the raster passed to <tt>TIFFReadRGBAImage</tt>; this is important
400     to insure the ``appropriate type of memory'' is passed on machines
401     with segmented architectures.
402   </p>
403   <p>
404     Alternatively, <tt>TIFFReadRGBAImage</tt> can be replaced with a
405     more low-level interface that permits an application to have more
406     control over this reading procedure.  The equivalent to the above
407     is:
408   </p>
409   <p style="margin-left: 40px">
410     <tt>#include "tiffio.h"<br>
411     main(int argc, char* argv[])<br>
412     {<br>
413     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen(argv[1], "r");<br>
414     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
415     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFRGBAImage img;<br>
416     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;char emsg[1024];<br>
417     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
418     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (TIFFRGBAImageBegin(&amp;img, tif, 0, emsg)) {<br>
419     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;size_t npixels;<br>
420     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32* raster;<br>
421     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
422     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;npixels = img.width * img.height;<br>
423     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;raster = (uint32*) _TIFFmalloc(npixels * sizeof (uint32));<br>
424     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (raster != NULL) {<br>
425     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (TIFFRGBAImageGet(&amp;img, raster, img.width, img.height)) {<br>
426     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;...process raster data...<br>
427     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
428     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_TIFFfree(raster);<br>
429     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
430     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFRGBAImageEnd(&amp;img);<br>
431     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;} else<br>
432     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFError(argv[1], emsg);<br>
433     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFClose(tif);<br>
434     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
435     &nbsp;&nbsp;&nbsp;&nbsp;exit(0);<br>
436     }</tt>
437   </p>
438   <p>
439     However this usage does not take advantage of the more fine-grained
440     control that's possible.  That is, by using this interface it is
441     possible to:
442   </p>
443   <ul>
444     <li>repeatedly fetch (and manipulate) an image without opening
445       and closing the file</li>
446     <li>interpose a method for packing raster pixel data according to
447       application-specific needs (or write the data at all)</li>
448     <li>interpose methods that handle TIFF formats that are not already
449       handled by the core library</li>
450   </ul>
451   <p>
452     The first item means that, for example, image viewers that want to
453     handle multiple files can cache decoding information in order to
454     speedup the work required to display a TIFF image.
455   </p>
456   <p>
457     The second item is the main reason for this interface.  By interposing
458     a "put method" (the routine that is called to pack pixel data in
459     the raster) it is possible share the core logic that understands how
460     to deal with TIFF while packing the resultant pixels in a format that
461     is optimized for the application.  This alternate format might be very
462     different than the 8-bit per sample ABGR format the library writes by
463     default.  For example, if the application is going to display the image
464     on an 8-bit colormap display the put routine might take the data and
465     convert it on-the-fly to the best colormap indices for display.
466   </p>
467   <p>
468     The last item permits an application to extend the library
469     without modifying the core code.
470     By overriding the code provided an application might add support
471     for some esoteric flavor of TIFF that it needs, or it might
472     substitute a packing routine that is able to do optimizations
473     using application/environment-specific information.
474   </p>
475   <p>
476     The TIFF image viewer found in <b>tools/sgigt.c</b> is an example
477     of an application that makes use of the <tt>TIFFRGBAImage</tt>
478     support.
479   </p>
480   <hr>
481   <h2 id="scanlines">Scanline-based Image I/O</h2>
482   <p>
483     The simplest interface provided by <tt>libtiff</tt> is a
484     scanline-oriented interface that can be used to read TIFF
485     images that have their image data organized in strips
486     (trying to use this interface to read data written in tiles
487     will produce errors.)
488     A scanline is a one pixel high row of image data whose width
489     is the width of the image.
490     Data is returned packed if the image data is stored with samples
491     packed together, or as arrays of separate samples if the data
492     is stored with samples separated.
493     The major limitation of the scanline-oriented interface, other
494     than the need to first identify an existing file as having a
495     suitable organization, is that random access to individual
496     scanlines can only be provided when data is not stored in a
497     compressed format, or when the number of rows in a strip
498     of image data is set to one (<tt>RowsPerStrip</tt> is one).
499   </p>
500   <p>
501     Two routines are provided for scanline-based i/o:
502     <tt>TIFFReadScanline</tt>
503     and
504     <tt>TIFFWriteScanline</tt>.
505     For example, to read the contents of a file that
506     is assumed to be organized in strips, the following might be used:
507   </p>
508   <p style="margin-left: 40px">
509     <tt>#include "tiffio.h"<br>
510     main()<br>
511     {<br>
512     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("myfile.tif", "r");<br>
513     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
514     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 imagelength;<br>
515     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tdata_t buf;<br>
516     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 row;<br>
517     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
518     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &amp;imagelength);<br>
519     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;buf = _TIFFmalloc(TIFFScanlineSize(tif));<br>
520     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (row = 0; row &lt; imagelength; row++)<br>
521     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffreadscanline(tif, buf, row);<br>
522     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_tifffree(buf);<br>
523     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffclose(tif);<br>
524     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
525     }</tt>
526   </p>
527   <p>
528     <tt>TIFFScanlineSize</tt> returns the number of bytes in
529     a decoded scanline, as returned by <tt>TIFFReadScanline</tt>.
530     Note however that if the file had been create with samples
531     written in separate planes, then the above code would only
532     read data that contained the first sample of each pixel;
533     to handle either case one might use the following instead:
534   </p>
535   <p style="margin-left: 40px">
536     <tt>#include "tiffio.h"<br>
537     main()<br>
538     {<br>
539     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("myfile.tif", "r");<br>
540     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
541     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 imagelength;<br>
542     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tdata_t buf;<br>
543     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 row;<br>
544     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
545     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &amp;imagelength);<br>
546     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_PLANARCONFIG, &amp;config);<br>
547     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;buf = _TIFFmalloc(TIFFScanlineSize(tif));<br>
548     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (config == PLANARCONFIG_CONTIG) {<br>
549     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (row = 0; row &lt; imagelength; row++)<br>
550     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffreadscanline(tif, buf, row);<br>
551     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;} else if (config == planarconfig_separate) {<br>
552     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint16 s, nsamples;<br>
553     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
554     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffgetfield(tif, tifftag_samplesperpixel, &amp;nsamples);<br>
555     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (s = 0; s &lt; nsamples; s++)<br>
556     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (row = 0; row &lt; imagelength; row++)<br>
557     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffreadscanline(tif, buf, row, s);<br>
558     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
559     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_tifffree(buf);<br>
560     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffclose(tif);<br>
561     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
562     }</tt>
563   </p>
564   <p>
565     Beware however that if the following code were used instead to
566     read data in the case <tt>PLANARCONFIG_SEPARATE</tt>,...
567   </p>
568   <p style="margin-left: 40px">
569     <tt>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (row = 0; row &lt; imagelength; row++)<br>
570     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (s = 0; s &lt; nsamples; s++)<br>
571     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffreadscanline(tif, buf, row, s);</tt>
572   </p>
573   <p>
574     ...then problems would arise if <tt>RowsPerStrip</tt> was not one
575     because the order in which scanlines are requested would require
576     random access to data within strips (something that is not supported
577     by the library when strips are compressed).
578   </p>
579   <hr>
580   <h2 id="strips">Strip-oriented Image I/O</h2>
581   <p>
582     The strip-oriented interfaces provided by the library provide
583     access to entire strips of data.  Unlike the scanline-oriented
584     calls, data can be read or written compressed or uncompressed.
585     Accessing data at a strip (or tile) level is often desirable
586     because there are no complications with regard to random access
587     to data within strips.
588   </p>
589   <p>
590     A simple example of reading an image by strips is:
591   </p>
592   <p style="margin-left: 40px">
593     <tt>#include "tiffio.h"<br>
594     main()<br>
595     {<br>
596     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("myfile.tif", "r");<br>
597     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
598     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tdata_t buf;<br>
599     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tstrip_t strip;<br>
600     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
601     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;buf = _TIFFmalloc(TIFFStripSize(tif));<br>
602     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (strip = 0; strip &lt; tiffnumberofstrips(tif); strip++)<br>
603     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffreadencodedstrip(tif, strip, buf, (tsize_t) -1);<br>
604     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_tifffree(buf);<br>
605     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffclose(tif);<br>
606     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
607     }</tt>
608   </p>
609   <p>
610     Notice how a strip size of <tt>-1</tt> is used; <tt>TIFFReadEncodedStrip</tt>
611     will calculate the appropriate size in this case.
612   </p>
613   <p>
614     The above code reads strips in the order in which the
615     data is physically stored in the file.  If multiple samples
616     are present and data is stored with <tt>PLANARCONFIG_SEPARATE</tt>
617     then all the strips of data holding the first sample will be
618     read, followed by strips for the second sample, etc.
619   </p>
620   <p>
621     Finally, note that the last strip of data in an image may have fewer
622     rows in it than specified by the <tt>RowsPerStrip</tt> tag.  A
623     reader should not assume that each decoded strip contains a full
624     set of rows in it.
625   </p>
626   <p>
627     The following is an example of how to read raw strips of data from
628     a file:
629   </p>
630   <p style="margin-left: 40px">
631     <tt>#include "tiffio.h"<br>
632     main()<br>
633     {<br>
634     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("myfile.tif", "r");<br>
635     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
636     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tdata_t buf;<br>
637     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tstrip_t strip;<br>
638     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32* bc;<br>
639     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 stripsize;<br>
640     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
641     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_STRIPBYTECOUNTS, &amp;bc);<br>
642     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;stripsize = bc[0];<br>
643     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;buf = _TIFFmalloc(stripsize);<br>
644     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (strip = 0; strip &lt; tiffnumberofstrips(tif); strip++) {<br>
645     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (bc[strip] &gt; stripsize) {<br>
646     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;buf = _TIFFrealloc(buf, bc[strip]);<br>
647     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;stripsize = bc[strip];<br>
648     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
649     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFReadRawStrip(tif, strip, buf, bc[strip]);<br>
650     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
651     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_TIFFfree(buf);<br>
652     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFClose(tif);<br>
653     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
654     }</tt>
655   </p>
656   <p>
657     As above the strips are read in the order in which they are
658     physically stored in the file; this may be different from the
659     logical ordering expected by an application.
660   </p>
661   <hr>
662   <h2 id="tiles">Tile-oriented Image I/O</h2>
663   <p>
664     Tiles of data may be read and written in a manner similar to strips.
665     With this interface, an image is
666     broken up into a set of rectangular areas that may have dimensions
667     less than the image width and height.  All the tiles
668     in an image have the same size, and the tile width and length must each
669     be a multiple of 16 pixels.  Tiles are ordered left-to-right and
670     top-to-bottom in an image.  As for scanlines, samples can be packed
671     contiguously or separately.  When separated, all the tiles for a sample
672     are colocated in the file.  That is, all the tiles for sample 0 appear
673     before the tiles for sample 1, etc.
674   </p>
675   <p>
676     Tiles and strips may also be extended in a z dimension to form
677     volumes.  Data volumes are organized as "slices".  That is, all the
678     data for a slice is colocated.  Volumes whose data is organized in
679     tiles can also have a tile depth so that data can be organized in
680     cubes.
681   </p>
682   <p>
683     There are actually two interfaces for tiles.
684     One interface is similar to scanlines,  to read a tiled image,
685     code of the following sort might be used:
686   </p>
687   <p style="margin-left: 40px">
688     <tt>main()<br>
689     {<br>
690     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("myfile.tif", "r");<br>
691     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
692     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 imageWidth, imageLength;<br>
693     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 tileWidth, tileLength;<br>
694     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;uint32 x, y;<br>
695     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tdata_t buf;<br>
696     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
697     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_IMAGEWIDTH, &amp;imageWidth);<br>
698     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &amp;imageLength);<br>
699     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_TILEWIDTH, &amp;tileWidth);<br>
700     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TIFFGetField(tif, TIFFTAG_TILELENGTH, &amp;tileLength);<br>
701     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;buf = _TIFFmalloc(TIFFTileSize(tif));<br>
702     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (y = 0; y &lt; imagelength; y += tilelength)<br>
703     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (x = 0; x &lt; imagewidth; x += tilewidth)<br>
704     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffreadtile(tif, buf, x, y, 0);<br>
705     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_tifffree(buf);<br>
706     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffclose(tif);<br>
707     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
708     }</tt>
709   </p>
710   <p>
711     (once again, we assume samples are packed contiguously.)
712   </p>
713   <p>
714     Alternatively a direct interface to the low-level data is provided
715     a la strips.  Tiles can be read with
716     <tt>TIFFReadEncodedTile</tt> or <tt>TIFFReadRawTile</tt>,
717     and written with <tt>TIFFWriteEncodedTile</tt> or
718     <tt>TIFFWriteRawTile</tt>. For example, to read all the tiles in an image:
719   </p>
720   <p style="margin-left: 40px">
721     <tt>#include "tiffio.h"<br>
722     main()<br>
723     {<br>
724     &nbsp;&nbsp;&nbsp;&nbsp;TIFF* tif = TIFFOpen("myfile.tif", "r");<br>
725     &nbsp;&nbsp;&nbsp;&nbsp;if (tif) {<br>
726     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tdata_t buf;<br>
727     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;ttile_t tile;<br>
728     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>
729     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;buf = _TIFFmalloc(TIFFTileSize(tif));<br>
730     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (tile = 0; tile &lt; tiffnumberoftiles(tif); tile++)<br>
731     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffreadencodedtile(tif, tile, buf, (tsize_t) -1);<br>
732     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_tifffree(buf);<br>
733     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tiffclose(tif);<br>
734     &nbsp;&nbsp;&nbsp;&nbsp;}<br>
735     }</tt>
736   </p>
737   <hr>
738   <h2 id="other">Other Stuff</h2>
739   <p>
740     Some other stuff will almost certainly go here...
741   </p>
742   <hr>
743   <p>
744     Last updated: $Date: 2005/12/28 06:53:18 $
745   </p>
746 </body>
747 </html>