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

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

?? libr263.cpp

?? Netmeeting是Windows系統(tǒng)自帶的網(wǎng)上聊天軟件
?? CPP
字號:
////////////////////////////////////////////////////////////////////////////
//
//
//    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    : libr263.cpp
//    Details : Entry point to encoder....
//
/////////////////////////////////////////////////////////////////////////////

/*************************************************
 * 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
 **************************************************/

#include "stdafx.h"
#include "libr263.h"


int InitH263Encoder(CParam *params)
{

  Global::pic = (Pict *)malloc(sizeof(Pict));
  
  if(!Global::pic) 
  {
  return -1;
  }

  Global::pic->unrestricted_mv_mode = DEF_UMV_MODE;
  Global::pic->use_gobsync = DEF_INSERT_SYNC;
  Global::pic->PB = 0;
  Global::pic->TR = 0;
  Global::pic->QP_mean = 0.0;

  if(params->format == CPARAM_QCIF) {
    Global::pels = QCIF_YWIDTH;
    Global::lines = QCIF_YHEIGHT;
    Global::cpels = QCIF_YWIDTH/2;
    Global::pic->source_format = SF_QCIF;
  } else if (params->format == CPARAM_CIF) {
    Global::pels = CIF_YWIDTH;
    Global::lines = CIF_YHEIGHT;
    Global::cpels = CIF_YWIDTH/2;
    Global::pic->source_format = SF_CIF;
  } else if (params->format == CPARAM_SQCIF) {
    Global::pels = SQCIF_YWIDTH;
    Global::lines = SQCIF_YHEIGHT;
    Global::cpels = SQCIF_YWIDTH/2;
    Global::pic->source_format = SF_SQCIF;
  } else if (params->format == CPARAM_4CIF) {
    Global::pels = CIF4_YWIDTH;
    Global::lines = CIF4_YHEIGHT;
    Global::cpels = CIF4_YWIDTH/2;
    Global::pic->source_format = SF_4CIF;  
  } else if (params->format == CPARAM_16CIF) {
    Global::pels = CIF16_YWIDTH;
    Global::lines = CIF16_YHEIGHT;
    Global::cpels = CIF16_YWIDTH/2;
    Global::pic->source_format = SF_16CIF;
  } else {
    Global::pels = params->pels;
    Global::lines = params->lines;
    Global::cpels = params->pels / 2;
    Global::pic->source_format = 0;	/* ILLEGAL H.263! Use it only for testing */
  }
  
  Global::mbr = Global::lines / MB_SIZE;
  Global::mbc = Global::pels / MB_SIZE;
  Global::uskip = Global::lines*Global::pels;
  Global::vskip = Global::uskip + Global::lines*Global::pels/4;
  Global::sizeof_frame = (Global::vskip + Global::lines*Global::pels/4)*sizeof(int);


  Global::headerlength = DEF_HEADERLENGTH;
  /* Initalize VLC_tables */
  InitHuff();
  mwinit();

  /* Init motion detection */
  init_motion_detection();


#ifdef VERYFASTIDCT
  init_idct();			/* Do this in case of VERYFASTIDCT */
#elif STANDARDIDCT
  init_idctref();		/* Do this in case of standard IDCT */
#endif
				/* Do nothing for FASTIDCT */

  /* Set internal variables */
  Global::advanced = DEF_ADV_MODE;
  Global::mv_outside_frame = DEF_UMV_MODE || DEF_ADV_MODE;
  Global::long_vectors = DEF_UMV_MODE;
  Global::pb_frames = DEF_PBF_MODE;
  Global::search_p_frames = DEF_SPIRAL_SEARCH;
  Global::trace = DEF_WRITE_TRACE;

  params->half_pixel_searchwindow = CPARAM_DEFAULT_SEARCHWINDOW; 
  params->inter = CPARAM_DEFAULT_INTER;
  params->search_method = CPARAM_DEFAULT_SEARCH_METHOD;
  params->advanced_method = CPARAM_DEFAULT_ADVANCED_METHOD;
  params->Q_inter = CPARAM_DEFAULT_INTER_Q;
  params->Q_intra = CPARAM_DEFAULT_INTRA_Q;

  params->interpolated_lum = (unsigned int*)malloc(Global::pels*Global::lines*4*sizeof(int));

  if(!params->interpolated_lum)
    return -1;

  params->recon =(unsigned int*) malloc(Global::sizeof_frame);
  if(!params->recon) {
    free(params->interpolated_lum);
    free(Global::pic);
    return -1;
  }

  return 0;
}

void SkipH263Frames(int frames_to_skip)
{
  Global::pic->TR += frames_to_skip % 256;
}

int CompressFrame(CParam *params, Bits *bits)
{
  if(!params->inter) {
    CodeIntraH263(params, bits);
  } else {
    CodeInterH263(params, bits);
  }
  bits->header += zeroflush();  /* pictures shall be byte aligned */
  Global::pic->TR += 1 % 256; /* one means 30 fps */
  return 0;
}

void ExitH263Encoder(CParam *params)
{
  mwcloseinit();
  free(params->interpolated_lum);
  free(params->recon);
  free(Global::pic);
  return;
}

/* Motion Detection part */

static int global_mb_threshold;
static int global_pixel_threshold;

/* This array is computed for QCIF
  movement_detection[] = {0, 354, 528, 177,
                          3, 353, 531, 178,
		          352, 179, 530, 1,
		          355, 176, 2, 529 };
			  */
/* This array determines the order in a pixel is checked per 4x4 block */
/* {x, y} within [0..3] */
static unsigned int movement_coords[16][2] = { {0,0}, {2,2},{0,3},{1,1},
		               		       {3,0},{1,2},{3,3},{2,1},
				               {0,2},{3,1},{2,3},{1,0},
				               {3,2},{0,1},{2,0},{1,3} };


static int movement_detection[16][4];

void init_motion_detection()
{
  unsigned int counter, pos;

  for(counter = 0; counter < 16; counter++) {
    pos = movement_coords[counter][0] + movement_coords[counter][1]*Global::pels;
    movement_detection[counter][0] = pos;
    movement_detection[counter][1] = pos + 4;
    movement_detection[counter][2] = pos + Global::pels*4;
    movement_detection[counter][3] = pos + Global::pels*4 + 4;
  }
  return;
}

//__inline__ static int Check8x8(unsigned int *orig, unsigned int *recon, int pos)
static int Check8x8(unsigned int *orig, unsigned int *recon, int pos)
{
  int value, index;
  register int thres = global_pixel_threshold;

  value = 0;

  /* Mark pixel changed when lum value differs more than "thres" */
  index = movement_detection[pos][0];
  value += abs(*(orig + index) - *(recon+index)) > thres;

  index = movement_detection[pos][1];
  value += abs(*(orig + index) - *(recon+index)) > thres;

  index = movement_detection[pos][2];				
  value += abs(*(orig + index) - *(recon+index)) > thres;

  index = movement_detection[pos][3];			
  value += abs(*(orig + index) - *(recon+index)) > thres;

  return value;
}

static int HasMoved(int call_time,  void *real,
	     void *recon, int x, int y)
{
  int offset1;
  unsigned int *MB_orig;
  unsigned int *MB_recon;
  int position;
  int value = 0;

  offset1 = (y*Global::pels+x)*MB_SIZE;
  position = call_time;

  /* Integration of 8x8 and 4x4 check might improve performance, 
     but is not done here */
  MB_orig = (unsigned int *) real + offset1;
  MB_recon = (unsigned int *) recon + offset1;
  value += Check8x8(MB_orig, MB_recon, position);

  MB_orig += 8; MB_recon += 8;
  value += Check8x8(MB_orig, MB_recon, position); 

  MB_orig += 8*Global::pels - 8; MB_recon += 8*Global::pels - 8;
  value += Check8x8(MB_orig, MB_recon, position);

  MB_orig += 8; MB_recon += 8;
  value += Check8x8(MB_orig, MB_recon, position);

  return value > global_mb_threshold;	
  /* Mark MB changed if more than "global_mb_threshold" pixels are changed */
}


int FindMotion(CParam *params, int mb_threshold, int pixel_threshold)
{
  static int call_time = 0;

  int j,i;
  int counter = 0;

  global_mb_threshold = mb_threshold;
  global_pixel_threshold = pixel_threshold;

  for(j = 0; j < Global::mbr; j++) {
    for(i = 0; i < Global::mbc; i++) {
      *(params->EncodeThisBlock + j*Global::mbc + i) = 
	HasMoved(call_time, params->data, params->recon, i,j);

      counter += *(params->EncodeThisBlock +j*Global::mbc + i);
    }
  }

  call_time = (call_time + 1) % 16;
 
  return counter;
}



?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线免费观看视频一区| 91精品一区二区三区在线观看| 亚洲美女区一区| 日韩无一区二区| 国产亚洲va综合人人澡精品| 欧美日韩一区二区三区不卡| 国产伦精一区二区三区| 亚洲午夜视频在线观看| 色婷婷精品大视频在线蜜桃视频| 亚洲地区一二三色| 93久久精品日日躁夜夜躁欧美| 久久欧美一区二区| 欧美视频自拍偷拍| 国产在线视频一区二区三区| 国产精品丝袜久久久久久app| 在线播放91灌醉迷j高跟美女| 国产综合色视频| 国产精品久久久久精k8| 国产精品第一页第二页第三页| 九九精品一区二区| 91精品国产综合久久久久久久 | 99久久综合精品| 欧美一级高清片| 一区二区三区日韩在线观看| 粉嫩蜜臀av国产精品网站| 2023国产精品| 麻豆精品蜜桃视频网站| 欧美一区午夜精品| 日韩精品一二区| 7777女厕盗摄久久久| 天天av天天翘天天综合网| 91成人免费网站| 亚洲黄色尤物视频| 色一区在线观看| 一区二区三区中文字幕电影 | 中文字幕免费不卡在线| 国产盗摄精品一区二区三区在线 | 国产乱码精品一区二区三 | 国产精品久久久久久亚洲毛片 | 国产69精品久久久久777| 久久夜色精品国产噜噜av| 国内外精品视频| 国产欧美综合在线观看第十页| 国产精品伊人色| 欧美激情一区二区三区不卡| 国产精品综合一区二区三区| 久久精品水蜜桃av综合天堂| 成人国产电影网| 亚洲三级小视频| 欧美日韩一区二区欧美激情| 奇米在线7777在线精品| 26uuu另类欧美亚洲曰本| 极品美女销魂一区二区三区| 欧美极品xxx| 欧美性猛交一区二区三区精品| 视频一区视频二区中文字幕| 日韩精品一区二区三区视频播放| 国产激情视频一区二区三区欧美 | 久久综合九色综合欧美98| 国产白丝网站精品污在线入口| 中文天堂在线一区| 色噜噜狠狠成人中文综合 | 国产精品一区二区在线播放| 中文字幕视频一区二区三区久| 欧美亚洲精品一区| 精品亚洲porn| 亚洲欧美乱综合| 欧美一区二视频| 粉嫩av亚洲一区二区图片| 亚洲图片欧美视频| 久久亚洲捆绑美女| 欧美亚洲尤物久久| 国产精华液一区二区三区| 亚洲国产另类av| 国产片一区二区| 欧美精品一卡两卡| 成人a免费在线看| 日韩高清在线不卡| 亚洲人精品午夜| 久久一区二区视频| 欧美亚日韩国产aⅴ精品中极品| 国产精品一区二区你懂的| 亚洲成人免费视| 欧美激情一区二区| 日韩一级黄色大片| 欧美在线观看视频在线| 成人免费观看视频| 激情综合色综合久久| 亚洲电影你懂得| 亚洲欧美在线aaa| 久久先锋影音av鲁色资源| 欧美视频在线不卡| 99免费精品视频| 国产一区二区三区电影在线观看| 亚洲国产裸拍裸体视频在线观看乱了 | 午夜私人影院久久久久| 国产精品人成在线观看免费| 日韩网站在线看片你懂的| 欧美视频你懂的| 91亚洲精品久久久蜜桃网站| 福利一区二区在线观看| 麻豆精品新av中文字幕| 日韩精品欧美精品| 香蕉影视欧美成人| 亚洲影视在线观看| 亚洲精品免费看| 亚洲视频电影在线| 日韩理论片网站| 中文字幕在线一区| 国产精品久久久久一区| 日本一区二区三级电影在线观看| 久久亚洲免费视频| 国产午夜精品久久| 中文字幕欧美国产| 中文字幕一区二区视频| 国产女主播在线一区二区| 欧美激情一区在线| 中文字幕在线观看不卡| 国产精品免费久久久久| 中文幕一区二区三区久久蜜桃| 欧美经典一区二区三区| 国产精品丝袜久久久久久app| 欧美激情在线一区二区| 国产精品久久久久三级| 亚洲欧美韩国综合色| 亚洲欧美日韩国产另类专区| 亚洲综合一区二区三区| 五月天网站亚洲| 久久精品理论片| 国产乱淫av一区二区三区| 国产精品一区二区免费不卡 | 国产精品中文字幕欧美| 国产成a人亚洲精品| fc2成人免费人成在线观看播放| 97精品视频在线观看自产线路二| 欧美中文字幕久久| 91精品在线免费| 国产亚洲精品bt天堂精选| 中文字幕中文字幕在线一区| 一区二区久久久| 日本成人在线视频网站| 国产制服丝袜一区| 91丝袜国产在线播放| 欧美羞羞免费网站| 欧美精品一区二区在线观看| 中文字幕中文字幕在线一区 | 日韩免费一区二区| 欧美国产日韩精品免费观看| 一区二区三区在线视频免费| 午夜免费欧美电影| 国产福利视频一区二区三区| 色婷婷久久99综合精品jk白丝| 制服.丝袜.亚洲.另类.中文| 久久久久国产一区二区三区四区| 亚洲欧美日本在线| 久久99久久久欧美国产| 色哟哟一区二区三区| 精品久久人人做人人爰| 亚洲区小说区图片区qvod| 久久精品av麻豆的观看方式| 91在线看国产| 精品国精品国产| 亚洲一区二区三区四区五区黄 | 色综合色综合色综合色综合色综合 | 2020国产精品自拍| 亚洲一区国产视频| 高清不卡一区二区| 欧美精品色综合| 亚洲视频中文字幕| 国产高清亚洲一区| 日韩欧美成人激情| 亚洲成人免费看| 99精品黄色片免费大全| 精品美女被调教视频大全网站| 亚洲成a人在线观看| 91丨九色丨蝌蚪富婆spa| 国产欧美精品区一区二区三区| 久久国产剧场电影| 制服丝袜亚洲精品中文字幕| 亚洲欧美色图小说| 成人av影视在线观看| 欧美精品一区二区三区一线天视频| 亚洲成人av资源| 欧美亚洲丝袜传媒另类| 亚洲美女一区二区三区| 99久久精品一区二区| 久久久美女毛片| 激情综合网最新| 精品久久久久久久久久久久久久久 | 成人午夜电影小说| 久久久久亚洲蜜桃| 韩国在线一区二区| 精品久久久久一区二区国产| 日韩成人免费看| 欧美精品一级二级三级| 婷婷综合另类小说色区| 欧美久久久久久久久久| 天堂精品中文字幕在线| 欧美一卡2卡3卡4卡| 青青青伊人色综合久久|