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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? bitio.c

?? VC小波應(yīng)用 視頻編碼播放 EZW2 WAVLETS TRANSFORMER
?? C
字號(hào):
/*---------------------------------------------------------------------------*/
/*---------------------------------------------------------------------------*/
/* The codes are from the book "The Data Compression Book" by Mark Nelson 
 * and Jean-Loup Gailly, M&T Books 1996.
 *
 * I did some changes to the end of file issue, but not really successful.
 *
 * Mow-Song, Ng 2/9/2002ge
 * msng@mmu.edu.my
 * http://www.pesona.mmu.edu.my/~msng
 *
 * I do not claim copyright to the code, but if you use them or modify them,
 * please drop me a mail.
 * 
 */
/*---------------------------------------------------------------------------*/
/*---------------------------------------------------------------------------*/

#include "bitio.h"

BIT_FILE *OpenOutputBitFile(char *name )
{
	//定義比特流文件句柄
	BIT_FILE *bit_file;
	//分配相應(yīng)的數(shù)據(jù)緩存空間
   bit_file = (BIT_FILE *) calloc( 1, sizeof( BIT_FILE ) );
	//打開(kāi)磁盤(pán)文件,bit_file將獲得其句柄
	if ( bit_file == NULL )
		return( bit_file );
	bit_file->file = fopen( name, "wb" );
	//如何文件打開(kāi)失敗,返回NULL
	if (bit_file->file == NULL){
		return NULL;
	}
	//寫(xiě)入比特流文件的標(biāo)志信息
   bit_file->rack = 0;
   bit_file->mask = 0x80;
	//返回文件的有效值
	return( bit_file );
}

BIT_FILE *OpenInputBitFile(char *name )
{
	//定義比特流文件句柄
	BIT_FILE *bit_file;
	//分配相應(yīng)的數(shù)據(jù)緩存空間
   bit_file = (BIT_FILE *) calloc( 1, sizeof( BIT_FILE ) );
	//打開(kāi)磁盤(pán)文件,bit_file將獲得其句柄
	if ( bit_file == NULL )
		return( bit_file );
	bit_file->file = fopen( name, "rb" );
	//如何文件打開(kāi)失敗,返回NULL
	if (bit_file->file == NULL){
		return NULL;
	}
	//寫(xiě)入比特流文件的標(biāo)志信息
   bit_file->rack = 0;
   bit_file->mask = 0x80;
	//返回文件的有效值
	return( bit_file );

}

void CloseOutputBitFile(BIT_FILE *bit_file )
{
   if ( bit_file->mask != 0x80 )
      if ( putc( bit_file->rack, bit_file->file ) != bit_file->rack )
         BitioError("Fatal error in CloseBitFile!\n" );
		fclose( bit_file->file );
		free( (char *) bit_file );
}

void CloseInputBitFile( BIT_FILE *bit_file )
{
   fclose( bit_file->file );
   free( (char *) bit_file );
}

void OutputBit(BIT_FILE *bit_file, int bit)
{
   if ( bit ){
      bit_file->rack |= bit_file->mask;
   }
   
   bit_file->mask >>= 1;
	
   if ( bit_file->mask == 0 ) {
      if ( putc( bit_file->rack, bit_file->file ) != bit_file->rack ){
         BitioError("Fatal error in OutputBit!\n" );
      }
      bit_file->rack = 0;
      bit_file->mask = 0x80;
   }
}

void OutputBits( BIT_FILE *bit_file, unsigned long code, int count)
{
   unsigned long mask;
	
   mask = 1L << ( count - 1 );
	
   while ( mask != 0) {
      if ( mask & code ){
         bit_file->rack |= bit_file->mask;
      }
		
      bit_file->mask >>= 1;
		
      if ( bit_file->mask == 0 ) {
         if ( putc( bit_file->rack, bit_file->file ) != bit_file->rack ){
            BitioError( "Fatal error in OutputBit!\n" );
         }
         
         bit_file->rack = 0;
         bit_file->mask = 0x80;
      }
		
      mask >>= 1;
   }
}

int InputBit(BIT_FILE *bit_file, int *EOFflag)
{
   int value;
	
   *EOFflag=0;
   if ( bit_file->mask == 0x80 ){
      bit_file->rack = getc( bit_file->file );	
      if ( bit_file->rack == EOF ){
         *EOFflag=1;
		}
   }
	
   value = bit_file->rack & bit_file->mask;
   bit_file->mask >>= 1;
   
   if ( bit_file->mask == 0 ){
      bit_file->mask = 0x80;
   }
	
   return( value ? 1 : 0 );
}

unsigned long InputBits(BIT_FILE *bit_file, int bit_count, int *EOFflag)
{
   unsigned long mask;
   unsigned long return_value;
	
   *EOFflag=0;
   mask = 1L << ( bit_count - 1 );
	
   return_value = 0;
	
   while ( mask != 0) {
      if ( bit_file->mask == 0x80 ) {
         bit_file->rack = getc( bit_file->file );
         
         if ( bit_file->rack == EOF ){
            *EOFflag=1;
         }
      }
      
      if ( bit_file->rack & bit_file->mask ){
         return_value |= mask;
      }
		
      mask >>= 1;
      bit_file->mask >>= 1;
      
      if ( bit_file->mask == 0 ){
         bit_file->mask = 0x80;
      }
   }
	
   return( return_value );
}

void FilePrintBinary(FILE *file, unsigned int code, int bits)
{
   unsigned int mask;
	
   mask = 1 << ( bits - 1 );
   while ( mask != 0 ) {
      if ( code & mask ){
         fputc( '1', file );
      }
      else{
         fputc( '0', file );
      }
      mask >>= 1;
   }
}

void BitioError(char *fmt, ...)
{
	va_list argptr;
	
	va_start( argptr, fmt );
	printf( "BitioError: " );
	vprintf( fmt, argptr );
	va_end( argptr );
	exit( -1 );
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品视频全国免费看| 欧美成人在线直播| 国产尤物一区二区| 亚洲一区二区三区四区五区黄| 日韩女优制服丝袜电影| 国产蜜臀av在线一区二区三区| 欧美日韩一区二区三区在线看 | 91精品国产综合久久香蕉麻豆| 国产传媒欧美日韩成人| 青青草视频一区| 一区二区激情视频| 日韩一区在线播放| 久久久久国产精品免费免费搜索| 欧美一区二区三区在线观看视频| 色菇凉天天综合网| 99精品在线观看视频| 国产一区二区精品久久91| 日本中文一区二区三区| 亚洲精品免费在线| 国产精品乱人伦| 国产精品人妖ts系列视频| 精品国产3级a| 欧美成人精品高清在线播放| 69堂成人精品免费视频| 欧美日韩国产123区| 91福利在线免费观看| 色综合久久久久| 99久久99久久久精品齐齐| 国产99久久久久| 国产精品一区二区三区99| 激情五月婷婷综合| 久久国产欧美日韩精品| 精彩视频一区二区三区| 九一久久久久久| 精品一区二区三区欧美| 精品一区二区在线播放| 青娱乐精品在线视频| 日本不卡不码高清免费观看 | 粉嫩欧美一区二区三区高清影视| 极品销魂美女一区二区三区| 精品综合免费视频观看| 久久97超碰国产精品超碰| 国产呦萝稀缺另类资源| 国产一区不卡视频| 夫妻av一区二区| 91麻豆免费视频| 欧美天堂一区二区三区| 51精品视频一区二区三区| 日韩三级在线免费观看| xf在线a精品一区二区视频网站| 久久精品欧美一区二区三区不卡| 久久久国产精华| 国产精品久久一卡二卡| 亚洲最新视频在线观看| 日日夜夜一区二区| 国产一区二区三区视频在线播放| 国产成人夜色高潮福利影视| 不卡视频一二三四| 欧美怡红院视频| 91精品国产综合久久福利软件| 精品粉嫩超白一线天av| 国产精品视频观看| 亚洲夂夂婷婷色拍ww47| 强制捆绑调教一区二区| 日韩欧美一级精品久久| 国产欧美日韩视频一区二区| 亚洲欧美日韩国产成人精品影院| 亚洲h在线观看| 国产一区在线观看视频| 91论坛在线播放| 日韩一区二区影院| 国产精品久久久久影院亚瑟| 亚洲国产视频网站| 韩国午夜理伦三级不卡影院| 99久久精品国产毛片| 欧美一区二区三区视频在线观看 | 色吊一区二区三区| 日韩欧美你懂的| 中文字幕中文字幕一区| 日韩精品电影在线| 成人黄色在线网站| 在线成人av网站| 国产精品免费免费| 日韩制服丝袜av| av在线综合网| 欧美一区二区日韩| 国产精品久久一级| 久久99精品国产91久久来源 | 国产色婷婷亚洲99精品小说| 樱桃视频在线观看一区| 国产乱一区二区| 欧美日韩的一区二区| 国产精品久久午夜| 激情亚洲综合在线| 欧美日韩国产精选| 亚洲欧洲韩国日本视频| 青草av.久久免费一区| 91福利精品第一导航| 国产免费成人在线视频| 蜜桃91丨九色丨蝌蚪91桃色| 一本一本大道香蕉久在线精品 | 日本午夜一区二区| 99国产精品久久久久| 久久日韩粉嫩一区二区三区| 视频一区二区不卡| caoporm超碰国产精品| 久久综合久久综合久久| 亚洲二区在线观看| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美精品一区二区蜜臀亚洲| 日韩精品高清不卡| 欧美日韩在线播放| 亚洲影视资源网| 91在线观看一区二区| 国产精品青草综合久久久久99| 久久国产麻豆精品| 日韩一区二区三| 天堂成人免费av电影一区| 欧美视频一区二| 亚洲激情男女视频| 色综合久久综合| 亚洲男人的天堂一区二区| 高清国产午夜精品久久久久久| 精品国产3级a| 国产在线精品一区在线观看麻豆| 91精品国产高清一区二区三区 | 日韩电影在线观看电影| 欧美日韩国产综合一区二区| 一区二区三区中文字幕精品精品 | 一本到高清视频免费精品| 国产精品女同一区二区三区| 国产成人av电影在线| 久久久久久久久久久久电影 | 亚洲1区2区3区4区| 欧美色电影在线| 亚洲成人三级小说| 3atv一区二区三区| 偷拍日韩校园综合在线| 欧美精品免费视频| 久久精品久久99精品久久| 欧美mv和日韩mv国产网站| 久久97超碰国产精品超碰| 精品久久久久久久人人人人传媒 | 精品国产露脸精彩对白| 国产在线视频一区二区| 欧美激情一区二区在线| 99视频国产精品| 亚洲另类在线视频| 欧美日韩五月天| 久久99精品视频| 久久品道一品道久久精品| 丁香激情综合国产| 亚洲美女淫视频| 91精品国产乱码| 国产伦精品一区二区三区视频青涩 | 亚洲蜜臀av乱码久久精品| 欧美午夜理伦三级在线观看| 美腿丝袜亚洲综合| 国产欧美精品一区二区色综合| 99精品偷自拍| 日本中文字幕一区| 日本一区二区动态图| 91黄色小视频| 美女视频黄久久| 国产精品久久久久一区| 欧美丰满一区二区免费视频 | 95精品视频在线| 天天色图综合网| 久久久久国产精品厨房| 一本一本大道香蕉久在线精品 | 一本色道久久综合亚洲91| 无码av免费一区二区三区试看 | 精品久久久久久久人人人人传媒| 成人视屏免费看| 天堂一区二区在线免费观看| 久久久久88色偷偷免费| 色综合天天狠狠| 精久久久久久久久久久| 亚洲综合色视频| wwww国产精品欧美| 色欧美乱欧美15图片| 韩国视频一区二区| 亚洲一级二级在线| 国产午夜精品久久久久久久 | 一区二区三区中文在线观看| 91精品国产综合久久精品app| 成人自拍视频在线观看| 午夜精品福利一区二区蜜股av| 国产精品丝袜一区| 日韩三区在线观看| 欧美亚一区二区| 成人国产视频在线观看| 男人的天堂亚洲一区| 亚洲美腿欧美偷拍| 国产女人水真多18毛片18精品视频| 欧美日韩一区二区在线观看| 成人动漫一区二区| 黄色日韩三级电影| 天天综合日日夜夜精品| 玉米视频成人免费看|