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

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

?? countbit.cpp

?? 通過源代碼詳細的介紹了VC++的用法
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
////////////////////////////////////////////////////////////////////////////
//
//
//    Project     : VideoNet version 1.1.
//    Description : Peer to Peer Video Conferencing over the LAN.
//	  Author      :	Nagareshwar Y Talekar ( nsry2002@yahoo.co.in)
//    Date        : 15-6-2004.
//
//    I have converted origional fast h.263 encoder library from C to C++ 
//	  so that it can be integrated into any windows application easily.
//	  I have removed some of unnecessary codes/files from the
//	  fast h263 library.Also moved definitions and declarations
//	  in their proper .h and .cpp files.
//
//    File description : 
//    Name    : countbit.cpp
//
//
/////////////////////////////////////////////////////////////////////////////

/************************************************* * libr263: fast H.263 encoder library * * Copyright (C) 1996, Roalt Aalmoes, Twente University * SPA multimedia group * * Based on Telenor TMN 1.6 encoder (Copyright (C) 1995, Telenor R&D) * created by Karl Lillevold  * * Author encoder: Roalt Aalmoes, <aalmoes@huygens.nl> *  * Date: 31-07-96 **************************************************/ /********************************************************************** * *	Name:		CountBitsMB *	Description:    counts bits used for MB info
 *	
 *	Input:	        Mode, COD, CBP, Picture and Bits structures
 *	Returns:       
 *	Side effects:
 *
 *	Date: 941129	Author: Karl.Lillevold@nta.no * ***********************************************************************/
#include "countbit.h"

void CountBitsMB(int Mode, int COD, int CBP, int CBPB, Pict *pic, Bits *bits){  extern EHUFF *vlc_cbpy, *vlc_cbpcm, *vlc_cbpcm_intra;  int cbpy, cbpcm, length;  /* COD */  if (Global::trace) {    fprintf(Global::tf,"MB-nr: %d",pic->MB);    if (pic->picture_coding_type == PCT_INTER)      fprintf(Global::tf,"  COD: %d\n",COD);  }  if (pic->picture_coding_type == PCT_INTER) {    mputv(1,COD);    bits->COD++;  }  if (COD)     return;    /* not coded */  /* CBPCM */  cbpcm = Mode | ((CBP&3)<<4);  if (Global::trace) {    fprintf(Global::tf,"CBPCM (CBP=%d) (cbpcm=%d): ",CBP,cbpcm);  }  if (pic->picture_coding_type == PCT_INTRA) {    length = Encode(cbpcm,vlc_cbpcm_intra);  } else {    length = Encode(cbpcm,vlc_cbpcm);  }  bits->CBPCM += length;      /* CBPY */  cbpy = CBP>>2;  if (Mode == MODE_INTRA || Mode == MODE_INTRA_Q) /* Intra */    cbpy = cbpy^15;  if (Global::trace) {    fprintf(Global::tf,"CBPY (CBP=%d) (cbpy=%d): ",CBP,cbpy);  }  length = Encode(cbpy, vlc_cbpy);  bits->CBPY += length;    return;}/********************************************************************** * *	Name:		CountBitsSlice *	Description:    couonts bits used for slice (GOB) info *	 *	Input:	        slice no., quantizer * *	Date: 94????	Author: Karl.Lillevold@nta.no * ***********************************************************************/int CountBitsSlice(int slice, int quant){  int bits = 0;  /* Picture Start Code */  if (Global::trace)    fprintf(Global::tf,"GOB sync (GBSC): ");  mputv(PSC_LENGTH,PSC); /* PSC */  bits += PSC_LENGTH;  /* Group Number */  if (Global::trace)    fprintf(Global::tf,"GN: ");  mputv(5,slice);  bits += 5;  /* GOB Sub Bitstream Indicator */  /* if CPM == 1: read 2 bits GSBI */  /* not supported in this version */  /* GOB Frame ID */  if (Global::trace)    fprintf(Global::tf,"GFID: ");  mputv(2, 0);    /* NB: in error-prone environments this value should change if      PTYPE in picture header changes. In this version of the encoder     PTYPE only changes when PB-frames are used in the following cases:     (i) after the first intra frame     (ii) if the distance between two P-frames is very large      Therefore I haven't implemented this GFID change */  /* GFID is not allowed to change unless PTYPE changes */  bits += 2;  /* Gquant */  if (Global::trace)    fprintf(Global::tf,"GQUANT: ");  mputv(5,quant);  bits += 5;  return bits;}/********************************************************************** * *	Name:		CountBitsCoeff *	Description:	counts bits used for coeffs *	 *	Input:		qcoeff, coding mode CBP, bits structure, no. of  *                      coeffs *			 *	Returns:	struct with no. of bits used *	Side effects:	 * *	Date: 940111	Author:	Karl.Lillevold@nta.no * ***********************************************************************/void CountBitsCoeff(int *qcoeff, int Mode, int CBP, Bits *bits, int ncoeffs){    int i;  if (Mode == MODE_INTRA) {    for (i = 0; i < 4; i++) {      bits->Y += CodeCoeff(Mode, qcoeff,i,ncoeffs);    }    for (i = 4; i < 6; i++) {      bits->C += CodeCoeff(Mode, qcoeff,i,ncoeffs);    }  }  else {    for (i = 0; i < 4; i++) {      if ((i==0 && CBP&32) || 	  (i==1 && CBP&16) ||	  (i==2 && CBP&8) || 	  (i==3 && CBP&4) || 	  (i==4 && CBP&2) ||	  (i==5 && CBP&1)) {	bits->Y += CodeCoeff(Mode, qcoeff, i, ncoeffs);      }    }    for (i = 4; i < 6; i++) {      if ((i==0 && CBP&32) || 	  (i==1 && CBP&16) ||	  (i==2 && CBP&8) || 	  (i==3 && CBP&4) || 	  (i==4 && CBP&2) ||	  (i==5 && CBP&1)) {	bits->C += CodeCoeff(Mode, qcoeff, i, ncoeffs);      }    }  }  return;}  int CodeCoeff(int Mode, int *qcoeff, int block, int ncoeffs){  int j, bits;  int prev_run, run, prev_level, level, first;  int prev_ind, ind, prev_s, s, length;  extern EHUFF *vlc_3d;  run = bits = 0;  first = 1;  prev_run = prev_level = prev_ind = level = s = prev_s = ind = 0;    for (j = block*ncoeffs; j< (block + 1)*ncoeffs; j++) {    /* Do this block's DC-coefficient first */    if (!(j%ncoeffs) && (Mode == MODE_INTRA)) {      /* DC coeff */      if (Global::trace) {	fprintf(Global::tf,"DC: ");      }      if (qcoeff[block*ncoeffs] != 128)	mputv(8,qcoeff[block*ncoeffs]);      else	mputv(8,255);      bits += 8;    }    else {      /* AC coeff */      s = 0;      /* Increment run if coeff is zero */      if ((level = qcoeff[j]) == 0) {	run++;      }      else {	/* code run & level and count bits */	if (level < 0) {	  s = 1;	  level = -level;	}	ind = level | run<<4;	ind = ind | 0<<12; /* Not last coeff */	if (!first) {	  /* Encode the previous ind */	  if (prev_level  < 13 && prev_run < 64) {	    length = Encode(prev_ind,vlc_3d);	  } else	    length = 0;	  if (length == 0) {  /* Escape coding */	    if (Global::trace) {	      fprintf(Global::tf,"Escape coding:\n");	    }	    if (prev_s == 1) {prev_level = (prev_level^0xff)+1;}	    Encode(ESCAPE,vlc_3d);	    mputv(1,0);	    mputv(6,prev_run);	    mputv(8,prev_level);	    bits += 22;	  }	  else {	    mputv(1,prev_s);	    bits += length + 1;	  }	}	prev_run = run; prev_s = s;	prev_level = level; prev_ind = ind;	run = first = 0;      }    }  }  /* Encode the last coeff */  if (!first) {    if (Global::trace) {      fprintf(Global::tf,"Last coeff: ");    }    prev_ind = prev_ind | 1<<12;   /* last coeff */    if (prev_level  < 13 && prev_run < 64) {       length = Encode(prev_ind,vlc_3d);    } else      length = 0;    if (length == 0) {  /* Escape coding */      if (Global::trace) {	fprintf(Global::tf,"Escape coding:\n");      }      if (prev_s == 1) {prev_level = (prev_level^0xff)+1;}      Encode(ESCAPE,vlc_3d);      mputv(1,1);      mputv(6,prev_run);      mputv(8,prev_level);      bits += 22;    }    else {      mputv(1,prev_s);      bits += length + 1;    }  }  return bits;} /********************************************************************** * *	Name:		FindCBP *	Description:	Finds the CBP for a macroblock *	 *	Input:		qcoeff and mode *			 *	Returns:	CBP *	Side effects:	 * *	Date: 940829	Author:	Karl.Lillevold@nta.no * ***********************************************************************/int FindCBP(int *qcoeff, int Mode, int ncoeffs){    int i,j;  int CBP = 0;				/* IF INTRABLOCK then intra =1 else 0 */  int intra = (Mode == MODE_INTRA);  /* Set CBP for this Macroblock */  for (i = 0; i < 6; i++) {				    /* First time i = 0: j = 0 ..64-1  set bit 5 if coeff != 0       Sec. time  i = 1; j = 64..128-1 set bit 4 if coeff != 0       */    /* OPTIMIZE: I think for i can be removed        and only values i=0 must be proessed */    for (j = i*ncoeffs + intra; j < (i+1)*ncoeffs; j++) {      if (qcoeff[j]) {	if (i == 0) {CBP |= 32;}	else if (i == 1) {CBP |= 16;}	else if (i == 2) {CBP |= 8;}	else if (i == 3) {CBP |= 4;}	else if (i == 4) {CBP |= 2;}	else if (i == 5) {CBP |= 1;}	else {	  fprintf(stderr,"Error in CBP assignment\n");	  exit(-1);	}	break;      }    }  }  return CBP;}void CountBitsVectors(MotionVector *MV_ptr, Bits *bits, 		      int x, int y, int Mode, int newgob, Pict *pic){  int y_vec, x_vec;  extern EHUFF *vlc_mv;  int pmv0, pmv1;  int start,stop,block;  MotionVector *MV_xy;  start = 0; stop = 0;  MV_xy = MV_ptr + y*Global::mbc + x;  for (block = start; block <= stop;  block++) {    FindPMV(MV_ptr,x,y,&pmv0,&pmv1, block, newgob, 1);    x_vec = (2*(*MV_xy).x + (*MV_xy).x_half) - pmv0;    y_vec = (2*(*MV_xy).y + (*MV_xy).y_half) - pmv1;    if (!Global::long_vectors) {      if (x_vec < -32) x_vec += 64;      else if (x_vec > 31) x_vec -= 64;      if (y_vec < -32) y_vec += 64;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩美女一区二区三区四区| 久久精品一区二区三区av| 国内成人精品2018免费看| 中文字幕不卡在线| 欧美精品日韩一本| 97久久精品人人爽人人爽蜜臀| 日本欧美一区二区三区乱码| 亚洲视频狠狠干| 国产日韩影视精品| 在线综合亚洲欧美在线视频| 91在线无精精品入口| 国产成人啪午夜精品网站男同| 韩国一区二区三区| 日韩精品一卡二卡三卡四卡无卡| 综合激情成人伊人| 久久久久久日产精品| 欧美一区二区三区四区高清| 欧美系列一区二区| jizzjizzjizz欧美| 成人毛片视频在线观看| 韩国av一区二区三区在线观看| 日本亚洲三级在线| 亚洲成人综合在线| 一级中文字幕一区二区| 亚洲同性gay激情无套| 国产午夜精品一区二区| 欧美成人一区二区三区片免费| 欧美三日本三级三级在线播放| 日本高清无吗v一区| 不卡电影一区二区三区| 成人高清在线视频| 成人激情午夜影院| 99在线热播精品免费| 国产精品一区在线观看你懂的| 麻豆91在线播放| 美女一区二区视频| 九九视频精品免费| 国产综合一区二区| 国产精品影视网| 国产激情一区二区三区四区| 国产精品69毛片高清亚洲| 国产麻豆精品theporn| 激情偷乱视频一区二区三区| 国内精品嫩模私拍在线| 国产精品亚洲一区二区三区在线 | 国产成人免费xxxxxxxx| 国产一区二区三区久久久| 国产一二精品视频| 国产传媒日韩欧美成人| 成人免费视频app| 色综合久久久久网| 日本高清不卡aⅴ免费网站| 欧美三级乱人伦电影| 欧美高清hd18日本| 欧美一区二区三区免费视频| 欧美一级专区免费大片| 久久精品视频一区| 中文字幕成人av| 一区二区三区四区精品在线视频| 亚洲午夜电影网| 裸体在线国模精品偷拍| 丰满岳乱妇一区二区三区| aa级大片欧美| 欧美日产在线观看| 亚洲乱码国产乱码精品精98午夜 | 精品在线一区二区| 国产成人啪免费观看软件| 99久久国产免费看| 欧美精品成人一区二区三区四区| 日韩欧美中文一区二区| 日本一区二区三区视频视频| 亚洲日本va午夜在线电影| 日欧美一区二区| 国产一区二区三区在线观看精品| 成人一级片在线观看| 欧美性大战久久久| 精品粉嫩aⅴ一区二区三区四区| 中文字幕国产一区二区| 亚洲国产精品久久人人爱蜜臀| 男女男精品网站| 99re这里只有精品首页| 日韩一区二区在线免费观看| 国产精品私人自拍| 日韩电影在线观看电影| 成人app软件下载大全免费| 欧美日韩久久一区二区| 日本一区二区久久| 日本网站在线观看一区二区三区| 成人免费视频app| 777午夜精品免费视频| 国产精品久久久一本精品| 日本成人在线电影网| 99麻豆久久久国产精品免费| 91精品国产综合久久久蜜臀图片| 国产精品毛片大码女人| 蜜臀av性久久久久蜜臀aⅴ流畅| 91麻豆福利精品推荐| 欧美精品一区视频| 丝瓜av网站精品一区二区| av网站免费线看精品| 久久免费电影网| 日本不卡一区二区| 色嗨嗨av一区二区三区| 欧美韩国日本综合| 另类成人小视频在线| 欧美三级资源在线| 国产精品你懂的在线| 久久电影网站中文字幕| 欧美日韩精品一区视频| 亚洲精品一卡二卡| 93久久精品日日躁夜夜躁欧美| 国产亚洲一区二区三区在线观看 | 青青草视频一区| 91国在线观看| 中文字幕乱码日本亚洲一区二区| 久久精品99国产精品| 欧美男女性生活在线直播观看| 亚洲人吸女人奶水| 97久久精品人人做人人爽| 欧美国产精品专区| 国产精品一区二区免费不卡| 精品蜜桃在线看| 久久99精品国产.久久久久久| 在线播放91灌醉迷j高跟美女| 一区二区三区毛片| 在线观看av一区| 最新日韩av在线| 99久久精品免费看国产| 国产精品免费丝袜| 成人精品免费网站| 亚洲欧洲精品天堂一级| av在线一区二区| 亚洲欧洲性图库| 99精品久久久久久| 亚洲免费在线电影| 在线一区二区视频| 午夜精品久久久久久久久| 欧美日韩免费电影| 亚洲成人av一区二区| 欧美精品在线观看一区二区| 奇米精品一区二区三区在线观看一 | 国产精品久久三| 99re这里只有精品首页| 亚洲黄色尤物视频| 欧美专区亚洲专区| 性做久久久久久久久| 日韩视频免费观看高清完整版在线观看 | 亚洲午夜电影在线| 欧美一区二区视频在线观看2022| 日韩av中文字幕一区二区| 欧美电视剧在线看免费| 国产成人夜色高潮福利影视| 国产精品免费视频观看| 在线看日本不卡| 麻豆久久一区二区| 国产午夜精品一区二区三区四区| 不卡电影免费在线播放一区| 亚洲综合在线五月| 欧美一级国产精品| 丁香天五香天堂综合| 一级中文字幕一区二区| 日韩视频一区二区三区| 成人一区二区三区在线观看| 亚洲国产成人tv| 精品国产三级电影在线观看| 国产不卡在线播放| 亚洲精品乱码久久久久久日本蜜臀| 在线一区二区三区四区五区| 日本怡春院一区二区| 国产精品看片你懂得| 欧美午夜电影网| 国精产品一区一区三区mba桃花| 国产精品三级久久久久三级| 欧美羞羞免费网站| 国产一区二区在线看| 亚洲人成人一区二区在线观看 | 最好看的中文字幕久久| 欧美精品久久99久久在免费线| 国产福利一区二区三区在线视频| 亚洲精品视频免费看| 精品少妇一区二区三区免费观看| 99视频在线观看一区三区| 日本v片在线高清不卡在线观看| 中文av一区二区| 91精品欧美综合在线观看最新| 国产高清一区日本| 五月婷婷久久综合| 国产精品福利电影一区二区三区四区| 欧美日韩国产一级二级| 成人免费毛片嘿嘿连载视频| 人人精品人人爱| 亚洲精品菠萝久久久久久久| 久久九九影视网| 日韩欧美综合一区| 欧美在线观看一区| 成人性视频网站| 久久av中文字幕片| 丝袜美腿亚洲综合| 亚洲综合激情网| 一区精品在线播放|