NAME
Imager::APIRef - Imager's C API - reference.
SYNOPSIS
i_color color;
color.rgba.r = 255; color.rgba.g = 0; color.rgba.b = 255;
double x[] = { ... };
double y[] = { ... };
i_polygon_t poly;
poly.count = sizeof(x) / sizeof(*x);
poly.x = x;
poly.y = y;
# Blit tools
# Context objects
im_context_refinc(aIMCTX, "a description");
im_context_refdec(aIMCTX, "a description");
# Data Types
i_img *img;
i_color black;
black.rgba.r = black.rgba.g = black.rgba.b = black.rgba.a = 0;
i_fill_t *fill;
i_img_dim x, y;
i_img_dim_u limit;
printf("left %" i_DF "\n", i_DFc(x));
printf("point (" i_DFp ")\n", i_DFcp(x, y));
# Drawing
i_arc(im, 50, 50, 20, 45, 135, &color);
i_arc_cfill(im, 50, 50, 35, 90, 135, fill);
i_arc_aa(im, 50, 50, 35, 90, 135, &color);
i_arc_aa_cfill(im, 50, 50, 35, 90, 135, fill);
i_circle_aa(im, 50, 50, 45, &color);
i_box(im, 0, 0, im->xsize-1, im->ysize-1, &color).
i_box_filled(im, 0, 0, im->xsize-1, im->ysize-1, &color);
i_box_cfill(im, 0, 0, im->xsize-1, im->ysize-1, fill);
i_flood_fill(im, 50, 50, &color);
i_flood_cfill(im, 50, 50, fill);
i_flood_fill_border(im, 50, 50, &color, &border);
i_flood_cfill_border(im, 50, 50, fill, border);
i_poly_poly_aa(im, 1, &poly, mode, color);
i_poly_aa_m(im, count, x, y, mode, color);
i_poly_poly_aa_cfill(im, 1, &poly, mode, fill);
i_poly_aa_cfill(im, count, x, y, mode, fill);
# Error handling
im_clear_error(aIMCTX);
i_clear_error();
i_push_error(0, "Yep, it's broken");
i_push_error(errno, "Error writing");
im_push_error(aIMCTX, 0, "Something is wrong");
va_args args;
va_start(args, lastarg);
im_push_errorvf(ctx, code, format, args);
i_push_errorf(errno, "Cannot open file %s: %d", filename, errno);
im_push_errorf(aIMCTX, errno, "Cannot open file %s: %d", filename, errno);
# Files
im_set_image_file_limits(aIMCTX, 500, 500, 1000000);
i_set_image_file_limits(500, 500, 1000000);
im_get_image_file_limits(aIMCTX, &width, &height, &bytes)
i_get_image_file_limits(&width, &height, &bytes)
im_int_check_image_file_limits(aIMCTX, width, height, channels, sizeof(i_sample_t))
i_int_check_image_file_limits(width, height, channels, sizeof(i_sample_t))
# Fills
i_fill_t *fill = i_new_fill_solidf(&fcolor, combine);
i_fill_t *fill = i_new_fill_solid(&color, combine);
i_fill_t *fill = i_new_fill_hatch(&fg_color, &bg_color, combine, hatch, custom_hatch, dx, dy);
i_fill_t *fill = i_new_fill_hatchf(&fg_fcolor, &bg_fcolor, combine, hatch, custom_hatch, dx, dy);
i_fill_t *fill = i_new_fill_image(src_img, matrix, x_offset, y_offset, combine);
fill = i_new_fill_fount(0, 0, 100, 100, i_ft_linear, i_ft_linear,
i_fr_triangle, 0, i_fts_grid, 9, 1, segs);
i_fill_destroy(fill);
# I/O Layers
ssize_t count = i_io_peekn(ig, buffer, sizeof(buffer));
ssize_t result = i_io_write(io, buffer, size)
char buffer[BUFSIZ]
ssize_t len = i_io_gets(buffer, sizeof(buffer), '\n');
io_glue_destroy(ig);
# Image
# Image creation/destruction
i_img *img = i_sametype(src, width, height);
i_img *img = i_sametype_chans_extra(src, width, height, channels, extra);
i_img *img = im_img_16_new_extra(aIMCTX, width, height, channels);
i_img *img = i_img_16_new_extra(width, height, channels);
i_img *img = im_img_8_new_extra(aIMCTX, width, height, channels, extra);
i_img *img = i_img_8_new_extra(width, height, channels, extra);
i_img *img = im_img_double_new_extra(aIMCTX, width, height, channels, extra);
i_img *img = i_img_double_new_extra(width, height, channels, extra);
i_img *img = im_img_float_new_extra(aIMCTX, width, height, channels, extra);
i_img *img = i_img_float_new_extra(width, height, channels, extra);
i_img *img = im_img_float_new(aIMCTX, width, height, channels);
i_img *img = i_img_float_new(width, height, channels);
i_img *img = im_img_double_new(aIMCTX, width, height, channels);
i_img *img = i_img_double_new(width, height, channels);
i_img *img = im_img_16_new(aIMCTX, width, height, channels);
i_img *img = i_img_16_new(width, height, channels);
i_img *img = im_img_8_new(aIMCTX, width, height, channels);
i_img *img = i_img_8_new(width, height, channels);
i_img *img = im_lin_img_16_new(aIMCTX, width, height, channels);
i_img *img = i_lin_img_16_new(width, height, channels);
i_img *img = im_lin_img_double_new(aIMCTX, width, height, channels);
i_img *img = i_lin_img_double_new(width, height, channels);
i_img *img = i_sametype_chans(src, width, height, channels);
i_img *img = im_lin_img_16_new_extra(aIMCTX, width, height, channels);
i_img *img = i_lin_img_16_new_extra(width, height, channels);
i_img *img = im_img_pal_new(aIMCTX, width, height, channels, max_palette_size)
i_img *img = i_img_pal_new(width, height, channels, max_palette_size)
i_img_destroy(img)
# Image Implementation
i_img *im = im_img_alloc(aIMCTX);
i_img *im = i_img_alloc();
im_img_init(aIMCTX, im);
i_img_init(im);
# Image Information
// only channel 0 writable
i_img_setmask(img, 0x01);
int mask = i_img_getmask(img);
if (i_img_linear(im)) { ... }
if (i_img_virtual(im)) { ... }
i_img_bits_t bits = i_img_bits(im);
int chans = i_img_channels(im);
int chans = i_img_getchannels(im);
int extra = i_img_extrachannels(im);
int totalch = i_img_totalchannels(im);
i_img_dim width = i_img_get_width(im);
i_img_dim height = i_img_get_height(im);
i_color_model_t cm = i_img_color_model(im);
int alpha_channel;
int has_alpha = i_img_alpha_channel(im, &alpha_channel);
int color_channels = i_img_color_channels(im);
if (i_img_all_channel_mask(im)) { ... }
if (!i_img_valid_channel_indexes(im, chans, chan_count)) { return -1; }
# Image quantization
# Logging
# mutex
i_mutex_t mutex;
# Mutex functions
i_mutex_t m = i_mutex_new();
i_mutex_destroy(m);
i_mutex_lock(m);
i_mutex_unlock(m);
# Paletted images
# Tags
i_tags_set(&img->tags, "i_comment", -1);
i_tags_setn(&img->tags, "i_xres", 204);
i_tags_setn(&img->tags, "i_yres", 196);
DESCRIPTION
Blit tools
- i_render_color(r, x, y, width, source, color)
-
Render the given color with the coverage specified by
source[0]
tosource[width-1]
.Renders in normal combine mode.
- i_render_delete(r)
-
Release an
i_render
object. - i_render_fill(r, x, y, width, source, fill)
-
Render the given fill with the coverage in
source[0]
throughsource[width-1]
. - i_render_line(r, x, y, width, source, fill)
-
Render the given fill with the coverage in
source[0]
throughsource[width-1]
. - i_render_linef(r, x, y, width, source, fill)
-
Render the given fill with the coverage in
source[0]
throughsource[width-1]
. - i_render_new(im, width)
-
Allocate a new
i_render
object and initialize it.
Context objects
- im_context_refdec(ctx, where)
-
im_context_refdec(aIMCTX, "a description");
Remove a reference to the context, releasing it if all references have been removed.
- im_context_refinc(ctx, where)
-
im_context_refinc(aIMCTX, "a description");
Add a new reference to the context.
Data Types
- i_img
-
i_img *img;
This is Imager's image type.
It contains the following members:
channels
- the number of channels in the image. This is only the channels associated with color and alpha channel. See alsoextrachannels
.extrachannels
- the number of extra channels associated with each pixel.xsize
,ysize
- the width and height of the image in pixelsbytes
- the number of bytes used to store the image data. Undefined where virtual is non-zero.ch_mask
- a mask of writable channels. eg. if this is 6 then only channels 1 and 2 are writable. There may be bits set for which there are no channels in the image.bits
- the number of bits stored per sample. Should be one of i_8_bits, i_16_bits, i_double_bits.type
- either i_direct_type for direct color images, or i_palette_type for paletted images.-
islinear
- whether the image samples are natively linear or use a tone curve. Accessor: i_img_linear(). isvirtual
- if zero then this image is-self contained. If non-zero then this image could be an interface to some other implementation.idata
- the image data. This should not be directly accessed. A new image implementation can use this to store its image data. "i_img_destroy()" will myfree() this pointer if it's non-null. Non-image implementors can use "i_img_data()" to fetch or optionally synthesize raw image data.tags
- a structure storing the image's tags. This should only be accessed via the i_tags_*() functions.ext_data
- a pointer for use internal to an image implementation. This should be freed by the image's destroy handler.im_data
- data internal to Imager. This is initialized by i_img_init().context
- the Imager API context this image belongs to.
- i_color
-
i_color black; black.rgba.r = black.rgba.g = black.rgba.b = black.rgba.a = 0;
Type for 8-bit/sample color.
Samples as per;
i_color c;
i_color is a union of:
gray - contains a single element gray_color, eg.
c.gray.gray_color
rgb
- contains three elementsr
,g
,b
, eg.c.rgb.r
rgba
- contains four elementsr
,g
,b
,a
, eg.c.rgba.a
cmyk
- contains four elementsc
,m
,y
,k
, eg.c.cmyk.y
. Note that Imager never uses CMYK colors except when reading/writing files.channels - an array of four channels, eg
c.channels[2]
.
- i_fcolor
-
This is the double/sample color type.
Its layout exactly corresponds to i_color.
- i_fill_t
-
i_fill_t *fill;
This is the "abstract" base type for Imager's fill types.
Unless you're implementing a new fill type you'll typically treat this as an opaque type.
- i_poly_fill_mode_t
-
Control how polygons are filled. Has the following values:
i_pfm_evenodd
- simple even-odd fills.i_pfm_nonzero
- non-zero winding rule fills.
- i_polygon_t
-
Represents a polygon. Has the following members:
x
,y
- arrays of x and y locations of vertices.count
- the number of entries in thex
andy
arrays.
- im_context_t
-
Imager's per-thread context.
- im_slot_t
-
Represents a slot in the context object.
- i_img_dim
-
i_img_dim x, y;
A signed integer type that represents an image dimension or ordinate.
May be larger than int on some platforms.
- i_img_dim_u
-
i_img_dim_u limit;
An unsigned variant of "i_img_dim".
- i_color_model_t
-
Returned by "i_img_color_model(im)" to indicate the color model of the image.
An enumerated type with the following possible values:
icm_unknown
- the image has no usable color data. In future versions of Imager this will be returned in a few limited cases, eg. when the source image is CMYK and the user has requested no color translation is done.icm_gray
- gray scale with no alpha channel.icm_gray_alpha
- gray scale with an alpha channel.icm_rgb
- RGBicm_rgb_alpha
- RGB with an alpha channel.
- i_DF
-
printf("left %" i_DF "\n", i_DFc(x));
This is a constant string that can be used with functions like printf() to format i_img_dim values after they're been cast with i_DFc().
Does not include the leading
%
. - i_DFc
-
Cast an
i_img_dim
value to a type for use with the i_DF format string. - i_DFcp
-
Casts two
i_img_dim
values for use with the i_DF (or i_DFp) format. - i_DFp
-
printf("point (" i_DFp ")\n", i_DFcp(x, y));
Format a pair of
i_img_dim
values. This format string does include the leading%
.
Drawing
- i_arc(im, x, y, rad, d1, d2, color)
-
i_arc(im, 50, 50, 20, 45, 135, &color);
Fills an arc centered at (x,y) with radius rad covering the range of angles in degrees from d1 to d2, with the color.
- i_arc_aa(im, x, y, rad, d1, d2, color)
-
i_arc_aa(im, 50, 50, 35, 90, 135, &color);
Anti-alias fills an arc centered at (x,y) with radius rad covering the range of angles in degrees from d1 to d2, with the color.
- i_arc_aa_cfill(im, x, y, rad, d1, d2, fill)
-
i_arc_aa_cfill(im, 50, 50, 35, 90, 135, fill);
Anti-alias fills an arc centered at (x,y) with radius rad covering the range of angles in degrees from d1 to d2, with the fill object.
- i_arc_cfill(im, x, y, rad, d1, d2, fill)
-
i_arc_cfill(im, 50, 50, 35, 90, 135, fill);
Fills an arc centered at (x,y) with radius rad covering the range of angles in degrees from d1 to d2, with the fill object.
- i_box(im, x1, y1, x2, y2, color)
-
i_box(im, 0, 0, im->xsize-1, im->ysize-1, &color).
Outlines the box from (x1,y1) to (x2,y2) inclusive with color.
- i_box_cfill(im, x1, y1, x2, y2, fill)
-
i_box_cfill(im, 0, 0, im->xsize-1, im->ysize-1, fill);
Fills the box from (x1,y1) to (x2,y2) inclusive with fill.
- i_box_filled(im, x1, y1, x2, y2, color)
-
i_box_filled(im, 0, 0, im->xsize-1, im->ysize-1, &color);
Fills the box from (x1,y1) to (x2,y2) inclusive with color.
- i_circle_aa(im, x, y, rad, color)
-
i_circle_aa(im, 50, 50, 45, &color);
Anti-alias fills a circle centered at (x,y) for radius rad with color.
- i_flood_cfill(
im
,seedx
,seedy
,fill
) -
i_flood_cfill(im, 50, 50, fill);
Flood fills the 4-connected region starting from the point (
seedx
,seedy
) withfill
.Returns false if (
seedx
,seedy
) are outside the image. - i_flood_cfill_border(
im
,seedx
,seedy
,fill
,border
) -
i_flood_cfill_border(im, 50, 50, fill, border);
Flood fills the 4-connected region starting from the point (
seedx
,seedy
) withfill
, the fill stops when it reaches pixels of colorborder
.Returns false if (
seedx
,seedy
) are outside the image. - i_flood_fill(
im
,seedx
,seedy
,color
) -
i_flood_fill(im, 50, 50, &color);
Flood fills the 4-connected region starting from the point (
seedx
,seedy
) with color.Returns false if (
seedx
,seedy
) are outside the image. - i_flood_fill_border(
im
,seedx
,seedy
,color
,border
) -
i_flood_fill_border(im, 50, 50, &color, &border);
Flood fills the 4-connected region starting from the point (
seedx
,seedy
) withcolor
, fill stops when the fill reaches a pixels with colorborder
.Returns false if (
seedx
,seedy
) are outside the image. - i_glin()
-
Retrieves (r-l) pixels starting from (l,y) into
colors
.count = i_glin(im, l, r, y, colors);
Returns the number of pixels retrieved.
- i_glinf()
-
Retrieves (r-l) pixels starting from (l,y) into
fcolors
.count = i_glinf(im, l, r, y, fcolors);
Returns the number of pixels retrieved.
- i_gpal(im, left, right, y, indexes)
-
Reads palette indexes for the horizontal line (left, y) to (right-1, y) into
indexes
.Returns the number of indexes read.
Always returns 0 for direct color images.
- i_gpix(im,
x
,y
,color
) -
Retrieves the
color
of the pixel (x,y).Returns 0 if the pixel was retrieved, or -1 if not.
- i_gpixf(im,
x
,y
,color
) -
Retrieves the floating point
color
of the pixel (x,y).Returns 0 if the pixel was retrieved, or -1 if not.
- i_gsamp(im, left, right, y, samples, channels, channel_count)
-
Reads sample values from
im
for the horizontal line (left, y) to (right-1,y) for the channels specified bychannels
, an array of int withchannel_count
elements.If channels is NULL then the first channels_count channels are retrieved for each pixel.
Returns the number of samples read (which should be (right-left) * channel_count)
- i_gsamp_bg(im, l, r, y, samples, out_channels, background)
-
Like
i_gsampf()
but applies the source image color over a supplied background color.This is intended for output to image formats that don't support alpha channels.
- i_gsamp_bits(im, left, right, y, samples, channels, channel_count, bits)
-
Reads integer samples scaled to
bits
bits of precision into theunsigned int
arraysamples
.Expect this to be slow unless
bits == im->bits
.Returns the number of samples copied, or -1 on error.
Not all image types implement this method.
Pushes errors, but does not call
i_clear_error()
. - i_gsampf(im, left, right, y, samples, channels, channel_count)
-
Reads floating point sample values from
im
for the horizontal line (left, y) to (right-1,y) for the channels specified bychannels
, an array of int with channel_count elements.If
channels
is NULL then the firstchannel_count
channels are retrieved for each pixel.Returns the number of samples read (which should be (
right
-left
) *channel_count
) - i_gsampf_bg(im, l, r, y, samples, out_channels, background)
-
Like
i_gsampf()
but applies the source image color over a supplied background color.This is intended for output to image formats that don't support alpha channels.
- i_line(
im
,x1
,y1
,x2
,y2
,color
,endp
) -
Draw a line to image using Bresenham's line drawing algorithm
im - image to draw to x1 - starting x coordinate y1 - starting x coordinate x2 - starting x coordinate y2 - starting x coordinate color - color to write to image endp - endpoint flag (boolean)
- i_line_aa(
im
,x1
,x2
,y1
,y2
,color
,endp
) -
Anti-alias draws a line from (x1,y1) to (x2, y2) in color.
The point (x2, y2) is drawn only if
endp
is set. - i_plin()
-
i_img *im = ...; i_img_dim l, r, y; i_color vals[...] = { ... colors ... }; i_img_dim count = i_plin(im, l, r, y, vals);
Sets (r-l) pixels starting from (l,y) using (r-l) values from colors.
Returns the number of pixels set.
- i_plinf()
-
i_img *im = ...; i_img_dim l, r, y; i_fcolor vals[...] = { ... colors ... }; i_img_dim count = i_plinf(im, l, r, y, vals);
Sets (r-l) pixels starting from (l,y) using (r-l) values from colors.
Returns the number of pixels set.
- i_poly_aa_cfill_m(im, count, x, y, mode, fill)
-
i_poly_aa_cfill(im, count, x, y, mode, fill);
Fill a polygon defined by the points specified by the x and y arrays with the fill specified by
fill
. - i_poly_aa_m(im, count, x, y, mode, color)
-
i_poly_aa_m(im, count, x, y, mode, color);
Fill a polygon defined by the points specified by the x and y arrays with the color specified by
color
. - i_poly_poly_aa(im, count, polys, mode, color)
-
i_poly_poly_aa(im, 1, &poly, mode, color);
Fill the
count
polygons defined bypolys
the color specified bycolor
.At least one polygon must be supplied.
All polygons must have at least 3 points.
- i_poly_poly_aa_cfill(im, count, polys, mode, fill)
-
i_poly_poly_aa_cfill(im, 1, &poly, mode, fill);
Fill the
count
polygons defined bypolys
the fill specified byfill
.At least one polygon must be supplied.
All polygons must have at least 3 points.
- i_ppal(im, left, right, y, indexes)
-
Writes palette indexes for the horizontal line (left, y) to (right-1, y) from
indexes
.Returns the number of indexes written.
Always returns 0 for direct color images.
- i_ppix(im, x, y, color)
-
Sets the pixel at (x,y) to color.
Returns 0 if the pixel was drawn, or -1 if not.
Does no alpha blending, just copies the channels from the supplied color to the image.
- i_ppixf(im,
x
,y
,fcolor
) -
Sets the pixel at (
x
,y
) to the floating point colorfcolor
.Returns 0 if the pixel was drawn, or -1 if not.
Does no alpha blending, just copies the channels from the supplied color to the image.
- i_psamp(im, left, right, y, samples, channels, channel_count)
-
Writes sample values from
samples
toim
for the horizontal line (left, y) to (right-1, y) inclusive for the channels specified bychannels
, an array ofint
withchannel_count
elements.If
channels
isNULL
then the firstchannels_count
channels are written to for each pixel.Returns the number of samples written, which should be (right - left) * channel_count. If a channel not in the image is in channels, left is negative, left is outside the image or y is outside the image, returns -1 and pushes an error.
- i_psamp_bits(im, left, right, y, samples, channels, channel_count, bits)
-
Writes integer samples scaled to
bits
bits of precision from theunsigned int
arraysamples
.Expect this to be slow unless
bits == im->bits
.Returns the number of samples copied, or -1 on error.
Not all image types implement this method.
Pushes errors, but does not call
i_clear_error()
. - i_psampf(im, left, right, y, samples, channels, channel_count)
-
Writes floating point sample values from
samples
toim
for the horizontal line (left, y) to (right-1, y) inclusive for the channels specified bychannels
, an array ofint
withchannel_count
elements.If
channels
isNULL
then the firstchannels_count
channels are written to for each pixel.Returns the number of samples written, which should be (right - left) * channel_count. If a channel not in the image is in channels, left is negative, left is outside the image or y is outside the image, returns -1 and pushes an error.
Error handling
- i_push_errorf(int code, char const *fmt, ...)
-
i_push_errorf(errno, "Cannot open file %s: %d", filename, errno);
A version of i_push_error() that does printf() like formatting.
Does not support perl specific format codes.
- im_clear_error(ctx)
-
im_clear_error(aIMCTX); i_clear_error();
Clears the error stack.
Called by any Imager function before doing any other processing.
Also callable as
i_clear_error()
. - im_push_error(ctx, code, message)
-
i_push_error(0, "Yep, it's broken"); i_push_error(errno, "Error writing"); im_push_error(aIMCTX, 0, "Something is wrong");
Called by an Imager function to push an error message onto the stack.
No message is pushed if the stack is full (since this means someone forgot to call i_clear_error(), or that a function that doesn't do error handling is calling function that does.).
- im_push_errorf(ctx, code, char const *fmt, ...)
-
im_push_errorf(aIMCTX, errno, "Cannot open file %s: %d", filename, errno);
A version of im_push_error() that does printf() like formatting.
Does not support perl specific format codes.
- im_push_errorvf(ctx, code, format, args)
-
va_args args; va_start(args, lastarg); im_push_errorvf(ctx, code, format, args);
Intended for use by higher level functions, takes a varargs pointer and a format to produce the finally pushed error message.
Does not support perl specific format codes.
Also callable as
i_push_errorvf(code, format, args)
Files
- i_get_file_background(im, &bg)
-
Retrieve the file write background color tag from the image.
If not present,
bg
is set to black.Returns 1 if the
i_background
tag was found and valid. - i_get_file_backgroundf(im, &bg)
-
Retrieve the file write background color tag from the image as a floating point color.
Implemented in terms of i_get_file_background().
If not present,
bg
is set to black.Returns 1 if the
i_background
tag was found and valid. - im_get_image_file_limits(ctx, &width, &height, &bytes)
-
im_get_image_file_limits(aIMCTX, &width, &height, &bytes) i_get_image_file_limits(&width, &height, &bytes)
Retrieves the file limits set by i_set_image_file_limits().
i_img_dim *width, *height - the maximum width and height of the image.
size_t *bytes - size in memory of the image in bytes.
Also callable as
i_get_image_file_limits(&width, &height, &bytes)
. - im_int_check_image_file_limits(width, height, channels, sample_size)
-
im_int_check_image_file_limits(aIMCTX, width, height, channels, sizeof(i_sample_t)) i_int_check_image_file_limits(width, height, channels, sizeof(i_sample_t))
Checks the size of a file in memory against the configured image file limits.
This also range checks the values to those permitted by Imager and checks for overflows in calculating the size.
Returns non-zero if the file is within limits.
This function is intended to be called by image file read functions.
Also callable as
i_int_check_image_file_limits(width, height, channels, sizeof(i_sample_t)
. - im_set_image_file_limits(ctx, width, height, bytes)
-
im_set_image_file_limits(aIMCTX, 500, 500, 1000000); i_set_image_file_limits(500, 500, 1000000);
Set limits on the sizes of images read by Imager.
Setting a limit to 0 means that limit is ignored.
Negative limits result in failure.
Parameters:
i_img_dim width, height - maximum width and height.
size_t bytes - maximum size in memory in bytes. A value of zero sets this limit to one gigabyte.
Returns non-zero on success.
Also callable as
i_set_image_file_limits(width, height, bytes)
.
Fills
- i_new_fill_fount(
xa
,ya
,xb
,yb
,type
,repeat
,combine
,super_sample
,ssample_param
,count
,segs
) -
fill = i_new_fill_fount(0, 0, 100, 100, i_ft_linear, i_ft_linear, i_fr_triangle, 0, i_fts_grid, 9, 1, segs);
Creates a new general fill which fills with a fountain fill.
- i_new_fill_hatch(
fg
,bg
,combine
,hatch
,cust_hatch
,dx
,dy
) -
i_fill_t *fill = i_new_fill_hatch(&fg_color, &bg_color, combine, hatch, custom_hatch, dx, dy);
Creates a new hatched fill with the
fg
color used for the 1 bits in the hatch andbg
for the 0 bits. Ifcombine
is non-zero alpha values will be combined.If
cust_hatch
is non-NULL it should be a pointer to 8 bytes of the hash definition, with the high-bits to the left.If
cust_hatch
is NULL then one of the standard hatches is used.(
dx
,dy
) are an offset into the hatch which can be used to hatch adjoining areas out of alignment, or to align the origin of a hatch with the side of a filled area. - i_new_fill_hatchf(
fg
,bg
,combine
,hatch
,cust_hatch
,dx
,dy
) -
i_fill_t *fill = i_new_fill_hatchf(&fg_fcolor, &bg_fcolor, combine, hatch, custom_hatch, dx, dy);
Creates a new hatched fill with the
fg
color used for the 1 bits in the hatch andbg
for the 0 bits. Ifcombine
is non-zero alpha values will be combined.If
cust_hatch
is non-NULL it should be a pointer to 8 bytes of the hash definition, with the high-bits to the left.If
cust_hatch
is NULL then one of the standard hatches is used.(
dx
,dy
) are an offset into the hatch which can be used to hatch adjoining areas out of alignment, or to align the origin of a hatch with the side of a filled area. - i_new_fill_image(
im
,matrix
,xoff
,yoff
,combine
) -
i_fill_t *fill = i_new_fill_image(src_img, matrix, x_offset, y_offset, combine);
Create an image based fill.
matrix is an array of 9 doubles representing a transformation matrix.
xoff
andyoff
are the offset into the image to start filling from. - i_new_fill_solid(color, combine)
-
i_fill_t *fill = i_new_fill_solid(&color, combine);
Create a solid fill based on an 8-bit color.
If combine is non-zero then alpha values will be combined.
- i_new_fill_solidf(color, combine)
-
i_fill_t *fill = i_new_fill_solidf(&fcolor, combine);
Create a solid fill based on a float color.
If combine is non-zero then alpha values will be combined.
- i_fill_destroy(fill)
-
i_fill_destroy(fill);
Call to destroy any fill object.
I/O Layers
- im_io_new_bufchain(ctx)
-
Returns a new io_glue object that has the 'empty' source and but can be written to and read from later (like a pseudo file).
Also callable as
io_new_bufchain()
. - im_io_new_buffer(ctx, data, length)
-
Returns a new io_glue object that has the source defined as reading from specified buffer. Note that the buffer is not copied.
ctx - an Imager context object data - buffer to read from length - length of buffer
Also callable as
io_new_buffer(data, length
. - im_io_new_cb(ctx, p, read_cb, write_cb, seek_cb, close_cb, destroy_cb)
-
Create a new I/O layer object that calls your supplied callbacks.
In general the callbacks should behave like the corresponding POSIX primitives.
read_cb
(p, buffer, length) should read up tolength
bytes intobuffer
and return the number of bytes read. At end of file, return 0. On error, return -1.write_cb
(p, buffer, length) should write up tolength
bytes frombuffer
and return the number of bytes written. A return value <= 0 will be treated as an error.seekcb
(p, offset, whence) should seek and return the new offset.close_cb
(p) should return 0 on success, -1 on failure.destroy_cb
(p) should release any memory specific to your callback handlers.
Also callable as
io_new_cb(p, readcb, writecb, seekcb, closecb, destroycb)
. - im_io_new_fd(ctx, file)
-
Returns a new io_glue object that has the source defined as reading from specified file descriptor. Note that the interface to receiving data from the io_glue callbacks hasn't been done yet.
ctx - and Imager context object file - file descriptor to read/write from
Also callable as
io_new_fd(file)
. - i_io_close(io)
-
Flush any pending output and perform the close action for the stream.
Returns 0 on success.
- i_io_eof()
-
Return true if the stream is at end of file.
- i_io_error()
-
Return true if the stream is in an error state. i_io_seek() will clear the error state.
- i_io_flush(io)
-
Flush any buffered output.
Returns true on success,
- i_io_getc(ig)
-
A macro to read a single byte from a buffered I/O glue object.
Returns EOF on failure, or a byte.
- i_io_gets(ig, buffer, size, end_of_line)
-
char buffer[BUFSIZ] ssize_t len = i_io_gets(buffer, sizeof(buffer), '\n');
Read up to
size
-1 bytes from the streamig
intobuffer
.If the byte
end_of_line
is seen then no further bytes will be read.Returns the number of bytes read.
Always
NUL
terminates the buffer. - i_io_is_buffered()
-
Returns true if the I/O layer object is buffered.
- i_io_mmap()
-
If the I/O object allows it, return the address and size of the data. For
fd
objects this will attempt to mmap() the file into memory.The memory may not be written to.
const void *p; size_t size; if (i_io_mmap(io, &p, &size)) { i_io_munmap(p); }
- i_io_munmap()
-
Remove the memory mapping created by i_io_mmap().
i_io_munmap(io);
- i_io_nextc()
-
Currently broken.
- i_io_peekc(ig)
-
Read the next character from the stream without advancing the stream.
On error or end of file, return EOF.
For unbuffered streams a single character buffer will be setup.
- i_io_peekn(ig, buffer, size)
-
ssize_t count = i_io_peekn(ig, buffer, sizeof(buffer));
Buffer at least
size
(at mostig->buf_size
bytes of data from the stream and returnsize
bytes of it to the caller inbuffer
.This ignores the buffered state of the stream, and will always setup buffering if needed.
If no
type
parameter is provided to Imager::read() or Imager::read_multi(), Imager will calli_io_peekn()
when probing for the file format.Returns -1 on error, 0 if there is no data before EOF, or the number of bytes read into
buffer
. - i_io_putc(ig, c)
-
Write a single character to the stream.
On success return c, on error returns EOF
- i_io_raw_close()
-
Raw close an I/O layer object. This will not flush any buffered data.
int result = i_io_raw_close(io)
- i_io_raw_read()
-
Raw read from an I/O layer object. This does not mix well with the buffer I/O functions.
char buf[SIZE]; ssize_t rd_size = i_io_raw_read(io, buf, SIZE);
- i_io_raw_seek()
-
Raw seek in an I/O layer object. This does not mix well with the buffer I/O functions.
off_t pos = i_io_raw_seek(io, offset, seek_type);
- i_io_raw_write()
-
Raw write to an I/O layer object. This does not mix well with the buffer I/O functions.
char data[SIZE] = "..."; ssize_t wr_size = i_io_raw_write(io, buf, SIZE);
- i_io_read(io, buffer, size)
-
Read up to
size
bytes from the streamio
intobuffer
.Returns the number of bytes read. Returns 0 on end of file. Returns -1 on error.
- i_io_seek(io, offset, whence)
-
Seek within the stream.
Acts like perl's seek.
- i_io_set_buffered(io, buffered)
-
Set the buffering mode of the stream.
If you switch buffering off on a stream with buffering on:
any buffered output will be flushed.
any existing buffered input will be consumed before reads become unbuffered.
Returns true on success. This may fail if any buffered output cannot be flushed.
- i_io_type()
-
Return the type of an I/O layer object.
int type = i_io_type(io);
- i_io_write(io, buffer, size)
-
ssize_t result = i_io_write(io, buffer, size)
Write to the given I/O stream.
Returns the number of bytes written.
- io_slurp(ig, c)
-
Takes the source that the io_glue is bound to and allocates space for a return buffer and returns the entire content in a single buffer. Note: This only works for io_glue objects created by io_new_bufchain(). It is useful for saving to scalars and such.
ig - io_glue object c - pointer to a pointer to where data should be copied to char *data; size_t size = io_slurp(ig, &data); ... do something with the data ... myfree(data);
io_slurp() will abort the program if the supplied I/O layer is not from io_new_bufchain().
- io_glue_destroy(ig)
-
io_glue_destroy(ig);
Destroy an io_glue objects. Should clean up all related buffers.
ig - io_glue object to destroy.
Image
- i_copy(source)
-
Creates a new image that is a copy of the image
source
.Tags are not copied, only the image data.
Returns: i_img *
- i_copyto(
dest
,src
,x1
,y1
,x2
,y2
,tx
,ty
) -
Copies image data from the area (
x1
,y1
)-[x2
,y2
] in the source image to a rectangle the same size with it's top-left corner at (tx
,ty
) in the destination image.If
x1
>x2
ory1
>y2
then the corresponding co-ordinates are swapped. - i_copyto_trans(
im
,src
,x1
,y1
,x2
,y2
,tx
,ty
,trans
) -
(
x1
,y1
) (x2
,y2
) specifies the region to copy (in the source coordinates) (tx
,ty
) specifies the upper left corner for the target image. pass NULL intrans
for non transparent i_colors. - i_img_info(im, info)
-
Return image information
im - Image pointer info - pointer to array to return data
info is an array of 4 integers with the following values:
info[0] - width info[1] - height info[2] - channels info[3] - channel mask
- i_rubthru(
im
,src
,tx
,ty
,src_minx
,src_miny
,src_maxx
,src_maxy
) -
Takes the sub image
src
[src_minx
,src_maxx
)[src_miny
,src_maxy
)> and overlays it at (tx
,ty
) on the image object.The alpha channel of each pixel in
src
is used to control how much the existing color inim
is replaced, if it is 255 then the color is completely replaced, if it is 0 then the original color is left unmodified.
Image creation/destruction
- i_sametype(
im
,xsize
,ysize
) -
i_img *img = i_sametype(src, width, height);
Returns an image of the same type (sample size, channels, paletted/direct).
For paletted images the palette is copied from the source.
- i_sametype_chans(
im
,xsize
,ysize
,channels
) -
i_img *img = i_sametype_chans(src, width, height, channels);
Returns an image of the same type (sample size) with the specified number of color channels.
For paletted images the equivalent direct type is returned.
- i_sametype_chans_extra(
im
,xsize
,ysize
,channels
,extra
) -
i_img *img = i_sametype_chans_extra(src, width, height, channels, extra);
Returns an image of the same type (sample size), with the specified number of color and extra channels.
For paletted images the equivalent direct type is returned.
- im_img_16_new(ctx, x, y, ch)
-
i_img *img = im_img_16_new(aIMCTX, width, height, channels); i_img *img = i_img_16_new(width, height, channels);
Creates a new 16-bit per sample image.
Also callable as
i_img_16_new(width, height, channels)
. - im_img_16_new_extra(ctx, x, y, ch)
-
i_img *img = im_img_16_new_extra(aIMCTX, width, height, channels); i_img *img = i_img_16_new_extra(width, height, channels);
Create a new 16-bit/sample image.
Returns the image on success, or NULL on failure.
Also callable as
i_img_16_new_extra(x, y, ch)
- im_img_8_new(ctx, x, y, ch)
-
i_img *img = im_img_8_new(aIMCTX, width, height, channels); i_img *img = i_img_8_new(width, height, channels);
Creates a new 8-bit per sample image.
Also callable as
i_img_8_new(width, height, channels)
. - im_img_8_new_extra(ctx, x, y, ch extra)
-
i_img *img = im_img_8_new_extra(aIMCTX, width, height, channels, extra); i_img *img = i_img_8_new_extra(width, height, channels, extra);
Creates a new image object x pixels wide, and y pixels high with ch color/alpha channels and
extra
extra channels. - im_img_double_new(ctx, x, y, ch)
-
i_img *img = im_img_double_new(aIMCTX, width, height, channels); i_img *img = i_img_double_new(width, height, channels);
Creates a new double per sample image.
Also callable as
i_img_double_new(width, height, channels)
. - im_img_double_new_extra(ctx, x, y, ch, extra)
-
i_img *img = im_img_double_new_extra(aIMCTX, width, height, channels, extra); i_img *img = i_img_double_new_extra(width, height, channels, extra);
Creates a new double per sample image, possibly with "Extra channels" in Imager::ImageTypes.
Also callable as
i_img_double_new_extra(width, height, channels, extra)
. - im_img_float_new(ctx, x, y, ch)
-
i_img *img = im_img_float_new(aIMCTX, width, height, channels); i_img *img = i_img_float_new(width, height, channels);
Creates a new float per sample image.
Also callable as
i_img_float_new(width, height, channels)
. - im_img_float_new_extra(ctx, x, y, ch, extra)
-
i_img *img = im_img_float_new_extra(aIMCTX, width, height, channels, extra); i_img *img = i_img_float_new_extra(width, height, channels, extra);
Creates a new float per sample image, possibly with "Extra channels" in Imager::ImageTypes.
Also callable as
i_img_float_new_extra(width, height, channels, extra)
. - im_img_pal_new(ctx,
x
,y
,channels
,maxpal
) -
i_img *img = im_img_pal_new(aIMCTX, width, height, channels, max_palette_size) i_img *img = i_img_pal_new(width, height, channels, max_palette_size)
Creates a new paletted image of the supplied dimensions.
maxpal
is the maximum palette size and should normally be 256.Returns a new image or NULL on failure.
Also callable as
i_img_pal_new(width, height, channels, max_palette_size)
. - im_lin_img_16_new(ctx, x, y, ch)
-
i_img *img = im_lin_img_16_new(aIMCTX, width, height, channels); i_img *img = i_lin_img_16_new(width, height, channels);
Create a new 16-bit/linear sample image.
Returns the image on success, or NULL on failure.
Also callable as
i_img_16_new(x, y, ch)
- im_lin_img_16_new_extra(ctx, x, y, ch)
-
i_img *img = im_lin_img_16_new_extra(aIMCTX, width, height, channels); i_img *img = i_lin_img_16_new_extra(width, height, channels);
Create a new linear 16-bit/sample image.
Returns the image on success, or NULL on failure.
Also callable as
i_lin_img_16_new_extra(x, y, ch)
- im_lin_img_double_new(ctx, x, y, ch)
-
i_img *img = im_lin_img_double_new(aIMCTX, width, height, channels); i_img *img = i_lin_img_double_new(width, height, channels);
Create a new double/linear sample image.
Returns the image on success, or NULL on failure.
Also callable as
i_img_double_new(x, y, ch)
- i_img_destroy()
-
i_img_destroy(img)
Reduce the reference count of an image object by 1, and if the reference count reaches zero, destroy the image object.
This is unrelated to Perl
SV
reference counts.
Image Implementation
- im_img_alloc()
-
i_img *im = im_img_alloc(aIMCTX); i_img *im = i_img_alloc();
Allocates a new i_img structure.
When implementing a new image type perform the following steps in your image object creation function:
allocate the image with i_img_new(), supplying the virtual table pointer, width, height, number of channels, number of extra channels and bit depth.
make any other modifications needed, such as marking the image as linear or virtual, allocating image data for non-virtual images.
initialize Imager's internal data by calling i_img_init() on the image object.
- im_img_init(aIMCTX, image)
-
im_img_init(aIMCTX, im); i_img_init(im);
Imager internal initialization of images.
See "im_img_alloc()" for more information.
Image Information
- i_img_all_channel_mask()
-
if (i_img_all_channel_mask(im)) { ... }
Returns true if the images channel mask covers all channels in the image, including any extra channels.
- i_img_alpha_channel(im, &channel)
-
int alpha_channel; int has_alpha = i_img_alpha_channel(im, &alpha_channel);
Work out the alpha channel for an image.
If the image has an alpha channel, sets
*channel
to the alpha channel index and returns non-zero.If the image has no alpha channel, returns zero and
*channel
is not modified.channel
may beNULL
. - i_img_bits()
-
i_img_bits_t bits = i_img_bits(im);
Returns the enum entry for the number of bits per sample in the image.
The absolute value of this as an integer is the number of bits in the representation of the sample.
- i_img_channels()
-
int chans = i_img_channels(im); int chans = i_img_getchannels(im);
Returns the number of color and alpha channels in the image. An RGBA image returns 4.
- i_img_color_channels(im)
-
int color_channels = i_img_color_channels(im);
Returns the number of color channels in the image. For now this is always 1 (for grayscale) or 3 (for RGB) but may be 0 in some special cases in a future release of Imager.
- i_img_color_model(im)
-
i_color_model_t cm = i_img_color_model(im);
Returns the color model for the image.
- i_img_extrachannels()
-
int extra = i_img_extrachannels(im);
Returns the number of extra channels, the channels in addition to the color and alpha channels in the image.
- i_img_get_height(
im
) -
i_img_dim height = i_img_get_height(im);
Returns the height in pixels of the image.
- i_img_get_width(
im
) -
i_img_dim width = i_img_get_width(im);
Returns the width in pixels of the image.
- i_img_getmask(
im
) -
int mask = i_img_getmask(img);
Get the image channel mask for
im
. - i_img_has_alpha(
im
) -
Return true if the image has an alpha channel.
- i_img_is_monochrome(img, &zero_is_white)
-
Tests an image to check it meets our monochrome tests.
The idea is that a file writer can use this to test where it should write the image in whatever bi-level format it uses, eg.
pbm
forpnm
.For performance of encoders we require monochrome images:
be paletted
have a palette of two colors, containing only
(0,0,0)
and(255,255,255)
in either order.
zero_is_white
is set to non-zero if the first palette entry is white. - i_img_linear()
-
if (i_img_linear(im)) { ... }
Returns whether the samples of the image are natively linear scale or not.
- i_img_refcnt()
-
Return the reference count for the image.
- i_img_setmask(
im
,ch_mask
) -
// only channel 0 writable i_img_setmask(img, 0x01);
Set the image channel mask for
im
toch_mask
.The image channel mask gives some control over which channels can be written to in the image.
- i_img_totalchannels()
-
int totalch = i_img_totalchannels(im);
Returns the total number of channels, including both the color, alpha and extra channels.
- i_img_type() =synposis if (i_img_type(im) == i_direct_type) { ... }
-
Returns the type of the image, whether it stores direct color
i_direct_type
or palette entries and a palettedi_palette_type
. - i_img_valid_channel_indexes()
-
if (!i_img_valid_channel_indexes(im, chans, chan_count)) { return -1; }
Return true if all of the channels specified by
chans
/chan_count
are present in the image.Used by image implementations to validate passed in channel lists.
- i_img_virtual()
-
if (i_img_virtual(im)) { ... }
Returns whether the image is virtual or not.
A virtual image represents a view on another image, or contains pixels generated by an algorithm, or some combination of the two.
Image quantization
- i_quant_makemap(
quant
,imgs
,count
) -
Analyzes the
count
images inimgs
according to the rules inquant
to build a color map (optimal or not depending onquant->make_colors
). - i_quant_translate(
quant
,img
) -
Quantize the image given the palette in
quant
.On success returns a pointer to a memory block of
img->xsize * img->ysize
i_palidx
entries.On failure returns NULL.
You should call myfree() on the returned block when you're done with it.
This function will fail if the supplied palette contains no colors.
- i_quant_transparent(
quant
,data
,img
,trans_index
) -
Dither the alpha channel on
img
into the palette indexes indata
. Pixels to be transparent are replaced withtrans_pixel
.The method used depends on the tr_* members of
quant
.
Logging
- i_lhead(file, line)
-
This is an internal function called by the mm_log() macro.
- i_loog(level, format, ...)
-
This is an internal function called by the mm_log() macro.
mutex
- i_mutex_t
-
i_mutex_t mutex;
Opaque type for Imager's mutex API.
Mutex functions
- i_mutex_new()
-
i_mutex_t m = i_mutex_new();
Create a mutex.
If a critical section cannot be created for whatever reason, Imager will abort.
- i_mutex_destroy(m)
-
i_mutex_destroy(m);
Destroy a mutex.
- i_mutex_lock(m)
-
i_mutex_lock(m);
Lock the mutex, waiting if another thread has the mutex locked.
- i_mutex_unlock(m)
-
i_mutex_unlock(m);
Release the mutex.
The behavior of releasing a mutex you don't hold is unspecified.
Paletted images
- i_addcolors(im, colors, count)
-
Adds colors to the image's palette.
On success returns the index of the lowest color added.
On failure returns -1.
Always fails for direct color images.
- i_colorcount(im)
-
Returns the number of colors in the image's palette.
Returns -1 for direct images.
- i_findcolor(im, color, &entry)
-
Searches the images palette for the given color.
On success sets *entry to the index of the color, and returns true.
On failure returns false.
Always fails on direct color images.
- i_getcolors(im, index, colors, count)
-
Retrieves count colors starting from index in the image's palette.
On success stores the colors into colors and returns true.
On failure returns false.
Always fails for direct color images.
Fails if there are less than index+count colors in the image's palette.
- i_maxcolors(im)
-
Returns the maximum number of colors the palette can hold for the image.
Returns -1 for direct color images.
- i_setcolors(im, index, colors, count)
-
Sets count colors starting from index in the image's palette.
On success returns true.
On failure returns false.
The image must have at least index+count colors in it's palette for this to succeed.
Always fails on direct color images.
Tags
-
Delete any tags with the given code.
Returns the number of tags deleted.
-
Delete any tags with the given name.
Returns the number of tags deleted.
-
Delete a tag by index.
Returns true on success.
-
Destroys the given tags structure. Called by i_img_destroy().
-
Searches for a tag of the given name starting from index start.
On success returns true and sets *entry.
On failure returns false.
-
Searches for a tag of the given code starting from index start.
On success returns true and sets *entry.
On failure returns false.
-
Retrieve a tag specified by name or code as color.
On success sets the i_color *value to the color and returns true.
On failure returns false.
-
Retrieves a tag as a floating point value.
If the tag has a string value then that is parsed as a floating point number, otherwise the integer value of the tag is used.
On success sets *value and returns true.
On failure returns false.
-
Retrieve a tag specified by name or code as an integer.
On success sets the int *value to the integer and returns true.
On failure returns false.
-
Retrieves a tag by name or code as a string.
On success copies the string to value for a max of value_size and returns true.
On failure returns false.
value_size must be at least large enough for a string representation of an integer.
The copied value is always
NUL
terminated. -
Initialize a tags structure. Should not be used if the tags structure has been previously used.
This should be called tags member of an i_img object on creation (in i_img_*_new() functions).
To destroy the contents use i_tags_destroy()
-
i_tags_set(&img->tags, "i_comment", -1);
Sets the given tag to the string data
If size is -1 then the strlen(data) bytes are stored.
Even on failure, if an existing tag name exists, it will be removed.
-
Stores the given color as a tag with the given name and code.
-
Equivalent to i_tags_set_float2(tags, name, code, value, 30).
-
Sets the tag with the given name and code to the given floating point value.
Since tags are strings or ints, we convert the value to a string before storage at the precision specified by
places
. -
i_tags_setn(&img->tags, "i_xres", 204); i_tags_setn(&img->tags, "i_yres", 196);
Sets the given tag to the integer
idata
Even on failure, if an existing tag
name
exists, it will be removed.
Uncategorized functions
- i_addcolors_forward(i_img *im, const i_color *colors, int count)
- i_colorcount_forward(i_img *im)
- i_findcolor_forward(i_img *im, const i_color *color, i_palidx *entry)
- i_getcolors_forward(i_img *im, int i, i_color *color, int count)
- i_gsamp_bits_fb
-
Provides a fallback for the i_gsamp_bits() entry in the image virtual table.
- i_gsampf_fp()
-
count = i_gsampf_fp(im, left, right, y, samps, chans, chan_count);
Implements i_gsampf() for an image in terms of the image's implementation of i_gsamp().
- i_gslin_fallback()
-
Fallback implementation for i_gslin() that fetches samples with i_gsamp() and converts them to linear.
- i_gslinf_fallback()
-
Fallback implementation for i_gslinf() that fetches samples with i_gsampf() and converts them to linear.
- i_image_data_alloc_t
-
i_img_data() returns a pointer to this mostly opaque type.
This must be released with i_img_data_release().
- i_img_data()
-
i_img_data(im, layout, bits, flags, &ptr, &size, &extrachannels)
Returns raw bytes representing the image.
Typical use is something like:
// image data I can write to a file void *data; size_t size; i_image_alloc_t *alloc = i_img_data(img, idf_rgb, i_8_bits, idf_synthesize, &data, &size, NULL); if (alloc) { // write to some file ... i_img_data_release(alloc); } // image data I can modify to modify the image void *data; size_t size; i_image_alloc_t *alloc = i_img_data(img, idf_rgb, i_8_bits, idf_writable, &data, &size, NULL); if (alloc) { // modify the image data ... i_img_data_release(alloc); }
Note that even without
idf_synthesize
the data pointer should be treated as pointing at read only data, unlessidf_writable
is set inflags
.Parameters:
img
- the image to return image data forlayout
- the desired image layout. Note that the typical Imager layouts areidf_palette
throughidf_rgb_alpha
. The numeric values ofidf_gray
throughidf_rgb_alpha
correspond to the Imager channel counts, but it's possible for third-party images (of which none exist at this point) may have another layout.bits
- the sample size for the images. This can be any ofi_8_bits
,i_16_bits
ori_double_bits
. Other sample sizes may be added.flags
- a bit combination of the following:idf_writable
- modifying samples pointed at will modify the image. Without this flag the data should be treated as read only (and this may be enforced.)idf_synthesize
- if the native image data doesn't match the requested format, Imager will allocate memory and synthesize the layout requested. Some layouts are not supported for synthesis includingidf_palette
in any case andidf_gray
oridf_gray_alpha
from any RGB layout.idf_extras
- allows for the original image data to be returned, ie. for non-synthesizes or writable data even if the image has extra channels stored for pixel.
&data
- a pointer tovoid *
which is filled with a pointer to the image data.&size
- a pointer tosize_t
which is filled with the size of the image data in bytes. This is intended for validating the result.&extrachannels
- a pointer toint
which will be filled with the number of extra channels in the image. This pointer may beNULL
if theidf_extras
flag isn't set. Extra channels are currently not implemented and this will always be set to zero.
- i_img_data_fallback()
-
Fallback for i_img_data(). This is used by image implementations of i_img_data()/
i_f_data
to produce synthesized data.i_img_data_fallback(im, layout, bits, flags, pptr, psize, pextrachannels)
The intent this is used something like:
i_image_alloc_t *my_img_data(...) { if (layout, bits, extrachannels matches image layout) { ... populate *pptr, *size, *extrachannels ... increment image refcount ... return new i_image_alloc_t. } else { return i_img_data_fallback(im, layout, bits, flags, pptr, psize, pextrachannels); } }
and my_img_data goes into the image's virtual table.
- i_img_refcnt_inc()
-
Increment the reference count of the image.
Aborts the program if the reference count overflows.
This is unrelated to Perl
SV
reference counts. - i_maxcolors_forward(i_img *im)
- i_new_image_data_alloc_free()
-
Create an image data allocation object that releases the memory block supplied using myfree().
This is used to generate the "i_image_data_alloc_t" object returned by i_img_data() when data is synthesized.
- i_psamp_bits_fb
-
Provides a fallback for the i_psamp_bits() entry in the image virtual table.
- i_psampf_fp()
-
count = i_psampf_fp(im, left, right, y, samps, chans, chan_count);
Implements i_psampf() for an image in terms of the image's implementation of i_psamp().
- i_pslin_fallback()
-
Fallback implementation for i_pslin() that converts the supplied linear samples to gamma samples, and calls i_psamp().
- i_pslinf_fallback()
-
Fallback implementation for i_pslin() that converts the supplied linear samples to gamma samples, and calls i_psampf().
- i_setcolors_forward(i_img *im, int i, const i_color *color, int count)
- i_utf8_advance(char **p, size_t *len)
-
Retrieve a
UTF-8
character from the stream.Modifies *p and *len to indicate the consumed characters.
This doesn't support the extended
UTF-8
encoding used by later versions of Perl. Since this is typically used to implement text output by font drivers, the strings supplied shouldn't have such out of range characters.This doesn't check that the
UTF-8
character is using the shortest possible representation.Returns ~0UL on failure.
- im_aligned_alloc_low(
align
,size
) -
Low level function to allocate aligned memory.
This will use malloc() and returned unaligned memory if no aligned allocation function was found during configuration.
align
must be a power of two.size
may be rounded up to a multiple ofalign
.This may return NULL on failure.
- im_aligned_free(
p
) -
Free a block of memory allocated with im_aligned_alloc_low().
- im_context_slot_get(ctx, slot)
-
Retrieve the value previously stored in the given slot of the context object.
- im_context_slot_new(destructor)
-
Allocate a new context-local-storage slot.
desctructor
will be called when the context is destroyed if the corresponding slot is non-NULL. - im_context_slot_set(slot, value)
-
Set the value of a slot.
Returns true on success.
Aborts if the slot supplied is invalid.
If reallocation of slot storage fails, returns false.
- im_decode_exif
-
im_decode_exif(im, data_base, data_size);
The data from
data_base
fordata_size
bytes will be scanned for EXIF data.Any data found will be used to set tags in the supplied image.
The intent is that invalid EXIF data will simply fail to set tags, and write to the log. In no case should this code exit when supplied invalid data.
Returns true if an EXIF header was seen.
- im_errors(ctx)
-
i_errmsg *errors = im_errors(aIMCTX); i_errmsg *errors = i_errors();
Returns a pointer to the first element of an array of error messages, terminated by a NULL pointer. The highest level message is first.
Also callable as
i_errors()
. - im_get_context()
-
Retrieve the context object for the current thread.
Inside Imager itself this is just a function pointer, which the Imager.xs BOOT handler initializes for use within perl. If you're taking the Imager code and embedding it elsewhere you need to initialize the
im_get_context
pointer at some point. - im_img_new()
-
i_img *im = im_img_new(aIMCTX, &myvtbl, xsize, ysize, chans, extrachans, i_8_bits);
Allocate a new image object, as with im_img_alloc(), and populate common fields from the supplied parameters.
- im_io_get_max_mmap_size()
-
size_t size = im_io_get_max_mmap_size(aIMCTX); size_t size = i_io_get_max_mmap_size();
Fetch the maximum address space than can be mapped by i_io_mmap() for files.
- im_io_set_max_mmap_size()
-
int ok size = im_io_set_max_mmap_size(aIMCTX, new_size); int ok size = i_io_set_max_mmap_size(new_size);
Set the maximum address space than can be mapped by i_io_mmap() for files.
UNDOCUMENTED
The following API functions are undocumented so far, hopefully this will change:
i_img_check_entries
i_img_valid_chans_assert
i_new_image_data_alloc_def
im_align_size
im_aligned_alloc_fatal
im_aligned_alloc_simd_fatal
im_aligned_alloc_simd_null
im_fatal
im_lhead
im_lin_img_double_new_extra
im_loog
mm_log
AUTHOR
Tony Cook <tonyc@cpan.org>
SEE ALSO
Imager, Imager::API, Imager::ExtUtils, Imager::Inline