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

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

?? motion.c

?? DVD轉(zhuǎn)換到AVI的源代碼
?? C
字號:
/* Copyright (C) 1996, MPEG Software Simulation Group. All Rights Reserved. */

/*
 * Disclaimer of Warranty
 *
 * These software programs are available to the user without any license fee or
 * royalty on an "as is" basis.  The MPEG Software Simulation Group disclaims
 * any and all warranties, whether express, implied, or statuary, including any
 * implied warranties or merchantability or of fitness for a particular
 * purpose.  In no event shall the copyright-holder be liable for any
 * incidental, punitive, or consequential damages of any kind whatsoever
 * arising from the use of these programs.
 *
 * This disclaimer of warranty extends to the user of these programs and user's
 * customers, employees, agents, transferees, successors, and assigns.
 *
 * The MPEG Software Simulation Group does not represent or warrant that the
 * programs furnished hereunder are free of infringement of any third-party
 * patents.
 *
 * Commercial implementations of MPEG-1 and MPEG-2 video, including shareware,
 * are subject to royalty fees to patent holders.  Many of these patents are
 * general enough such that they are unavoidable regardless of implementation
 * design.
 *
 */

#include "global.h"
#include "getbit.h"

/* private prototypes */
__forceinline static void motion_vector(int *PMV, int *dmvector, int h_r_size, int v_r_size, 
	int dmv, int mvscale, int full_pel_vector);
__forceinline static void decode_motion_vector(int *pred, int r_size, int motion_code,
	int motion_residualesidual, int full_pel_vector);
__forceinline static int Get_motion_code(void);
__forceinline static int Get_dmvector(void);

/* ISO/IEC 13818-2 sections 6.2.5.2, 6.3.17.2, and 7.6.3: Motion vectors */
void motion_vectors(int PMV[2][2][2],int dmvector[2],
					int motion_vertical_field_select[2][2], int s,
					int motion_vector_count, int mv_format, int h_r_size,
					int v_r_size, int dmv, int mvscale)
{
	if (motion_vector_count==1)
	{
		if (mv_format==MV_FIELD && !dmv)
			motion_vertical_field_select[1][s] =
			motion_vertical_field_select[0][s] = Get_Bits(1);

		motion_vector(PMV[0][s],dmvector,h_r_size,v_r_size,dmv,mvscale,0);

		/* update other motion vector predictors */
		PMV[1][s][0] = PMV[0][s][0];
		PMV[1][s][1] = PMV[0][s][1];
	}
	else
	{
		motion_vertical_field_select[0][s] = Get_Bits(1);
		motion_vector(PMV[0][s],dmvector,h_r_size,v_r_size,dmv,mvscale,0);
		motion_vertical_field_select[1][s] = Get_Bits(1);
		motion_vector(PMV[1][s],dmvector,h_r_size,v_r_size,dmv,mvscale,0);
	}
}

/* get and decode motion vector and differential motion vector for one prediction */
void motion_vector(int *PMV, int *dmvector, int h_r_size, int v_r_size,
				   int dmv, int mvscale, int full_pel_vector)
{
	int motion_code, motion_residual;

	/* horizontal component */
	/* ISO/IEC 13818-2 Table B-10 */
	motion_code = Get_motion_code();

	motion_residual = (h_r_size!=0 && motion_code!=0) ? Get_Bits(h_r_size) : 0;

	decode_motion_vector(&PMV[0],h_r_size,motion_code,motion_residual,full_pel_vector);

	if (dmv)
		dmvector[0] = Get_dmvector();

	/* vertical component */
	motion_code     = Get_motion_code();
	motion_residual = (v_r_size!=0 && motion_code!=0) ? Get_Bits(v_r_size) : 0;

	if (mvscale)
		PMV[1] >>= 1; /* DIV 2 */

	decode_motion_vector(&PMV[1],v_r_size,motion_code,motion_residual,full_pel_vector);

	if (mvscale)
		PMV[1] <<= 1;

	if (dmv)
		dmvector[1] = Get_dmvector();
}

/* calculate motion vector component */
/* ISO/IEC 13818-2 section 7.6.3.1: Decoding the motion vectors */
/* Note: the arithmetic here is more elegant than that which is shown 
   in 7.6.3.1.  The end results (PMV[][][]) should, however, be the same.  */
static void decode_motion_vector(int *pred, int r_size, int motion_code,
								 int motion_residual, int full_pel_vector)
{
	int lim, vec;

	lim = 16<<r_size;
	vec = full_pel_vector ? (*pred >> 1) : (*pred);

	if (motion_code>0)
	{
		vec+= ((motion_code-1)<<r_size) + motion_residual + 1;
		if (vec>=lim)
			vec-= lim + lim;
	}
	else if (motion_code<0)
	{
		vec-= ((-motion_code-1)<<r_size) + motion_residual + 1;
		if (vec<-lim)
			vec+= lim + lim;
	}

	*pred = full_pel_vector ? (vec<<1) : vec;
}

/* ISO/IEC 13818-2 section 7.6.3.6: Dual prime additional arithmetic */
void Dual_Prime_Arithmetic(int DMV[][2],int *dmvector, int mvx,int mvy)
{
	if (picture_structure==FRAME_PICTURE)
	{
		if (top_field_first)
		{
			/* vector for prediction of top field from bottom field */
			DMV[0][0] = ((mvx  +(mvx>0))>>1) + dmvector[0];
			DMV[0][1] = ((mvy  +(mvy>0))>>1) + dmvector[1] - 1;

			/* vector for prediction of bottom field from top field */
			DMV[1][0] = ((3*mvx+(mvx>0))>>1) + dmvector[0];
			DMV[1][1] = ((3*mvy+(mvy>0))>>1) + dmvector[1] + 1;
		}
		else
		{
			/* vector for prediction of top field from bottom field */
			DMV[0][0] = ((3*mvx+(mvx>0))>>1) + dmvector[0];
			DMV[0][1] = ((3*mvy+(mvy>0))>>1) + dmvector[1] - 1;

			/* vector for prediction of bottom field from top field */
			DMV[1][0] = ((mvx  +(mvx>0))>>1) + dmvector[0];
			DMV[1][1] = ((mvy  +(mvy>0))>>1) + dmvector[1] + 1;
		}
	}
	else
	{
		/* vector for prediction from field of opposite 'parity' */
		DMV[0][0] = ((mvx+(mvx>0))>>1) + dmvector[0];
		DMV[0][1] = ((mvy+(mvy>0))>>1) + dmvector[1];

		/* correct for vertical field shift */
		if (picture_structure==TOP_FIELD)
			DMV[0][1]--;
		else
			DMV[0][1]++;
	}
}

static int Get_motion_code()
{
	int code;

	if (Get_Bits(1))
		return 0;

	if ((code = Show_Bits(9))>=64)
	{
		code >>= 6;
		Flush_Buffer(MVtab0[code].len);

		return Get_Bits(1)?-MVtab0[code].val:MVtab0[code].val;
	}

	if (code>=24)
	{
		code >>= 3;
		Flush_Buffer(MVtab1[code].len);

		return Get_Bits(1)?-MVtab1[code].val:MVtab1[code].val;
	}

	if ((code-=12)<0)
	{
		Fault_Flag = 10;
		return 0;
	}

	Flush_Buffer(MVtab2[code].len);

	return Get_Bits(1) ? -MVtab2[code].val : MVtab2[code].val;
}

/* get differential motion vector (for dual prime prediction) */
static int Get_dmvector()
{
	if (Get_Bits(1))
		return Get_Bits(1) ? -1 : 1;
	else
		return 0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久免费看少妇高潮| 国产精品99久久久久| 精品写真视频在线观看| 99国产精品久久久久久久久久久| 欧美日韩国产大片| 欧美韩日一区二区三区| 蜜桃精品视频在线| 91免费版在线看| 国产精品区一区二区三| 久草中文综合在线| 欧美美女直播网站| 亚洲女爱视频在线| 福利电影一区二区| 26uuu另类欧美亚洲曰本| 视频在线在亚洲| 欧美中文字幕一区二区三区| 中文字幕国产一区| 国产sm精品调教视频网站| 日韩欧美精品在线| 轻轻草成人在线| 欧美视频在线观看一区二区| 一区二区三区精品在线| 91麻豆国产精品久久| 欧美经典一区二区| 国产精品系列在线观看| 久久综合精品国产一区二区三区| 人人爽香蕉精品| 欧美丰满美乳xxx高潮www| 亚洲一区二区成人在线观看| 日本高清不卡一区| 亚洲图片欧美色图| 欧美剧情片在线观看| 五月天网站亚洲| 欧美日韩精品专区| 秋霞午夜鲁丝一区二区老狼| 欧美xxx久久| 国产寡妇亲子伦一区二区| 久久亚洲综合色一区二区三区| 精品影院一区二区久久久| 久久综合999| 国产v综合v亚洲欧| 亚洲精品写真福利| 欧美日韩国产免费一区二区| 亚洲18女电影在线观看| 欧美精品久久一区二区三区| 奇米综合一区二区三区精品视频| 日韩午夜电影在线观看| 国产一区二区三区观看| 国产精品久久久久一区二区三区共| 成人91在线观看| 亚洲精品视频在线观看网站| 欧美老年两性高潮| 国产精品影视网| 亚洲精品国产a久久久久久| 91精品啪在线观看国产60岁| 捆绑调教一区二区三区| 国产精品网曝门| 精品视频全国免费看| 国产原创一区二区三区| 综合亚洲深深色噜噜狠狠网站| 欧美性大战久久| 国产一区二区三区不卡在线观看| 亚洲日本va在线观看| 这里是久久伊人| 福利一区二区在线| 日日夜夜精品视频免费| 国产精品久久久久久久久免费樱桃| 日本道色综合久久| 国产尤物一区二区| 亚洲午夜精品久久久久久久久| xvideos.蜜桃一区二区| 91一区二区在线观看| 免费精品视频在线| 亚洲天堂网中文字| www国产成人免费观看视频 深夜成人网| 91在线观看视频| 另类欧美日韩国产在线| 亚洲乱码国产乱码精品精的特点 | 日韩精品三区四区| 欧美国产视频在线| 7777精品久久久大香线蕉| 成人美女视频在线观看| 日韩电影在线一区| 综合亚洲深深色噜噜狠狠网站| 欧美电影精品一区二区| 欧美日韩一卡二卡三卡 | 欧美视频中文字幕| 成人永久免费视频| 麻豆精品在线视频| 亚洲123区在线观看| 最新高清无码专区| 久久精品网站免费观看| 日韩精品专区在线影院观看| 欧美性感一类影片在线播放| 91麻豆国产在线观看| 国产精品1024| 国产一区二三区| 免费国产亚洲视频| 欧美96一区二区免费视频| 综合电影一区二区三区| 日本一区二区三区在线不卡| 精品国产污网站| 日韩久久久精品| 日韩精品在线一区二区| 欧美高清一级片在线| 欧美日韩一卡二卡三卡| 欧美日韩一区二区在线观看视频| 99re热视频精品| 99精品视频在线免费观看| 成人黄色小视频| 99riav久久精品riav| 97se亚洲国产综合自在线 | 国产一区二区在线影院| 免费成人av资源网| 精品一区二区综合| 精品一区二区三区在线观看| 久久se精品一区精品二区| 久久精品国产色蜜蜜麻豆| 久久69国产一区二区蜜臀| 国产主播一区二区三区| 国产精品18久久久久久久久| 丁香五精品蜜臀久久久久99网站 | 91视频你懂的| 久草中文综合在线| 久久99热99| 中文字幕精品—区二区四季| 色一情一乱一乱一91av| 婷婷综合在线观看| 欧美高清在线视频| 国产乱码精品一品二品| 国产suv一区二区三区88区| 蜜桃一区二区三区在线| 亚洲成人动漫一区| 午夜精品影院在线观看| 亚洲一二三四在线观看| 亚洲一区二区三区美女| 国产精品一区二区久激情瑜伽| 久久久久久久久久久99999| 亚洲欧美日本在线| 欧美一级欧美一级在线播放| 欧美一级日韩免费不卡| 国产亚洲自拍一区| 亚洲三级电影网站| 蜜臀a∨国产成人精品| 成人午夜激情片| 欧美无砖专区一中文字| 精品区一区二区| 亚洲精选在线视频| 蜜桃视频在线观看一区二区| 成人性视频免费网站| 欧美日韩国产一级片| 精品免费99久久| 亚洲一区视频在线| 韩国在线一区二区| 欧洲精品中文字幕| 国产欧美精品一区| 亚洲大片精品永久免费| 国产精品一区免费视频| 在线免费一区三区| 久久一区二区三区四区| 尤物av一区二区| 丁香婷婷综合激情五月色| 欧美色爱综合网| 中文子幕无线码一区tr| 日韩av电影一区| 日本久久一区二区三区| 国产精品久久久一区麻豆最新章节| 亚洲色图欧洲色图| 亚洲精品在线三区| 伊人性伊人情综合网| 成人精品gif动图一区| 欧美一区二区三区思思人| 性做久久久久久| 在线观看亚洲精品视频| 日本一区二区高清| 精品一区免费av| 精品人伦一区二区色婷婷| 亚洲成人一区二区| 在线不卡欧美精品一区二区三区| 亚洲高清久久久| 一区二区不卡在线播放| 成人晚上爱看视频| 久久久久国产精品麻豆| 免费在线观看不卡| 在线成人免费观看| 亚洲午夜一区二区| 欧洲一区在线观看| 亚洲激情自拍偷拍| 94色蜜桃网一区二区三区| 99久久精品久久久久久清纯| 久久综合九色综合欧美亚洲| 成人听书哪个软件好| 亚洲欧美自拍偷拍色图| 在线看国产日韩| 日本少妇一区二区| 久久综合一区二区| 91麻豆国产福利在线观看| 亚洲一区二区视频在线| 日韩视频123| 99re视频精品|