亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tga.cpp

?? 仿游戲 Diablo 的源代碼
?? CPP
字號:
/* 讀取TGA圖像文件,支持8,15,16,24位色 */
#include <errno.h>
#include <string.h>
#include "gl.h"

typedef struct TGAHEADER{
	BYTE identsize;
	BYTE colormaptype;
	BYTE imagetype;
	WORD colormapstart;
	WORD colormaplength;
	BYTE colormapbits;
	WORD xstart, ystart;
	WORD width, height;
	BYTE bitsperpixel;
	BYTE descriptor;
} TGAHEADER;

static PixelInfo *pixelInfo;

static int ReadHeader( TGAHEADER *tgaheader, File *fp )
{
	tgaheader->identsize = fp->Getc();
	tgaheader->colormaptype = fp->Getc();
	tgaheader->imagetype = fp->Getc();
	tgaheader->colormapstart = fp->Getw();
	tgaheader->colormaplength = fp->Getw();
	tgaheader->colormapbits = fp->Getc();
	tgaheader->xstart = fp->Getw();
	tgaheader->ystart = fp->Getw();
	tgaheader->width = fp->Getw();
	tgaheader->height = fp->Getw();
	tgaheader->bitsperpixel = fp->Getc();
	tgaheader->descriptor = fp->Getc();

	if( tgaheader->colormapstart + tgaheader->colormaplength >= 256 )
		return -1;
	return 0;
}

static void ReadPalette( Palette *pal, int start, int length, File *fp )
{
	for( int i=start; i<start+length; i++ ){
		pal->palette[i].rgb = 0;
		pal->palette[i].rgbRed = fp->Getc();
		pal->palette[i].rgbGreen = fp->Getc();
		pal->palette[i].rgbBlue = fp->Getc();
	}
	pal->Convert();
}

static void ReadRleTga8( char *bmp, int width, File *fp )
{
	BYTE val;
	int count;
	
	do{
		count = fp->Getc();
		if( count & 0x80 ){
			count = ( count & 0x7f ) + 1;
			width -= count;
			val = fp->Getc();
			while( count -- )
				*( bmp ++ ) = val;
		}
		else{
			count ++;
			width -= count;
			fp->Read( bmp, count );
			bmp += count;
		}
	} while( width );
}

// load 15bit color mode file
static void ReadRleTga16( char *bmp, int width, File *fp )
{
	WORD val;
	WORD color;
	int count;

	do{
		count = fp->Getc();
		if( count & 0x80 ){
			count = ( count & 0x7f ) + 1;
			width -= count;
			val = fp->Getw();
			color = ((( val >> 10 ) & 0x1f ) << pixelInfo->redPos )
				| ((( val >> 5 ) & 0x1f ) << (pixelInfo->redPos - pixelInfo->greenPos))
				| ( val & 0x1f );
			while( count-- )
				*((short*) bmp++ ) = color;
		}
		else{
			count ++;
			width -= count;
			while( count-- ){
				val = fp->Getw();
				color = ((( val >> 10 ) & 0x1f ) << pixelInfo->redPos )
					| ((( val >> 5 ) & 0x1f ) << (pixelInfo->redPos - pixelInfo->greenPos))
					| ( val & 0x1f );
				*((short*) bmp ++ ) = color;
			}
		}
	} while( width );
}

static void ReadRleTga24( char *bmp, int width, File *fp )
{
	BYTE value[4];
	int count;

	do{
		count = fp->Getc();
		if( count & 0x80 ){
			count = ( count & 0x7f ) + 1;
			width -= count;
			fp->Read( value, 3 );
			while( count -- ){
				bmp[2] = value[2];
				bmp[1] = value[1];
				bmp[0] = value[0];
				bmp += 3;
			}
		}
		else{
			count ++;
			width -= count;
			while( count -- ){
				fp->Read( value, 3 );
				bmp[2] = value[2];
				bmp[1] = value[1];
				bmp[0] = value[0];
				bmp += 3;
			}
		}
	} while( width );
}

Bitmap* LoadTga( char *filename, Palette *pal )
{
	int compressed, y, yc, i;
	Bitmap *bmp;
	BYTE rgb[3];
	Palette paltemp;
	TGAHEADER tgaheader;
	WORD w, *s;
	File *fp;

	errno = 0;
	if( ( fp = cfile.Open( filename )) == NULL )
		return NULL;

	if( ReadHeader( &tgaheader, fp ) != 0 ){
		fp->Close();
		return NULL;
	}
	compressed = tgaheader.imagetype & 8;
	tgaheader.imagetype &= 7;
	if( tgaheader.imagetype < 1 || tgaheader.imagetype > 3 ){
		fp->Close();
		return NULL;
	}
	fp->Seek( tgaheader.identsize, SEEK_CUR );
	if( tgaheader.colormaplength != 0 ){
		if( pal != NULL ){
			ReadPalette( &paltemp, tgaheader.colormapstart, tgaheader.colormaplength, fp );
		}
		else
			fp->Seek( tgaheader.colormaplength * 3, SEEK_CUR );
	}
	
	switch( tgaheader.imagetype ){
	case 1:
		if( tgaheader.colormaptype != 1 || tgaheader.bitsperpixel != 8 ){
			fp->Close();
			return NULL;
		}
		if( pal != NULL )
			memcpy( (long*)pal, (long*)&paltemp, 256 );
		break;
	case 2:
	 /* truecolor image */
		if( ( tgaheader.colormaptype == 0 ) && (( tgaheader.bitsperpixel == 15 ) 
			|| ( tgaheader.bitsperpixel == 16 ) 
			|| ( tgaheader.bitsperpixel == 24 )) )
			break;
		else{
			fp->Close();
			return NULL;
		}

		break;
	case 3:
	 /* grayscale image */
		if(( tgaheader.colormaptype !=0 ) || ( tgaheader.bitsperpixel != 8 )){
			fp->Close();
			return NULL;
		}
		break;
	}

/*	if( tgaheader.bitsperpixel == 15 || tgaheader.bitsperpixel == 16 ){
		if( screenInfo.colorDepth == 16 )
			pixelInfo = &pixelInfo16;
		else if( screenInfo.colorDepth == 15 )
			pixelInfo = &pixelInfo15;	// photoshop is shit !!!!!
		//tgaheader.bitsperpixel = (BYTE)screenInfo.colorDepth;
	}
*/
	if( tgaheader.bitsperpixel == 16 )
		tgaheader.bitsperpixel = 15;
	if( tgaheader.bitsperpixel == 15 )
		pixelInfo = &pixelInfo15;	

	bmp = CreateBitmapEx( tgaheader.width, tgaheader.height, tgaheader.bitsperpixel );
	if( bmp == NULL ){
		fp->Close();
		return NULL;
	}
	if( tgaheader.bitsperpixel == 8 )
		(( Bitmap8* )bmp )->palette = pal;

	for( y = tgaheader.height; y!=0; y-- ){
		yc = ( tgaheader.descriptor & 0x20 ) ? tgaheader.height - y : y - 1;
		switch( tgaheader.imagetype ){
		case 1:
		case 3:
			if( compressed )
				ReadRleTga8( bmp->line[yc], tgaheader.width, fp );
			else
				fp->Read( bmp->line[yc], tgaheader.width );
			break;

		case 2:
			if( tgaheader.bitsperpixel == 24 ){
				if( compressed ){
					ReadRleTga24( bmp->line[yc], tgaheader.width, fp );
				}
				else{
					//printf( "%d\n", pixelInfo->redPos/8 );

					for( i=0; i<tgaheader.width; i++ ){
						fp->Read( rgb, 3 );
						bmp->line[yc][ i*3 + 2 ] = rgb[2];
						bmp->line[yc][ i*3 + 1 ] = rgb[1];
						bmp->line[yc][ i*3 + 0 ] = rgb[0];
					}
				}
			}
			else{
				if( compressed ){
					ReadRleTga16( bmp->line[yc], tgaheader.width, fp );
				}
				else{
					s = ( WORD* )( bmp->line[yc] );
					for( i=0; i<tgaheader.width; i++ ){
						w = fp->Getw();
						s[ i ] = ((( w >> 10 ) & 0x1f ) << pixelInfo->redPos )
							| ((( w >> 5) & 0x1f ) << (pixelInfo->redPos - pixelInfo->greenPos ))
							| ( w & 0x1f );
					}
				}
			}
			break;
		} // end of switch
	} // end of for
	
	fp->Close();
	if( errno ){
		delete bmp;
		return NULL;
	}
	return bmp;
}

int SaveTga( char *filename, Bitmap *bmp )
{
	FILE *fp;
	int depth, x, y, temp;

	errno = 0;

	if( ( fp = fopen( filename, "wb" )) == NULL )
		return errno;

	depth = bmp->colorDepth;
	if( depth == 15 )
		depth = 16;
	else if( depth == 32 )
		depth = 24;
/*	BYTE identsize;
	BYTE colormaptype;
	BYTE imagetype;
	WORD colormapstart;
	WORD colormaplength;
	BYTE colormapbits;
	WORD xstart, ystart;
	WORD width, height;
	BYTE bitsperpixel;
	BYTE descriptor;
*/
	fputc( 0, fp );
	fputc( (depth == 8 ) ? 1 : 0, fp );
	fputc( (depth == 8 ) ? 1 : 2, fp );
	temp = 0;
	fwrite( &temp, 1, 2, fp );
	temp = ( depth == 8 ) ? 256 : 0;
	fwrite( &temp, 1, 2, fp );
	temp = ( depth == 8 ) ? 24 : 0;
	fputc( temp, fp );
	temp = 0;
	fwrite( &temp, 2, 2, fp );
	fwrite( &(bmp->width), 2, 1, fp );
	fwrite( &(bmp->height), 2, 1, fp );
	fputc( depth, fp );
	fputc( 1, fp );
	if( depth == 8 ){
	}

	switch( bmp->colorDepth ){

	case 8:
		for( y = bmp->height-1; y>=0; y-- )
			for( x=0; x<bmp->width; x++ )
				fputc( bmp->GetPixel( x, y ), fp );
	break;

	case 15:
		for( y = bmp->height-1; y>=0; y-- )
			for( x=0; x<bmp->width; x++ ){
				temp = bmp->GetPixel( x, y );
				fwrite( &temp, 2, 1, fp );
			}
	break;

	case 16:
		for( y = bmp->height-1; y>=0; y-- )
			for( x=0; x<bmp->width; x++ ){
				temp = bmp->GetPixel( x, y );
				fwrite( &temp, 2, 1, fp );
			}
	break;

	case 24:
		for( y = bmp->height-1; y>=0; y-- )
			for( x=0; x<bmp->width; x++ ){
				temp = bmp->GetPixel( x, y );
				fwrite( &temp, 3, 1, fp );
			}
	break;

	case 32:
		for( y = bmp->height-1; y>=0; y-- )
			for( x=0; x<bmp->width; x++ ){
				temp = bmp->GetPixel( x, y );
				fwrite( &temp, 3, 1, fp );
			}
	break;
	}

	fclose( fp );
	return errno;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91国模大尺度私拍在线视频| 国产成人在线电影| 日韩一区欧美小说| 国产午夜久久久久| 国产视频在线观看一区二区三区| 日韩精品一区二区三区视频播放| 欧美剧在线免费观看网站| 欧美日韩免费一区二区三区视频| 欧美在线观看一区| 欧美精品xxxxbbbb| 这里只有精品免费| 精品国产a毛片| 久久久久久免费| 成人欧美一区二区三区视频网页 | 欧美一区二区三区色| 欧美日韩成人一区二区| 8v天堂国产在线一区二区| 日韩欧美一区二区三区在线| 久久天天做天天爱综合色| 国产性色一区二区| 亚洲精品第1页| 日一区二区三区| 国产精品一区二区在线看| 91在线免费播放| 欧美日韩免费观看一区三区| 日韩欧美视频一区| 中文字幕av资源一区| 一个色综合av| 精品中文av资源站在线观看| 高清成人免费视频| 精品1区2区3区| 久久久久久久久久美女| 亚洲免费毛片网站| 美日韩一区二区| 99这里只有精品| 日韩精品一区二区三区中文精品| 18涩涩午夜精品.www| 久久精品免费看| 一本色道亚洲精品aⅴ| 欧美成人精品二区三区99精品| 国产精品国产自产拍高清av| 天天色 色综合| 欧美亚一区二区| 精品区一区二区| 亚洲精品欧美在线| 国产乱码精品一区二区三区忘忧草 | 亚洲一区二区三区影院| 国产精品影视网| 9191成人精品久久| 亚洲三级久久久| 国产乱码精品一区二区三区忘忧草| 色8久久人人97超碰香蕉987| 久久品道一品道久久精品| 亚洲国产精品一区二区www在线| 国内久久婷婷综合| 欧美年轻男男videosbes| 欧美国产精品v| 久久av资源网| 91麻豆精品国产91久久久久久| 中文字幕综合网| 成人精品国产一区二区4080| 久久午夜免费电影| 久久精品国产亚洲a| 欧美色老头old∨ideo| 亚洲欧美在线视频观看| 国产不卡免费视频| 久久婷婷久久一区二区三区| 精品亚洲国内自在自线福利| 在线观看91av| 青娱乐精品视频在线| 欧美精品色综合| 天堂资源在线中文精品| 欧美色视频一区| 午夜久久久久久久久| 欧美日韩国产首页在线观看| 亚洲精品ww久久久久久p站| 色中色一区二区| 亚洲国产一区视频| 欧美在线啊v一区| 亚洲成av人片在线观看无码| 欧美日韩五月天| 五月综合激情婷婷六月色窝| 91精品国产一区二区| 日本欧美久久久久免费播放网| 91精选在线观看| 美国三级日本三级久久99 | 国产精品美女久久久久久久| 国产精品1区二区.| 国产精品久久久99| 在线视频欧美精品| 日韩国产高清在线| 精品久久久久一区二区国产| 岛国一区二区在线观看| 日韩一区有码在线| 欧美精品第1页| 国模一区二区三区白浆| 中文字幕欧美国产| 91女人视频在线观看| 亚洲国产成人高清精品| 91精品国产高清一区二区三区| 狠狠色丁香婷综合久久| 日本一区二区三区在线观看| 色悠久久久久综合欧美99| 日韩1区2区3区| 国产亚洲成av人在线观看导航| 色婷婷精品大在线视频| 蜜桃av一区二区三区电影| 国产午夜精品一区二区| 色婷婷综合激情| 久久99精品一区二区三区| 国产精品成人一区二区三区夜夜夜| 欧美色手机在线观看| 国产精品99久久久久久似苏梦涵| 亚洲精品中文字幕乱码三区| 日韩欧美在线一区二区三区| 99久久精品免费看国产| 麻豆一区二区在线| 亚洲另类春色国产| 精品va天堂亚洲国产| 在线观看视频一区二区欧美日韩| 久久精品国产一区二区三区免费看| 亚洲色图视频网站| 国产免费久久精品| 日韩一二三区不卡| 欧美在线短视频| 99久久精品国产毛片| 国产毛片精品视频| 午夜影院久久久| 亚洲欧美成aⅴ人在线观看| 亚洲蜜桃精久久久久久久| 日韩一区二区三区精品视频| 91浏览器在线视频| 成人一区在线看| 九色综合狠狠综合久久| 亚洲午夜电影网| 亚洲三级电影网站| 国产日韩精品视频一区| 欧美成人免费网站| 欧美电影在线免费观看| 欧美影院精品一区| 色综合久久88色综合天天| 成人毛片视频在线观看| 国产精品一二三四五| 蜜臀va亚洲va欧美va天堂| 一区二区三区在线免费播放| 国产精品国产三级国产普通话蜜臀 | 欧美一区二区免费观在线| 色哟哟一区二区三区| av一区二区三区黑人| 成人免费视频视频在线观看免费 | 日韩av网站免费在线| 亚洲图片自拍偷拍| 亚洲一区影音先锋| 亚洲亚洲人成综合网络| 亚洲国产精品尤物yw在线观看| 亚洲欧美日韩国产一区二区三区 | 在线视频国产一区| 91浏览器在线视频| 欧美在线视频日韩| 欧美精品一级二级三级| 欧美精品久久99久久在免费线| 884aa四虎影成人精品一区| 欧美一区二区在线不卡| 日韩精品一区二区三区蜜臀 | 欧美一卡2卡三卡4卡5免费| 欧美精品在线视频| 日韩欧美国产一区在线观看| 精品电影一区二区三区 | 欧日韩精品视频| 欧美综合亚洲图片综合区| 欧美精品免费视频| 2024国产精品| 国产精品色眯眯| 亚洲精品国产一区二区精华液| 午夜精品一区二区三区免费视频| 日韩成人精品在线| 国产成人午夜99999| 色狠狠综合天天综合综合| 欧美日韩在线一区二区| 精品88久久久久88久久久| 久久久久久亚洲综合| 亚洲自拍另类综合| 激情综合色播激情啊| 99国产精品国产精品毛片| 欧美日韩激情在线| 久久色在线观看| 亚洲免费观看高清完整版在线观看熊| 亚洲无线码一区二区三区| 国产精品自拍网站| 色偷偷88欧美精品久久久| 精品久久免费看| 亚洲午夜一区二区三区| 国产aⅴ综合色| 欧美二区三区91| 一区二区三区中文在线观看| 狠狠色综合日日| 欧美亚洲综合网| 日韩一区有码在线| 国产一区二区0| 91精品福利在线一区二区三区|