1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184
|
#ifndef __IMAGE_H__
#define __IMAGE_H__
/* +-------------------------------------------------------------------+ */
/* | Copyright (C) 1993, David Koblas (koblas@netcom.com) | */
/* | Copyright 1995, 1996 Torsten Martinsen (bullestock@dk-online.dk) | */
/* | | */
/* | Permission to use, copy, modify, and to distribute this software | */
/* | and its documentation for any purpose is hereby granted without | */
/* | fee, provided that the above copyright notice appear in all | */
/* | copies and that both that copyright notice and this permission | */
/* | notice appear in supporting documentation. There is no | */
/* | representations about the suitability of this software for | */
/* | any purpose. this software is provided "as is" without express | */
/* | or implied warranty. | */
/* | | */
/* +-------------------------------------------------------------------+ */
/* $Id: image.h,v 1.17 2005/03/20 20:15:32 demailly Exp $ */
typedef struct {
int refCount; /* reference count */
/*
** Special notes:
** if the image isBW then there will be a two entry
** colormap BLACK == 0, WHITE == 1
** if the image isGrey, then the colormap is 256 entries
** BLACK == 0 .. WHITE == 255
*/
int isGrey, isBW; /* simple indicator flags GreyScale, Black & White */
/*
** bytes per pixel (3 for RGB, 2 for 0..256+ cmap, 1 for 0..256 cmap)
*/
int scale;
/*
** Colormap entries
** rgb rgb rgb [1..size]
*/
int cmapPacked; /* Boolean, is the colormap packed
down to just the used colors */
int cmapSize; /* number of colors in colormap == 0 if no colormap */
unsigned char *cmapData;
/*
** Image data
** either rgb rgb rgb
** or idx idx idx
**
** if image has colormap, and the size > 256, then
** data is pointers to unsigned shorts.
*/
int width, height; /* width, height of image */
unsigned char *data;
unsigned char *alpha;
/*
** These values are here because the XPM calls are TOO dependant
** on X Windows. They are not, and should not, be used by anything
** else.
*/
unsigned long sourcePixmap;
unsigned long sourceColormap;
unsigned long sourceMask;
} Image;
#if defined(_XLIB_H_) || defined(_X11_XLIB_H_)
/* Used to transfer information to routines in iprocess.c */
struct imageprocessinfo {
int oilArea;
int noiseDelta;
int spreadDistance;
int pixelizeXSize;
int pixelizeYSize;
int despeckleMask;
int smoothMaskSize;
int tilt;
int solarizeThreshold;
int contrastW;
int contrastB;
int redshift;
int greenshift;
int blueshift;
int quantizeColors;
double rescale_x;
double rescale_y;
int interpolate;
int tiltX1;
int tiltY1;
int tiltX2;
int tiltY2;
double linearA;
double linearB;
double linearC;
double linearD;
XColor *background;
};
#endif
#define ImageAlphaPixel(image, x, y) ((image)->alpha+((x)+(y)*(image)->width))
#define ImagePixel(image, x, y) \
(((image)->cmapSize == 0) \
? &((image)->data[((y) * (image)->width + (x)) * 3]) \
: (((image)->cmapSize > 256) \
? &((image)->cmapData[((unsigned short *)(image)->data) \
[(y) * (image)->width + (x)] * 3]) \
: &((image)->cmapData[(image)->data[(y)*(image)->width+(x)] * 3])))
#define ImageSetCmap(image, index, r, g, b) do { \
image->cmapData[(index) * 3 + 0] = r; \
image->cmapData[(index) * 3 + 1] = g; \
image->cmapData[(index) * 3 + 2] = b; \
} while (0)
/* image.c */
Image *ImageNew(int width, int height);
Image *ImageNewCmap(int width, int height, int size);
Image *ImageNewBW(int width, int height);
Image *ImageNewGrey(int width, int height);
Image *ImageToRGB(Image * image);
void ImageMakeMask(Image * image);
void ImageDelete(Image * image);
void ImageCopy(Image * image, Image * output);
int ImageToMemory(Image * image);
#ifdef _XtIntrinsic_h
Image *PixmapToImage(Widget w, Pixmap pix, Colormap cmap);
void PixmapToImageMask(Widget w, Image * image, Pixmap mask);
Image *ClipboardGetImage(int num);
Boolean ImageToPixmap(Image * image, Widget w, Pixmap * pix,
Colormap * cmap);
void get_color_components(Pixel p, unsigned char *c);
Pixel get_pixel_from_colors(unsigned char *c);
Pixmap MaskDataToPixmap(Widget w, int width, int height,
char *data, XRectangle * rect);
Pixmap ImageMaskToPixmap(Widget w, Image * image);
Pixmap AlphaToPixmap(Widget w, int width, int height,
char *data, XRectangle * rect);
Boolean ImageToPixmapCmap(Image * image, Widget w, Pixmap * pix,
Colormap cmap);
void ImageToCanvas(Image * input, Pixmap mask);
void ImageToRegion(Image * input, XRectangle rectangle, Pixmap mask);
#endif
/* imageComp.c */
Image *ImageCompress(Image * input, int ncolors, int noforce);
/* iprocess.c */
int RegionX();
int RegionY();
int RegionWidth();
int RegionHeight();
Image * CanvasToImage();
Image *ImageSmooth(Image * input);
Image *ImageSharpen(Image * input);
Image *ImageEdge(Image * input);
Image *ImageEmboss(Image * input);
Image *ImageInvert(Image * input);
Image *ImageOilPaint(Image * input);
Image *ImageAddNoise(Image * input);
Image *ImageSpread(Image * input);
Image *ImageBlend(Image * input);
Image *ImagePixelize(Image * input);
Image *ImageDespeckle(Image * input);
Image *ImageNormContrast(Image * input);
Image *ImageHistogram(Image * input);
Image *ImageSolarize(Image * input);
Image *ImageGrey(Image * input);
Image *ImageBWMask(Image * input);
Image *ImageModifyRGB(Image * input);
Image *ImageQuantize(Image * input);
Image *ImageUserDefined(Image * input);
Image *ImageTilt(Image * input);
Image *ImageDirectionalFilter(Image * input);
Image *ImageFromFile(char *file);
/* texture.c */
Image *draw_plasma(int w, int h);
Image *draw_landscape(int w, int h, int clouds);
#endif /* __IMAGE_H__ */
|