reduced number of image extensions checked by doing more intelligent path examination...
[divverent/darkplaces.git] / image.h
1
2 #ifndef IMAGE_H
3 #define IMAGE_H
4
5
6 extern int image_width, image_height;
7
8
9 // swizzle components (even converting number of components) and flip images
10 // (warning: input must be different than output due to non-linear read/write)
11 // (tip: component indices can contain values | 0x80000000 to tell it to
12 // store them directly into output, so 255 | 0x80000000 would write 255)
13 void Image_CopyMux(unsigned char *outpixels, const unsigned char *inpixels, int inputwidth, int inputheight, qboolean inputflipx, qboolean inputflipy, qboolean inputflipdiagonal, int numoutputcomponents, int numinputcomponents, int *outputinputcomponentindices);
14
15 // applies gamma correction to RGB pixels, in can be the same as out
16 void Image_GammaRemapRGB(const unsigned char *in, unsigned char *out, int pixels, const unsigned char *gammar, const unsigned char *gammag, const unsigned char *gammab);
17
18 // converts 8bit image data to RGBA, in can not be the same as out
19 void Image_Copy8bitRGBA(const unsigned char *in, unsigned char *out, int pixels, const unsigned int *pal);
20
21 unsigned char *LoadTGA (const unsigned char *f, int filesize, int matchwidth, int matchheight);
22
23 // loads a texture, as pixel data
24 unsigned char *loadimagepixels (const char *filename, qboolean complain, int matchwidth, int matchheight);
25
26 // loads a texture, as a texture
27 rtexture_t *loadtextureimage (rtexturepool_t *pool, const char *filename, int matchwidth, int matchheight, qboolean complain, int flags);
28
29 // writes a RGB TGA that is already upside down (which TGA wants)
30 qboolean Image_WriteTGARGB_preflipped (const char *filename, int width, int height, const unsigned char *data, unsigned char *buffer);
31
32 // writes a RGBA TGA
33 void Image_WriteTGARGBA (const char *filename, int width, int height, const unsigned char *data);
34
35 // resizes the image (in can not be the same as out)
36 void Image_Resample (const void *indata, int inwidth, int inheight, int indepth, void *outdata, int outwidth, int outheight, int outdepth, int bytesperpixel, int quality);
37
38 // scales the image down by a power of 2 (in can be the same as out)
39 void Image_MipReduce(const unsigned char *in, unsigned char *out, int *width, int *height, int *depth, int destwidth, int destheight, int destdepth, int bytesperpixel);
40
41 // only used by menuplyr coloring
42 unsigned char *LoadLMP (const unsigned char *f, int filesize, int matchwidth, int matchheight, qboolean loadAs8Bit);
43
44 void Image_HeightmapToNormalmap(const unsigned char *inpixels, unsigned char *outpixels, int width, int height, int clamp, float bumpscale);
45
46 typedef struct imageskin_s
47 {
48         unsigned char *basepixels;int basepixels_width;int basepixels_height;
49         unsigned char *nmappixels;int nmappixels_width;int nmappixels_height;
50         unsigned char *glowpixels;int glowpixels_width;int glowpixels_height;
51         unsigned char *glosspixels;int glosspixels_width;int glosspixels_height;
52         unsigned char *pantspixels;int pantspixels_width;int pantspixels_height;
53         unsigned char *shirtpixels;int shirtpixels_width;int shirtpixels_height;
54         unsigned char *maskpixels;int maskpixels_width;int maskpixels_height;
55 }
56 imageskin_t;
57
58 int image_loadskin(imageskin_t *s, const char *name);
59 void image_freeskin(imageskin_t *s);
60
61 #endif
62