TIFFReadRGBAStrip¶
Synopsis¶
#include <tiffio.h>
-
int TIFFReadRGBAStrip(TIFF *tif, uint32_t row, uint32_t *raster)¶
-
int TIFFReadRGBAStripExt(TIFF *tif, uint32_t row, uint32_t *raster, int stop_on_error)¶
Description¶
TIFFReadRGBAStrip()
reads a single strip of a strip-based image
into memory, storing the result in the user supplied RGBA raster.
The raster is assumed to be an array of ImageWidth
× RowsPerStrip
32-bit entries, where ImageWidth
is the width of the image
(TIFFTAG_IMAGEWIDTH
) and RowsPerStrip
is the maximum lines
in a strip (TIFFTAG_ROWSPERSTRIP
).
TIFFReadRGBAStripExt()
provides the paramater stop_on_error.
Its behaviour is described at TIFFReadRGBAImage.
The row value should be the row of the first row in the strip
(strip × RowsPerStrip
, zero based).
Note that the raster is assume to be organized such that the pixel at location (x, y) is raster [ y × width + x ]; with the raster origin in the lower-left hand corner of the strip. That is bottom to top organization. When reading a partial last strip in the file the last line of the image will begin at the beginning of the buffer.
Raster pixels are 8-bit packed red, green, blue, alpha samples. The macros
TIFFGetR
, TIFFGetG
, TIFFGetB
, and
TIFFGetA
should be used to access individual samples. Images
without Associated Alpha matting information have a constant Alpha of 1.0
(255).
See the TIFFRGBAImage page for more details on how various image types are converted to RGBA values.
Notes¶
TIFFReadRGBAStrip()
is just a wrapper around the more general
TIFFRGBAImage facilities. It's main advantage over the similar
TIFFReadRGBAImage()
function is that for large images a single
buffer capable of holding the whole image doesn't need to be allocated,
only enough for one strip. The TIFFReadRGBATile()
function
does a similar operation for tiled images.
For general notes see TIFFRGBImage notes.
Return values¶
1 is returned if the image was successfully read and converted. Otherwise, 0 is returned if an error was encountered.
Diagnostics¶
All error messages are directed to the TIFFErrorExtR()
routine.
"Sorry, can not handle %d-bit pictures"
:
The image had
BitsPerSample
other than 1, 2, 4, 8, or 16.
"Sorry, can not handle %d-channel images"
:
The image had
SamplesPerPixel
other than 1, 3, or 4.
Missing needed "PhotometricInterpretation" tag
:
The image did not have a tag that describes how to display the data.
No "PhotometricInterpretation" tag, assuming RGB
:
The image was missing a tag that describes how to display it, but because it has 3 or 4 samples/pixel, it is assumed to be RGB.
No "PhotometricInterpretation" tag, assuming min-is-black\fP
:
The image was missing a tag that describes how to display it, but because it has 1 sample/pixel, it is assumed to be a grayscale or bilevel image.
"No space for photometric conversion table"
:
There was insufficient memory for a table used to convert image samples to 8-bit RGB.
Missing required "Colormap" tag
:
A Palette image did not have a required
Colormap
tag.
"No space for tile buffer"
:
There was insufficient memory to allocate an i/o buffer.
"No space for strip buffer"
:
There was insufficient memory to allocate an i/o buffer.
"Can not handle format"
:
The image has a format (combination of
BitsPerSample
,SamplesPerPixel
, andPhotometricInterpretation
) thatTIFFReadRGBAImage()
can not handle.
"No space for B&W mapping table"
:
There was insufficient memory to allocate a table used to map grayscale data to RGB.
"No space for Palette mapping table"
:
There was insufficient memory to allocate a table used to map data to 8-bit RGB.
See also¶
TIFFOpen (3tiff), TIFFRGBAImage (3tiff), TIFFReadRGBAImage (3tiff), TIFFReadRGBATile (3tiff), libtiff (3tiff)