mirror of
https://github.com/nillerusr/source-engine.git
synced 2025-01-10 01:16:47 +00:00
112 lines
2.5 KiB
C++
112 lines
2.5 KiB
C++
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||
|
//
|
||
|
// Purpose:
|
||
|
//
|
||
|
// $NoKeywords: $
|
||
|
//
|
||
|
//=============================================================================//
|
||
|
#include <stdlib.h>
|
||
|
#include <stdlib.h>
|
||
|
#include <sys/types.h>
|
||
|
#include <sys/stat.h>
|
||
|
#include "vtf/vtf.h"
|
||
|
#include "UtlBuffer.h"
|
||
|
|
||
|
int main( int argc, char **argv )
|
||
|
{
|
||
|
if( argc != 5 )
|
||
|
{
|
||
|
fprintf( stderr, "Usage: vtfscreen blah.vtf 0 1 2\n" );
|
||
|
exit( -1 );
|
||
|
}
|
||
|
const char *pSrcFilename = argv[1];
|
||
|
int rOffset = atoi( argv[2] );
|
||
|
int gOffset = atoi( argv[3] );
|
||
|
int bOffset = atoi( argv[4] );
|
||
|
CUtlBuffer srcData;
|
||
|
|
||
|
struct _stat buf;
|
||
|
if( _stat( pSrcFilename, &buf ) == -1 )
|
||
|
{
|
||
|
fprintf( stderr, "Couldn't stat %s\n", pSrcFilename );
|
||
|
exit( -1 );
|
||
|
}
|
||
|
|
||
|
int srcFileSize = buf.st_size;
|
||
|
|
||
|
srcData.EnsureCapacity( srcFileSize );
|
||
|
|
||
|
FILE *fp = fopen( pSrcFilename, "rb" );
|
||
|
if( !fp )
|
||
|
{
|
||
|
fprintf( stderr, "Couldn't open %s\n", pSrcFilename );
|
||
|
exit( -1 );
|
||
|
}
|
||
|
|
||
|
int nBytesRead = fread( srcData.Base(), 1, srcFileSize, fp );
|
||
|
fclose( fp );
|
||
|
|
||
|
srcData.SeekPut( CUtlBuffer::SEEK_HEAD, nBytesRead );
|
||
|
|
||
|
IVTFTexture *pSrcTexture = CreateVTFTexture();
|
||
|
|
||
|
pSrcTexture->Unserialize( srcData );
|
||
|
ImageFormat srcFormat = pSrcTexture->Format();
|
||
|
pSrcTexture->ConvertImageFormat( IMAGE_FORMAT_DEFAULT, false );
|
||
|
|
||
|
int totalSize = pSrcTexture->ComputeTotalSize();
|
||
|
|
||
|
unsigned char *pImageData = pSrcTexture->ImageData();
|
||
|
int i;
|
||
|
for( i = 0; i < totalSize; i += 4 )
|
||
|
{
|
||
|
#if 0
|
||
|
// ATI BEFORE E32003
|
||
|
int r, g, b;
|
||
|
r = ( int )pImageData[i+0];
|
||
|
g = ( int )pImageData[i+1];
|
||
|
b = ( int )pImageData[i+2];
|
||
|
|
||
|
int grey = r + g + b;
|
||
|
grey = grey / 3;
|
||
|
pImageData[i+0] = 0;
|
||
|
pImageData[i+1] = grey;
|
||
|
pImageData[i+2] = 0;
|
||
|
#endif
|
||
|
#if 0
|
||
|
// NVIDIA - first e3 build
|
||
|
pImageData[i+1] = 0;
|
||
|
pImageData[i+2] = 0;
|
||
|
#endif
|
||
|
#if 0
|
||
|
// ATI e3 build on . .get the green component and stomp all channels with it.
|
||
|
pImageData[i+0] = pImageData[i+1];
|
||
|
pImageData[i+2] = pImageData[i+1];
|
||
|
#endif
|
||
|
#if 0
|
||
|
// Intel . .get the blue component and stomp all channels with it.
|
||
|
pImageData[i+0] = pImageData[i+2];
|
||
|
pImageData[i+1] = pImageData[i+2];
|
||
|
#endif
|
||
|
// leave alpha alone
|
||
|
int tmpR, tmpG, tmpB;
|
||
|
tmpR = pImageData[i+rOffset];
|
||
|
tmpG = pImageData[i+gOffset];
|
||
|
tmpB = pImageData[i+bOffset];
|
||
|
pImageData[i+0] = tmpR;
|
||
|
pImageData[i+1] = tmpG;
|
||
|
pImageData[i+2] = tmpB;
|
||
|
}
|
||
|
|
||
|
pSrcTexture->ConvertImageFormat( srcFormat, false );
|
||
|
CUtlBuffer dstData;
|
||
|
|
||
|
pSrcTexture->Serialize( dstData );
|
||
|
|
||
|
fp = fopen( pSrcFilename, "wb" );
|
||
|
fwrite( dstData.Base(), 1, dstData.TellPut(), fp );
|
||
|
fclose( fp );
|
||
|
|
||
|
return 0;
|
||
|
}
|