//========= Copyright © 1996-2005, Valve Corporation, All rights reserved. ============// // // Purpose: // // $NoKeywords: $ // //=============================================================================// #if !defined( _GAMECONSOLE ) #include #endif #include #include "UtlBuffer.h" #include #include #include "FileSystem.h" // dgoodenough - select the correct stubs header based on current console // PS3_BUILDFIX #if defined( _PS3 ) #include "ps3/ps3_win32stubs.h" #endif #if defined( _X360 ) #include "xbox/xbox_win32stubs.h" #endif // memdbgon must be the last include file in a .cpp file!!! #include "tier0/memdbgon.h" using namespace vgui; #define TYP_LUMPY 64 // 64 + grab command number typedef struct { char identification[4]; // should be WAD2 or 2DAW int numlumps; int infotableofs; } wadinfo_t; typedef struct { int filepos; int disksize; int size; // uncompressed char type; char compression; char pad1, pad2; char name[16]; // must be null terminated } lumpinfo_t; typedef struct { char name[16]; unsigned width, height; unsigned offsets[4]; // four mip maps stored } miptex_t; unsigned char pixdata[256]; float linearpalette[256][3]; float d_red, d_green, d_blue; int colors_used; int color_used[256]; float maxdistortion; unsigned char palLogo[768]; /* ============= AveragePixels ============= */ unsigned char AveragePixels (int count) { return pixdata[0]; } /* ============== GrabMip filename MIP x y width height must be multiples of sixteen ============== */ int GrabMip ( HANDLE hdib, unsigned char *lump_p, char *lumpname, COLORREF crf, int *width, int *height) { int i,x,y,xl,yl,xh,yh,w,h; unsigned char *screen_p, *source; miptex_t *qtex; int miplevel, mipstep; int xx, yy; int count; int byteimagewidth, byteimageheight; unsigned char *byteimage; LPBITMAPINFO lpbmi; // pointer to BITMAPINFO structure (Win3.0) /* get pointer to BITMAPINFO (Win 3.0) */ // dgoodenough - GlobalLock is win32 specific, skip using it for now, we'll fix this up later // PS3_BUILDFIX // FIXME FIXME FIXME - This will need help. #if defined( _PS3 ) lpbmi = NULL; #else lpbmi = (LPBITMAPINFO)::GlobalLock((HGLOBAL)hdib); #endif unsigned char *lump_start = lump_p; xl = yl = 0; w = lpbmi->bmiHeader.biWidth; h = lpbmi->bmiHeader.biHeight; *width = w; *height = h; byteimage = (unsigned char *)((LPSTR)lpbmi + sizeof( BITMAPINFOHEADER ) + 256 * sizeof( RGBQUAD ) ); if ( (w & 15) || (h & 15) ) return 0; //Error ("line %i: miptex sizes must be multiples of 16", scriptline); xh = xl+w; yh = yl+h; qtex = (miptex_t *)lump_p; qtex->width = (unsigned)(w); qtex->height = (unsigned)(h); Q_strncpy (qtex->name, lumpname, sizeof( qtex->name) ); lump_p = (unsigned char *)&qtex->offsets[4]; byteimagewidth = w; byteimageheight = h; source = (unsigned char *)lump_p; qtex->offsets[0] = (unsigned)((unsigned char *)lump_p - (unsigned char *)qtex); // We're reading from a dib, so go bottom up screen_p = byteimage + (h - 1) * w; for (y=yl ; yoffsets[miplevel] = (unsigned)(lump_p - (unsigned char *)qtex); mipstep = 1<> 8) & 0xFF); *lump_p++ = (unsigned char)((crf >> 16) & 0xFF); return lump_p - lump_start; } void UpdateLogoWAD( void *phdib, int r, int g, int b ) { char logoname[ 32 ]; char *pszName; Q_strncpy( logoname, "LOGO", sizeof( logoname ) ); pszName = &logoname[ 0 ]; HANDLE hdib = (HANDLE)phdib; COLORREF crf = RGB( r, g, b ); if ((!pszName) || (pszName[0] == 0) || (hdib == NULL)) return; // Generate lump unsigned char *buf = (unsigned char *)_alloca( 16384 ); CUtlBuffer buffer( 0, 16384 ); int width, height; int length = GrabMip (hdib, buf, pszName, crf, &width, &height); if ( length == 0 ) { return; } bool sizevalid = false; if ( width == height ) { if ( width == 16 || width == 32 || width == 64 ) { sizevalid = true; } } if ( !sizevalid ) return; while (length & 3) length++; // Write Header wadinfo_t header; header.identification[0] = 'W'; header.identification[1] = 'A'; header.identification[2] = 'D'; header.identification[3] = '3'; header.numlumps = 1; header.infotableofs = 0; buffer.Put( &header, sizeof( wadinfo_t ) ); // Fill Ino info table lumpinfo_t info; Q_memset (&info, 0, sizeof(info)); Q_strncpy(info.name, pszName, sizeof( info.name ) ); info.filepos = (int)sizeof(wadinfo_t); info.size = info.disksize = length; info.type = TYP_LUMPY; info.compression = 0; // Write Lump buffer.Put( buf, length ); // Write info table buffer.Put( &info, sizeof( lumpinfo_t ) ); int savepos = buffer.TellPut(); buffer.SeekPut( CUtlBuffer::SEEK_HEAD, 0 ); header.infotableofs = length + sizeof(wadinfo_t); buffer.Put( &header, sizeof( wadinfo_t ) ); buffer.SeekPut( CUtlBuffer::SEEK_HEAD, savepos ); // Output to file FileHandle_t file; file = g_pFullFileSystem->Open( "pldecal.wad", "wb" ); if ( file != FILESYSTEM_INVALID_HANDLE ) { g_pFullFileSystem->Write( buffer.Base(), buffer.TellPut(), file ); g_pFullFileSystem->Close( file ); } }