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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? jpegdecode.c

?? STM32不完全手冊 例程源碼 29個
?? C
?? 第 1 頁 / 共 3 頁
字號:
	}
}
//Huffman Decode   MCU 出口 MCUBuffer  入口Blockbuffer[  ] 
int DecodeMCUBlock(void)
{
	short *lpMCUBuffer;
	short i,j;
	int funcret;  
	if (IntervalFlag)//差值復(fù)位 
	{			    
		lp+=2;  
		lp-=P_Cal(lp);	 
		ycoef=ucoef=vcoef=0;
		BitPos=0;
		CurByte=0;
	}
	switch(comp_num)
	{
		case 3:	 //comp_num 指圖的類型(彩色圖、灰度圖) 
			lpMCUBuffer=MCUBuffer;
			for (i=0;i<SampRate_Y_H*SampRate_Y_V;i++)  //Y
			{
				funcret=HufBlock(YDcIndex,YAcIndex);//解碼4 * (8*8) 
				if (funcret!=FUNC_OK)
					return funcret;
				BlockBuffer[0]=BlockBuffer[0]+ycoef;//直流分量是差值,所以要累加。
				ycoef=BlockBuffer[0];
				for (j=0;j<64;j++)
					*lpMCUBuffer++=BlockBuffer[j];
			}
			for (i=0;i<SampRate_U_H*SampRate_U_V;i++)  //U
			{
				funcret=HufBlock(UVDcIndex,UVAcIndex);
				if (funcret!=FUNC_OK)
					return funcret;
				BlockBuffer[0]=BlockBuffer[0]+ucoef;
				ucoef=BlockBuffer[0];
				for (j=0;j<64;j++)
					*lpMCUBuffer++=BlockBuffer[j];
			}
			for (i=0;i<SampRate_V_H*SampRate_V_V;i++)  //V
			{
				funcret=HufBlock(UVDcIndex,UVAcIndex);
				if (funcret!=FUNC_OK)
					return funcret;
				BlockBuffer[0]=BlockBuffer[0]+vcoef;
				vcoef=BlockBuffer[0];
				for (j=0;j<64;j++)
					*lpMCUBuffer++=BlockBuffer[j];
			}
			break;
		case 1:	//Gray Picture 
			lpMCUBuffer=MCUBuffer;
			funcret=HufBlock(YDcIndex,YAcIndex);
			if (funcret!=FUNC_OK)
				return funcret;
			BlockBuffer[0]=BlockBuffer[0]+ycoef;
			ycoef=BlockBuffer[0];
			for (j=0;j<64;j++)
				*lpMCUBuffer++=BlockBuffer[j];
			for (i=0;i<128;i++)
				*lpMCUBuffer++=0;
			break;
		default:
			return FUNC_FORMAT_ERROR;
	}
	return FUNC_OK;
}
//Huffman Decode (8*8) DU   出口 Blockbuffer[ ] 入口 vvalue 
int HufBlock(u8 dchufindex,u8 achufindex)
{
	short count=0;
	short i;
	int funcret;   
	//dc
	HufTabIndex=dchufindex;
	funcret=DecodeElement();
	if(funcret!=FUNC_OK)return funcret;	  
	BlockBuffer[count++]=vvalue;//解出的直流系數(shù) 
	//ac
	HufTabIndex=achufindex;
	while (count<64)
	{
		funcret=DecodeElement();
		if(funcret!=FUNC_OK)
			return funcret;
		if ((rrun==0)&&(vvalue==0))
		{
			for (i=count;i<64;i++)BlockBuffer[i]=0;	 
			count=64;
		}
		else
		{						    
			for (i=0;i<rrun;i++)BlockBuffer[count++]=0;//前面的零	 
			BlockBuffer[count++]=vvalue;//解出的值 
		}
	}
	return FUNC_OK;
}
//Huffman 解碼  每個元素   出口 vvalue 入口 讀文件ReadByte 
int DecodeElement()
{
	int thiscode,tempcode;
	unsigned short temp,valueex;
	short codelen;
	u8 hufexbyte,runsize,tempsize,sign;
	u8 newbyte,lastbyte;

	if(BitPos>=1) //BitPos指示當(dāng)前比特位置 
	{
		BitPos--;
		thiscode=(u8)CurByte>>BitPos;//取一個比特
		CurByte=CurByte&And[BitPos];   //清除取走的比特位 
	}
	else							   //取出的一個字節(jié)已用完
	{								   //新取
		lastbyte=ReadByte();		   //讀出一個字節(jié)
		BitPos--;					   //and[]:=0x0,0x1,0x3,0x7,0xf,0x1f,0x2f,0x3f,0x4f 
		newbyte=CurByte&And[BitPos];
		thiscode=lastbyte>>7;
		CurByte=newbyte;
	}
	codelen=1;
	//與Huffman表中的碼字匹配,直自找到為止 
	while ((thiscode<huf_min_value[HufTabIndex][codelen-1])||
		  (code_len_table[HufTabIndex][codelen-1]==0)||
		  (thiscode>huf_max_value[HufTabIndex][codelen-1]))
	{
		if(BitPos>=1)//取出的一個字節(jié)還有
		{
			BitPos--;
			tempcode=(u8)CurByte>>BitPos;
			CurByte=CurByte&And[BitPos];
		}
		else
		{
			lastbyte=ReadByte();
			BitPos--;
			newbyte=CurByte&And[BitPos];
			tempcode=(u8)lastbyte>>7;
			CurByte=newbyte;
		}
		thiscode=(thiscode<<1)+tempcode;
		codelen++;
		if(codelen>16)return FUNC_FORMAT_ERROR;	   
	}  //while
	temp=thiscode-huf_min_value[HufTabIndex][codelen-1]+code_pos_table[HufTabIndex][codelen-1];
	hufexbyte=(u8)code_value_table[HufTabIndex][temp];
	rrun=(short)(hufexbyte>>4);	 //一個字節(jié)中,高四位是其前面的零的個數(shù)。
	runsize=hufexbyte&0x0f;		 //后四位為后面字的尺寸
	if(runsize==0)
	{
		vvalue=0;
		return FUNC_OK;
	}
	tempsize=runsize;
	if(BitPos>=runsize)
	{
		BitPos-=runsize;
		valueex=(u8)CurByte>>BitPos;
		CurByte=CurByte&And[BitPos];
	}
	else
	{
		valueex=CurByte;
		tempsize-=BitPos;
		while(tempsize>8)
		{
			lastbyte=ReadByte();
			valueex=(valueex<<8)+(u8)lastbyte;
			tempsize-=8;
		}  //while
		lastbyte=ReadByte();
		BitPos-=tempsize;
		valueex=(valueex<<tempsize)+(lastbyte>>BitPos);
		CurByte=lastbyte&And[BitPos];
	}  //else
	sign=valueex>>(runsize-1);
	if(sign)vvalue=valueex;//解出的碼值 
	else
	{
		valueex=valueex^0xffff;
		temp=0xffff<<runsize;
		vvalue=-(short)(valueex^temp);
	}
	return FUNC_OK;
}
//反量化MCU中的每個組件   入口 MCUBuffer 出口 QtZzMCUBuffer 
void IQtIZzMCUComponent(short flag)
{
	short H,VV;
	short i,j;
	short *pQtZzMCUBuffer;
	short  *pMCUBuffer;

	switch(flag){
	case 0:
		H=SampRate_Y_H;
		VV=SampRate_Y_V;
		pMCUBuffer=MCUBuffer;
		pQtZzMCUBuffer=QtZzMCUBuffer;
		break;
	case 1:
		H=SampRate_U_H;
		VV=SampRate_U_V;
		pMCUBuffer=MCUBuffer+Y_in_MCU*64;
		pQtZzMCUBuffer=QtZzMCUBuffer+Y_in_MCU*64;
		break;
	case 2:
		H=SampRate_V_H;
		VV=SampRate_V_V;
		pMCUBuffer=MCUBuffer+(Y_in_MCU+U_in_MCU)*64;
		pQtZzMCUBuffer=QtZzMCUBuffer+(Y_in_MCU+U_in_MCU)*64;
		break;
	}
	for(i=0;i<VV;i++)
		for (j=0;j<H;j++)
			IQtIZzBlock(pMCUBuffer+(i*H+j)*64,pQtZzMCUBuffer+(i*H+j)*64,flag);
}
//要量化的字 
//反量化 8*8 DU 
void IQtIZzBlock(short  *s ,short * d,short flag)
{
	short i,j;
	short tag;
	short *pQt;
	int buffer2[8][8];
	int *buffer1;
	short offset;

	switch(flag)
	{
		case 0:	  //亮度
			pQt=YQtTable;
			offset=128;
			break;
		case 1:	  //紅
			pQt=UQtTable;
			offset=0;
			break;
		case 2:	  //藍(lán) 
			pQt=VQtTable;
			offset=0;
			break;
	}

	for(i=0;i<8;i++)
		for(j=0;j<8;j++)
		{
			tag=Zig_Zag[i][j];
			buffer2[i][j]=(int)s[tag]*(int)pQt[tag];
		}
	buffer1=(int *)buffer2;
	Fast_IDCT(buffer1);//反DCT
	for(i=0;i<8;i++)
		for(j=0;j<8;j++)
			d[i*8+j]=buffer2[i][j]+offset;
}
//快速反DCT
void Fast_IDCT(int * block)
{
	short i;		 
	for (i=0; i<8; i++)idctrow(block+8*i);	    
	for (i=0; i<8; i++)idctcol(block+i);    
}
//從源文件讀取一個字節(jié)
u8 ReadByte(void)
{
	u8 i;   						   
	i=*lp++;  
	lp-=P_Cal(lp);//經(jīng)過P_Cal的處理,把指針移動	  
	if(i==0xff)lp++;   
	BitPos=8;
	CurByte=i;
	return i;
}
//初始化快速反DCT
void Initialize_Fast_IDCT(void)
{
	short i;

	iclp = iclip+512;
	for (i= -512; i<512; i++)
		iclp[i] = (i<-256) ? -256 : ((i>255) ? 255 : i);
}
////////////////////////////////////////////////////////////////////////
void idctrow(int * blk)
{
	int x0, x1, x2, x3, x4, x5, x6, x7, x8;
	//intcut
	if (!((x1 = blk[4]<<11) | (x2 = blk[6]) | (x3 = blk[2]) |
		(x4 = blk[1]) | (x5 = blk[7]) | (x6 = blk[5]) | (x7 = blk[3])))
	{
		blk[0]=blk[1]=blk[2]=blk[3]=blk[4]=blk[5]=blk[6]=blk[7]=blk[0]<<3;
		return;
	}
	x0 = (blk[0]<<11) + 128; // for proper rounding in the fourth stage 
	//first stage
	x8 = W7*(x4+x5);
	x4 = x8 + (W1-W7)*x4;
	x5 = x8 - (W1+W7)*x5;
	x8 = W3*(x6+x7);
	x6 = x8 - (W3-W5)*x6;
	x7 = x8 - (W3+W5)*x7;
	//second stage
	x8 = x0 + x1;
	x0 -= x1;
	x1 = W6*(x3+x2);
	x2 = x1 - (W2+W6)*x2;
	x3 = x1 + (W2-W6)*x3;
	x1 = x4 + x6;
	x4 -= x6;
	x6 = x5 + x7;
	x5 -= x7;
	//third stage
	x7 = x8 + x3;
	x8 -= x3;
	x3 = x0 + x2;
	x0 -= x2;
	x2 = (181*(x4+x5)+128)>>8;
	x4 = (181*(x4-x5)+128)>>8;
	//fourth stage
	blk[0] = (x7+x1)>>8;
	blk[1] = (x3+x2)>>8;
	blk[2] = (x0+x4)>>8;
	blk[3] = (x8+x6)>>8;
	blk[4] = (x8-x6)>>8;
	blk[5] = (x0-x4)>>8;
	blk[6] = (x3-x2)>>8;
	blk[7] = (x7-x1)>>8;
}
//////////////////////////////////////////////////////////////////////////////
void idctcol(int * blk)
{
	int x0, x1, x2, x3, x4, x5, x6, x7, x8;
	//intcut
	if (!((x1 = (blk[8*4]<<8)) | (x2 = blk[8*6]) | (x3 = blk[8*2]) |
		(x4 = blk[8*1]) | (x5 = blk[8*7]) | (x6 = blk[8*5]) | (x7 = blk[8*3])))
	{
		blk[8*0]=blk[8*1]=blk[8*2]=blk[8*3]=blk[8*4]=blk[8*5]
			=blk[8*6]=blk[8*7]=iclp[(blk[8*0]+32)>>6];
		return;
	}
	x0 = (blk[8*0]<<8) + 8192;
	//first stage
	x8 = W7*(x4+x5) + 4;
	x4 = (x8+(W1-W7)*x4)>>3;
	x5 = (x8-(W1+W7)*x5)>>3;
	x8 = W3*(x6+x7) + 4;
	x6 = (x8-(W3-W5)*x6)>>3;
	x7 = (x8-(W3+W5)*x7)>>3;
	//second stage
	x8 = x0 + x1;
	x0 -= x1;
	x1 = W6*(x3+x2) + 4;
	x2 = (x1-(W2+W6)*x2)>>3;
	x3 = (x1+(W2-W6)*x3)>>3;
	x1 = x4 + x6;
	x4 -= x6;
	x6 = x5 + x7;
	x5 -= x7;
	//third stage
	x7 = x8 + x3;
	x8 -= x3;
	x3 = x0 + x2;
	x0 -= x2;
	x2 = (181*(x4+x5)+128)>>8;
	x4 = (181*(x4-x5)+128)>>8;
	//fourth stage
	blk[8*0] = iclp[(x7+x1)>>14];
	blk[8*1] = iclp[(x3+x2)>>14];
	blk[8*2] = iclp[(x0+x4)>>14];
	blk[8*3] = iclp[(x8+x6)>>14];
	blk[8*4] = iclp[(x8-x6)>>14];
	blk[8*5] = iclp[(x0-x4)>>14];
	blk[8*6] = iclp[(x3-x2)>>14];
	blk[8*7] = iclp[(x7-x1)>>14];
}
			 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2023国产一二三区日本精品2022| 色偷偷久久一区二区三区| 亚洲精品视频一区| 国产精品欧美一级免费| 中文字幕精品综合| 国产欧美视频一区二区| 国产精品乱码一区二区三区软件| 久久精品亚洲精品国产欧美 | 亚洲一区二区视频| 亚洲三级免费观看| 一区二区三区四区av| 一区二区三区在线免费观看| 亚洲私人黄色宅男| 亚洲一区电影777| 五月天中文字幕一区二区| 日本怡春院一区二区| 美脚の诱脚舐め脚责91 | 国产suv精品一区二区883| 国产成人午夜精品5599| 成人激情av网| 欧美老年两性高潮| 久久久综合精品| 亚洲丝袜另类动漫二区| 日韩电影在线观看网站| 国产成人亚洲综合a∨猫咪| 色婷婷精品大视频在线蜜桃视频| 欧美三级乱人伦电影| 2欧美一区二区三区在线观看视频| 中文字幕av一区二区三区高| 一区二区高清免费观看影视大全| 日日摸夜夜添夜夜添国产精品| 久久精品国产网站| 一本色道综合亚洲| 日韩精品一区二区三区视频在线观看 | av一区二区三区| 欧美日韩电影在线| 亚洲国产成人一区二区三区| 亚洲激情在线激情| 国产精品夜夜嗨| 欧美一区二区精品久久911| 国产精品三级av| 免费国产亚洲视频| 日本丶国产丶欧美色综合| 日韩欧美高清一区| 亚洲一级不卡视频| 99久久99久久精品免费看蜜桃| 欧美精品三级日韩久久| 中文字幕永久在线不卡| 极品美女销魂一区二区三区免费| 97国产一区二区| 国产午夜精品一区二区三区视频 | 亚洲国产精品传媒在线观看| 午夜精品久久久久久久久久| 成人免费高清视频在线观看| 日韩欧美国产三级电影视频| 亚洲线精品一区二区三区| 成人开心网精品视频| 欧美草草影院在线视频| 日韩电影免费在线| 欧美日韩不卡视频| 亚洲电影第三页| 在线亚洲人成电影网站色www| 国产女人水真多18毛片18精品视频 | 日韩欧美高清dvd碟片| 亚洲午夜三级在线| 91国产免费观看| 国产精品久久久一本精品| 国产麻豆成人精品| 久久午夜国产精品| 国产资源在线一区| 久久久久久久综合狠狠综合| 麻豆国产欧美一区二区三区| 7777精品伊人久久久大香线蕉的| 午夜亚洲国产au精品一区二区| 91成人国产精品| 亚洲一区二区三区精品在线| 91福利在线观看| 亚洲国产视频在线| 日本久久电影网| 亚洲国产精品一区二区久久恐怖片| 日本黄色一区二区| 亚洲一区二区三区在线看| 欧洲中文字幕精品| 日韩激情一区二区| 日韩欧美资源站| 国产麻豆精品一区二区| 欧美国产综合一区二区| 91网站最新地址| 五月综合激情婷婷六月色窝| 91麻豆精品国产91久久久久| 亚洲高清中文字幕| 日韩女优av电影在线观看| 国产一区二区0| 最新欧美精品一区二区三区| 色妹子一区二区| 琪琪久久久久日韩精品| 亚洲精品在线观看视频| 99久久er热在这里只有精品66| 亚洲午夜精品17c| 欧美成人福利视频| 97se亚洲国产综合自在线| 一区二区成人在线视频| 欧美成人精精品一区二区频| 成人性生交大合| 午夜电影一区二区三区| 久久久久久久综合日本| 色综合久久综合网| 久久成人久久鬼色| 亚洲视频精选在线| 日韩欧美一二区| 色系网站成人免费| 国产乱码精品一品二品| 亚洲乱码国产乱码精品精的特点 | 国产成人午夜99999| 亚洲精品成人精品456| 精品国免费一区二区三区| 97超碰欧美中文字幕| 精品一区二区三区免费播放| 亚洲精品写真福利| 国产午夜精品福利| 7777精品伊人久久久大香线蕉的| 色播五月激情综合网| 欧美日韩国产成人在线免费| 国产盗摄一区二区三区| 日韩国产欧美三级| 国产精品对白交换视频| www国产亚洲精品久久麻豆| 欧美亚洲国产一区在线观看网站| 精品在线播放免费| 亚洲第一会所有码转帖| 国产精品欧美经典| 国产婷婷一区二区| 精品乱人伦小说| 欧美高清一级片在线| 91国偷自产一区二区三区观看| 国产成人免费在线| 韩国av一区二区三区在线观看| 午夜不卡av免费| 亚洲专区一二三| 综合久久一区二区三区| 国产清纯美女被跳蛋高潮一区二区久久w | 亚洲综合色视频| 日韩毛片精品高清免费| 国产欧美精品国产国产专区| 欧美成人精品1314www| 欧美精品久久99| 欧美亚洲高清一区二区三区不卡| av电影在线观看不卡| www.在线欧美| 91在线观看一区二区| 色狠狠av一区二区三区| 成+人+亚洲+综合天堂| 岛国一区二区在线观看| 国产成人午夜视频| 成熟亚洲日本毛茸茸凸凹| 国产suv精品一区二区三区| 国产69精品久久久久777| 国产高清久久久久| 成人h动漫精品| 91视频.com| 欧洲精品一区二区三区在线观看| 欧美综合久久久| 欧美日韩精品一区二区三区蜜桃 | 日韩精品电影一区亚洲| 日韩精品国产欧美| 精品亚洲国产成人av制服丝袜| 国产美女精品人人做人人爽| 国产suv一区二区三区88区| www.久久精品| 欧美性感一类影片在线播放| 欧美精品在欧美一区二区少妇| 欧美一区三区二区| 欧美不卡一区二区| 国产精品三级av| 亚洲尤物视频在线| 美女mm1313爽爽久久久蜜臀| 久久精品国产99| 成人激情校园春色| 欧美日韩精品高清| 久久精品一区二区三区四区| 国产精品不卡在线| 奇米一区二区三区av| 岛国av在线一区| 欧美日韩精品免费| 国产欧美在线观看一区| 亚洲精品v日韩精品| 久久99精品久久久久久国产越南| av成人免费在线观看| 91精品国产色综合久久久蜜香臀| 2023国产精华国产精品| 一区二区国产视频| 国产二区国产一区在线观看| 欧美在线综合视频| 久久久午夜电影| 夜夜嗨av一区二区三区四季av| 日韩电影在线看| 91福利精品视频| 国产精品入口麻豆原神| 蜜臀a∨国产成人精品| 91丨九色porny丨蝌蚪|