123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446 |
- #include "r_local.h"
- image_t *draw_chars;
- image_t *Draw_FindPic (char *name)
- {
- image_t *image;
- char fullname[MAX_QPATH];
- if (name[0] != '/' && name[0] != '\\')
- {
- Com_sprintf (fullname, sizeof(fullname), "pics/%s.pcx", name);
- image = R_FindImage (fullname, it_pic);
- }
- else
- image = R_FindImage (name+1, it_pic);
- return image;
- }
- void Draw_InitLocal (void)
- {
- draw_chars = Draw_FindPic ("conchars");
- }
- void Draw_Char (int x, int y, int num)
- {
- byte *dest;
- byte *source;
- int drawline;
- int row, col;
- num &= 255;
- if (num == 32 || num == 32+128)
- return;
- if (y <= -8)
- return;
- if ( ( y + 8 ) > vid.height )
- return;
- #ifdef PARANOID
- if (y > vid.height - 8 || x < 0 || x > vid.width - 8)
- ri.Sys_Error (ERR_FATAL,"Con_DrawCharacter: (%i, %i)", x, y);
- if (num < 0 || num > 255)
- ri.Sys_Error (ERR_FATAL,"Con_DrawCharacter: char %i", num);
- #endif
- row = num>>4;
- col = num&15;
- source = draw_chars->pixels[0] + (row<<10) + (col<<3);
- if (y < 0)
- {
- drawline = 8 + y;
- source -= 128*y;
- y = 0;
- }
- else
- drawline = 8;
- dest = vid.buffer + y*vid.rowbytes + x;
- while (drawline--)
- {
- if (source[0] != TRANSPARENT_COLOR)
- dest[0] = source[0];
- if (source[1] != TRANSPARENT_COLOR)
- dest[1] = source[1];
- if (source[2] != TRANSPARENT_COLOR)
- dest[2] = source[2];
- if (source[3] != TRANSPARENT_COLOR)
- dest[3] = source[3];
- if (source[4] != TRANSPARENT_COLOR)
- dest[4] = source[4];
- if (source[5] != TRANSPARENT_COLOR)
- dest[5] = source[5];
- if (source[6] != TRANSPARENT_COLOR)
- dest[6] = source[6];
- if (source[7] != TRANSPARENT_COLOR)
- dest[7] = source[7];
- source += 128;
- dest += vid.rowbytes;
- }
- }
- void Draw_GetPicSize (int *w, int *h, char *pic)
- {
- image_t *gl;
- gl = Draw_FindPic (pic);
- if (!gl)
- {
- *w = *h = -1;
- return;
- }
- *w = gl->width;
- *h = gl->height;
- }
- void Draw_StretchPicImplementation (int x, int y, int w, int h, image_t *pic)
- {
- byte *dest, *source;
- int v, u, sv;
- int height;
- int f, fstep;
- int skip;
- if ((x < 0) ||
- (x + w > vid.width) ||
- (y + h > vid.height))
- {
- ri.Sys_Error (ERR_FATAL,"Draw_Pic: bad coordinates");
- }
- height = h;
- if (y < 0)
- {
- skip = -y;
- height += y;
- y = 0;
- }
- else
- skip = 0;
- dest = vid.buffer + y * vid.rowbytes + x;
- for (v=0 ; v<height ; v++, dest += vid.rowbytes)
- {
- sv = (skip + v)*pic->height/h;
- source = pic->pixels[0] + sv*pic->width;
- if (w == pic->width)
- memcpy (dest, source, w);
- else
- {
- f = 0;
- fstep = pic->width*0x10000/w;
- for (u=0 ; u<w ; u+=4)
- {
- dest[u] = source[f>>16];
- f += fstep;
- dest[u+1] = source[f>>16];
- f += fstep;
- dest[u+2] = source[f>>16];
- f += fstep;
- dest[u+3] = source[f>>16];
- f += fstep;
- }
- }
- }
- }
- void Draw_StretchPic (int x, int y, int w, int h, char *name)
- {
- image_t *pic;
- pic = Draw_FindPic (name);
- if (!pic)
- {
- ri.Con_Printf (PRINT_ALL, "Can't find pic: %s\n", name);
- return;
- }
- Draw_StretchPicImplementation (x, y, w, h, pic);
- }
- void Draw_StretchRaw (int x, int y, int w, int h, int cols, int rows, byte *data)
- {
- image_t pic;
- pic.pixels[0] = data;
- pic.width = cols;
- pic.height = rows;
- Draw_StretchPicImplementation (x, y, w, h, &pic);
- }
- void Draw_Pic (int x, int y, char *name)
- {
- image_t *pic;
- byte *dest, *source;
- int v, u;
- int tbyte;
- int height;
- pic = Draw_FindPic (name);
- if (!pic)
- {
- ri.Con_Printf (PRINT_ALL, "Can't find pic: %s\n", name);
- return;
- }
- if ((x < 0) ||
- (x + pic->width > vid.width) ||
- (y + pic->height > vid.height))
- return;
- height = pic->height;
- source = pic->pixels[0];
- if (y < 0)
- {
- height += y;
- source += pic->width*-y;
- y = 0;
- }
- dest = vid.buffer + y * vid.rowbytes + x;
- if (!pic->transparent)
- {
- for (v=0 ; v<height ; v++)
- {
- memcpy (dest, source, pic->width);
- dest += vid.rowbytes;
- source += pic->width;
- }
- }
- else
- {
- if (pic->width & 7)
- {
- for (v=0 ; v<height ; v++)
- {
- for (u=0 ; u<pic->width ; u++)
- if ( (tbyte=source[u]) != TRANSPARENT_COLOR)
- dest[u] = tbyte;
- dest += vid.rowbytes;
- source += pic->width;
- }
- }
- else
- {
- for (v=0 ; v<height ; v++)
- {
- for (u=0 ; u<pic->width ; u+=8)
- {
- if ( (tbyte=source[u]) != TRANSPARENT_COLOR)
- dest[u] = tbyte;
- if ( (tbyte=source[u+1]) != TRANSPARENT_COLOR)
- dest[u+1] = tbyte;
- if ( (tbyte=source[u+2]) != TRANSPARENT_COLOR)
- dest[u+2] = tbyte;
- if ( (tbyte=source[u+3]) != TRANSPARENT_COLOR)
- dest[u+3] = tbyte;
- if ( (tbyte=source[u+4]) != TRANSPARENT_COLOR)
- dest[u+4] = tbyte;
- if ( (tbyte=source[u+5]) != TRANSPARENT_COLOR)
- dest[u+5] = tbyte;
- if ( (tbyte=source[u+6]) != TRANSPARENT_COLOR)
- dest[u+6] = tbyte;
- if ( (tbyte=source[u+7]) != TRANSPARENT_COLOR)
- dest[u+7] = tbyte;
- }
- dest += vid.rowbytes;
- source += pic->width;
- }
- }
- }
- }
- void Draw_TileClear (int x, int y, int w, int h, char *name)
- {
- int i, j;
- byte *psrc;
- byte *pdest;
- image_t *pic;
- int x2;
- if (x < 0)
- {
- w += x;
- x = 0;
- }
- if (y < 0)
- {
- h += y;
- y = 0;
- }
- if (x + w > vid.width)
- w = vid.width - x;
- if (y + h > vid.height)
- h = vid.height - y;
- if (w <= 0 || h <= 0)
- return;
- pic = Draw_FindPic (name);
- if (!pic)
- {
- ri.Con_Printf (PRINT_ALL, "Can't find pic: %s\n", name);
- return;
- }
- x2 = x + w;
- pdest = vid.buffer + y*vid.rowbytes;
- for (i=0 ; i<h ; i++, pdest += vid.rowbytes)
- {
- psrc = pic->pixels[0] + pic->width * ((i+y)&63);
- for (j=x ; j<x2 ; j++)
- pdest[j] = psrc[j&63];
- }
- }
- void Draw_Fill (int x, int y, int w, int h, int c)
- {
- byte *dest;
- int u, v;
- if (x+w > vid.width)
- w = vid.width - x;
- if (y+h > vid.height)
- h = vid.height - y;
- if (x < 0)
- {
- w += x;
- x = 0;
- }
- if (y < 0)
- {
- h += y;
- y = 0;
- }
- if (w < 0 || h < 0)
- return;
- dest = vid.buffer + y*vid.rowbytes + x;
- for (v=0 ; v<h ; v++, dest += vid.rowbytes)
- for (u=0 ; u<w ; u++)
- dest[u] = c;
- }
- void Draw_FadeScreen (void)
- {
- int x,y;
- byte *pbuf;
- int t;
- for (y=0 ; y<vid.height ; y++)
- {
- pbuf = (byte *)(vid.buffer + vid.rowbytes*y);
- t = (y & 1) << 1;
- for (x=0 ; x<vid.width ; x++)
- {
- if ((x & 3) != t)
- pbuf[x] = 0;
- }
- }
- }
|