/* Copyright (C) 2001-2023 Artifex Software, Inc. All Rights Reserved. This software is provided AS-IS with no warranty, either express or implied. This software is distributed under license and may not be copied, modified or distributed except as expressly authorized under the terms of the license contained in the file LICENSE in this distribution. Refer to licensing information at http://www.artifex.com or contact Artifex Software, Inc., 39 Mesa Street, Suite 108A, San Francisco, CA 94129, USA, for further information. */ /* ImageType 4 image parameter definition */ #ifndef gsiparm4_INCLUDED # define gsiparm4_INCLUDED #include "gsiparam.h" /* * See Section 4.3 of the Adobe PostScript Version 3010 Supplement * for a definition of ImageType 4 images. */ typedef struct gs_image4_s { gs_pixel_image_common; /* * If MaskColor_is_range is false, the first N elements of * MaskColor are sample values; if MaskColor_is_range is true, * the first 2*N elements are ranges of sample values. * * Currently, the largest sample values supported by the library are 12 * bits, but eventually we want to support DevicePixel images with * samples up to 32 bits as well. */ bool MaskColor_is_range; uint MaskColor[GS_IMAGE_MAX_COMPONENTS * 2]; /* * Define the parent image type that gave rise to this. * Used to avoid the use of mixed halftoning methods * between images and their masks, which * can cause misalignment issues in pixel replications. */ gs_image_parent_t image_parent_type; } gs_image4_t; #define private_st_gs_image4() /* in gximage4.c */\ extern_st(st_gs_pixel_image);\ gs_private_st_suffix_add0(st_gs_image4, gs_image4_t, "gs_image4_t",\ image4_enum_ptrs, image4_reloc_ptrs, st_gs_pixel_image) /* * Initialize an ImageType 4 image. Defaults: * MaskColor_is_range = false */ void gs_image4_t_init(gs_image4_t * pim, gs_color_space * color_space); #endif /* gsiparm4_INCLUDED */