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

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

?? lzwcode.cpp

?? hglz壓縮算法
?? CPP
字號:
#include "stdafx.h"
#include "stdio.h"
#include "memory.h"
#include "assert.h"
#include "lzwtable.h"
#include "lzwcode.h"

/*
CDecodeBitArray
*/
CDecodeBitArray::CDecodeBitArray(DWORD dwInitWidth)// width in bit
{
	m_pbBits=NULL;
	m_dwWidthInByte=0;
	m_dwTail=m_dwHead=0;
	if(dwInitWidth)
		InitBits(dwInitWidth);
}
CDecodeBitArray::~CDecodeBitArray()
{
	ClearBits();
}
void CDecodeBitArray::ClearBits(void)
{
	if(m_pbBits)
		delete m_pbBits;
	m_dwTail=m_dwHead=0;
	m_dwWidthInByte=0;
}
void CDecodeBitArray::InitBits(DWORD dwInitWidth)
{
	ClearBits();
	DWORD dwLength=dwInitWidth/8;
	dwLength+=(dwInitWidth%8)?1:0;
	m_pbBits=new BYTE[dwLength];
	m_dwHead=m_dwTail=0;
	m_dwWidthInByte=dwLength;
}
void CDecodeBitArray::InitBytes(DWORD dwInitWidth)
{
	InitBits(dwInitWidth*8);
}
DWORD CDecodeBitArray::GetLeftBytes(void)
{
	DWORD dwLeftBytes;
	DWORD dwLeftBits=GetLeftBits();
	dwLeftBytes=dwLeftBits/8;
	dwLeftBytes+=(dwLeftBits%8)?1:0;
	return dwLeftBytes;
}
WORD CDecodeBitArray::RemoveBits(int iWidth)
{
	WORD wGet=0;
	for(int i=iWidth-1;i>=0;i--)
	{
		if(RemoveFirstBit())
			SET_BIT_1(wGet,i);
	}
	return wGet;
}
WORD CDecodeBitArray::RemoveFirstBit(void)
{
	BYTE* pbFirstByte=m_pbBits+m_dwHead/8;
	BYTE bFirstByte=*pbFirstByte;
	WORD wGet=(CHECK_BIT_1(bFirstByte,7-m_dwHead%8))?1:0;
	m_dwHead++;
	return wGet;
}
BOOL CDecodeBitArray::AddBytes(BYTE* pbAdd,int iLength)
{
	if(m_pbBits==NULL)
		return FALSE;
	Resort();
	memcpy(m_pbBits+m_dwTail/8,pbAdd,iLength);
	m_dwTail+=8*(DWORD)iLength;
	return TRUE;
}
void CDecodeBitArray::Resort(void)
{// because m_dwTail%8 always equal 0
	if(m_dwHead<8)
		return;
	if(m_dwTail==m_dwHead)
	{
		m_dwTail=m_dwHead=0;
		return;
	}
	DWORD dwLength=GetLeftBytes();
	DWORD dwHead=m_dwHead%8;
	DWORD dwMove=m_dwHead-dwHead;
	memcpy(m_pbBits,m_pbBits+(m_dwHead/8),(int)dwLength);
	m_dwHead=dwHead;
	m_dwTail-=dwMove;
}

/*
class CEncodeBitArray
*/
CEncodeBitArray::CEncodeBitArray(DWORD dwInitWidth)
{
	if(dwInitWidth==0)
		m_pbBits=NULL;
	else
		InitBits(dwInitWidth);
}
CEncodeBitArray::~CEncodeBitArray()
{
	ClearBits();
}
BOOL CEncodeBitArray::InitBits(DWORD dwInitWidth)
{
	ClearBits();
	assert(dwInitWidth);
	m_dwWidthInByte=dwInitWidth/8;
	m_dwWidthInByte+=(dwInitWidth%8)?1:0;
	m_pbBits=new BYTE[m_dwWidthInByte];
	m_dwTail=0;
	return TRUE;
}
void CEncodeBitArray::ClearBits(void)
{
	if(m_pbBits)
		delete m_pbBits;
	m_pbBits=NULL;
}
BOOL CEncodeBitArray::AddBits(WORD wAdd,int iWidth)
{
	if(m_pbBits==NULL)
		return FALSE;
	for(int i=iWidth-1;i>=0;i--)
	{
		BYTE* pbByte=m_pbBits+m_dwTail/8;
		if(CHECK_BIT_1(wAdd,i))
			SET_BIT_1(*pbByte,7-m_dwTail%8);
		else
			SET_BIT_0(*pbByte,7-m_dwTail%8);
		m_dwTail++;
	}
	return TRUE;
}
DWORD CEncodeBitArray::GetBytesWidth(void)
{
	DWORD dwBytes=m_dwTail/8;
	dwBytes+=(m_dwTail%8)?1:0;
	return dwBytes;
}
int CEncodeBitArray::RemoveBytes(BYTE *pbGet,int iWant)
{
	if(m_pbBits==NULL)
		return -1;
	int iTotal=(int)GetBytesWidth();
	if(iWant>iTotal)
		iWant=iTotal;
	if(pbGet!=NULL)
		memcpy(pbGet,m_pbBits,iWant);
	memcpy(m_pbBits,m_pbBits+iWant,iTotal-iWant);
	int iTail=(int)m_dwTail;
	iTail-=iWant*8;
	if(iTail<0)
		iTail=0;
	m_dwTail=iTail;
	return iWant;
}
BOOL CLZWDecode::BeginLZWDecode(const DWORD dwLength,// the compressed length
								FUN_LZWDECODEGETNEXTBYTES pfunLZWGetNextBytes,
								FUN_LZWDECODEPUTNEXTBYTE pfunLZWPutNextByte,
								WORD wBuffer,
								FUN_LZWDECODEDBYTES pfunLZWDecodedBytes,
								DWORD dwBytesOnce)
{
	m_dwDecodedByte=0;
	//printf("enter decode press a key\n");
	BYTE *pbNewData=new BYTE[4000],*pbOutData=new BYTE[4000];
	BYTE *pbBuffer=new BYTE[wBuffer];
	BYTE bFirst;
	m_LZWTable.InitLZWTable();
	int iBitWidth=9;
	m_iTotalEntry=LZW_BEGIN_ENTRY;
	BYTE* pbDecodedData;
	WORD wOld,wLastLen;
	m_baContain.InitBits((wBuffer+20)*8);
	int iR=0;
	DWORD dwRead=0;
	while(1)
	{
		if(m_baContain.GetLeftBytes()<5)
		{
			WORD wGetBytes=wBuffer;
			if((DWORD)wGetBytes+dwRead>dwLength)
				wGetBytes=(WORD)(dwLength-dwRead);
			if(wGetBytes!=0)
			{
				pfunLZWGetNextBytes(pbBuffer,wGetBytes);
				m_baContain.AddBytes(pbBuffer,wBuffer);
				dwRead+=wGetBytes;
			}
		}
		int iT=m_iTotalEntry+1;
		iT>>=9;
		iBitWidth=9;
		while(iT>0)
		{
			iT>>=1;
			iBitWidth++;
		}
		WORD wGet=m_baContain.RemoveBits(iBitWidth);
		if(wGet==LZW_END_CODE)
		{
			break;
		}
		if(wGet==LZW_CLEAR_CODE)
		{
			m_LZWTable.InitLZWTable();
			wGet=m_baContain.RemoveBits(9);
			if(wGet==LZW_END_CODE)
				break;
			pbDecodedData=m_LZWTable.GetMatchData(wGet);
			WriteDecode(pbDecodedData,
						pfunLZWPutNextByte,
						pfunLZWDecodedBytes,
						dwBytesOnce);
			wOld=wGet;
			m_iTotalEntry=258;
		}
		else
		{// not clear
			pbDecodedData=m_LZWTable.GetMatchData(wGet);
			if(NULL!=pbDecodedData)
			{// in table
				bFirst=pbDecodedData[2];
				WriteDecode(pbDecodedData,
							pfunLZWPutNextByte,
							pfunLZWDecodedBytes,
							dwBytesOnce);
				if(wOld!=LZW_CLEAR_CODE)
				{// not the first code be read in
					pbDecodedData=m_LZWTable.GetMatchData(wOld);
					wLastLen=*((WORD*)pbDecodedData);
					memcpy(pbNewData,pbDecodedData+2,wLastLen);
					pbNewData[wLastLen]=bFirst;
					m_LZWTable.AddToChild((WORD)m_iTotalEntry,pbNewData,wLastLen+1);
					m_iTotalEntry+=1;
				}
				wOld=wGet;
			}
			else
			{
				pbDecodedData=m_LZWTable.GetMatchData(wOld);
				bFirst=pbDecodedData[2];
				wLastLen=*((WORD*)pbDecodedData);
				memcpy(pbOutData+2,pbDecodedData+2,wLastLen);
				pbOutData[wLastLen+2]=bFirst;
				*((WORD*)pbOutData)=wLastLen+1;
				WriteDecode(pbOutData,
							pfunLZWPutNextByte,
							pfunLZWDecodedBytes,
							dwBytesOnce);
				if(m_iTotalEntry>=4096)
				{
					int _j=0;
				}
				m_LZWTable.AddToChild((WORD)m_iTotalEntry,pbOutData+2,wLastLen+1);
				m_iTotalEntry+=1;
				wOld=wGet;
			}
		}
		//pbDecodedData=table.GetMatchData(wGet);
		//WORD wLen=*((WORD*)pbDecodedData);
		//pbDecodedData+=2;
	}
	delete pbNewData;
	delete pbOutData;
	delete pbBuffer;
	return dwRead==dwLength;
}								
void CLZWDecode::WriteDecode(BYTE* pbWrite,
							FUN_LZWDECODEPUTNEXTBYTE pfunLZWPutNextByte,
							FUN_LZWDECODEDBYTES pfunLZWDecodedBytes,
							DWORD dwBytesOnce)
{
	if(pbWrite==NULL)
		return;
	WORD wLength=*((WORD*)pbWrite);
	pbWrite+=2;
	for(DWORD i=0;i<wLength;i++)
	{
		pfunLZWPutNextByte(*pbWrite);
		pbWrite++;
		if((pfunLZWDecodedBytes!=NULL)
			&& (dwBytesOnce)
			&& (m_dwDecodedByte%dwBytesOnce==0))
		{
			pfunLZWDecodedBytes();
		}
	}
	m_dwDecodedByte+=wLength;
}
void CLZWDecode::EndLZWDecode(FUN_LZWDECODEPUTNEXTBYTE pfunLZWPutNextByte)
{
}

/*
CLZWEncode
*/
BOOL CLZWEncode::BeginLZWEncode(const DWORD dwLength,
								FUN_LZWENCODEGETNEXTBYTE pfunLZWGetNextByte,
								FUN_LZWENCODEPUTNEXTBYTES pfunLZWPutNextBytes,
								WORD wBufferLen,
								FUN_LZWENCODEDBYTES pfunLZWEncodedBytes,
								DWORD dwBytesOnce)
{
	m_dwCompressedLength=0;
	int iBufferLen=wBufferLen;
	BYTE bGet;
	m_LZWTable.InitLZWTable();// init the entry table
	m_baContain.InitBits((iBufferLen+8)*8);// init the bit array
	m_baContain.AddBits(LZW_CLEAR_CODE,9);// add the first clear code
	/// below : begin the algorithm
	PLZWENCODEENTRY pCurrent=m_LZWTable.GetHead();
	int iBitWidth;
	DWORD dwEncoded=0;
	for(DWORD i=0;i<dwLength;i++)
	{// for each byte
		if(!pfunLZWGetNextByte(bGet))
			return FALSE;
		PLZWENCODEENTRY pChild=m_LZWTable.FindMatchChild(bGet,pCurrent);
		if(pChild)
		{// has found the continue
			pCurrent=pChild;
		}
		else
		{// not find write last code & add new entry 
			iBitWidth=GetBitWidth();
			WORD wW=pCurrent->wCode;
			m_baContain.AddBits(wW,iBitWidth);// add last code to buffer
			m_LZWTable.AddToChild(bGet,pCurrent);// add last code to table
			if(m_baContain.GetBytesWidth()>(DWORD)iBufferLen)
			{
				m_dwCompressedLength+=(DWORD)iBufferLen;
				pfunLZWPutNextBytes(m_baContain.GetBits(),iBufferLen);
				m_baContain.RemoveBytes(NULL,iBufferLen);
			}
			if(m_LZWTable.GetTableEntryNumber()>=(m_wMaxEntry-3))
			{
				iBitWidth=GetBitWidth();
				m_baContain.AddBits(LZW_CLEAR_CODE,iBitWidth);
				m_LZWTable.InitLZWTable();
			}
			pCurrent=m_LZWTable.FindMatchChild(bGet,m_LZWTable.GetHead());
		}
		dwEncoded++;
		if(pfunLZWEncodedBytes && dwEncoded==dwBytesOnce)         
		{
			pfunLZWEncodedBytes();
			dwEncoded=0;
		}
	}
	iBitWidth=GetBitWidth();
	m_baContain.AddBits(pCurrent->wCode,iBitWidth);// add last code to buffer
	return TRUE;
}
void CLZWEncode::EndLZWEncode(FUN_LZWENCODEPUTNEXTBYTES pfunLZWPutNextBytes)
{
	int iBitWidth=GetBitWidth();
	m_baContain.AddBits(LZW_END_CODE,iBitWidth);
	m_dwCompressedLength+=m_baContain.GetBytesWidth();
	pfunLZWPutNextBytes(m_baContain.GetBits(),(int)m_baContain.GetBytesWidth());
	m_LZWTable.ClearLZWTable();
	m_baContain.ClearBits();
};
int CLZWEncode::GetBitWidth(void)
{
	int iTotal=(int)m_LZWTable.GetTableEntryNumber();
	iTotal>>=9;
	int iBitWidth=9;
	while(iTotal>0)
	{
		iTotal>>=1;
		iBitWidth+=1;
	}
	return iBitWidth;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人白浆超碰人人人人| 欧美性色综合网| 91看片淫黄大片一级| 欧美日韩亚洲综合在线| 久久久国产精品麻豆| 一区二区三区欧美在线观看| 韩国成人精品a∨在线观看| 色偷偷88欧美精品久久久| 久久综合久久综合久久| 亚洲国产成人精品视频| 成人性视频网站| 精品国产成人在线影院 | 成人午夜视频免费看| 欧美一区二区三区免费在线看 | 亚洲精品国产无套在线观| 久久66热偷产精品| 欧美久久久久免费| 亚洲一区二区影院| 99久久99久久综合| 欧美激情一区不卡| 国产一区美女在线| 日韩一级片网站| 日韩精品色哟哟| 欧美日韩的一区二区| 亚洲风情在线资源站| 欧美曰成人黄网| 亚洲精品你懂的| 91在线观看下载| 亚洲天堂网中文字| 91偷拍与自偷拍精品| 国产精品成人一区二区艾草 | 国产精品视频线看| 国产成人一级电影| 欧美韩国一区二区| 成人免费视频app| 亚洲欧洲在线观看av| 成人av网在线| 亚洲色图一区二区| 91视频观看免费| 一区二区三区精品在线| 欧美午夜精品一区| 天天综合网天天综合色| 51精品国自产在线| 欧美a级理论片| 精品日韩av一区二区| 国产另类ts人妖一区二区| 国产丝袜欧美中文另类| av中文字幕一区| 亚洲一区二区美女| 欧美一区中文字幕| 国产主播一区二区| 国产精品久久久一区麻豆最新章节| 成人av电影免费在线播放| 国产精品少妇自拍| 91久久精品一区二区| 亚洲成人1区2区| 欧美变态tickling挠脚心| 国产麻豆精品theporn| 国产精品国产自产拍在线| 在线视频一区二区三| 奇米888四色在线精品| 久久精品亚洲国产奇米99| 一本大道久久精品懂色aⅴ| 亚洲大片精品永久免费| 久久一二三国产| 91香蕉视频mp4| 美女视频黄a大片欧美| 中文字幕av一区 二区| 色妞www精品视频| 欧美96一区二区免费视频| 国产精品免费aⅴ片在线观看| 色婷婷激情久久| 久久99九九99精品| 亚洲蜜臀av乱码久久精品蜜桃| 7777精品伊人久久久大香线蕉完整版| 国产伦精品一区二区三区在线观看| 国产精品乱人伦| 51久久夜色精品国产麻豆| 99久久免费国产| 免费高清成人在线| 亚洲精品少妇30p| 久久久精品天堂| 欧美日韩五月天| eeuss鲁片一区二区三区| 日韩1区2区日韩1区2区| 亚洲色图一区二区| 久久免费偷拍视频| 欧美老女人在线| a在线播放不卡| 国产一区91精品张津瑜| 亚洲午夜精品久久久久久久久| 欧美激情一区二区在线| 欧美不卡一区二区| 欧美午夜宅男影院| 色综合久久中文综合久久牛| 国产乱人伦偷精品视频免下载| 亚洲6080在线| 亚洲欧美另类小说视频| 中文字幕免费一区| 久久久综合九色合综国产精品| 7777精品伊人久久久大香线蕉超级流畅 | 蜜臀av一区二区在线免费观看| 亚洲自拍偷拍网站| 综合色中文字幕| 国产精品久久久久7777按摩| 久久久久久久av麻豆果冻| 欧美日韩国产乱码电影| 色婷婷精品久久二区二区蜜臂av | 国产一区二区三区黄视频| 三级不卡在线观看| 一二三四区精品视频| ...av二区三区久久精品| 国产精品理论片在线观看| 国产日韩一级二级三级| 26uuu国产电影一区二区| 精品国产电影一区二区| 久久婷婷色综合| 国产日韩欧美一区二区三区乱码| 久久久高清一区二区三区| 国产午夜亚洲精品不卡| 中文字幕欧美激情| 中文字幕一区视频| 亚洲精品国产第一综合99久久| 亚洲综合在线观看视频| 香蕉影视欧美成人| 日韩av电影免费观看高清完整版 | 亚洲国产精品久久不卡毛片| 亚洲激情五月婷婷| 亚洲成人午夜电影| 日本伊人色综合网| 久久精品国产99久久6| 国产一区二区三区黄视频 | 蜜臀va亚洲va欧美va天堂| 美女视频一区二区| 国产麻豆精品久久一二三| 成人黄色在线看| 欧美性受xxxx黑人xyx性爽| 欧美日韩国产系列| 精品国产三级a在线观看| 国产欧美一区二区精品秋霞影院 | 久久久亚洲精品石原莉奈| 中文字幕一区二区视频| 亚洲一区二区三区四区在线观看 | 亚洲1区2区3区视频| 麻豆精品久久久| 成人激情免费电影网址| 欧美性生交片4| 久久理论电影网| 一区二区免费视频| 麻豆精品视频在线观看视频| 成人国产电影网| 欧美日韩高清一区二区| 国产亚洲成av人在线观看导航| 一区二区理论电影在线观看| 狂野欧美性猛交blacked| 96av麻豆蜜桃一区二区| 欧美成人在线直播| 亚洲黄色性网站| 国产一区高清在线| 欧美在线观看禁18| 国产亚洲成av人在线观看导航| 香蕉av福利精品导航| 国产宾馆实践打屁股91| 欧美日韩不卡一区| 国产精品乱人伦| 国产真实乱子伦精品视频| 91久久精品日日躁夜夜躁欧美| 精品国产91洋老外米糕| 亚洲在线免费播放| 不卡的av中国片| 精品99999| 日本三级韩国三级欧美三级| 91精彩视频在线观看| 国产欧美日韩精品一区| 日本中文字幕一区二区有限公司| av在线一区二区三区| 国产日韩欧美综合一区| 免费av网站大全久久| 在线观看成人免费视频| 亚洲欧洲日韩一区二区三区| 国产乱码字幕精品高清av| 日韩视频不卡中文| 亚洲国产日韩a在线播放| 99精品国产99久久久久久白柏| 日本一区二区三区视频视频| 国产伦精品一区二区三区免费| 91精品在线免费| 婷婷综合五月天| 欧美日本韩国一区二区三区视频| 一区二区三区中文在线观看| 成人99免费视频| 中文字幕精品三区| 国产高清精品网站| 日本一区二区免费在线观看视频| 韩日精品视频一区| 久久综合狠狠综合久久激情| 久久99久国产精品黄毛片色诱| 91精品免费在线| 日本欧美韩国一区三区| 欧美一区国产二区|