1 Do not edit this file, it is generated automatically by apidocs.perl
2 from Imager's source files.
4 Each function description has a comment listing the source file where
5 you can find the documentation.
9 Imager::APIRef - Imager's C API - reference.
14 color.rgba.r = 255; color.rgba.g = 0; color.rgba.b = 255;
20 black.rgba.r = black.rgba.g = black.rgba.b = black.rgba.a = 0;
25 i_arc(im, 50, 50, 20, 45, 135, &color);
26 i_arc_cfill(im, 50, 50, 35, 90, 135, fill);
27 i_arc_aa(im, 50, 50, 35, 90, 135, &color);
28 i_arc_aa_cfill(im, 50, 50, 35, 90, 135, fill);
29 i_circle_aa(im, 50, 50, 45, &color);
30 i_box(im, 0, 0, im->xsize-1, im->ysize-1, &color).
31 i_box_filled(im, 0, 0, im->xsize-1, im->ysize-1, &color);
32 i_box_cfill(im, 0, 0, im->xsize-1, im->ysize-1, fill);
33 i_flood_fill(im, 50, 50, &color);
34 i_flood_cfill(im, 50, 50, fill);
35 i_flood_fill_border(im, 50, 50, &color, &border);
36 i_flood_cfill_border(im, 50, 50, fill, border);
40 i_push_error(0, "Yep, it's broken");
41 i_push_error(errno, "Error writing");
42 i_push_errorf(errno, "Cannot open file %s: %d", filename, errno);
45 i_set_image_file_limits(500, 500, 1000000);
46 i_get_image_file_limits(&width, &height, &bytes)
47 i_i_int_check_image_file_limits(width, height, channels, sizeof(i_sample_t))
50 i_fill_t *fill = i_new_fill_solidf(&fcolor, combine);
51 i_fill_t *fill = i_new_fill_solid(&color, combine);
52 i_fill_t *fill = i_new_fill_hatch(&fg_color, &bg_color, combine, hatch, custom_hatch, dx, dy);
53 i_fill_t *fill = i_new_fill_hatchf(&fg_fcolor, &bg_fcolor, combine, hatch, custom_hatch, dx, dy);
54 i_fill_t *fill = i_new_fill_image(src_img, matrix, x_offset, y_offset, combine);
55 fill = i_new_fill_fount(0, 0, 100, 100, i_ft_linear, i_ft_linear,
56 i_fr_triangle, 0, i_fts_grid, 9, 1, segs);
61 # Image creation/destruction
62 i_img *img = i_img_8_new(width, height, channels);
63 i_img *img = i_sametype(src, width, height);
64 i_img *img = i_sametype_chans(src, width, height, channels);
65 i_img *img = i_img_pal_new(width, height, channels, max_palette_size)
66 i_img *img = i_img_double_new(width, height, channels);
67 i_img *img = i_img_16_new(width, height, channels);
70 # Image Implementation
73 // only channel 0 writeable
74 i_img_setmask(img, 0x01);
75 int mask = i_img_getmask(img);
76 int channels = i_img_getchannels(img);
77 i_img_dim width = i_img_get_width(im);
78 i_img_dim height = i_img_get_height(im);
87 i_tags_set(&img->tags, "i_comment", -1);
88 i_tags_setn(&img->tags, "i_xres", 204);
89 i_tags_setn(&img->tags, "i_yres", 196);
99 This is Imager's image type.
101 It contains the following members:
107 C<channels> - the number of channels in the image
111 C<xsize>, C<ysize> - the width and height of the image in pixels
115 C<bytes> - the number of bytes used to store the image data. Undefined
116 where virtual is non-zero.
120 C<ch_mask> - a mask of writable channels. eg. if this is 6 then only
121 channels 1 and 2 are writable. There may be bits set for which there
122 are no channels in the image.
126 C<bits> - the number of bits stored per sample. Should be one of
127 i_8_bits, i_16_bits, i_double_bits.
131 C<type> - either i_direct_type for direct color images, or i_palette_type
136 C<virtual> - if zero then this image is-self contained. If non-zero
137 then this image could be an interface to some other implementation.
141 C<idata> - the image data. This should not be directly accessed. A new
142 image implementation can use this to store its image data.
143 i_img_destroy() will myfree() this pointer if it's non-null.
147 C<tags> - a structure storing the image's tags. This should only be
148 accessed via the i_tags_*() functions.
152 C<ext_data> - a pointer for use internal to an image implementation.
153 This should be freed by the image's destroy handler.
157 C<im_data> - data internal to Imager. This is initialized by
162 i_f_ppix, i_f_ppixf, i_f_plin, i_f_plinf, i_f_gpix, i_f_gpixf,
163 i_f_glin, i_f_glinf, i_f_gsamp, i_f_gampf - implementations for each
164 of the required image functions. An image implementation should
165 initialize these between calling i_img_alloc() and i_img_init().
169 i_f_gpal, i_f_ppal, i_f_addcolors, i_f_getcolors, i_f_colorcount,
170 i_f_maxcolors, i_f_findcolor, i_f_setcolors - implementations for each
171 paletted image function.
175 i_f_destroy - custom image destruction function. This should be used
176 to release memory if necessary.
180 i_f_gsamp_bits - implements i_gsamp_bits() for this image.
184 i_f_psamp_bits - implements i_psamp_bits() for this image.
190 From: File imdatatypes.h
194 Type for 8-bit/sample color.
200 i_color is a union of:
206 gray - contains a single element gray_color, eg. C<c.gray.gray_color>
210 C<rgb> - contains three elements C<r>, C<g>, C<b>, eg. C<c.rgb.r>
214 C<rgba> - contains four elements C<r>, C<g>, C<b>, C<a>, eg. C<c.rgba.a>
218 C<cmyk> - contains four elements C<c>, C<m>, C<y>, C<k>,
219 eg. C<c.cmyk.y>. Note that Imager never uses CMYK colors except when
220 reading/writing files.
224 channels - an array of four channels, eg C<c.channels[2]>.
230 From: File imdatatypes.h
234 This is the double/sample color type.
236 Its layout exactly corresponds to i_color.
240 From: File imdatatypes.h
244 This is the "abstract" base type for Imager's fill types.
246 Unless you're implementing a new fill type you'll typically treat this
251 From: File imdatatypes.h
255 A signed integer type that represents an image dimension or ordinate.
257 May be larger than int on some platforms.
261 From: File imdatatypes.h
270 =item i_arc(im, x, y, rad, d1, d2, color)
273 Fills an arc centered at (x,y) with radius I<rad> covering the range
274 of angles in degrees from d1 to d2, with the color.
280 =item i_arc_aa(im, x, y, rad, d1, d2, color)
283 Anti-alias fills an arc centered at (x,y) with radius I<rad> covering
284 the range of angles in degrees from d1 to d2, with the color.
290 =item i_arc_aa_cfill(im, x, y, rad, d1, d2, fill)
293 Anti-alias fills an arc centered at (x,y) with radius I<rad> covering
294 the range of angles in degrees from d1 to d2, with the fill object.
300 =item i_arc_cfill(im, x, y, rad, d1, d2, fill)
303 Fills an arc centered at (x,y) with radius I<rad> covering the range
304 of angles in degrees from d1 to d2, with the fill object.
310 =item i_box(im, x1, y1, x2, y2, color)
313 Outlines the box from (x1,y1) to (x2,y2) inclusive with I<color>.
319 =item i_box_cfill(im, x1, y1, x2, y2, fill)
322 Fills the box from (x1,y1) to (x2,y2) inclusive with fill.
328 =item i_box_filled(im, x1, y1, x2, y2, color)
331 Fills the box from (x1,y1) to (x2,y2) inclusive with color.
337 =item i_circle_aa(im, x, y, rad, color)
340 Anti-alias fills a circle centered at (x,y) for radius I<rad> with
347 =item i_flood_cfill(C<im>, C<seedx>, C<seedy>, C<fill>)
350 Flood fills the 4-connected region starting from the point (C<seedx>,
351 C<seedy>) with C<fill>.
353 Returns false if (C<seedx>, C<seedy>) are outside the image.
359 =item i_flood_cfill_border(C<im>, C<seedx>, C<seedy>, C<fill>, C<border>)
362 Flood fills the 4-connected region starting from the point (C<seedx>,
363 C<seedy>) with C<fill>, the fill stops when it reaches pixels of color
366 Returns false if (C<seedx>, C<seedy>) are outside the image.
372 =item i_flood_fill(C<im>, C<seedx>, C<seedy>, C<color>)
375 Flood fills the 4-connected region starting from the point (C<seedx>,
376 C<seedy>) with I<color>.
378 Returns false if (C<seedx>, C<seedy>) are outside the image.
384 =item i_flood_fill_border(C<im>, C<seedx>, C<seedy>, C<color>, C<border>)
387 Flood fills the 4-connected region starting from the point (C<seedx>,
388 C<seedy>) with C<color>, fill stops when the fill reaches a pixels
389 with color C<border>.
391 Returns false if (C<seedx>, C<seedy>) are outside the image.
397 =item i_glin(im, l, r, y, colors)
400 Retrieves (r-l) pixels starting from (l,y) into I<colors>.
402 Returns the number of pixels retrieved.
408 =item i_glinf(im, l, r, y, colors)
411 Retrieves (r-l) pixels starting from (l,y) into I<colors> as floating
414 Returns the number of pixels retrieved.
420 =item i_gpal(im, left, right, y, indexes)
423 Reads palette indexes for the horizontal line (left, y) to (right-1,
426 Returns the number of indexes read.
428 Always returns 0 for direct color images.
434 =item i_gpix(im, C<x>, C<y>, C<color>)
437 Retrieves the C<color> of the pixel (x,y).
439 Returns 0 if the pixel was retrieved, or -1 if not.
445 =item i_gpixf(im, C<x>, C<y>, C<fcolor>)
448 Retrieves the color of the pixel (x,y) as a floating point color into
451 Returns 0 if the pixel was retrieved, or -1 if not.
457 =item i_gsamp(im, left, right, y, samples, channels, channel_count)
460 Reads sample values from C<im> for the horizontal line (left, y) to
461 (right-1,y) for the channels specified by C<channels>, an array of int
462 with C<channel_count> elements.
464 If channels is NULL then the first channels_count channels are retrieved for
467 Returns the number of samples read (which should be (right-left) *
474 =item i_gsampf(im, left, right, y, samples, channels, channel_count)
477 Reads floating point sample values from C<im> for the horizontal line
478 (left, y) to (right-1,y) for the channels specified by C<channels>, an
479 array of int with channel_count elements.
481 If C<channels> is NULL then the first C<channel_count> channels are
482 retrieved for each pixel.
484 Returns the number of samples read (which should be (C<right>-C<left>)
491 =item i_line(C<im>, C<x1>, C<y1>, C<x2>, C<y2>, C<color>, C<endp>)
494 =for stopwords Bresenham's
496 Draw a line to image using Bresenham's line drawing algorithm
498 im - image to draw to
499 x1 - starting x coordinate
500 y1 - starting x coordinate
501 x2 - starting x coordinate
502 y2 - starting x coordinate
503 color - color to write to image
504 endp - endpoint flag (boolean)
510 =item i_line_aa(C<im>, C<x1>, C<x2>, C<y1>, C<y2>, C<color>, C<endp>)
513 Anti-alias draws a line from (x1,y1) to (x2, y2) in color.
515 The point (x2, y2) is drawn only if C<endp> is set.
521 =item i_plin(im, l, r, y, colors)
524 Sets (r-l) pixels starting from (l,y) using (r-l) values from
527 Returns the number of pixels set.
533 =item i_plinf(im, C<left>, C<right>, C<fcolors>)
536 Sets (right-left) pixels starting from (left,y) using (right-left)
537 floating point colors from C<fcolors>.
539 Returns the number of pixels set.
545 =item i_ppal(im, left, right, y, indexes)
548 Writes palette indexes for the horizontal line (left, y) to (right-1,
551 Returns the number of indexes written.
553 Always returns 0 for direct color images.
559 =item i_ppix(im, x, y, color)
562 Sets the pixel at (x,y) to I<color>.
564 Returns 0 if the pixel was drawn, or -1 if not.
566 Does no alpha blending, just copies the channels from the supplied
573 =item i_ppixf(im, C<x>, C<y>, C<fcolor>)
576 Sets the pixel at (C<x>,C<y>) to the floating point color C<fcolor>.
578 Returns 0 if the pixel was drawn, or -1 if not.
580 Does no alpha blending, just copies the channels from the supplied
590 =head2 Error handling
594 =item i_clear_error()
596 Clears the error stack.
598 Called by any Imager function before doing any other processing.
604 =item i_push_error(int code, char const *msg)
606 Called by an Imager function to push an error message onto the stack.
608 No message is pushed if the stack is full (since this means someone
609 forgot to call i_clear_error(), or that a function that doesn't do
610 error handling is calling function that does.).
616 =item i_push_errorf(int code, char const *fmt, ...)
618 A version of i_push_error() that does printf() like formatting.
620 Does not support perl specific format codes.
626 =item i_push_errorvf(int C<code>, char const *C<fmt>, va_list C<ap>)
629 Intended for use by higher level functions, takes a varargs pointer
630 and a format to produce the finally pushed error message.
632 Does not support perl specific format codes.
645 =item i_get_image_file_limits(&width, &height, &bytes)
648 Retrieves the file limits set by i_set_image_file_limits().
654 =item i_int_check_image_file_limits(width, height, channels, sample_size)
657 Checks the size of a file in memory against the configured image file
660 This also range checks the values to those permitted by Imager and
661 checks for overflows in calculating the size.
663 Returns non-zero if the file is within limits.
665 This function is intended to be called by image file read functions.
671 =item i_set_image_file_limits(width, height, bytes)
674 Set limits on the sizes of images read by Imager.
676 Setting a limit to 0 means that limit is ignored.
678 Negative limits result in failure.
680 Returns non-zero on success.
693 =item i_new_fill_fount(C<xa>, C<ya>, C<xb>, C<yb>, C<type>, C<repeat>, C<combine>, C<super_sample>, C<ssample_param>, C<count>, C<segs>)
697 Creates a new general fill which fills with a fountain fill.
701 From: File filters.im
703 =item i_new_fill_hatch(C<fg>, C<bg>, C<combine>, C<hatch>, C<cust_hatch>, C<dx>, C<dy>)
706 Creates a new hatched fill with the C<fg> color used for the 1 bits in
707 the hatch and C<bg> for the 0 bits. If C<combine> is non-zero alpha
708 values will be combined.
710 If C<cust_hatch> is non-NULL it should be a pointer to 8 bytes of the
711 hash definition, with the high-bits to the left.
713 If C<cust_hatch> is NULL then one of the standard hatches is used.
715 (C<dx>, C<dy>) are an offset into the hatch which can be used to hatch
716 adjoining areas out of alignment, or to align the origin of a hatch
717 with the the side of a filled area.
723 =item i_new_fill_hatchf(C<fg>, C<bg>, C<combine>, C<hatch>, C<cust_hatch>, C<dx>, C<dy>)
726 Creates a new hatched fill with the C<fg> color used for the 1 bits in
727 the hatch and C<bg> for the 0 bits. If C<combine> is non-zero alpha
728 values will be combined.
730 If C<cust_hatch> is non-NULL it should be a pointer to 8 bytes of the
731 hash definition, with the high-bits to the left.
733 If C<cust_hatch> is NULL then one of the standard hatches is used.
735 (C<dx>, C<dy>) are an offset into the hatch which can be used to hatch
736 adjoining areas out of alignment, or to align the origin of a hatch
737 with the the side of a filled area.
743 =item i_new_fill_image(C<im>, C<matrix>, C<xoff>, C<yoff>, C<combine>)
746 Create an image based fill.
748 matrix is an array of 9 doubles representing a transformation matrix.
750 C<xoff> and C<yoff> are the offset into the image to start filling from.
756 =item i_new_fill_solid(color, combine)
759 Create a solid fill based on an 8-bit color.
761 If combine is non-zero then alpha values will be combined.
767 =item i_new_fill_solidf(color, combine)
770 Create a solid fill based on a float color.
772 If combine is non-zero then alpha values will be combined.
778 =item i_fill_destroy(fill)
780 Call to destroy any fill object.
796 Creates a new image that is a copy of the image C<source>.
798 Tags are not copied, only the image data.
806 =item i_copyto(C<dest>, C<src>, C<x1>, C<y1>, C<x2>, C<y2>, C<tx>, C<ty>)
809 Copies image data from the area (C<x1>,C<y1>)-[C<x2>,C<y2>] in the
810 source image to a rectangle the same size with it's top-left corner at
811 (C<tx>,C<ty>) in the destination image.
813 If C<x1> > C<x2> or C<y1> > C<y2> then the corresponding co-ordinates
820 =item i_copyto_trans(C<im>, C<src>, C<x1>, C<y1>, C<x2>, C<y2>, C<tx>, C<ty>, C<trans>)
823 (C<x1>,C<y1>) (C<x2>,C<y2>) specifies the region to copy (in the
824 source coordinates) (C<tx>,C<ty>) specifies the upper left corner for
825 the target image. pass NULL in C<trans> for non transparent i_colors.
831 =item i_img_info(im, info)
834 Return image information
837 info - pointer to array to return data
839 info is an array of 4 integers with the following values:
844 info[3] - channel mask
850 =item i_rubthru(C<im>, C<src>, C<tx>, C<ty>, C<src_minx>, C<src_miny>, C<src_maxx>, C<src_maxy>)
853 Takes the sub image C<src>[C<src_minx>, C<src_maxx>)[C<src_miny>, C<src_maxy>)> and
854 overlays it at (C<tx>,C<ty>) on the image object.
856 The alpha channel of each pixel in C<src> is used to control how much
857 the existing color in C<im> is replaced, if it is 255 then the color
858 is completely replaced, if it is 0 then the original color is left
863 From: File rubthru.im
868 =head2 Image creation/destruction
872 =item i_img_16_new(x, y, ch)
875 Create a new 16-bit/sample image.
877 Returns the image on success, or NULL on failure.
883 =item i_img_8_new(x, y, ch)
887 Creates a new image object I<x> pixels wide, and I<y> pixels high with
894 =item i_img_double_new(int x, int y, int ch)
896 Creates a new double per sample image.
900 From: File imgdouble.c
902 =item i_img_pal_new(C<x>, C<y>, C<channels>, C<maxpal>)
905 Creates a new paletted image of the supplied dimensions.
907 C<maxpal> is the maximum palette size and should normally be 256.
909 Returns a new image or NULL on failure.
915 =item i_sametype(C<im>, C<xsize>, C<ysize>)
918 Returns an image of the same type (sample size, channels, paletted/direct).
920 For paletted images the palette is copied from the source.
926 =item i_sametype_chans(C<im>, C<xsize>, C<ysize>, C<channels>)
929 Returns an image of the same type (sample size).
931 For paletted images the equivalent direct type is returned.
937 =item i_img_destroy(C<img>)
939 Destroy an image object
948 =head2 Image Implementation
954 Allocates a new i_img structure.
956 When implementing a new image type perform the following steps in your
957 image object creation function:
963 allocate the image with i_img_alloc().
967 initialize any function pointers or other data as needed, you can
968 overwrite the whole block if you need to.
972 initialize Imager's internal data by calling i_img_init() on the image
981 =item i_img_init(C<img>)
983 Imager internal initialization of images.
985 Currently this does very little, in the future it may be used to
986 support threads, or color profiles.
995 =head2 Image Information
999 =item i_img_color_channels(C<im>)
1002 The number of channels holding color information.
1006 From: File immacros.h
1008 =item i_img_get_height(C<im>)
1010 Returns the height in pixels of the image.
1016 =item i_img_get_width(C<im>)
1018 Returns the width in pixels of the image.
1024 =item i_img_getchannels(C<im>)
1026 Get the number of channels in C<im>.
1032 =item i_img_getmask(C<im>)
1034 Get the image channel mask for C<im>.
1040 =item i_img_has_alpha(C<im>)
1043 Return true if the image has an alpha channel.
1047 From: File immacros.h
1049 =item i_img_setmask(C<im>, C<ch_mask>)
1051 Set the image channel mask for C<im> to C<ch_mask>.
1053 The image channel mask gives some control over which channels can be
1054 written to in the image.
1063 =head2 Image quantization
1067 =item i_quant_makemap(C<quant>, C<imgs>, C<count>)
1070 Analyzes the C<count> images in C<imgs> according to the rules in
1071 C<quant> to build a color map (optimal or not depending on
1072 C<< quant->make_colors >>).
1078 =item i_quant_translate(C<quant>, C<img>)
1081 Quantize the image given the palette in C<quant>.
1083 On success returns a pointer to a memory block of C<< img->xsize *
1084 img->ysize >> C<i_palidx> entries.
1086 On failure returns NULL.
1088 You should call myfree() on the returned block when you're done with
1091 This function will fail if the supplied palette contains no colors.
1097 =item i_quant_transparent(C<quant>, C<data>, C<img>, C<trans_index>)
1100 Dither the alpha channel on C<img> into the palette indexes in
1101 C<data>. Pixels to be transparent are replaced with C<trans_pixel>.
1103 The method used depends on the tr_* members of C<quant>.
1116 =item i_lhead(file, line)
1118 This is an internal function called by the mm_log() macro.
1124 =item i_loog(level, format, ...)
1126 This is an internal function called by the mm_log() macro.
1132 =item mm_log((level, format, ...))
1134 This is the main entry point to logging. Note that the extra set of
1135 parentheses are required due to limitations in C89 macros.
1137 This will format a string with the current file and line number to the
1138 log file if logging is enabled.
1147 =head2 Paletted images
1151 =item i_addcolors(im, colors, count)
1154 Adds colors to the image's palette.
1156 On success returns the index of the lowest color added.
1158 On failure returns -1.
1160 Always fails for direct color images.
1166 =item i_colorcount(im)
1169 Returns the number of colors in the image's palette.
1171 Returns -1 for direct images.
1177 =item i_findcolor(im, color, &entry)
1180 Searches the images palette for the given color.
1182 On success sets *I<entry> to the index of the color, and returns true.
1184 On failure returns false.
1186 Always fails on direct color images.
1192 =item i_getcolors(im, index, colors, count)
1195 Retrieves I<count> colors starting from I<index> in the image's
1198 On success stores the colors into I<colors> and returns true.
1200 On failure returns false.
1202 Always fails for direct color images.
1204 Fails if there are less than I<index>+I<count> colors in the image's
1211 =item i_maxcolors(im)
1214 Returns the maximum number of colors the palette can hold for the
1217 Returns -1 for direct color images.
1223 =item i_setcolors(im, index, colors, count)
1226 Sets I<count> colors starting from I<index> in the image's palette.
1228 On success returns true.
1230 On failure returns false.
1232 The image must have at least I<index>+I<count> colors in it's palette
1233 for this to succeed.
1235 Always fails on direct color images.
1248 =item i_tags_delbycode(tags, code)
1251 Delete any tags with the given code.
1253 Returns the number of tags deleted.
1259 =item i_tags_delbyname(tags, name)
1262 Delete any tags with the given name.
1264 Returns the number of tags deleted.
1270 =item i_tags_delete(tags, index)
1273 Delete a tag by index.
1275 Returns true on success.
1281 =item i_tags_destroy(tags)
1284 Destroys the given tags structure. Called by i_img_destroy().
1290 =item i_tags_find(tags, name, start, &entry)
1293 Searches for a tag of the given I<name> starting from index I<start>.
1295 On success returns true and sets *I<entry>.
1297 On failure returns false.
1303 =item i_tags_findn(tags, code, start, &entry)
1306 Searches for a tag of the given I<code> starting from index I<start>.
1308 On success returns true and sets *I<entry>.
1310 On failure returns false.
1316 =item i_tags_get_color(tags, name, code, &value)
1319 Retrieve a tag specified by name or code as color.
1321 On success sets the i_color *I<value> to the color and returns true.
1323 On failure returns false.
1329 =item i_tags_get_float(tags, name, code, value)
1332 Retrieves a tag as a floating point value.
1334 If the tag has a string value then that is parsed as a floating point
1335 number, otherwise the integer value of the tag is used.
1337 On success sets *I<value> and returns true.
1339 On failure returns false.
1345 =item i_tags_get_int(tags, name, code, &value)
1348 Retrieve a tag specified by name or code as an integer.
1350 On success sets the int *I<value> to the integer and returns true.
1352 On failure returns false.
1358 =item i_tags_get_string(tags, name, code, value, value_size)
1361 Retrieves a tag by name or code as a string.
1363 On success copies the string to value for a max of value_size and
1366 On failure returns false.
1368 value_size must be at least large enough for a string representation
1371 The copied value is always C<NUL> terminated.
1377 =item i_tags_new(i_img_tags *tags)
1380 Initialize a tags structure. Should not be used if the tags structure
1381 has been previously used.
1383 This should be called tags member of an i_img object on creation (in
1384 i_img_*_new() functions).
1386 To destroy the contents use i_tags_destroy()
1392 =item i_tags_set(tags, name, data, size)
1394 Sets the given tag to the string I<data>
1396 If size is -1 then the strlen(I<data>) bytes are stored.
1398 Even on failure, if an existing tag I<name> exists, it will be
1405 =item i_tags_set_color(tags, name, code, &value)
1408 Stores the given color as a tag with the given name and code.
1414 =item i_tags_set_float(tags, name, code, value)
1417 Equivalent to i_tags_set_float2(tags, name, code, value, 30).
1423 =item i_tags_set_float2(tags, name, code, value, places)
1426 Sets the tag with the given name and code to the given floating point
1429 Since tags are strings or ints, we convert the value to a string before
1430 storage at the precision specified by C<places>.
1436 =item i_tags_setn(C<tags>, C<name>, C<idata>)
1438 Sets the given tag to the integer C<idata>
1440 Even on failure, if an existing tag C<name> exists, it will be
1453 Tony Cook <tony@imager.perl.org>
1457 Imager, Imager::ExtUtils, Imager::Inline