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

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

?? cl_cin.c

?? quakeIII源碼這個不用我多說吧
?? C
?? 第 1 頁 / 共 4 頁
字號:
/*
===========================================================================
Copyright (C) 1999-2005 Id Software, Inc.

This file is part of Quake III Arena source code.

Quake III Arena source code is free software; you can redistribute it
and/or modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the License,
or (at your option) any later version.

Quake III Arena source code is distributed in the hope that it will be
useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with Foobar; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
===========================================================================
*/

/*****************************************************************************
 * name:		cl_cin.c
 *
 * desc:		video and cinematic playback
 *
 * $Archive: /MissionPack/code/client/cl_cin.c $
 *
 * cl_glconfig.hwtype trtypes 3dfx/ragepro need 256x256
 *
 *****************************************************************************/

#include "client.h"
#include "snd_local.h"

#define MAXSIZE				8
#define MINSIZE				4

#define DEFAULT_CIN_WIDTH	512
#define DEFAULT_CIN_HEIGHT	512

#define ROQ_QUAD			0x1000
#define ROQ_QUAD_INFO		0x1001
#define ROQ_CODEBOOK		0x1002
#define ROQ_QUAD_VQ			0x1011
#define ROQ_QUAD_JPEG		0x1012
#define ROQ_QUAD_HANG		0x1013
#define ROQ_PACKET			0x1030
#define ZA_SOUND_MONO		0x1020
#define ZA_SOUND_STEREO		0x1021

#define MAX_VIDEO_HANDLES	16

extern glconfig_t glConfig;
extern	int		s_paintedtime;
extern	int		s_rawend;


static void RoQ_init( void );

/******************************************************************************
*
* Class:		trFMV
*
* Description:	RoQ/RnR manipulation routines
*				not entirely complete for first run
*
******************************************************************************/

static	long				ROQ_YY_tab[256];
static	long				ROQ_UB_tab[256];
static	long				ROQ_UG_tab[256];
static	long				ROQ_VG_tab[256];
static	long				ROQ_VR_tab[256];
static	unsigned short		vq2[256*16*4];
static	unsigned short		vq4[256*64*4];
static	unsigned short		vq8[256*256*4];


typedef struct {
	byte				linbuf[DEFAULT_CIN_WIDTH*DEFAULT_CIN_HEIGHT*4*2];
	byte				file[65536];
	short				sqrTable[256];

	unsigned int		mcomp[256];
	byte				*qStatus[2][32768];

	long				oldXOff, oldYOff, oldysize, oldxsize;

	int					currentHandle;
} cinematics_t;

typedef struct {
	char				fileName[MAX_OSPATH];
	int					CIN_WIDTH, CIN_HEIGHT;
	int					xpos, ypos, width, height;
	qboolean			looping, holdAtEnd, dirty, alterGameState, silent, shader;
	fileHandle_t		iFile;
	e_status			status;
	unsigned int		startTime;
	unsigned int		lastTime;
	long				tfps;
	long				RoQPlayed;
	long				ROQSize;
	unsigned int		RoQFrameSize;
	long				onQuad;
	long				numQuads;
	long				samplesPerLine;
	unsigned int		roq_id;
	long				screenDelta;

	void ( *VQ0)(byte *status, void *qdata );
	void ( *VQ1)(byte *status, void *qdata );
	void ( *VQNormal)(byte *status, void *qdata );
	void ( *VQBuffer)(byte *status, void *qdata );

	long				samplesPerPixel;				// defaults to 2
	byte*				gray;
	unsigned int		xsize, ysize, maxsize, minsize;

	qboolean			half, smootheddouble, inMemory;
	long				normalBuffer0;
	long				roq_flags;
	long				roqF0;
	long				roqF1;
	long				t[2];
	long				roqFPS;
	int					playonwalls;
	byte*				buf;
	long				drawX, drawY;
} cin_cache;

static cinematics_t		cin;
static cin_cache		cinTable[MAX_VIDEO_HANDLES];
static int				currentHandle = -1;
static int				CL_handle = -1;

extern int				s_soundtime;		// sample PAIRS
extern int   			s_paintedtime; 		// sample PAIRS


void CIN_CloseAllVideos(void) {
	int		i;

	for ( i = 0 ; i < MAX_VIDEO_HANDLES ; i++ ) {
		if (cinTable[i].fileName[0] != 0 ) {
			CIN_StopCinematic(i);
		}
	}
}


static int CIN_HandleForVideo(void) {
	int		i;

	for ( i = 0 ; i < MAX_VIDEO_HANDLES ; i++ ) {
		if ( cinTable[i].fileName[0] == 0 ) {
			return i;
		}
	}
	Com_Error( ERR_DROP, "CIN_HandleForVideo: none free" );
	return -1;
}


extern int CL_ScaledMilliseconds(void);

//-----------------------------------------------------------------------------
// RllSetupTable
//
// Allocates and initializes the square table.
//
// Parameters:	None
//
// Returns:		Nothing
//-----------------------------------------------------------------------------
static void RllSetupTable()
{
	int z;

	for (z=0;z<128;z++) {
		cin.sqrTable[z] = (short)(z*z);
		cin.sqrTable[z+128] = (short)(-cin.sqrTable[z]);
	}
}



//-----------------------------------------------------------------------------
// RllDecodeMonoToMono
//
// Decode mono source data into a mono buffer.
//
// Parameters:	from -> buffer holding encoded data
//				to ->	buffer to hold decoded data
//				size =	number of bytes of input (= # of shorts of output)
//				signedOutput = 0 for unsigned output, non-zero for signed output
//				flag = flags from asset header
//
// Returns:		Number of samples placed in output buffer
//-----------------------------------------------------------------------------
long RllDecodeMonoToMono(unsigned char *from,short *to,unsigned int size,char signedOutput ,unsigned short flag)
{
	unsigned int z;
	int prev;
	
	if (signedOutput)	
		prev =  flag - 0x8000;
	else 
		prev = flag;

	for (z=0;z<size;z++) {
		prev = to[z] = (short)(prev + cin.sqrTable[from[z]]); 
	}
	return size;	//*sizeof(short));
}


//-----------------------------------------------------------------------------
// RllDecodeMonoToStereo
//
// Decode mono source data into a stereo buffer. Output is 4 times the number
// of bytes in the input.
//
// Parameters:	from -> buffer holding encoded data
//				to ->	buffer to hold decoded data
//				size =	number of bytes of input (= 1/4 # of bytes of output)
//				signedOutput = 0 for unsigned output, non-zero for signed output
//				flag = flags from asset header
//
// Returns:		Number of samples placed in output buffer
//-----------------------------------------------------------------------------
long RllDecodeMonoToStereo(unsigned char *from,short *to,unsigned int size,char signedOutput,unsigned short flag)
{
	unsigned int z;
	int prev;
	
	if (signedOutput)	
		prev =  flag - 0x8000;
	else 
		prev = flag;

	for (z = 0; z < size; z++) {
		prev = (short)(prev + cin.sqrTable[from[z]]);
		to[z*2+0] = to[z*2+1] = (short)(prev);
	}
	
	return size;	// * 2 * sizeof(short));
}


//-----------------------------------------------------------------------------
// RllDecodeStereoToStereo
//
// Decode stereo source data into a stereo buffer.
//
// Parameters:	from -> buffer holding encoded data
//				to ->	buffer to hold decoded data
//				size =	number of bytes of input (= 1/2 # of bytes of output)
//				signedOutput = 0 for unsigned output, non-zero for signed output
//				flag = flags from asset header
//
// Returns:		Number of samples placed in output buffer
//-----------------------------------------------------------------------------
long RllDecodeStereoToStereo(unsigned char *from,short *to,unsigned int size,char signedOutput, unsigned short flag)
{
	unsigned int z;
	unsigned char *zz = from;
	int	prevL, prevR;

	if (signedOutput) {
		prevL = (flag & 0xff00) - 0x8000;
		prevR = ((flag & 0x00ff) << 8) - 0x8000;
	} else {
		prevL = flag & 0xff00;
		prevR = (flag & 0x00ff) << 8;
	}

	for (z=0;z<size;z+=2) {
                prevL = (short)(prevL + cin.sqrTable[*zz++]); 
                prevR = (short)(prevR + cin.sqrTable[*zz++]);
                to[z+0] = (short)(prevL);
                to[z+1] = (short)(prevR);
	}
	
	return (size>>1);	//*sizeof(short));
}


//-----------------------------------------------------------------------------
// RllDecodeStereoToMono
//
// Decode stereo source data into a mono buffer.
//
// Parameters:	from -> buffer holding encoded data
//				to ->	buffer to hold decoded data
//				size =	number of bytes of input (= # of bytes of output)
//				signedOutput = 0 for unsigned output, non-zero for signed output
//				flag = flags from asset header
//
// Returns:		Number of samples placed in output buffer
//-----------------------------------------------------------------------------
long RllDecodeStereoToMono(unsigned char *from,short *to,unsigned int size,char signedOutput, unsigned short flag)
{
	unsigned int z;
	int prevL,prevR;
	
	if (signedOutput) {
		prevL = (flag & 0xff00) - 0x8000;
		prevR = ((flag & 0x00ff) << 8) -0x8000;
	} else {
		prevL = flag & 0xff00;
		prevR = (flag & 0x00ff) << 8;
	}

	for (z=0;z<size;z+=1) {
		prevL= prevL + cin.sqrTable[from[z*2]];
		prevR = prevR + cin.sqrTable[from[z*2+1]];
		to[z] = (short)((prevL + prevR)/2);
	}

	return size;
}

/******************************************************************************
*
* Function:		
*
* Description:	
*
******************************************************************************/

static void move8_32( byte *src, byte *dst, int spl )
{
	double *dsrc, *ddst;
	int dspl;

	dsrc = (double *)src;
	ddst = (double *)dst;
	dspl = spl>>3;

	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
}

/******************************************************************************
*
* Function:		
*
* Description:	
*
******************************************************************************/

static void move4_32( byte *src, byte *dst, int spl  )
{
	double *dsrc, *ddst;
	int dspl;

	dsrc = (double *)src;
	ddst = (double *)dst;
	dspl = spl>>3;

	ddst[0] = dsrc[0]; ddst[1] = dsrc[1];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1];
	dsrc += dspl; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1];
}

/******************************************************************************
*
* Function:		
*
* Description:	
*
******************************************************************************/

static void blit8_32( byte *src, byte *dst, int spl  )
{
	double *dsrc, *ddst;
	int dspl;

	dsrc = (double *)src;
	ddst = (double *)dst;
	dspl = spl>>3;

	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += 4; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += 4; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += 4; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += 4; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += 4; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += 4; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
	dsrc += 4; ddst += dspl;
	ddst[0] = dsrc[0]; ddst[1] = dsrc[1]; ddst[2] = dsrc[2]; ddst[3] = dsrc[3];
}

/******************************************************************************
*
* Function:		
*
* Description:	
*
******************************************************************************/
#define movs double
static void blit4_32( byte *src, byte *dst, int spl  )
{
	movs *dsrc, *ddst;
	int dspl;

	dsrc = (movs *)src;
	ddst = (movs *)dst;
	dspl = spl>>3;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美欧美欧美欧美| www国产精品av| 粉嫩久久99精品久久久久久夜| 亚洲视频综合在线| 欧美性色aⅴ视频一区日韩精品| 一区二区欧美在线观看| 欧美精品一区二区三区蜜桃视频| 99久久精品国产一区| 裸体歌舞表演一区二区| 亚洲国产aⅴ成人精品无吗| 日本一区二区三区视频视频| 日韩午夜在线影院| 欧美色精品在线视频| 成人毛片在线观看| 国产老肥熟一区二区三区| 无码av免费一区二区三区试看 | 国产色综合一区| 7777精品伊人久久久大香线蕉完整版| 91网站黄www| 成人综合在线视频| 狠狠色丁香久久婷婷综合丁香| 亚洲大尺度视频在线观看| 亚洲精品久久嫩草网站秘色| 欧美激情一区二区三区在线| 26uuu久久天堂性欧美| 欧美一区二区三区免费观看视频| 91久久人澡人人添人人爽欧美| 成人一区二区三区在线观看| 国产精品自拍一区| 国产一区二区免费视频| 精品在线观看免费| 久久精品国产亚洲5555| 日韩精品三区四区| 三级精品在线观看| 日韩成人午夜精品| 天天色 色综合| 午夜欧美视频在线观看| 亚洲va欧美va人人爽| 亚洲电影第三页| 天天操天天干天天综合网| 亚洲成人高清在线| 日韩在线卡一卡二| 日本欧美在线看| 麻豆成人久久精品二区三区小说| 乱中年女人伦av一区二区| 免费成人性网站| 国产一区啦啦啦在线观看| 国产传媒欧美日韩成人| 成人一区二区三区在线观看| eeuss鲁一区二区三区| 一本色道久久综合亚洲91 | 奇米影视在线99精品| 麻豆精品在线视频| 国产高清不卡二三区| 成人免费黄色大片| 欧洲另类一二三四区| 欧美高清dvd| 久久先锋影音av鲁色资源| 欧美国产一区二区| 夜夜爽夜夜爽精品视频| 日韩专区欧美专区| 国产麻豆精品theporn| 91亚洲精品久久久蜜桃网站 | 国产女人aaa级久久久级| 亚洲人亚洲人成电影网站色| 亚洲国产中文字幕在线视频综合 | 国产精品一区三区| 色综合天天视频在线观看| 欧美日韩欧美一区二区| 日韩欧美电影一区| 亚洲欧洲99久久| 图片区小说区区亚洲影院| 国产乱人伦偷精品视频免下载| av在线这里只有精品| 91精品久久久久久久99蜜桃| 久久免费精品国产久精品久久久久| 中文字幕高清一区| 午夜视频在线观看一区二区| 国产乱人伦偷精品视频不卡 | 91精品综合久久久久久| 国产婷婷精品av在线| 亚洲制服丝袜av| 国内偷窥港台综合视频在线播放| 99精品视频一区二区| 日韩一级黄色大片| 亚洲日本成人在线观看| 韩国三级电影一区二区| 91福利小视频| 国产亚洲一区二区三区四区| 一区二区三区中文字幕| 极品少妇一区二区三区精品视频| 91香蕉视频污在线| 精品国产一区二区三区忘忧草| 一区二区三区在线播| 国产大片一区二区| 日韩视频一区在线观看| 亚洲综合成人在线视频| 懂色中文一区二区在线播放| 欧美剧情电影在线观看完整版免费励志电影| 欧美精品一区二区久久久| 亚洲综合精品自拍| 成人av网站在线| 精品国产sm最大网站| 五月激情综合色| 日本韩国欧美国产| √…a在线天堂一区| 国产一区二区三区免费在线观看| 欧美日韩国产系列| 亚洲综合免费观看高清完整版在线 | 国产一区福利在线| 精品国内片67194| 午夜天堂影视香蕉久久| 蜜桃视频在线一区| 成人一区二区三区中文字幕| 欧美大黄免费观看| 亚洲视频 欧洲视频| 成人手机在线视频| 久久久久久久久久看片| 麻豆国产精品777777在线| 成人午夜私人影院| 久久久不卡网国产精品一区| 蜜桃视频一区二区| 93久久精品日日躁夜夜躁欧美| 国产亚洲成年网址在线观看| 日韩黄色在线观看| 欧美疯狂做受xxxx富婆| 亚洲高清在线视频| 在线视频你懂得一区二区三区| 国产精品护士白丝一区av| 国产91精品一区二区麻豆网站| wwwwxxxxx欧美| 国产自产v一区二区三区c| 欧美一级片在线看| 蜜桃视频在线观看一区二区| 欧美一区二区三区在线看| 日本不卡视频在线| 日韩午夜av电影| 久久66热re国产| 精品粉嫩超白一线天av| 精品一区二区免费在线观看| 精品欧美一区二区久久| 久久99精品一区二区三区三区| 日韩视频免费观看高清完整版在线观看 | 高清成人免费视频| 国产欧美日韩在线观看| 成人中文字幕在线| 国产精品免费看片| 一本大道久久a久久精二百| 亚洲一区二区偷拍精品| 欧美裸体一区二区三区| 蜜桃av一区二区| 久久精品夜色噜噜亚洲aⅴ| 成人高清免费观看| 中文字幕亚洲在| 欧美在线免费播放| 人人狠狠综合久久亚洲| 久久久欧美精品sm网站| av不卡免费电影| 亚洲男人都懂的| 91麻豆精品国产自产在线观看一区| 精品一区二区在线免费观看| 国产欧美一区二区三区在线老狼| 成人sese在线| 天天做天天摸天天爽国产一区| 精品日韩99亚洲| eeuss国产一区二区三区| 一区二区三区日韩精品| 日韩免费电影一区| 成人精品视频网站| 午夜在线电影亚洲一区| 久久男人中文字幕资源站| 99久久er热在这里只有精品15 | 成人激情动漫在线观看| 亚洲免费观看高清| 日韩欧美中文字幕制服| 91香蕉国产在线观看软件| 日韩av电影免费观看高清完整版在线观看| 精品国产凹凸成av人导航| 色94色欧美sute亚洲13| 狠狠v欧美v日韩v亚洲ⅴ| 尤物av一区二区| 久久久三级国产网站| 欧洲在线/亚洲| 国产精品一区二区久久不卡| 亚洲国产成人高清精品| 国产欧美精品在线观看| 91精品国产综合久久小美女| 99国产精品久久久久| 久久精品国产99| 亚洲一区二区三区视频在线播放 | 亚洲天堂2016| 制服.丝袜.亚洲.中文.综合| 99国产精品久久久久久久久久久| 日本成人中文字幕| 欧美在线free| 麻豆国产精品官网| 亚洲综合精品自拍| 日本一区二区动态图| 日韩免费在线观看| 91国偷自产一区二区使用方法|