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

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

?? compress.c

?? 圖像處理圖像集 壓縮源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
	if((funcret=InitTag())!=FUNC_OK){
		GlobalUnlock(hJpegBuf);
		GlobalFree(hJpegBuf);
		showerror(funcret);
		return FALSE;
	}
	//create new bitmapfileheader and bitmapinfoheader
	memset((char *)&bf,0,sizeof(BITMAPFILEHEADER));	
	memset((char *)&bi,0,sizeof(BITMAPINFOHEADER));

	bi.biSize=(DWORD)sizeof(BITMAPINFOHEADER);
	bi.biWidth=(LONG)(ImgWidth);
	bi.biHeight=(LONG)(ImgHeight);
	bi.biPlanes=1;
	bi.biBitCount=24;
	bi.biClrUsed=0;
	bi.biClrImportant=0;
	bi.biCompression=BI_RGB;
	NumColors=0;
	LineBytes=(DWORD)WIDTHBYTES(bi.biWidth*bi.biBitCount);
	ImgSize=(DWORD)LineBytes*bi.biHeight;

	bf.bfType=0x4d42;
	bf.bfSize=sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+NumColors*sizeof(RGBQUAD)+ImgSize;
	bf.bfOffBits=(DWORD)(NumColors*sizeof(RGBQUAD)+sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER));
	BufSize=bf.bfSize-sizeof(BITMAPFILEHEADER);

	if((hImgData=GlobalAlloc(GHND,BufSize))==NULL){
		GlobalUnlock(hJpegBuf);
		GlobalFree(hJpegBuf);
		showerror(FUNC_MEMORY_ERROR);
		return FALSE;
	}
	lpImgData=(LPBITMAPINFOHEADER)GlobalLock(hImgData); 
	memcpy(lpImgData,(char *)&bi,sizeof(BITMAPINFOHEADER));
	lpPtr=(char *)lpImgData+sizeof(BITMAPINFOHEADER);

	if((SampRate_Y_H==0)||(SampRate_Y_V==0)){
		GlobalUnlock(hJpegBuf);
		GlobalFree(hJpegBuf);
		GlobalUnlock(hImgData);
		GlobalFree(hImgData);
		hImgData=NULL;
		showerror(FUNC_FORMAT_ERROR);
		return FALSE ;
	}

	funcret=Decode();
	if(funcret==FUNC_OK){
		hDc=GetDC(hWnd);
		hBitmap=CreateDIBitmap(hDc,	(LPBITMAPINFOHEADER)lpImgData, (LONG)CBM_INIT,
						(LPSTR)lpImgData+sizeof(BITMAPINFOHEADER) +NumColors*sizeof(RGBQUAD),
   						(LPBITMAPINFO)lpImgData, DIB_RGB_COLORS);

		hfbmp=_lcreat("c:\\jpeg2bmp.bmp",0);
		_lwrite(hfbmp,(LPSTR)&bf,sizeof(BITMAPFILEHEADER)); 
		_lwrite(hfbmp,(LPSTR)lpImgData,BufSize);
		_lclose(hfbmp);
		ReleaseDC(hWnd,hDc);
		GlobalUnlock(hJpegBuf);
		GlobalFree(hJpegBuf);
		GlobalUnlock(hImgData);
		return TRUE;
	}
	else{
		GlobalUnlock(hJpegBuf);
		GlobalFree(hJpegBuf);
		GlobalUnlock(hImgData);
		GlobalFree(hImgData);
		hImgData=NULL;
		showerror(funcret);
		return FALSE;
	}
}
/////////////////////////////////////////////////
void showerror(int funcret)
{
	switch(funcret){
	case FUNC_MEMORY_ERROR:
    	MessageBox(NULL,"Error alloc memory!","ErrorMessage",MB_OK|MB_ICONEXCLAMATION);
		break;
	case FUNC_FILE_ERROR:
    	MessageBox(NULL,"File not found!","ErrorMessage",MB_OK|MB_ICONEXCLAMATION);
		break;
	case FUNC_FORMAT_ERROR:
		MessageBox(NULL,"File format error!","Error Message",MB_OK|MB_ICONEXCLAMATION);
		break;
	}
}
////////////////////////////////////////////////////////////////////////////////
int InitTag()
{
	BOOL finish=FALSE;
	BYTE id;
	short  llength;
	short  i,j,k;
	short  huftab1,huftab2;
	short  huftabindex;
	BYTE hf_table_index;
	BYTE qt_table_index;
	BYTE comnum;

	unsigned char  *lptemp;
	short  ccount;

	lp=lpJpegBuf+2;

	while (!finish){
		id=*(lp+1);
		lp+=2;
		switch (id){
		case M_APP0:
			llength=MAKEWORD(*(lp+1),*lp);
			lp+=llength;
			break;
		case M_DQT:
			llength=MAKEWORD(*(lp+1),*lp);
			qt_table_index=(*(lp+2))&0x0f;
			lptemp=lp+3;
			if(llength<80){
				for(i=0;i<64;i++)
					qt_table[qt_table_index][i]=(short)*(lptemp++);
			}
			else{
				for(i=0;i<64;i++)
					qt_table[qt_table_index][i]=(short)*(lptemp++);
                qt_table_index=(*(lptemp++))&0x0f;
  				for(i=0;i<64;i++)
					qt_table[qt_table_index][i]=(short)*(lptemp++);
  			}
  			lp+=llength;		
			break;
		case M_SOF0:
	 		llength=MAKEWORD(*(lp+1),*lp);
	 		ImgHeight=MAKEWORD(*(lp+4),*(lp+3));
	 		ImgWidth=MAKEWORD(*(lp+6),*(lp+5));
            comp_num=*(lp+7);
		    if((comp_num!=1)&&(comp_num!=3))
	  			return FUNC_FORMAT_ERROR;
			if(comp_num==3){
				comp_index[0]=*(lp+8);
	  			SampRate_Y_H=(*(lp+9))>>4;
	  			SampRate_Y_V=(*(lp+9))&0x0f;
	  			YQtTable=(short *)qt_table[*(lp+10)];

				comp_index[1]=*(lp+11);
				SampRate_U_H=(*(lp+12))>>4;
	  			SampRate_U_V=(*(lp+12))&0x0f;
	  			UQtTable=(short *)qt_table[*(lp+13)];

	  			comp_index[2]=*(lp+14);
	  			SampRate_V_H=(*(lp+15))>>4;
	  			SampRate_V_V=(*(lp+15))&0x0f;
				VQtTable=(short *)qt_table[*(lp+16)];
	  		}
			else{
	  			comp_index[0]=*(lp+8);
				SampRate_Y_H=(*(lp+9))>>4;
	  			SampRate_Y_V=(*(lp+9))&0x0f;
	  			YQtTable=(short *)qt_table[*(lp+10)];

				comp_index[1]=*(lp+8);
	  			SampRate_U_H=1;
	  			SampRate_U_V=1;
	  			UQtTable=(short *)qt_table[*(lp+10)];

				comp_index[2]=*(lp+8);
				SampRate_V_H=1;
	  			SampRate_V_V=1;
	  			VQtTable=(short *)qt_table[*(lp+10)];
			}
  			lp+=llength;						    
			break;
		case M_DHT:             
			llength=MAKEWORD(*(lp+1),*lp);
			if (llength<0xd0){
				huftab1=(short)(*(lp+2))>>4;     //huftab1=0,1
		 		huftab2=(short)(*(lp+2))&0x0f;   //huftab2=0,1
				huftabindex=huftab1*2+huftab2;
		 		lptemp=lp+3;
				for (i=0; i<16; i++)
					code_len_table[huftabindex][i]=(short)(*(lptemp++));
				j=0;
				for (i=0; i<16; i++)
					if(code_len_table[huftabindex][i]!=0){
						k=0;
						while(k<code_len_table[huftabindex][i]){
							code_value_table[huftabindex][k+j]=(short)(*(lptemp++));
							k++;
						}
						j+=k;	
					}
				i=0;
				while (code_len_table[huftabindex][i]==0)
		 			i++;
				for (j=0;j<i;j++){
					huf_min_value[huftabindex][j]=0;
					huf_max_value[huftabindex][j]=0;
				}
				huf_min_value[huftabindex][i]=0;
				huf_max_value[huftabindex][i]=code_len_table[huftabindex][i]-1;
				for (j=i+1;j<16;j++){
					huf_min_value[huftabindex][j]=(huf_max_value[huftabindex][j-1]+1)<<1;
					huf_max_value[huftabindex][j]=huf_min_value[huftabindex][j]+code_len_table[huftabindex][j]-1;
				}
				code_pos_table[huftabindex][0]=0;
				for (j=1;j<16;j++)
		  			code_pos_table[huftabindex][j]=code_len_table[huftabindex][j-1]+code_pos_table[huftabindex][j-1];
		  		lp+=llength;
			}  //if
			else{
	 			hf_table_index=*(lp+2);
				lp+=2;
				while (hf_table_index!=0xff){
					huftab1=(short)hf_table_index>>4;     //huftab1=0,1
			 		huftab2=(short)hf_table_index&0x0f;   //huftab2=0,1
					huftabindex=huftab1*2+huftab2;
					lptemp=lp+1;
					ccount=0;
					for (i=0; i<16; i++){
						code_len_table[huftabindex][i]=(short)(*(lptemp++));
						ccount+=code_len_table[huftabindex][i];
					}
					ccount+=17;	
					j=0;
					for (i=0; i<16; i++)
						if(code_len_table[huftabindex][i]!=0){
							k=0;
							while(k<code_len_table[huftabindex][i])
							{
								code_value_table[huftabindex][k+j]=(short)(*(lptemp++));
								k++;
							}
							j+=k;
						}
					i=0;
					while (code_len_table[huftabindex][i]==0)
						i++;
					for (j=0;j<i;j++){
						huf_min_value[huftabindex][j]=0;
						huf_max_value[huftabindex][j]=0;
					}
					huf_min_value[huftabindex][i]=0;
					huf_max_value[huftabindex][i]=code_len_table[huftabindex][i]-1;
					for (j=i+1;j<16;j++){
						huf_min_value[huftabindex][j]=(huf_max_value[huftabindex][j-1]+1)<<1;
						huf_max_value[huftabindex][j]=huf_min_value[huftabindex][j]+code_len_table[huftabindex][j]-1;
					}
					code_pos_table[huftabindex][0]=0;
					for (j=1;j<16;j++)
						code_pos_table[huftabindex][j]=code_len_table[huftabindex][j-1]+code_pos_table[huftabindex][j-1];
					lp+=ccount;
					hf_table_index=*lp;
				}  //while
			}  //else
			break;
		case M_DRI:
			llength=MAKEWORD(*(lp+1),*lp);
			restart=MAKEWORD(*(lp+3),*(lp+2));
			lp+=llength;
			break;
		case M_SOS:
			llength=MAKEWORD(*(lp+1),*lp);
			comnum=*(lp+2);
			if(comnum!=comp_num)
				return FUNC_FORMAT_ERROR;
			lptemp=lp+3;
			for (i=0;i<comp_num;i++){
				if(*lptemp==comp_index[0]){
					YDcIndex=(*(lptemp+1))>>4;   //Y
					YAcIndex=((*(lptemp+1))&0x0f)+2;
				}
				else{
					UVDcIndex=(*(lptemp+1))>>4;   //U,V
					UVAcIndex=((*(lptemp+1))&0x0f)+2;
				}
				lptemp+=2;
			}
			lp+=llength;
			finish=TRUE;
			break;
		case M_EOI:    
			return FUNC_FORMAT_ERROR;
			break;
		default:
 			if ((id&0xf0)!=0xd0){
				llength=MAKEWORD(*(lp+1),*lp);
	 			lp+=llength;
			}
			else lp+=2;
			break;
  		}  //switch
	} //while
	return FUNC_OK;
}
/////////////////////////////////////////////////////////////////
void InitTable()
{
	short i,j;
	sizei=sizej=0;
	ImgWidth=ImgHeight=0;
	rrun=vvalue=0;
	BitPos=0;
	CurByte=0;
	IntervalFlag=FALSE;
	restart=0;
	for(i=0;i<3;i++)
		for(j=0;j<64;j++)
			qt_table[i][j]=0;
	comp_num=0;
	HufTabIndex=0;
	for(i=0;i<3;i++)
		comp_index[i]=0;
	for(i=0;i<4;i++)
		for(j=0;j<16;j++){
			code_len_table[i][j]=0;
			code_pos_table[i][j]=0;
			huf_max_value[i][j]=0;
			huf_min_value[i][j]=0;
		}
	for(i=0;i<4;i++)
		for(j=0;j<256;j++)
			code_value_table[i][j]=0;
	
	for(i=0;i<10*64;i++){
		MCUBuffer[i]=0;
		QtZzMCUBuffer[i]=0;
	}
	for(i=0;i<64;i++){
		Y[i]=0;
		U[i]=0;
		V[i]=0;
		BlockBuffer[i]=0;
	}
	ycoef=ucoef=vcoef=0;
}
/////////////////////////////////////////////////////////////////////////
int Decode()
{
	int funcret;

	Y_in_MCU=SampRate_Y_H*SampRate_Y_V;
	U_in_MCU=SampRate_U_H*SampRate_U_V;
	V_in_MCU=SampRate_V_H*SampRate_V_V;
	H_YtoU=SampRate_Y_H/SampRate_U_H;
	V_YtoU=SampRate_Y_V/SampRate_U_V;
	H_YtoV=SampRate_Y_H/SampRate_V_H;
	V_YtoV=SampRate_Y_V/SampRate_V_V;
	Initialize_Fast_IDCT();
	while((funcret=DecodeMCUBlock())==FUNC_OK){
		interval++;
		if((restart)&&(interval % restart==0))
			 IntervalFlag=TRUE;
		else
			IntervalFlag=FALSE;
		IQtIZzMCUComponent(0);
		IQtIZzMCUComponent(1);
		IQtIZzMCUComponent(2);
		GetYUV(0);
		GetYUV(1);
		GetYUV(2);
		StoreBuffer();
		sizej+=SampRate_Y_H*8;
		if(sizej>=ImgWidth){
			sizej=0;
			sizei+=SampRate_Y_V*8;
		}
		if ((sizej==0)&&(sizei>=ImgHeight))
			break;
		}
	return funcret;
}
/////////////////////////////////////////////////////////////////////////////////////////
void  GetYUV(short flag)
{
	short	H,VV;
	short	i,j,k,h;
	int		*buf;
	int		*pQtZzMCU;

	switch(flag){
	case 0:
		H=SampRate_Y_H;
		VV=SampRate_Y_V;
		buf=Y;
		pQtZzMCU=QtZzMCUBuffer;
		break;
	case 1:
		H=SampRate_U_H;
		VV=SampRate_U_V;
		buf=U;
		pQtZzMCU=QtZzMCUBuffer+Y_in_MCU*64;
		break;
	case 2:
		H=SampRate_V_H;
		VV=SampRate_V_V;
		buf=V;
		pQtZzMCU=QtZzMCUBuffer+(Y_in_MCU+U_in_MCU)*64;
		break;
	}
	for (i=0;i<VV;i++)
		for(j=0;j<H;j++)
			for(k=0;k<8;k++)
				for(h=0;h<8;h++)
					buf[(i*8+k)*SampRate_Y_H*8+j*8+h]=*pQtZzMCU++;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产伦一区二区三区观看体验| 亚洲日本免费电影| 最新中文字幕一区二区三区| 无吗不卡中文字幕| a在线播放不卡| 欧美mv日韩mv国产网站app| 亚洲精品久久7777| av亚洲精华国产精华| 欧美大片国产精品| 日本91福利区| 欧美日韩精品欧美日韩精品一综合| 中文字幕精品一区二区精品绿巨人| 轻轻草成人在线| 国产成人综合在线| 国产成人免费在线视频| 欧美艳星brazzers| 亚洲欧美综合网| 岛国一区二区在线观看| 精品久久久久久无| 免费成人av在线播放| 欧美三级视频在线| 亚洲国产精品久久人人爱| 成人成人成人在线视频| 日本一区二区综合亚洲| 国产成人精品影视| 欧美国产97人人爽人人喊| 国产不卡高清在线观看视频| 久久久久久亚洲综合影院红桃 | 粗大黑人巨茎大战欧美成人| 久久欧美一区二区| 成人小视频在线观看| 精品国产第一区二区三区观看体验| 亚洲国产成人av网| 欧美另类高清zo欧美| 亚洲成人免费视频| 日韩欧美激情在线| 激情图片小说一区| 中文字幕欧美激情| 91猫先生在线| 爽好多水快深点欧美视频| 欧美一二三区在线观看| 国内成人免费视频| 中文无字幕一区二区三区 | 亚洲裸体在线观看| 在线视频观看一区| 日本不卡1234视频| 久久九九久精品国产免费直播| 成人小视频免费观看| 亚洲天堂中文字幕| 欧美二区乱c少妇| 美国毛片一区二区| 欧美国产日韩在线观看| 色94色欧美sute亚洲13| 午夜精品123| 国产日韩欧美高清在线| 91福利区一区二区三区| 免费欧美高清视频| 国产精品免费免费| 欧美人与禽zozo性伦| 经典三级视频一区| 亚洲乱码中文字幕| 欧美电影免费观看高清完整版| 成人综合在线观看| 午夜精品福利一区二区三区av| 精品99一区二区三区| 91国偷自产一区二区使用方法| 美日韩一区二区| 中文字幕一区二区三区精华液| 制服丝袜中文字幕一区| 成人午夜在线播放| 日韩综合一区二区| 国产精品少妇自拍| 欧美电视剧在线看免费| 色婷婷精品久久二区二区蜜臂av| 美女诱惑一区二区| 一区二区三区四区不卡视频| ww亚洲ww在线观看国产| 欧美日韩精品电影| 97se狠狠狠综合亚洲狠狠| 久久精品国产精品亚洲红杏| 椎名由奈av一区二区三区| 欧美一区午夜精品| 91麻豆国产在线观看| 国产麻豆精品95视频| 三级精品在线观看| 亚洲天堂中文字幕| 亚洲国产精品高清| 久久久噜噜噜久久人人看| 6080国产精品一区二区| 色激情天天射综合网| 成人在线综合网| 国产很黄免费观看久久| 美女视频一区二区三区| 亚洲成人激情自拍| 亚洲亚洲精品在线观看| ㊣最新国产の精品bt伙计久久| 国产午夜一区二区三区| 精品国免费一区二区三区| 欧美福利视频导航| 欧美日韩一区二区三区四区五区| caoporm超碰国产精品| 成人免费观看av| 国产精品99久久久久久宅男| 久久99精品国产.久久久久| 天堂va蜜桃一区二区三区 | 欧美狂野另类xxxxoooo| 色综合天天天天做夜夜夜夜做| 国产成人在线免费观看| 国产精品一品视频| 国产成人精品一区二区三区四区| 国产一区二区美女| 国产一区二区三区在线观看精品| 老司机一区二区| 久久精品国产一区二区三| 蜜桃视频在线观看一区二区| 捆绑调教一区二区三区| 国产在线精品一区二区不卡了| 奇米影视在线99精品| 免费视频一区二区| 狠狠色伊人亚洲综合成人| 国产伦精一区二区三区| 国产成人三级在线观看| 成人综合婷婷国产精品久久| 成人高清在线视频| 91丨porny丨中文| 欧美日韩国产高清一区二区三区| 在线不卡a资源高清| 精品捆绑美女sm三区| 久久精品夜色噜噜亚洲a∨| 国产精品初高中害羞小美女文| |精品福利一区二区三区| 亚洲美女在线国产| 日韩影视精彩在线| 国产伦精品一区二区三区在线观看| 国产99久久久久久免费看农村| av男人天堂一区| 欧美日韩国产一二三| 欧美成人精品福利| 国产精品免费久久| 亚洲高清免费一级二级三级| 美女一区二区三区| 成人午夜电影久久影院| 欧美午夜精品久久久久久超碰 | 国产精品久久久久久久岛一牛影视 | 亚洲成人高清在线| 精品亚洲成a人在线观看| fc2成人免费人成在线观看播放| 欧美视频在线观看一区| 日韩午夜中文字幕| 国产精品久久福利| 天天亚洲美女在线视频| 国产成人综合亚洲网站| 欧美在线制服丝袜| 国产婷婷一区二区| 五月综合激情网| av在线播放成人| 欧美va日韩va| 亚洲一二三级电影| 粉嫩aⅴ一区二区三区四区 | 欧美日本免费一区二区三区| 久久久另类综合| 五月天激情综合| 91在线云播放| 久久久99精品久久| 日韩av电影免费观看高清完整版| 国产91精品露脸国语对白| 91精品国产欧美一区二区成人 | 久久99精品国产麻豆婷婷| 91麻豆国产福利精品| xf在线a精品一区二区视频网站| 亚洲一区在线观看网站| 成人综合日日夜夜| 久久久久久久久久久久电影 | 26uuu精品一区二区| 亚洲午夜免费福利视频| 成人不卡免费av| 久久久久国产成人精品亚洲午夜| 日韩精品乱码av一区二区| 在线观看日韩高清av| 国产精品国产三级国产a| 国产精品羞羞答答xxdd| 精品少妇一区二区三区| 免费国产亚洲视频| 欧美精品三级在线观看| 亚洲图片自拍偷拍| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 日本一区二区三级电影在线观看| 另类成人小视频在线| 欧美一区二区三区免费在线看 | 亚洲欧美日韩国产综合| 国产成人在线看| 国产日韩欧美综合在线| 国产精品综合一区二区| 久久久99精品免费观看不卡| 极品尤物av久久免费看| 久久精品一区二区三区不卡牛牛| 国内久久精品视频| 精品国一区二区三区| 国产一区二区不卡在线| 国产亚洲美州欧州综合国|