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

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

?? bitstrm.cpp

?? visual c++小波技術和工程實踐隨書光盤
?? CPP
?? 第 1 頁 / 共 2 頁
字號:

Int CInBitStream::eof () const
{
	if(m_uNumOfBitsInBuffer==0)
		return (m_pInStream->eof())?(EOF):0;
	else
		return 0;
}

Int CInBitStream::peekBits (const UInt numBits) const
{
	assert (numBits <= 32);
	UInt iBitsToRet;
	Int nBitsToPeek = numBits - m_uNumOfBitsInBuffer;

	if (nBitsToPeek <= 0)
		iBitsToRet = getbit (m_chDecBuffer, 7, numBits);
	else
	{
		streampos strmpos = m_pInStream->tellg();
		Int eofstate = m_pInStream->eof();
		iBitsToRet = getbit (m_chDecBuffer, 7, m_uNumOfBitsInBuffer);
		for (; nBitsToPeek > 0; nBitsToPeek -= 8) {
			int chNext = m_pInStream->get();			//get the next ch
			Int iNext = chNext & 0x000000FF;			//clean the upper bits 
			if (nBitsToPeek < 8){						//fractional char
				iNext = iNext >> (8 - nBitsToPeek);
				iBitsToRet = iNext | (iBitsToRet << nBitsToPeek);
			}
			else	{
				iBitsToRet = iBitsToRet << 8;			//full char
				iBitsToRet |= iNext;
			}
		}
		m_pInStream->seekg (strmpos);		// reset the strm ptr pos
		if(eofstate==0)
			m_pInStream->clear();				// get rid of new eofs
	}			
	
	return iBitsToRet;		
}

Int CInBitStream::peekOneBit (const UInt numBits) const
{
	Int iBit,chNext;
	Int nBitsToPeek = numBits - m_uNumOfBitsInBuffer;
	
	if(nBitsToPeek<=0)
		iBit=m_chDecBuffer&(256>>numBits);
	else
	{
		streampos strmpos = m_pInStream->tellg();
		Int eofstate = m_pInStream->eof();
		for (; nBitsToPeek > 0; nBitsToPeek -= 8)
			chNext = m_pInStream->get();
		nBitsToPeek += 8;
		iBit=chNext&(256>>nBitsToPeek);
		m_pInStream->seekg (strmpos);		// reset the strm ptr pos
		if(eofstate==0)
			m_pInStream->clear();				// get rid of new eofs
	}

	return iBit!=0;
}

//wchen-9-30-97: peekflush () function name changed
//wchen-9-30-97: matching of stuffing bits done outside bitstrm.cpp because bitstrm.cpp should be generic 
//	Added for error resilience mode By Toshiba
Int CInBitStream::peekBitsTillByteAlign (Int& nBitsToPeek) const
{
	assert (m_uNumOfBitsInBuffer != 8);
//	if(m_bFlashEnable){
	nBitsToPeek = (m_uNumOfBitsInBuffer == 0) ? 8 : m_uNumOfBitsInBuffer;
	return peekBits(nBitsToPeek);
//	}
//	return 0;
}

//wchen-9-30-97: function name changed
//added by toshiba for error resilience
//	Modified for error resilient mode by Toshiba(1997-11-14)
Int CInBitStream::peekBitsFromByteAlign (Int nBitsToPeek) const
//Int CInBitStream::peekBitsFromByteAlign (UInt nBitsToPeek) const
//	End Toshiba(1997-11-14)
{
	assert (nBitsToPeek <= 32);
	UInt iBitsToRet = 0;

//	if (nBitsToPeek <= 0)
//		iBitsToRet = getbit (m_chDecBuffer, 7, numBits);
	//wchen-9-30-97
	if (nBitsToPeek == 0)		// UInt can never to negative
		return 0;				// no need to call get bits
	else
	{
		streampos strmpos = m_pInStream->tellg();
		Int eofstate = m_pInStream->eof();
		if (m_uNumOfBitsInBuffer==0)	
			m_pInStream->get();	//length of stuffing bit = 8bits
		for (; nBitsToPeek > 0; nBitsToPeek -= 8) {
			Int chNext = m_pInStream->get();			//get the next ch
			Int iNext = chNext & 0x000000FF;			//clean the upper bits 
			if (nBitsToPeek < 8){						//fractional char
				iNext = iNext >> (8 - nBitsToPeek);
				iBitsToRet = iNext | (iBitsToRet << nBitsToPeek);
			}
			else	{
				iBitsToRet = iBitsToRet << 8;			//full char
				iBitsToRet |= iNext;
			}
		}
		m_pInStream->seekg (strmpos);		// reset the strm ptr pos
		if (eofstate==0)
			m_pInStream->clear();				// get rid of new eofs
	}
	return iBitsToRet;		
}

Void COutBitStream::putBits (Char *pBits, Int lNOfBits)
{
    assert(lNOfBits>=0);
    while(lNOfBits>0)
    {
        if(lNOfBits>8)
        {
            putBitsC((Int)(*pBits),8);
            lNOfBits-=8;
            pBits++;
        }
        else
        {
            putBitsC((Int)(*pBits),(UInt)lNOfBits);
            break;
        }
    }
}

Void COutBitStream::putBitStream(COutBitStream &cStrm)
{
	cStrm.m_pchBufferRun[0]=cStrm.m_chEncBuffer >> cStrm.m_uEncNumEmptyBits;
	putBits(cStrm.m_pchBuffer,cStrm.m_lCounter);
}

Int COutBitStream::flush ()
{
	Int nBits = 0;
	if (m_uEncNumEmptyBits != 8) {
		nBits = m_uEncNumEmptyBits;
		putBits ((Int) 0, (UInt) 1);
		putBits ((Int) 0xFFFF, nBits - 1);

/*
		*m_pchBufferRun++ = m_chEncBuffer;
		m_iBuffer++;
		m_lCounter += m_uEncNumEmptyBits;
		nBits = m_uEncNumEmptyBits;
		m_uEncNumEmptyBits = 8;
		m_chEncBuffer = 0;
*/
	}
	else	{
		nBits = 8;
		putBits ((Int) 0x007F, nBits);
	}
	return nBits;
}

Void COutBitStream::trace (const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName;
		m_pstrmTrace->flush ();
	}
}

Void COutBitStream::trace (Int iValue, const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName << "= ";
		(*m_pstrmTrace) << iValue << "\n";
		m_pstrmTrace->flush ();
	}
}

Void COutBitStream::trace (UInt uiValue, const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName << "= ";
		(*m_pstrmTrace) << uiValue << "\n";
		m_pstrmTrace->flush ();
	}
}

Void COutBitStream::trace (Float fltValue, const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName << "= ";
		(*m_pstrmTrace) << fltValue << "\n";
		m_pstrmTrace->flush ();
	}
}

#ifndef __DOUBLE_PRECISION_
Void COutBitStream::trace (Double dblValue, const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName << "= ";
		(*m_pstrmTrace) << dblValue << "\n";
		m_pstrmTrace->flush ();
	}
}
#endif

Void COutBitStream::trace (const CMotionVector& mvValue, const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName << "= ";
		(*m_pstrmTrace) << mvValue.iMVX + mvValue.iMVX + mvValue.iHalfX << ", ";
		(*m_pstrmTrace) << mvValue.iMVY + mvValue.iMVY + mvValue.iHalfY << "\n ";
		m_pstrmTrace->flush ();
	}
}

Void COutBitStream::trace (const CVector2D& vctValue, const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName << "= ";
		(*m_pstrmTrace) << vctValue.x << ", ";
		(*m_pstrmTrace) << vctValue.y << "\n ";
		m_pstrmTrace->flush ();
	}
}

Void COutBitStream::trace (const CSite& stValue, const Char* rgchSymbolName)
{
	if (m_pstrmTrace != NULL)	{
		m_pstrmTrace->width (20);
		(*m_pstrmTrace) << rgchSymbolName << "= ";
		(*m_pstrmTrace) << stValue.x << ", ";
		(*m_pstrmTrace) << stValue.y << "\n ";
		m_pstrmTrace->flush ();
	}
}

Void COutBitStream::trace (const CFloatImage* pfi, const Char* rgchSymbolName, CRct rct)
{
	if (m_pstrmTrace == NULL)
		return;
	Int iValue;
	(*m_pstrmTrace) << rgchSymbolName << "= \n";
	if (rct.valid ())	{
		for (CoordI iY = rct.top; iY < rct.bottom; iY++)	{
			const PixelF* ppxlf = pfi->pixels (rct.left, iY);
			for (CoordI iX = rct.left; iX < rct.right; iX++)	{	
				iValue = (Int) *ppxlf;
				(*m_pstrmTrace) << iValue << " ";
				ppxlf++;
			}
			(*m_pstrmTrace) << "\n";
		}

	}
	else	{
		const PixelF* ppxlf = pfi->pixels ();
		for (CoordI iY = pfi->where ().top; iY < pfi->where ().bottom; iY++)	{
			for (CoordI iX = pfi->where ().left; iX < pfi->where ().right; iX++)	{	
				iValue = (Int) *ppxlf;
				(*m_pstrmTrace) << iValue << " ";
				ppxlf++;
			}
			(*m_pstrmTrace) << "\n";
		}
	}
	m_pstrmTrace->flush ();
}

Void COutBitStream::trace (const Float* ppxlf, UInt cElem, const Char* rgchSymbolName)
{
	if (m_pstrmTrace == NULL)
			return;	
	Int iValue;	
	(*m_pstrmTrace) << rgchSymbolName << ": \n";
	for (UInt iElem = 0; iElem < cElem; iElem++)	{
			iValue = (Int) *ppxlf;
			(*m_pstrmTrace) << iValue << " ";
			ppxlf++;
	}
	(*m_pstrmTrace) << "\n";
	m_pstrmTrace->flush ();
}

Void COutBitStream::trace (const Int* rgi, UInt cElem, const Char* rgchSymbolName)
{
	if (m_pstrmTrace == NULL)
		return;	
	(*m_pstrmTrace) << rgchSymbolName << ": \n";
	for (UInt iElem = 0; iElem < cElem; iElem++)	{
		(*m_pstrmTrace) << *rgi++ << " ";
	}
	(*m_pstrmTrace) << "\n";
	m_pstrmTrace->flush ();
}

Void COutBitStream::trace (const PixelC* rgpxlc, Int cCol, Int cRow, const Char* rgchSymbolName)	//this is for tracing shape buffers
{
	if (m_pstrmTrace == NULL)
		return;	
	(*m_pstrmTrace) << rgchSymbolName << ": \n";
	for (Int iRow = -1; iRow < cRow; iRow++)	{
		for (Int iCol = -1; iCol < cCol; iCol++)	{
			if (iRow == -1)
				(*m_pstrmTrace) << "-";
			else if (iCol == -1)	{
				m_pstrmTrace->width (2);
				(*m_pstrmTrace) << iRow << "|"; 
			}
			else
				(*m_pstrmTrace) << (*rgpxlc++ == OPAQUE); 
		}
		(*m_pstrmTrace) << "\n";		
	}
	m_pstrmTrace->flush ();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av电影在线观看一区| 国产精品欧美精品| 欧美精品一区男女天堂| 九色porny丨国产精品| 成人综合在线视频| 91国模大尺度私拍在线视频| 欧美一区二区在线播放| 中文字幕av一区二区三区高| 夜夜精品视频一区二区| 久久91精品久久久久久秒播| 成人av网站免费| 欧美疯狂做受xxxx富婆| 日本一区二区三级电影在线观看| 亚洲一区二区三区视频在线播放 | 国产成人精品免费在线| 色综合久久88色综合天天| 日韩欧美一区二区免费| 国产精品国产自产拍高清av| 日本大胆欧美人术艺术动态| 成人午夜免费av| 欧美一区二区啪啪| 亚洲日韩欧美一区二区在线| 美女性感视频久久| 99精品国产视频| 欧美成人vr18sexvr| 亚洲综合激情另类小说区| 国内精品不卡在线| 欧洲国内综合视频| 国产丝袜美腿一区二区三区| 亚洲福中文字幕伊人影院| 国产精品一区二区果冻传媒| 欧美三片在线视频观看| 亚洲国产精华液网站w| 久久精品国产在热久久| 欧美视频一区二区在线观看| 中文字幕在线不卡一区| 国产资源在线一区| 欧美日韩一区小说| 亚洲色大成网站www久久九九| 韩国精品一区二区| 欧美久久久久久久久中文字幕| 中文字幕亚洲在| 国产麻豆91精品| 日韩欧美一区二区不卡| 欧美最猛性xxxxx直播| 中文在线免费一区三区高中清不卡 | 天天色综合天天| caoporm超碰国产精品| 久久先锋影音av鲁色资源| 日韩精品欧美精品| 日本韩国精品在线| 亚洲女子a中天字幕| 成人黄色软件下载| 久久精品欧美一区二区三区不卡| 日韩和欧美一区二区三区| 在线一区二区三区四区五区 | 国产91精品露脸国语对白| 精品乱码亚洲一区二区不卡| 亚洲成年人影院| 欧美日韩高清影院| 亚洲在线观看免费视频| 91视视频在线观看入口直接观看www| 久久影院视频免费| 狠狠久久亚洲欧美| 91精品黄色片免费大全| 亚洲大片免费看| 欧美色电影在线| 日韩国产欧美在线播放| 555www色欧美视频| 日本特黄久久久高潮| 欧美精品亚洲二区| 日韩精品1区2区3区| 69久久夜色精品国产69蝌蚪网| 亚洲国产精品精华液网站| 欧美色欧美亚洲另类二区| 亚洲在线免费播放| 91麻豆精品国产91久久久久久| 偷拍自拍另类欧美| 日韩欧美中文字幕精品| 久久国产夜色精品鲁鲁99| 精品国产凹凸成av人导航| 国产一区二区三区在线观看免费 | 老司机一区二区| 欧美精品一区二区三区在线播放| 国产乱子轮精品视频| 国产日韩v精品一区二区| 国产传媒日韩欧美成人| 国产精品久久影院| 91网上在线视频| 亚洲一区二区欧美| 日韩免费观看高清完整版在线观看| 久久精品免费看| 中文字幕欧美日韩一区| 91色综合久久久久婷婷| 亚洲成人自拍偷拍| 日韩欧美国产综合| 成人免费看视频| 一区二区三区欧美在线观看| 91精品国产综合久久久久久久久久| 老司机午夜精品99久久| 欧美国产日产图区| 91黄色免费网站| 久久99久久99| 国产精品麻豆视频| 欧美色视频在线观看| 美国欧美日韩国产在线播放| 中文字幕欧美日韩一区| 欧美性受xxxx| 久久99精品久久久久久国产越南| 亚洲国产高清不卡| 欧美日韩国产小视频| 韩国欧美国产1区| 亚洲丝袜精品丝袜在线| 欧美美女激情18p| 成人小视频在线观看| 亚洲高清免费在线| 国产欧美一区二区精品忘忧草| 日本丰满少妇一区二区三区| 久久成人免费网| 亚洲区小说区图片区qvod| 日韩欧美在线影院| 97国产一区二区| 精东粉嫩av免费一区二区三区 | 色88888久久久久久影院按摩| 免费欧美日韩国产三级电影| 欧美国产一区视频在线观看| 欧美日韩国产高清一区二区| 成人午夜免费av| 日本aⅴ免费视频一区二区三区| 中文字幕乱码一区二区免费| 91精品国产色综合久久不卡蜜臀| 丰满放荡岳乱妇91ww| 视频一区中文字幕| 综合在线观看色| 精品免费日韩av| 欧美日韩精品福利| 成人精品国产福利| 蜜桃av一区二区三区电影| 亚洲人xxxx| 欧美激情综合在线| 日韩午夜在线影院| 欧美在线观看视频在线| 国产精品99久久久久久宅男| 午夜免费久久看| 亚洲精品国产a| 国产喂奶挤奶一区二区三区| 欧美一区二区三区免费大片 | 怡红院av一区二区三区| 国产三级精品三级| 欧美一级高清大全免费观看| 91福利社在线观看| 成人三级伦理片| 激情综合一区二区三区| 午夜久久福利影院| 亚洲精品欧美激情| 国产精品私人影院| 2020日本不卡一区二区视频| 在线成人av网站| 欧美主播一区二区三区| 懂色中文一区二区在线播放| 久久er99热精品一区二区| 日韩精品午夜视频| 亚洲成av人片一区二区梦乃 | 欧美日韩大陆在线| 欧美亚洲禁片免费| 在线一区二区三区| 色综合久久中文字幕| 成人性生交大合| 成人福利在线看| 成人a免费在线看| 粉嫩av一区二区三区| 国产尤物一区二区| 国模套图日韩精品一区二区| 久久精品国产秦先生| 美女mm1313爽爽久久久蜜臀| 日本成人中文字幕在线视频| 日韩精品亚洲一区二区三区免费| 亚洲第一福利一区| 亚洲大尺度视频在线观看| 亚洲小说春色综合另类电影| 尤物av一区二区| 亚洲综合视频在线观看| 亚洲一区二区免费视频| 亚洲成av人片在线| 日本系列欧美系列| 免费成人性网站| 蜜桃91丨九色丨蝌蚪91桃色| 久草中文综合在线| 国内外精品视频| 粉嫩高潮美女一区二区三区| 成人精品视频一区二区三区| 国产成人在线观看免费网站| 岛国av在线一区| 色综合天天天天做夜夜夜夜做| 91亚洲精品久久久蜜桃| 91成人免费在线视频| 在线播放国产精品二区一二区四区| 欧美精品乱码久久久久久| 日韩视频在线永久播放| 欧美mv日韩mv国产网站app|