summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xsrc/H5IMimage.c781
-rwxr-xr-xsrc/H5IMimage.h204
-rwxr-xr-xsrc/H5IMpalette.c291
-rwxr-xr-xsrc/H5IMpalette.h56
4 files changed, 1332 insertions, 0 deletions
diff --git a/src/H5IMimage.c b/src/H5IMimage.c
new file mode 100755
index 0000000..1ebe844
--- /dev/null
+++ b/src/H5IMimage.c
@@ -0,0 +1,781 @@
+/****************************************************************************
+ * NCSA HDF *
+ * Scientific Data Technologies *
+ * National Center for Supercomputing Applications *
+ * University of Illinois at Urbana-Champaign *
+ * 605 E. Springfield, Champaign IL 61820 *
+ * *
+ * For conditions of distribution and use, see the accompanying *
+ * hdf/COPYING file. *
+ * *
+ ****************************************************************************/
+
+#include "H5IMimage.h"
+#include "H5Iprivate.h"
+#include "H5Pprivate.h"
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5IMmake_image
+ *
+ * Purpose:
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 01, 2001
+ *
+ * Comments:
+ * based on HDF5 Image and Palette Specification
+ * http://hdf.ncsa.uiuc.edu/HDF5/H5Image/ImageSpec.html
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+herr_t H5IMmake_image( hid_t loc_id,
+ const char *dset_name,
+ hsize_t width,
+ hsize_t height,
+ hid_t plist_id,
+ const void *buffer )
+{
+ int rank;
+ herr_t status;
+ hsize_t dims[3];
+ const H5IM_imageinfo_t *imageinfo;
+
+ /* First we get some information about the image */
+
+ /* Default 8bit image */
+
+ if ( plist_id == H5IM_8BIT )
+ {
+ imageinfo = &H5IM_create_dflt8bit;
+ rank = 2;
+ }
+
+ /* Default 24bit image */
+
+ else if ( plist_id == H5IM_24BIT )
+ {
+ imageinfo = &H5IM_create_dflt24bit;
+ rank = 3;
+ }
+
+ /* User defined image */
+
+ else
+ {
+
+ /* Check valid plist, get it */
+ if ( H5P_get_class(plist_id) != H5P_IMAGE ||
+ NULL == ( imageinfo = H5I_object(plist_id)))
+ {
+ return FAIL;
+ }
+
+
+ if ( strcmp( imageinfo->subclass, "IMAGE_GRAYSCALE") == 0 )
+ rank = 2;
+ else if ( strcmp( imageinfo->subclass, "IMAGE_BITMAP") == 0 )
+ rank = 2;
+ else if ( strcmp( imageinfo->subclass, "IMAGE_TRUECOLOR") == 0 )
+ rank = 3;
+ else if ( strcmp( imageinfo->subclass, "IMAGE_INDEXED") == 0 )
+ rank = 2;
+ else
+ return FAIL;
+
+ }
+
+ /* Initialize the image dimensions */
+ dims[0] = height;
+ dims[1] = width;
+
+ /* Number of color planes is defined as the third dimension */
+ dims[2] = imageinfo->color_planes;
+
+ /* Make the dataset */
+ status = H5Lmake_dataset( loc_id, dset_name, rank, dims, H5T_NATIVE_UCHAR, H5T_NATIVE_UCHAR, buffer );
+
+ /* Attach the CLASS attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, "CLASS", "IMAGE" );
+
+ /* Attach the VERSION attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, "IMAGE_VERSION", "1.2" );
+
+ /* Attach the IMAGE_SUBCLASS attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, "IMAGE_SUBCLASS", imageinfo->subclass );
+
+ /* Attach the IMAGE_COLORMODEL attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, "IMAGE_COLORMODEL", imageinfo->color_model );
+
+ /* Attach the IMAGE_INTERLACE attribute. This attributes is only for true color images */
+ status = H5Lattach_attribute( loc_id, dset_name, "IMAGE_INTERLACE", imageinfo->interlace );
+
+ /* Attach the IMAGE_COLORPLANES attribute. This attribute is only for true color images */
+ status = H5Lattach_attribute_numerical( loc_id, dset_name, "IMAGE_COLORPLANES", 1, H5T_NATIVE_INT, (void*)&imageinfo->color_planes );
+
+ /* Attach the IMAGE_WHITE_IS_ZERO attribute */
+ status = H5Lattach_attribute_numerical( loc_id, dset_name, "IMAGE_WHITE_IS_ZERO", 1, H5T_NATIVE_INT, (void*)&imageinfo->white_is_zero );
+
+ /* Attach the IMAGE_MINMAXRANGE attribute */
+ status = H5Lattach_attribute_numerical( loc_id, dset_name, "IMAGE_MINMAXRANGE", 2, H5T_NATIVE_INT, (void*)&imageinfo->minmax );
+
+ /* Attach the IMAGE_BACKGROUNDINDEX attribute */
+ status = H5Lattach_attribute_numerical( loc_id, dset_name, "IMAGE_BACKGROUNDINDEX", 1, H5T_NATIVE_INT, (void*)&imageinfo->bkindex );
+
+ /* Attach the IMAGE_TRANSPARENCY attribute */
+ status = H5Lattach_attribute_numerical( loc_id, dset_name, "IMAGE_TRANSPARENCY", 1, H5T_NATIVE_INT, (void*)&imageinfo->trindex );
+
+ /* Attach the IMAGE_ASPECTRATIO attribute */
+ status = H5Lattach_attribute_numerical( loc_id, dset_name, "IMAGE_ASPECTRATIO", 1, H5T_NATIVE_INT, (void*)&imageinfo->aspect_ratio );
+
+ /* Attach the IMAGE_GAMMACORRECTION attribute */
+ status = H5Lattach_attribute_numerical( loc_id, dset_name, "IMAGE_GAMMACORRECTION", 1, H5T_NATIVE_FLOAT, (void*)&imageinfo->gamma_correction );
+
+ return status;
+}
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5IMset_subclass
+ *
+ * Purpose:
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: June 8, 2001
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+H5IMset_subclass( hid_t plist_id, const char* str )
+{
+
+ H5IM_imageinfo_t *imageinfo = NULL;
+
+ /* Check valid plist, get it */
+ if ( H5P_get_class(plist_id) != H5P_IMAGE ||
+ NULL == ( imageinfo = H5I_object(plist_id)))
+ {
+ return FAIL;
+ }
+
+ /* Set the subclass */
+ strcpy( imageinfo->subclass, str );
+
+ /* Set the number of color planes for 24bit images to a default value of 3*/
+ if ( strcmp( str, "IMAGE_TRUECOLOR") == 0 )
+ imageinfo->color_planes = 3;
+
+ return 1;
+
+}
+
+/*-------------------------------------------------------------------------
+ * Function: H5IMset_interlace
+ *
+ * Purpose:
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: June 8, 2001
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+H5IMset_interlace( hid_t plist_id, const char* str )
+{
+
+ H5IM_imageinfo_t *imageinfo = NULL;
+
+ /* Check valid plist, get it */
+ if ( H5P_get_class(plist_id) != H5P_IMAGE ||
+ NULL == ( imageinfo = H5I_object(plist_id)))
+ {
+ return FAIL;
+ }
+
+ /* Set the interlace */
+ strcpy( imageinfo->interlace, str );
+
+ return 1;
+
+}
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5IMset_color_planes
+ *
+ * Purpose:
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: June 8, 2001
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+herr_t H5IMset_color_planes( hid_t plist_id, int n )
+{
+
+ H5IM_imageinfo_t *imageinfo = NULL;
+
+ /* Check valid plist, get it */
+ if ( H5P_get_class(plist_id) != H5P_IMAGE ||
+ NULL == ( imageinfo = H5I_object(plist_id)))
+ {
+ return FAIL;
+ }
+
+ /* Set the number of color planes */
+ imageinfo->color_planes = n;
+
+ return 1;
+
+}
+
+
+
+
+
+
+/******************************************** OLD **********************************/
+
+
+#if 0
+
+
+
+
+
+herr_t H5Lmake_image( hid_t loc_id,
+ const char *dset_name,
+ const hsize_t *dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *buffer,
+ H5L_imageinfo_t imageinfo )
+{
+
+ char *attr_name[] = {"CLASS","IMAGE_VERSION"};
+ char *attr_data[] = {"IMAGE","1.2"};
+ char attr_color[20];
+ char attr_subclass[20];
+ char attr_interlace[20];
+ herr_t status;
+ int rank;
+
+ /* First we find the type of image. Version 1.2 only supports indexed and true color images.
+ * Indexed images are stored as 2D datasets, true color images are stored as 3D datasets,
+ * with the third dimension defining the number of color planes in the image.
+ */
+
+ switch ( imageinfo.subclass )
+ {
+ case H5L_IMAGE_GRAYSCALE:
+ strcpy(attr_subclass,"IMAGE_GRAYSCALE");
+ return FAIL;
+ break;
+ case H5L_IMAGE_BITMAP:
+ strcpy(attr_subclass,"IMAGE_BITMAP");
+ return FAIL;
+ break;
+ case H5L_IMAGE_TRUECOLOR:
+ strcpy(attr_subclass,"IMAGE_TRUECOLOR");
+ rank = 3;
+ break;
+ case H5L_IMAGE_INDEXED:
+ strcpy(attr_subclass,"IMAGE_INDEXED");
+ rank = 2;
+ break;
+ default:
+ return FAIL;
+ };
+
+
+ /* Find the interlace mode */
+
+ switch ( imageinfo.interlace )
+ {
+ case H5L_INTERLACE_PIXEL:
+ strcpy(attr_interlace,"INTERLACE_PIXEL");
+ break;
+ case H5L_INTERLACE_PLANE:
+ strcpy(attr_interlace,"INTERLACE_PLANE");
+ break;
+ case H5L_INTERLACE_LINE:
+ strcpy(attr_interlace,"INTERLACE_LINE");
+ break;
+ };
+
+
+
+ /* Make the dataset */
+ status = H5Lmake_dataset( loc_id, dset_name, rank, dims, file_type_id, mem_type_id, buffer );
+
+ /* Then we attach the required attributes */
+
+ /* Attach the CLASS attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, attr_name[0], attr_data[0] );
+
+ /* Attach the VERSION attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, attr_name[1], attr_data[1] );
+
+ /* Attach the IMAGE_SUBCLASS attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, "IMAGE_SUBCLASS", attr_subclass );
+
+ /* Attach the INTERLACE_MODE attribute. This attribute is only for true color images*/
+ if ( rank == 3 )
+ status = H5Lattach_attribute( loc_id, dset_name, "INTERLACE_MODE", attr_interlace );
+
+
+ /* We now attach the optional attributes */
+
+
+ /* Image color model atrribute */
+
+ switch ( imageinfo.color_model )
+ {
+ case H5L_MODEL_RGB:
+ strcpy(attr_color,"RGB");
+ break;
+ case H5L_MODEL_YUV:
+ strcpy(attr_color,"YUV");
+ break;
+ case H5L_MODEL_CMY:
+ strcpy(attr_color,"CMY");
+ break;
+ case H5L_MODEL_CMYK:
+ strcpy(attr_color,"CMYK");
+ case H5L_MODEL_YCBCR:
+ strcpy(attr_color,"YCbCr");
+ break;
+ case H5L_MODEL_HSV:
+ strcpy(attr_color,"HSV");
+ break;
+ default:
+ return FAIL;
+ };
+
+ /* Attach the IMAGE_COLORMODEL attribute */
+ status = H5Lattach_attribute( loc_id, dset_name, "IMAGE_COLORMODEL", attr_color );
+
+ return status;
+}
+
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5Lmake_image_indexed
+ *
+ * Purpose:
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 01, 2001
+ *
+ * Comments:
+ *
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+
+herr_t H5Lmake_image_indexed( hid_t loc_id,
+ const char *dset_name,
+ const hsize_t *dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *buffer )
+{
+
+ H5L_imageinfo_t imageinfo;
+ herr_t status;
+
+ /* Initialize the image info for an indexed, RGB color model image */
+
+ imageinfo.subclass = H5L_IMAGE_INDEXED;
+ imageinfo.interlace = H5L_INTERLACE_PIXEL;
+ imageinfo.white_is_zero = -1;
+ imageinfo.minmax[0] = -1;
+ imageinfo.minmax[1] = -1;
+ imageinfo.bkindex = -1;
+ imageinfo.trindex = -1;
+ imageinfo.aspect_ratio = -1;
+ imageinfo.color_model = H5L_MODEL_RGB;
+ imageinfo.gamma_correction = -1;
+
+
+ /* Make the image dataset */
+ status = H5Lmake_image( loc_id, dset_name, dims, file_type_id, mem_type_id,
+ buffer, imageinfo );
+
+ return status;
+}
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5Lmake_image_truecolor
+ *
+ * Purpose:
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 01, 2001
+ *
+ * Comments:
+ *
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+
+herr_t H5Lmake_image_truecolor( hid_t loc_id,
+ const char *dset_name,
+ const hsize_t *dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *buffer )
+{
+
+ H5L_imageinfo_t imageinfo;
+ herr_t status;
+
+ /* Initialize the image info for a true color, RGB color model image */
+
+ imageinfo.subclass = H5L_IMAGE_TRUECOLOR;
+ imageinfo.interlace = H5L_INTERLACE_PIXEL;
+ imageinfo.white_is_zero = -1;
+ imageinfo.minmax[0] = -1;
+ imageinfo.minmax[1] = -1;
+ imageinfo.bkindex = -1;
+ imageinfo.trindex = -1;
+ imageinfo.aspect_ratio = -1;
+ imageinfo.color_model = H5L_MODEL_RGB;
+ imageinfo.gamma_correction = -1;
+
+
+ /* Make the image dataset */
+ status = H5Lmake_image( loc_id, dset_name, dims, file_type_id, mem_type_id,
+ buffer, imageinfo );
+
+ return status;
+}
+
+
+
+
+/*-------------------------------------------------------------------------
+ * Function: find_palette
+ *
+ * Purpose: operator function used by H5L_find_palette
+ *
+ * Return:
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 28, 2001
+ *
+ * Comments:
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+static herr_t find_palette( hid_t UNUSED loc_id, const char *name, void *op_data)
+{
+
+ /* Define a default zero value for return. This will cause the iterator to continue if
+ * the palette attribute is not found yet.
+ */
+
+ int ret = 0;
+
+ /* Define a positive value for return value if the attribute was found. This will
+ * cause the iterator to immediately return that positive value,
+ * indicating short-circuit success
+ */
+
+ if( HDstrcmp( name, "PALETTE" ) == 0 )
+ ret = 1;
+
+
+ return ret;
+}
+
+
+
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5L_find_palette
+ *
+ * Purpose: Find the atrribute "PALETTE" in the image dataset
+ *
+ * Return: Success: 1, Failure: 0
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 11, 2001
+ *
+ * Comments:
+ * The function uses H5Aiterate with the operator function find_palette
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+herr_t H5L_find_palette( hid_t loc_id )
+{
+
+ unsigned int attr_num; /* Starting attribute to look up */
+ herr_t ret;
+
+ attr_num = 0;
+ ret = H5Aiterate( loc_id, &attr_num, find_palette, 0 );
+
+ return ret;
+}
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5Lattach_palette
+ *
+ * Purpose: This function attaches a palette to an existing image dataset
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 01, 2001
+ *
+ * Comments:
+ * based on HDF5 Image and Palette Specification
+ * http://hdf.ncsa.uiuc.edu/HDF5/H5Image/ImageSpec.html
+ *
+ * An image (dataset) within an HDF5 file may optionally specify an array of
+ * palettes to be viewed with. The dataset will have an attribute
+ * which contains an array of object reference pointers which refer to palettes in the file.
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+
+herr_t H5Lattach_palette( hid_t loc_id,
+ const char *image_name,
+ const char *pal_name,
+ const hsize_t *pal_dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *pal_data,
+ H5L_colormodel_t color_model,
+ H5L_palette_t palette_t,
+ const char *rangeindex,
+ const void *minmax )
+
+{
+
+ char *attr_name[] = {"CLASS","PAL_COLORMODEL","PAL_TYPE","RANGE_INDEX",
+ "PAL_MINMAXNUMERIC","PAL_VERSION"};
+ hid_t image_id;
+ hid_t attr_type;
+ hid_t attr_id;
+ hid_t attr_space_id;
+ herr_t status;
+ hid_t attr_class;
+ hobj_ref_t ref; /* write a new reference */
+ hobj_ref_t *refbuf; /* buffer to read references */
+ hssize_t n_refs;
+ hsize_t dim_ref;
+ char attr_color[5];
+ char attr_paltype[11];
+ int ok_pal;
+
+ switch ( color_model )
+ {
+ case H5L_MODEL_RGB:
+ strcpy(attr_color,"RGB");
+ break;
+ case H5L_MODEL_YUV:
+ strcpy(attr_color,"YUV");
+ break;
+ case H5L_MODEL_CMY:
+ strcpy(attr_color,"CMY");
+ break;
+ case H5L_MODEL_CMYK:
+ strcpy(attr_color,"CMYK");
+ break;
+ case H5L_MODEL_YCBCR:
+ strcpy(attr_color,"YCbCr");
+ break;
+ case H5L_MODEL_HSV:
+ strcpy(attr_color,"HSV");
+ break;
+ default:
+ return FAIL;
+ };
+
+ switch ( palette_t )
+ {
+ case H5L_PAL_STANDARD:
+ strcpy(attr_paltype,"STANDARD8");
+ break;
+ case H5L_PAL_RANGEINDEX:
+ strcpy(attr_paltype,"RANGEINDEX");
+ break;
+ default:
+ return FAIL;
+ };
+
+
+ /* First we create the palette dataset and attach to it the required attributes
+ * that identify it as a palette
+ */
+
+ /* Make the palette dataset. The palette is created on the same local id. */
+ status = H5Lmake_dataset( loc_id, pal_name, 2, pal_dims, file_type_id, mem_type_id, pal_data );
+
+ /* Attach the attribute "CLASS" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, attr_name[0], "PALETTE" );
+
+ /* Attach the attribute "PAL_COLORMODEL" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, attr_name[1], attr_color );
+
+ /* Attach the attribute "PAL_TYPE" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, attr_name[2], attr_paltype );
+
+ /* Attach the attribute "PAL_VERSION" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, attr_name[5], "1.2" );
+
+ /* The image dataset may or not have the attribute "PALETTE"
+ * First we try to open to see if it is already there; if not, it is created.
+ * If it exists, the array of references is extended to hold the reference
+ * to the new palette
+ */
+
+ /* First wet the image id */
+ image_id = H5Dopen( loc_id, image_name );
+
+ /* Try to find the attribute "PALETTE" on the >>image<< dataset */
+ ok_pal = H5L_find_palette( image_id );
+
+ /* It does not exist. We create the attribute and one reference */
+ if ( ok_pal <= 0 )
+ {
+
+ attr_space_id = H5Screate( H5S_SCALAR );
+
+ /* Create the attribute type for the reference */
+ attr_type = H5Tcopy( H5T_STD_REF_OBJ );
+
+ /* Create the attribute "PALETTE" to be attached to the image*/
+ attr_id = H5Acreate( image_id, "PALETTE", attr_type, attr_space_id, H5P_DEFAULT );
+
+ /* Create a reference. The reference is created on the local id. */
+ status = H5Rcreate( &ref, loc_id, pal_name, H5R_OBJECT, -1 );
+
+ /* Write the attribute with the reference */
+ status = H5Awrite( attr_id, attr_type, &ref );
+
+ status = H5Sclose( attr_space_id );
+
+ }
+
+ /* The attribute already exists, open it */
+
+ else if ( ok_pal == 1 )
+
+ {
+
+ attr_id = H5Aopen_name( image_id, "PALETTE" );
+
+ attr_type = H5Aget_type( attr_id );
+
+ attr_class = H5Tget_class( attr_type );
+
+ /* Check if it is really a reference */
+
+ if ( attr_class == H5T_REFERENCE )
+ {
+
+ /* Get and save the old reference(s) */
+
+ attr_space_id = H5Aget_space( attr_id );
+
+ n_refs = H5Sget_simple_extent_npoints( attr_space_id );
+
+ dim_ref = n_refs + 1;
+
+ refbuf = malloc( sizeof(hobj_ref_t) * (int)dim_ref );
+
+ status = H5Aread( attr_id, attr_type, refbuf );
+
+ status = H5Sclose( attr_space_id );
+
+ /* The attribute must be deleted, in order to the new one can reflect the changes*/
+ status = H5Adelete( image_id, "PALETTE" );
+
+ /* Create a new reference for this palette. */
+ status = H5Rcreate( &ref, loc_id, pal_name, H5R_OBJECT, -1 );
+
+ refbuf[n_refs] = ref;
+
+ /* Create the data space for the new references */
+ attr_space_id = H5Screate_simple( 1, &dim_ref, NULL );
+
+ /* Create the attribute again with the changes of space */
+ attr_id = H5Acreate( image_id, "PALETTE", attr_type, attr_space_id, H5P_DEFAULT );
+
+ /* Write the attribute with the new references */
+ status = H5Awrite( attr_id, attr_type, refbuf );
+
+ status = H5Sclose( attr_space_id );
+
+ free( refbuf );
+
+ } /* H5T_REFERENCE */
+
+ status = H5Tclose( attr_type );
+
+ /* Close the attribute. */
+ status = H5Aclose( attr_id );
+
+ }
+
+ /* Close the image dataset. */
+ status = H5Dclose( image_id );
+
+ return status;
+}
+
+
+#endif
diff --git a/src/H5IMimage.h b/src/H5IMimage.h
new file mode 100755
index 0000000..cc5b0b1
--- /dev/null
+++ b/src/H5IMimage.h
@@ -0,0 +1,204 @@
+
+/****************************************************************************
+ * NCSA HDF *
+ * Scientific Data Technologies *
+ * National Center for Supercomputing Applications *
+ * University of Illinois at Urbana-Champaign *
+ * 605 E. Springfield, Champaign IL 61820 *
+ * *
+ * For conditions of distribution and use, see the accompanying *
+ * hdf/COPYING file. *
+ * *
+ ****************************************************************************/
+
+
+#ifndef _H5IMimage_H
+#define _H5IMimage_H
+
+
+#include "H5lite.h"
+
+
+/* HDF5 image information */
+typedef struct H5IM_imageinfo_t
+{
+ char subclass[20]; /* Image subclass */
+ char color_model[20]; /* Color model */
+ char interlace[20]; /* Interlace mode for 24 bit images */
+ int white_is_zero; /* For grayscale, bitmap images */
+ int minmax[2]; /* Minimum, maximum value of data */
+ int bkindex; /* Index of the background color */
+ int trindex; /* Index of the transparent color */
+ int aspect_ratio; /* Aspect ratio */
+ float gamma_correction; /* Gamma correction */
+ hsize_t color_planes; /* Number of color planes */
+} H5IM_imageinfo_t;
+
+
+
+
+/* Default Template identifier for 8bit images */
+#define H5IM_8BIT 0
+
+/* Default Template identifier for 24bit images */
+#define H5IM_24BIT 1
+
+
+/* Default struct H5L_imageinfo_t for 8bit images */
+static const H5IM_imageinfo_t H5IM_create_dflt8bit =
+{
+
+ "IMAGE_INDEXED", /* Image subclass */
+ "RGB", /* Color model */
+ "NOT_DEFINED", /* Interlace mode */
+ -1, /* white_is_zero */
+ {-1,-1}, /* Minimum, maximum value of data */
+ -1, /* Index of the background color */
+ -1, /* Index of the transparent color */
+ -1, /* Aspect ratio */
+ -1, /* Gamma correction */
+ 0 /* Number of color planes */
+};
+
+
+/* Default struct H5L_imageinfo_t for 24bit images */
+static const H5IM_imageinfo_t H5IM_create_dflt24bit =
+{
+
+ "IMAGE_TRUECOLOR", /* Image subclass */
+ "RGB", /* Color model */
+ "INTERLACE_PIXEL", /* Interlace mode */
+ -1, /* white_is_zero */
+ {-1,-1}, /* Minimum, maximum value of data */
+ -1, /* Index of the background color */
+ -1, /* Index of the transparent color */
+ -1, /* Aspect ratio */
+ -1, /* Gamma correction */
+ 3 /* Number of color planes */
+};
+
+
+
+herr_t H5IMmake_image( hid_t loc_id,
+ const char *dset_name,
+ hsize_t width,
+ hsize_t height,
+ hid_t plist_id,
+ const void *buffer );
+
+
+herr_t H5IMset_subclass ( hid_t plist_id, const char* str );
+herr_t H5IMset_interlace( hid_t plist_id, const char* str );
+herr_t H5IMset_color_planes( hid_t plist_id, int n );
+
+
+
+
+/*********************** OLD *****************************/
+
+
+#if 0
+
+#define H5L_NORANGEINDEX 0
+#define H5L_NOMINMAX 0
+
+
+
+/* HDF5 image subclass */
+typedef enum H5L_imagesc_t
+{
+ H5L_IMAGE_GRAYSCALE,
+ H5L_IMAGE_BITMAP,
+ H5L_IMAGE_TRUECOLOR,
+ H5L_IMAGE_INDEXED
+} H5L_imagesc_t;
+
+
+
+/* HDF5 image/palette color models */
+typedef enum H5L_colormodel_t
+{
+ H5L_MODEL_RGB = 0, /*RGB */
+ H5L_MODEL_YUV = 1, /*YUV */
+ H5L_MODEL_CMY = 2, /*CMY */
+ H5L_MODEL_CMYK = 3, /*CMYK */
+ H5L_MODEL_YCBCR = 4, /*YCbCr */
+ H5L_MODEL_HSV = 5, /*HSV */
+} H5L_colormodel_t;
+
+
+/* HDF5 image interlace mode */
+typedef enum H5L_interlace_t
+{
+ H5L_NOT_DEFINED = -1,
+ H5L_INTERLACE_PIXEL = 0,
+ H5L_INTERLACE_PLANE = 1,
+ H5L_INTERLACE_LINE = 2
+} H5L_interlace_t;
+
+
+
+/* HDF5 palette types */
+typedef enum H5L_palette_t
+{
+ H5L_PAL_STANDARD,
+ H5L_PAL_RANGEINDEX
+} H5L_palette_t;
+
+
+
+
+
+/* HDF5 image information */
+typedef struct H5L_imageinfo_t
+{
+ H5L_imagesc_t subclass; /* Image subclass */
+ H5L_interlace_t interlace; /* Interlace mode */
+ int white_is_zero; /* For grayscale, bitmap images */
+ int minmax[2]; /* Minimum, maximum value of data */
+ int bkindex; /* Index of the background color */
+ int trindex; /* Index of the transparent color */
+ int aspect_ratio; /* Aspect ratio */
+ H5L_colormodel_t color_model; /* Color model */
+ float gamma_correction;/* Gamma correction */
+} H5L_imageinfo_t;
+
+
+
+herr_t H5Lmake_image( hid_t loc_id,
+ const char *dset_name,
+ const hsize_t *dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *buffer,
+ H5L_imageinfo_t imageinfo );
+
+herr_t H5Lmake_image_indexed( hid_t loc_id,
+ const char *dset_name,
+ const hsize_t *dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *buffer );
+
+herr_t H5Lmake_image_truecolor( hid_t loc_id,
+ const char *dset_name,
+ const hsize_t *dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *buffer );
+
+herr_t H5Lattach_palette( hid_t loc_id,
+ const char *image_name,
+ const char *pal_name,
+ const hsize_t *pal_dims,
+ hid_t file_type_id,
+ hid_t mem_type_id,
+ const void *pal_data,
+ H5L_colormodel_t color_model,
+ H5L_palette_t palette_t,
+ const char *rangeindex,
+ const void *minmax );
+
+#endif
+
+#endif
diff --git a/src/H5IMpalette.c b/src/H5IMpalette.c
new file mode 100755
index 0000000..e2c96c1
--- /dev/null
+++ b/src/H5IMpalette.c
@@ -0,0 +1,291 @@
+/****************************************************************************
+ * NCSA HDF *
+ * Scientific Data Technologies *
+ * National Center for Supercomputing Applications *
+ * University of Illinois at Urbana-Champaign *
+ * 605 E. Springfield, Champaign IL 61820 *
+ * *
+ * For conditions of distribution and use, see the accompanying *
+ * hdf/COPYING file. *
+ * *
+ ****************************************************************************/
+
+#include "H5IMpalette.h"
+#include "H5Iprivate.h"
+#include "H5Pprivate.h"
+
+
+/*local operator function */
+static herr_t find_palette( hid_t UNUSED loc_id, const char *name, void *op_data);
+/*private function */
+herr_t H5IM_find_palette( hid_t loc_id );
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5IMattach_palette
+ *
+ * Purpose: This function attaches a palette to an existing image dataset
+ *
+ * Return: Success: 0, Failure: -1
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 01, 2001
+ *
+ * Comments:
+ * based on HDF5 Image and Palette Specification
+ * http://hdf.ncsa.uiuc.edu/HDF5/H5Image/ImageSpec.html
+ *
+ * An image (dataset) within an HDF5 file may optionally specify an array of
+ * palettes to be viewed with. The dataset will have an attribute
+ * which contains an array of object reference pointers which refer to palettes in the file.
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+
+herr_t H5IMattach_palette( hid_t loc_id,
+ const char *image_name,
+ const char *pal_name,
+ const hsize_t *pal_dims,
+ hid_t plist_id,
+ const void *pal_data )
+
+{
+
+ hid_t image_id;
+ hid_t attr_type;
+ hid_t attr_id;
+ hid_t attr_space_id;
+ herr_t status;
+ hid_t attr_class;
+ hobj_ref_t ref; /* write a new reference */
+ hobj_ref_t *refbuf; /* buffer to read references */
+ hssize_t n_refs;
+ hsize_t dim_ref;
+ int ok_pal;
+ const H5IM_paletteinfo_t *info;
+
+ /* First we get some information about the palette */
+
+ /* Default palette */
+
+ if ( plist_id == H5IM_STDPALETTE )
+ {
+ info = &H5IM_create_dfltpalette;
+ }
+
+ /* User defined palette */
+
+ else
+ {
+
+ /* Check valid plist, get it */
+ if ( H5P_get_class(plist_id) != H5P_PALETTE ||
+ NULL == ( info = H5I_object(plist_id)))
+ {
+ return FAIL;
+ }
+
+
+ }
+
+
+/* First we create the palette dataset and attach to it the required attributes
+ * that identify it as a palette
+ */
+
+ /* Make the palette dataset. The palette is created on the same local id. */
+ status = H5Lmake_dataset( loc_id, pal_name, 2, pal_dims, H5T_NATIVE_UCHAR, H5T_NATIVE_UCHAR, pal_data );
+
+ /* Attach the attribute "CLASS" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, "CLASS", "PALETTE" );
+
+ /* Attach the attribute "PAL_VERSION" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, "PAL_VERSION", "1.2" );
+
+ /* Attach the attribute "PAL_COLORMODEL" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, "PAL_COLORMODEL", info->color_model );
+
+ /* Attach the attribute "PAL_TYPE" to the >>palette<< dataset*/
+ status = H5Lattach_attribute( loc_id, pal_name, "PAL_TYPE", info->type );
+
+ /* Attach the PAL_MINMAXNUMERIC attribute */
+ status = H5Lattach_attribute_numerical( loc_id, pal_name, "PAL_MINMAXNUMERIC", 2, H5T_NATIVE_INT, (void*)&info->minmax );
+
+ /* The image dataset may or not have the attribute "PALETTE"
+ * First we try to open to see if it is already there; if not, it is created.
+ * If it exists, the array of references is extended to hold the reference
+ * to the new palette
+ */
+
+ /* First wet the image id */
+ image_id = H5Dopen( loc_id, image_name );
+
+ /* Try to find the attribute "PALETTE" on the >>image<< dataset */
+ ok_pal = H5IM_find_palette( image_id );
+
+ /* It does not exist. We create the attribute and one reference */
+ if ( ok_pal <= 0 )
+ {
+
+ attr_space_id = H5Screate( H5S_SCALAR );
+
+ /* Create the attribute type for the reference */
+ attr_type = H5Tcopy( H5T_STD_REF_OBJ );
+
+ /* Create the attribute "PALETTE" to be attached to the image*/
+ attr_id = H5Acreate( image_id, "PALETTE", attr_type, attr_space_id, H5P_DEFAULT );
+
+ /* Create a reference. The reference is created on the local id. */
+ status = H5Rcreate( &ref, loc_id, pal_name, H5R_OBJECT, -1 );
+
+ /* Write the attribute with the reference */
+ status = H5Awrite( attr_id, attr_type, &ref );
+
+ status = H5Sclose( attr_space_id );
+
+ }
+
+ /* The attribute already exists, open it */
+
+ else if ( ok_pal == 1 )
+
+ {
+
+ attr_id = H5Aopen_name( image_id, "PALETTE" );
+
+ attr_type = H5Aget_type( attr_id );
+
+ attr_class = H5Tget_class( attr_type );
+
+ /* Check if it is really a reference */
+
+ if ( attr_class == H5T_REFERENCE )
+ {
+
+ /* Get and save the old reference(s) */
+
+ attr_space_id = H5Aget_space( attr_id );
+
+ n_refs = H5Sget_simple_extent_npoints( attr_space_id );
+
+ dim_ref = n_refs + 1;
+
+ refbuf = malloc( sizeof(hobj_ref_t) * (int)dim_ref );
+
+ status = H5Aread( attr_id, attr_type, refbuf );
+
+ status = H5Sclose( attr_space_id );
+
+ /* The attribute must be deleted, in order to the new one can reflect the changes*/
+ status = H5Adelete( image_id, "PALETTE" );
+
+ /* Create a new reference for this palette. */
+ status = H5Rcreate( &ref, loc_id, pal_name, H5R_OBJECT, -1 );
+
+ refbuf[n_refs] = ref;
+
+ /* Create the data space for the new references */
+ attr_space_id = H5Screate_simple( 1, &dim_ref, NULL );
+
+ /* Create the attribute again with the changes of space */
+ attr_id = H5Acreate( image_id, "PALETTE", attr_type, attr_space_id, H5P_DEFAULT );
+
+ /* Write the attribute with the new references */
+ status = H5Awrite( attr_id, attr_type, refbuf );
+
+ status = H5Sclose( attr_space_id );
+
+ free( refbuf );
+
+ } /* H5T_REFERENCE */
+
+ status = H5Tclose( attr_type );
+
+ /* Close the attribute. */
+ status = H5Aclose( attr_id );
+
+ }
+
+ /* Close the image dataset. */
+ status = H5Dclose( image_id );
+
+ return status;
+}
+
+
+
+
+/*-------------------------------------------------------------------------
+ * Function: find_palette
+ *
+ * Purpose: operator function used by H5L_find_palette
+ *
+ * Return:
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 28, 2001
+ *
+ * Comments:
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+static herr_t find_palette( hid_t UNUSED loc_id, const char *name, void *op_data)
+{
+
+ /* Define a default zero value for return. This will cause the iterator to continue if
+ * the palette attribute is not found yet.
+ */
+
+ int ret = 0;
+
+ /* Define a positive value for return value if the attribute was found. This will
+ * cause the iterator to immediately return that positive value,
+ * indicating short-circuit success
+ */
+
+ if( HDstrcmp( name, "PALETTE" ) == 0 )
+ ret = 1;
+
+
+ return ret;
+}
+
+
+/*-------------------------------------------------------------------------
+ * Function: H5IM_find_palette
+ *
+ * Purpose: Find the atrribute "PALETTE" in the image dataset
+ *
+ * Return: Success: 1, Failure: 0
+ *
+ * Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
+ *
+ * Date: May 11, 2001
+ *
+ * Comments:
+ * The function uses H5Aiterate with the operator function find_palette
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+
+herr_t H5IM_find_palette( hid_t loc_id )
+{
+
+ unsigned int attr_num; /* Starting attribute to look up */
+ herr_t ret;
+
+ attr_num = 0;
+ ret = H5Aiterate( loc_id, &attr_num, find_palette, 0 );
+
+ return ret;
+}
diff --git a/src/H5IMpalette.h b/src/H5IMpalette.h
new file mode 100755
index 0000000..487c67f
--- /dev/null
+++ b/src/H5IMpalette.h
@@ -0,0 +1,56 @@
+
+/****************************************************************************
+ * NCSA HDF *
+ * Scientific Data Technologies *
+ * National Center for Supercomputing Applications *
+ * University of Illinois at Urbana-Champaign *
+ * 605 E. Springfield, Champaign IL 61820 *
+ * *
+ * For conditions of distribution and use, see the accompanying *
+ * hdf/COPYING file. *
+ * *
+ ****************************************************************************/
+
+
+#ifndef _H5IMpalette_H
+#define _H5IMpalette_H
+
+
+#include "H5lite.h"
+
+
+
+/* HDF5 palette information */
+typedef struct H5IM_paletteinfo_t
+{
+ char color_model[20]; /* Color model, PAL_COLORMODEL */
+ char type[20]; /* Type, PAL_TYPE */
+ int minmax[2]; /* Minimum, maximum value of data, PAL_MINMAXNUMERIC*/
+} H5IM_paletteinfo_t;
+
+
+
+/* Default Template identifier for palletes */
+#define H5IM_STDPALETTE 0
+
+/* Default struct H5L_imageinfo_t for 8bit images */
+static const H5IM_paletteinfo_t H5IM_create_dfltpalette =
+{
+
+ "RGB", /* Color model, PAL_COLORMODEL */
+ "STANDARD8", /* Type, PAL_TYPE */
+ {-1,-1}, /* Minimum, maximum value of data, PAL_MINMAXNUMERIC */
+};
+
+
+
+herr_t H5IMattach_palette( hid_t loc_id,
+ const char *image_name,
+ const char *pal_name,
+ const hsize_t *pal_dims,
+ hid_t plist_id,
+ const void *pal_data );
+
+
+
+#endif