header

header — get, set and walk image headers

Stability Level

Stable, unless otherwise indicated

Functions

Types and Values

Object Hierarchy


Includes

#include <vips/vips.h>

Description

These functions let you get at image header data (including metadata) in a uniform way.

Use vips_image_get_typeof() to test for the existance and GType of a header field.

You can attach arbitrary metadata to images. Metadata is copied as images are processed, so all images which used this image as input, directly or indirectly, will have this same bit of metadata attached to them. Copying is implemented with reference-counted pointers, so it is efficient, even for large items of data. This does however mean that metadata items need to be immutable. Metadata is handy for things like ICC profiles or EXIF data.

Various convenience functions (eg. vips_image_set_int()) let you easily attach simple types like numbers, strings and memory blocks to images. Use vips_image_map() to loop over an image's fields, including all metadata.

Items of metadata are identified by strings. Some strings are reserved, for example the ICC profile for an image is known by convention as "icc-profile-data".

If you save an image in VIPS format, all metadata (with a restriction, see below) is automatically saved for you in a block of XML at the end of the file. When you load a VIPS image, the metadata is restored. You can use the vipsedit command-line tool to extract or replace this block of XML.

VIPS metadata is based on GValue. See the docs for that system if you want to do fancy stuff such as defining a new metadata type. VIPS defines a new GValue called vips_save_string, a variety of string, see vips_value_set_save_string(). If your GValue can be transformed to vips_save_string, it will be saved and loaded to and from VIPS files for you.

VIPS provides a couple of base classes which implement reference-counted areas of memory. If you base your metadata on one of these types, it can be copied between images efficiently.

Functions

vips_format_sizeof ()

guint64
vips_format_sizeof (VipsBandFormat format);

Parameters

format

format type

 

Returns

number of bytes for a band format, or -1 on error.


vips_image_get_width ()

int
vips_image_get_width (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the number of pixels across the image.


vips_image_get_height ()

int
vips_image_get_height (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the number of pixels down the image.


vips_image_get_bands ()

int
vips_image_get_bands (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the number of bands (channels) in the image.


vips_image_get_format ()

VipsBandFormat
vips_image_get_format (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the format of each band element.


vips_image_get_coding ()

VipsCoding
vips_image_get_coding (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the image coding


vips_image_get_interpretation ()

VipsInterpretation
vips_image_get_interpretation (const VipsImage *image);

Return the VipsInterpretation set in the image header. Use vips_image_guess_interpretation() if you want a sanity-checked value.

Parameters

image

image to get from

 

Returns

the VipsInterpretation from the image header.


vips_image_guess_interpretation ()

VipsInterpretation
vips_image_guess_interpretation (const VipsImage *image);

Return the VipsInterpretation for an image, guessing a sane value if the set value looks crazy.

Parameters

image

image to guess for

 

Returns

a sensible VipsInterpretation for the image.


vips_image_get_xres ()

double
vips_image_get_xres (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the horizontal image resolution in pixels per millimeter.


vips_image_get_yres ()

double
vips_image_get_yres (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the vertical image resolution in pixels per millimeter.


vips_image_get_xoffset ()

int
vips_image_get_xoffset (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the horizontal position of the image origin, in pixels.


vips_image_get_yoffset ()

int
vips_image_get_yoffset (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the vertical position of the image origin, in pixels.


vips_image_get_filename ()

const char *
vips_image_get_filename (const VipsImage *image);

Parameters

image

image to get from

 

Returns

the name of the file the image was loaded from.


vips_image_get_mode ()

const char *
vips_image_get_mode (const VipsImage *image);

Image modes are things like "t", meaning a memory buffer, and "p" meaning a delayed computation.

Parameters

image

image to get from

 

Returns

the image mode.


vips_image_get_scale ()

double
vips_image_get_scale (const VipsImage *image);

Matrix images can have an optional scale field for use by integer convolution.

Parameters

image

image to get from

 

Returns

the scale.


vips_image_get_offset ()

double
vips_image_get_offset (const VipsImage *image);

Matrix images can have an optional offset field for use by integer convolution.

Parameters

image

image to get from

 

Returns

the offset.


vips_image_get_data ()

const void *
vips_image_get_data (VipsImage *image);

Return a pointer to the image's pixel data, if possible. This can involve allocating large amounts of memory and performing a long computation. Image pixels are laid out in band-packed rows.

See also: vips_image_wio_input().

Parameters

image

image to get data for

 

Returns

a pointer to pixel data, if possible.

[transfer none]


vips_image_init_fields ()

void
vips_image_init_fields (VipsImage *image,
                        int xsize,
                        int ysize,
                        int bands,
                        VipsBandFormat format,
                        VipsCoding coding,
                        VipsInterpretation interpretation,
                        double xres,
                        double yres);

A convenience function to set the header fields after creating an image. Normally you copy the fields from your input images with vips_image_pipelinev() and then make any adjustments you need, but if you are creating an image from scratch, for example vips_black() or vips_jpegload(), you do need to set all the fields yourself.

See also: vips_image_pipelinev().

Parameters

image

image to init

 

xsize

image width

 

ysize

image height

 

bands

image bands

 

format

band format

 

coding

image coding

 

interpretation

image type

 

xres

horizontal resolution, pixels per millimetre

 

yres

vertical resolution, pixels per millimetre

 

vips_image_set ()

void
vips_image_set (VipsImage *image,
                const char *field,
                GValue *value);

Set a piece of metadata on image . Any old metadata with that name is destroyed. The GValue is copied into the image, so you need to unset the value when you're done with it.

For example, to set an integer on an image (though you would use the convenience function vips_image_set_int() in practice), you would do:

GValue value = { 0 };

g_value_init (&value, G_TYPE_INT);
g_value_set_int (&value, 42);
vips_image_set (image, field, &value);
g_value_unset (&value);

See also: vips_image_get().

Parameters

image

image to set the metadata on

 

field

the name to give the metadata

 

value

the GValue to copy into the image

 

vips_image_get ()

int
vips_image_get (const VipsImage *image,
                const char *field,
                GValue *value_copy);

Fill value_copy with a copy of the header field. value_copy must be zeroed but uninitialised.

This will return -1 and add a message to the error buffer if the field does not exist. Use vips_image_get_typeof() to test for the existence of a field first if you are not certain it will be there.

For example, to read a double from an image (though of course you would use vips_image_get_double() in practice):

GValue value = { 0 };
double d;

if (vips_image_get (image, field, &value))
  return -1;

if (G_VALUE_TYPE (&value) != G_TYPE_DOUBLE) {
  vips_error( "mydomain", 
    _("field \"%s\" is of type %s, not double"),
    field, 
    g_type_name (G_VALUE_TYPE (&value)));
  g_value_unset (&value);
  return -1;
}

d = g_value_get_double (&value);
g_value_unset (&value);

See also: vips_image_get_typeof(), vips_image_get_double().

Parameters

image

image to get the field from from

 

field

the name to give the metadata

 

value_copy

the GValue is copied into this.

[transfer full][out caller-allocates]

Returns

0 on success, -1 otherwise.

[skip]


vips_image_get_as_string ()

int
vips_image_get_as_string (const VipsImage *image,
                          const char *field,
                          char **out);

Gets out from im under the name field . This function will read any field, returning it as a printable string. You need to free the string with g_free() when you are done with it.

See also: vips_image_get(), vips_image_get_typeof().

Parameters

image

image to get the header field from

 

field

field name

 

out

return field value as string.

[transfer full]

Returns

0 on success, -1 otherwise.


vips_image_get_typeof ()

GType
vips_image_get_typeof (const VipsImage *image,
                       const char *field);

Read the GType for a header field. Returns zero if there is no field of that name.

See also: vips_image_get().

Parameters

image

image to test

 

field

the name to search for

 

Returns

the GType of the field, or zero if there is no field of that name.


vips_image_remove ()

gboolean
vips_image_remove (VipsImage *image,
                   const char *field);

Find and remove an item of metadata. Return FALSE if no metadata of that name was found.

See also: vips_image_set(), vips_image_get_typeof().

Parameters

image

image to test

 

field

the name to search for

 

Returns

TRUE if an item of metadata of that name was found and removed


VipsImageMapFn ()

void *
(*VipsImageMapFn) (VipsImage *image,
                   const char *field,
                   GValue *value,
                   void *a);

vips_image_map ()

void *
vips_image_map (VipsImage *image,
                VipsImageMapFn fn,
                void *a);

This function calls fn for every header field, including every item of metadata.

Like all _map functions, the user function should return NULL to continue iteration, or a non-NULL pointer to indicate early termination.

See also: vips_image_get_typeof(), vips_image_get().

Parameters

image

image to map over

 

fn

function to call for each header field.

[scope call]

a

user data for function

 

Returns

NULL on success, the failing pointer otherwise.

[transfer none]


vips_image_set_area ()

void
vips_image_set_area (VipsImage *image,
                     const char *field,
                     VipsCallbackFn free_fn,
                     void *data);

Attaches data as a metadata item on image under the name field . When VIPS no longer needs the metadata, it will be freed with free_fn .

See also: vips_image_get_double(), vips_image_set()

Parameters

image

image to attach the metadata to

 

field

metadata name

 

free_fn

free function for data .

[scope async]

data

pointer to area of memory

 

vips_image_get_area ()

int
vips_image_get_area (const VipsImage *image,
                     const char *field,
                     void **data);

Gets data from image under the name field . A convenience function over vips_image_get(). Use vips_image_get_typeof() to test for the existance of a piece of metadata.

See also: vips_image_set_area(), vips_image_get(), vips_image_get_typeof()

Parameters

image

image to get the metadata from

 

field

metadata name

 

data

return metadata value

 

Returns

0 on success, -1 otherwise.


vips_image_set_blob ()

void
vips_image_set_blob (VipsImage *image,
                     const char *field,
                     VipsCallbackFn free_fn,
                     void *data,
                     size_t length);

Attaches blob as a metadata item on image under the name field . A convenience function over vips_image_set() using an vips_blob.

See also: vips_image_get_blob(), vips_image_set().

Parameters

image

image to attach the metadata to

 

field

metadata name

 

free_fn

free function for data .

[scope async]

data

pointer to area of memory

 

length

length of memory area

 

vips_image_get_blob ()

int
vips_image_get_blob (const VipsImage *image,
                     const char *field,
                     void **data,
                     size_t *length);

Gets blob from image under the name field , optionally return its length in length . A convenience function over vips_image_get(). Use vips_image_get_typeof() to test for the existance of a piece of metadata.

See also: vips_image_get(), vips_image_get_typeof(), vips_blob_get(),

Parameters

image

image to get the metadata from

 

field

metadata name

 

data

pointer to area of memory

 

length

return the blob length here, optionally

 

Returns

0 on success, -1 otherwise.


vips_image_get_int ()

int
vips_image_get_int (const VipsImage *image,
                    const char *field,
                    int *out);

Gets out from im under the name field . This function searches for int-valued fields.

See also: vips_image_get(), vips_image_get_typeof()

Parameters

image

image to get the header field from

 

field

field name

 

out

return field value

 

Returns

0 on success, -1 otherwise.


vips_image_set_int ()

void
vips_image_set_int (VipsImage *image,
                    const char *field,
                    int i);

Attaches i as a metadata item on image under the name field . A convenience function over vips_image_set().

See also: vips_image_get_int(), vips_image_set()

Parameters

image

image to attach the metadata to

 

field

metadata name

 

i

metadata value

 

vips_image_get_double ()

int
vips_image_get_double (const VipsImage *image,
                       const char *field,
                       double *out);

Gets out from im under the name field . This function searches for double-valued fields.

See also: vips_image_get(), vips_image_get_typeof()

Parameters

image

image to get the header field from

 

field

field name

 

out

return field value

 

Returns

0 on success, -1 otherwise.


vips_image_set_double ()

void
vips_image_set_double (VipsImage *image,
                       const char *field,
                       double d);

Attaches d as a metadata item on image under the name field . A convenience function over vips_image_set().

See also: vips_image_get_double(), vips_image_set()

Parameters

image

image to attach the metadata to

 

field

metadata name

 

d

metadata value

 

vips_image_get_string ()

int
vips_image_get_string (const VipsImage *image,
                       const char *field,
                       const char **out);

Gets out from im under the name field . This function searches for string-valued fields.

Do not free out .

See also: vips_image_get(), vips_image_get_typeof()

Parameters

image

image to get the header field from

 

field

field name

 

out

return field value

 

Returns

0 on success, -1 otherwise.


vips_image_set_string ()

void
vips_image_set_string (VipsImage *image,
                       const char *field,
                       const char *str);

Attaches str as a metadata item on image under the name field . A convenience function over vips_image_set() using an vips_ref_string.

See also: vips_image_get_double(), vips_image_set(), vips_ref_string

Parameters

image

image to attach the metadata to

 

field

metadata name

 

str

metadata value

 

vips_image_history_printf ()

int
vips_image_history_printf (VipsImage *image,
                           const char *format,
                           ...);

Add a line to the image history. The format and arguments are expanded, the date and time is appended prefixed with a hash character, and the whole string is appended to the image history and terminated with a newline.

For example:

vips_image_history_printf (image, "vips invert %s %s", 
  in->filename, out->filename);

Might add the string

"vips invert /home/john/fred.v /home/john/jim.v # Fri Apr 3 23:30:35 2009\n"

VIPS operations don't add history lines for you because a single action at the application level might involve many VIPS operations. History must be recorded by the application.

Parameters

image

add history line to this image

 

format

printf() format string

 

...

arguments to format string

 

Returns

0 on success, -1 on error.


vips_image_history_args ()

int
vips_image_history_args (VipsImage *image,
                         const char *name,
                         int argc,
                         char *argv[]);

Formats the name/argv as a single string and calls vips_image_history_printf(). A convenience function for command-line prorams.

See also: vips_image_get_history().

Parameters

image

image to attach history line to

 

name

program name

 

argc

number of program arguments

 

argv

program arguments

 

Returns

0 on success, -1 on error.


vips_image_get_history ()

const char *
vips_image_get_history (VipsImage *image);

This function reads the image history as a C string. The string is owned by VIPS and must not be freed.

VIPS tracks the history of each image, that is, the sequence of operations that generated that image. Applications built on VIPS need to call vips_image_history_printf() for each action they perform, setting the command-line equivalent for the action.

See also: vips_image_history_printf().

Parameters

image

get history from here

 

Returns

The history of image as a C string. Do not free!.

[transfer none]

Types and Values

VIPS_META_EXIF_NAME

#define VIPS_META_EXIF_NAME "exif-data"

The name that JPEG read and write operations use for the image's EXIF data.


VIPS_META_XMP_NAME

#define VIPS_META_XMP_NAME "xmp-data"

The name that JPEG read and write operations use for the image's XMP data.


VIPS_META_IPCT_NAME

#define VIPS_META_IPCT_NAME "ipct-data"

The name that JPEG read and write operations use for the image's IPCT data.


VIPS_META_ICC_NAME

#define VIPS_META_ICC_NAME "icc-profile-data"

The name we use to attach an ICC profile. The file read and write operations for TIFF, JPEG, PNG and others use this item of metadata to attach and save ICC profiles. The profile is updated by the vips_icc_transform() operations.


VIPS_META_XML

#define VIPS_META_XML "xml-header"

The original XML that was used to code the metadata after reading a VIPS format file.


VIPS_META_RESOLUTION_UNIT

#define VIPS_META_RESOLUTION_UNIT "resolution-unit"

The JPEG and TIFF read and write operations use this to record the file's preferred unit for resolution.


VIPS_META_LOADER

#define VIPS_META_LOADER "vips-loader"

Record the name of the original loader here. Handy for hinting file formats and for debugging.

See Also

type