mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
screenshots: if compiled with USE_LIBPNG, always use PNG, even for
color-inversed shots. For both PNG and TGA, change the way they're done in 8-bit mode: instead of XORing every byte with 15, save the inverse palette (each component taken 255-x). git-svn-id: https://svn.eduke32.com/eduke32@2219 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
d1d94e083f
commit
98bcc0e60c
1 changed files with 41 additions and 43 deletions
|
@ -4847,9 +4847,9 @@ static void drawalls(int32_t bunch)
|
||||||
|
|
||||||
#ifdef ENGINE_SCREENSHOT_DEBUG
|
#ifdef ENGINE_SCREENSHOT_DEBUG
|
||||||
if (engine_screenshot)
|
if (engine_screenshot)
|
||||||
#ifdef YAX_ENABLE
|
# ifdef YAX_ENABLE
|
||||||
if (!g_nodraw)
|
if (!g_nodraw)
|
||||||
#endif
|
# endif
|
||||||
{
|
{
|
||||||
static char fn[32], tmpbuf[80];
|
static char fn[32], tmpbuf[80];
|
||||||
static char bakframe[MAXXDIM*MAXYDIM];
|
static char bakframe[MAXXDIM*MAXYDIM];
|
||||||
|
@ -15415,15 +15415,15 @@ static int32_t screencapture_common1(char *fn, const char *ext, BFILE** filptr)
|
||||||
|
|
||||||
#ifdef USE_LIBPNG
|
#ifdef USE_LIBPNG
|
||||||
// PNG screenshots -- adapted from libpng example.c
|
// PNG screenshots -- adapted from libpng example.c
|
||||||
int32_t screencapture_png(const char *filename, char inverseit, const char *versionstr)
|
static int32_t screencapture_png(const char *filename, char inverseit, const char *versionstr)
|
||||||
{
|
{
|
||||||
int32_t i;
|
int32_t i;
|
||||||
BFILE *fp;
|
BFILE *fp;
|
||||||
#ifdef USE_OPENGL
|
# ifdef USE_OPENGL
|
||||||
# define HICOLOR (rendmode>=3 && qsetmode==200)
|
# define HICOLOR (rendmode>=3 && qsetmode==200)
|
||||||
#else
|
# else
|
||||||
# define HICOLOR 0
|
# define HICOLOR 0
|
||||||
#endif
|
# endif
|
||||||
png_structp png_ptr;
|
png_structp png_ptr;
|
||||||
png_infop info_ptr;
|
png_infop info_ptr;
|
||||||
png_colorp palette = NULL;
|
png_colorp palette = NULL;
|
||||||
|
@ -15434,19 +15434,17 @@ int32_t screencapture_png(const char *filename, char inverseit, const char *vers
|
||||||
|
|
||||||
char fn[32]; // careful...
|
char fn[32]; // careful...
|
||||||
|
|
||||||
UNREFERENCED_PARAMETER(inverseit);
|
|
||||||
|
|
||||||
Bstrcpy(fn, filename);
|
Bstrcpy(fn, filename);
|
||||||
i = screencapture_common1(fn, "png", &fp);
|
i = screencapture_common1(fn, "png", &fp);
|
||||||
if (i)
|
if (i)
|
||||||
return i;
|
return i;
|
||||||
|
|
||||||
/* Create and initialize the png_struct with default error handling. */
|
/* Create and initialize the png_struct with default error handling. */
|
||||||
#ifndef NEDMALLOC
|
# ifndef NEDMALLOC
|
||||||
png_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
|
png_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
|
||||||
#else
|
# else
|
||||||
png_ptr = png_create_write_struct_2(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL, Bmalloc, Bfree);
|
png_ptr = png_create_write_struct_2(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL, Bmalloc, Bfree);
|
||||||
#endif
|
# endif
|
||||||
if (png_ptr == NULL)
|
if (png_ptr == NULL)
|
||||||
{
|
{
|
||||||
Bfclose(fp);
|
Bfclose(fp);
|
||||||
|
@ -15493,9 +15491,9 @@ int32_t screencapture_png(const char *filename, char inverseit, const char *vers
|
||||||
{
|
{
|
||||||
for (i=0; i<256; i++)
|
for (i=0; i<256; i++)
|
||||||
{
|
{
|
||||||
palette[i].red = curpalettefaded[i].r;
|
palette[i].red = inverseit ? 255-curpalettefaded[i].r : curpalettefaded[i].r;
|
||||||
palette[i].green = curpalettefaded[i].g;
|
palette[i].green = inverseit ? 255-curpalettefaded[i].g : curpalettefaded[i].g;
|
||||||
palette[i].blue = curpalettefaded[i].b;
|
palette[i].blue = inverseit ? 255-curpalettefaded[i].b : curpalettefaded[i].b;
|
||||||
}
|
}
|
||||||
|
|
||||||
png_set_PLTE(png_ptr, info_ptr, palette, 256);
|
png_set_PLTE(png_ptr, info_ptr, palette, 256);
|
||||||
|
@ -15521,13 +15519,13 @@ int32_t screencapture_png(const char *filename, char inverseit, const char *vers
|
||||||
buf = (png_bytep)png_malloc(png_ptr, xdim*ydim);
|
buf = (png_bytep)png_malloc(png_ptr, xdim*ydim);
|
||||||
Bmemcpy(buf, (char *)frameplace, xdim*ydim);
|
Bmemcpy(buf, (char *)frameplace, xdim*ydim);
|
||||||
}
|
}
|
||||||
#ifdef USE_OPENGL
|
# ifdef USE_OPENGL
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
buf = (png_bytep)png_malloc(png_ptr, xdim*ydim*3);
|
buf = (png_bytep)png_malloc(png_ptr, xdim*ydim*3);
|
||||||
bglReadPixels(0,0,xdim,ydim,GL_RGB,GL_UNSIGNED_BYTE,buf);
|
bglReadPixels(0,0,xdim,ydim,GL_RGB,GL_UNSIGNED_BYTE,buf);
|
||||||
}
|
}
|
||||||
#endif
|
# endif
|
||||||
enddrawing(); //}}}
|
enddrawing(); //}}}
|
||||||
|
|
||||||
rowptrs = (png_bytepp)png_malloc(png_ptr, ydim*sizeof(png_bytep));
|
rowptrs = (png_bytepp)png_malloc(png_ptr, ydim*sizeof(png_bytep));
|
||||||
|
@ -15558,10 +15556,11 @@ int32_t screencapture_png(const char *filename, char inverseit, const char *vers
|
||||||
capturecount++;
|
capturecount++;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#undef HICOLOR
|
# undef HICOLOR
|
||||||
#endif // defined USE_LIBPNG
|
|
||||||
|
|
||||||
int32_t screencapture_tga(const char *filename, char inverseit)
|
#else // if !defined USE_LIBPNG
|
||||||
|
|
||||||
|
static int32_t screencapture_tga(const char *filename, char inverseit)
|
||||||
{
|
{
|
||||||
int32_t i,j;
|
int32_t i,j;
|
||||||
char *ptr, head[18] = { 0,1,1,0,0,0,1,24,0,0,0,0,0/*wlo*/,0/*whi*/,0/*hlo*/,0/*hhi*/,8,0 };
|
char *ptr, head[18] = { 0,1,1,0,0,0,1,24,0,0,0,0,0/*wlo*/,0/*whi*/,0/*hlo*/,0/*hhi*/,8,0 };
|
||||||
|
@ -15573,7 +15572,7 @@ int32_t screencapture_tga(const char *filename, char inverseit)
|
||||||
if (i)
|
if (i)
|
||||||
return i;
|
return i;
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
# ifdef USE_OPENGL
|
||||||
if (rendmode >= 3 && qsetmode == 200)
|
if (rendmode >= 3 && qsetmode == 200)
|
||||||
{
|
{
|
||||||
head[1] = 0; // no colourmap
|
head[1] = 0; // no colourmap
|
||||||
|
@ -15585,7 +15584,7 @@ int32_t screencapture_tga(const char *filename, char inverseit)
|
||||||
head[7] = 0; // colourmap entry size
|
head[7] = 0; // colourmap entry size
|
||||||
head[16] = 24; // 24 bits per pixel
|
head[16] = 24; // 24 bits per pixel
|
||||||
}
|
}
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
head[12] = xdim & 0xff;
|
head[12] = xdim & 0xff;
|
||||||
head[13] = (xdim >> 8) & 0xff;
|
head[13] = (xdim >> 8) & 0xff;
|
||||||
|
@ -15598,39 +15597,42 @@ int32_t screencapture_tga(const char *filename, char inverseit)
|
||||||
ptr = (char *)frameplace;
|
ptr = (char *)frameplace;
|
||||||
|
|
||||||
// palette first
|
// palette first
|
||||||
#ifdef USE_OPENGL
|
# ifdef USE_OPENGL
|
||||||
if (rendmode < 3 || (rendmode >= 3 && qsetmode != 200))
|
if (rendmode < 3 || (rendmode >= 3 && qsetmode != 200))
|
||||||
{
|
{
|
||||||
#endif
|
# endif
|
||||||
//getpalette(0,256,palette);
|
//getpalette(0,256,palette);
|
||||||
for (i=0; i<256; i++)
|
for (i=0; i<256; i++)
|
||||||
{
|
{
|
||||||
Bfputc(curpalettefaded[i].b, fil); // b
|
Bfputc(inverseit ? 255-curpalettefaded[i].b : curpalettefaded[i].b, fil); // b
|
||||||
Bfputc(curpalettefaded[i].g, fil); // g
|
Bfputc(inverseit ? 255-curpalettefaded[i].g : curpalettefaded[i].g, fil); // g
|
||||||
Bfputc(curpalettefaded[i].r, fil); // r
|
Bfputc(inverseit ? 255-curpalettefaded[i].r : curpalettefaded[i].r, fil); // r
|
||||||
}
|
}
|
||||||
#ifdef USE_OPENGL
|
# ifdef USE_OPENGL
|
||||||
}
|
}
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
|
# if 0
|
||||||
// targa renders bottom to top, from left to right
|
// targa renders bottom to top, from left to right
|
||||||
if (inverseit && qsetmode != 200)
|
if (inverseit && qsetmode != 200)
|
||||||
{
|
{
|
||||||
inversebuf = (char *)Bmalloc(bytesperline);
|
inversebuf = Bmalloc(bytesperline);
|
||||||
if (inversebuf)
|
if (inversebuf)
|
||||||
{
|
{
|
||||||
for (i=ydim-1; i>=0; i--)
|
for (i=ydim-1; i>=0; i--)
|
||||||
{
|
{
|
||||||
copybuf(ptr+i*bytesperline, inversebuf, xdim >> 2);
|
Bmemcpy(inversebuf, ptr+i*bytesperline, xdim);
|
||||||
for (j=0; j < (bytesperline>>2); j++)((int32_t *)inversebuf)[j] ^= 0x0f0f0f0fL;
|
for (j=0; j<xdim; j++) /* used to be j<bytesperline */
|
||||||
|
inversebuf[j] ^= 0x0f;
|
||||||
Bfwrite(inversebuf, xdim, 1, fil);
|
Bfwrite(inversebuf, xdim, 1, fil);
|
||||||
}
|
}
|
||||||
Bfree(inversebuf);
|
Bfree(inversebuf);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
# endif
|
||||||
{
|
{
|
||||||
#ifdef USE_OPENGL
|
# ifdef USE_OPENGL
|
||||||
if (rendmode >= 3 && qsetmode == 200)
|
if (rendmode >= 3 && qsetmode == 200)
|
||||||
{
|
{
|
||||||
char c;
|
char c;
|
||||||
|
@ -15651,13 +15653,11 @@ int32_t screencapture_tga(const char *filename, char inverseit)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
# endif
|
||||||
{
|
{
|
||||||
#endif
|
|
||||||
for (i=ydim-1; i>=0; i--)
|
for (i=ydim-1; i>=0; i--)
|
||||||
Bfwrite(ptr+i*bytesperline, xdim, 1, fil);
|
Bfwrite(ptr+i*bytesperline, xdim, 1, fil);
|
||||||
#ifdef USE_OPENGL
|
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
enddrawing(); //}}}
|
enddrawing(); //}}}
|
||||||
|
@ -15668,6 +15668,8 @@ int32_t screencapture_tga(const char *filename, char inverseit)
|
||||||
capturecount++;
|
capturecount++;
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
# endif
|
||||||
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
// PCX is nasty, which is why I've lifted these functions from the PCX spec by ZSoft
|
// PCX is nasty, which is why I've lifted these functions from the PCX spec by ZSoft
|
||||||
|
@ -15841,14 +15843,10 @@ int32_t screencapture(const char *filename, char inverseit, const char *versions
|
||||||
{
|
{
|
||||||
#ifndef USE_LIBPNG
|
#ifndef USE_LIBPNG
|
||||||
UNREFERENCED_PARAMETER(versionstr);
|
UNREFERENCED_PARAMETER(versionstr);
|
||||||
#else
|
|
||||||
if (!inverseit)
|
|
||||||
return screencapture_png(filename,inverseit,versionstr);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
// if (captureformat == 0)
|
|
||||||
return screencapture_tga(filename,inverseit);
|
return screencapture_tga(filename,inverseit);
|
||||||
// else return screencapture_pcx(filename,inverseit);
|
#else
|
||||||
|
return screencapture_png(filename,inverseit,versionstr);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue