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

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

?? snd_mix.c

?? 著名游戲quake2原代碼最新版本(vc6.0可以編譯的)
?? C
字號:
/*
Copyright (C) 1997-2001 Id Software, Inc.

This program 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.

This program 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 this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

*/
// snd_mix.c -- portable code to mix sounds for snd_dma.c

#include "client.h"
#include "snd_loc.h"

#define	PAINTBUFFER_SIZE	2048
portable_samplepair_t paintbuffer[PAINTBUFFER_SIZE];
int		snd_scaletable[32][256];
int 	*snd_p, snd_linear_count, snd_vol;
short	*snd_out;

void S_WriteLinearBlastStereo16 (void);

#if !(defined __linux__ && defined __i386__)
#if	!id386

void S_WriteLinearBlastStereo16 (void)
{
	int		i;
	int		val;

	for (i=0 ; i<snd_linear_count ; i+=2)
	{
		val = snd_p[i]>>8;
		if (val > 0x7fff)
			snd_out[i] = 0x7fff;
		else if (val < (short)0x8000)
			snd_out[i] = (short)0x8000;
		else
			snd_out[i] = val;

		val = snd_p[i+1]>>8;
		if (val > 0x7fff)
			snd_out[i+1] = 0x7fff;
		else if (val < (short)0x8000)
			snd_out[i+1] = (short)0x8000;
		else
			snd_out[i+1] = val;
	}
}
#else
__declspec( naked ) void S_WriteLinearBlastStereo16 (void)
{
	__asm {

 push edi
 push ebx
 mov ecx,ds:dword ptr[snd_linear_count]
 mov ebx,ds:dword ptr[snd_p]
 mov edi,ds:dword ptr[snd_out]
LWLBLoopTop:
 mov eax,ds:dword ptr[-8+ebx+ecx*4]
 sar eax,8
 cmp eax,07FFFh
 jg LClampHigh
 cmp eax,0FFFF8000h
 jnl LClampDone
 mov eax,0FFFF8000h
 jmp LClampDone
LClampHigh:
 mov eax,07FFFh
LClampDone:
 mov edx,ds:dword ptr[-4+ebx+ecx*4]
 sar edx,8
 cmp edx,07FFFh
 jg LClampHigh2
 cmp edx,0FFFF8000h
 jnl LClampDone2
 mov edx,0FFFF8000h
 jmp LClampDone2
LClampHigh2:
 mov edx,07FFFh
LClampDone2:
 shl edx,16
 and eax,0FFFFh
 or edx,eax
 mov ds:dword ptr[-4+edi+ecx*2],edx
 sub ecx,2
 jnz LWLBLoopTop
 pop ebx
 pop edi
 ret
	}
}

#endif
#endif

void S_TransferStereo16 (unsigned long *pbuf, int endtime)
{
	int		lpos;
	int		lpaintedtime;
	
	snd_p = (int *) paintbuffer;
	lpaintedtime = paintedtime;

	while (lpaintedtime < endtime)
	{
	// handle recirculating buffer issues
		lpos = lpaintedtime & ((dma.samples>>1)-1);

		snd_out = (short *) pbuf + (lpos<<1);

		snd_linear_count = (dma.samples>>1) - lpos;
		if (lpaintedtime + snd_linear_count > endtime)
			snd_linear_count = endtime - lpaintedtime;

		snd_linear_count <<= 1;

	// write a linear blast of samples
		S_WriteLinearBlastStereo16 ();

		snd_p += snd_linear_count;
		lpaintedtime += (snd_linear_count>>1);
	}
}

/*
===================
S_TransferPaintBuffer

===================
*/
void S_TransferPaintBuffer(int endtime)
{
	int 	out_idx;
	int 	count;
	int 	out_mask;
	int 	*p;
	int 	step;
	int		val;
	unsigned long *pbuf;

	pbuf = (unsigned long *)dma.buffer;

	if (s_testsound->value)
	{
		int		i;
		int		count;

		// write a fixed sine wave
		count = (endtime - paintedtime);
		for (i=0 ; i<count ; i++)
			paintbuffer[i].left = paintbuffer[i].right = sin((paintedtime+i)*0.1)*20000*256;
	}


	if (dma.samplebits == 16 && dma.channels == 2)
	{	// optimized case
		S_TransferStereo16 (pbuf, endtime);
	}
	else
	{	// general case
		p = (int *) paintbuffer;
		count = (endtime - paintedtime) * dma.channels;
		out_mask = dma.samples - 1; 
		out_idx = paintedtime * dma.channels & out_mask;
		step = 3 - dma.channels;

		if (dma.samplebits == 16)
		{
			short *out = (short *) pbuf;
			while (count--)
			{
				val = *p >> 8;
				p+= step;
				if (val > 0x7fff)
					val = 0x7fff;
				else if (val < (short)0x8000)
					val = (short)0x8000;
				out[out_idx] = val;
				out_idx = (out_idx + 1) & out_mask;
			}
		}
		else if (dma.samplebits == 8)
		{
			unsigned char *out = (unsigned char *) pbuf;
			while (count--)
			{
				val = *p >> 8;
				p+= step;
				if (val > 0x7fff)
					val = 0x7fff;
				else if (val < (short)0x8000)
					val = (short)0x8000;
				out[out_idx] = (val>>8) + 128;
				out_idx = (out_idx + 1) & out_mask;
			}
		}
	}
}


/*
===============================================================================

CHANNEL MIXING

===============================================================================
*/

void S_PaintChannelFrom8 (channel_t *ch, sfxcache_t *sc, int endtime, int offset);
void S_PaintChannelFrom16 (channel_t *ch, sfxcache_t *sc, int endtime, int offset);

void S_PaintChannels(int endtime)
{
	int 	i;
	int 	end;
	channel_t *ch;
	sfxcache_t	*sc;
	int		ltime, count;
	playsound_t	*ps;

	snd_vol = s_volume->value*256;

//Com_Printf ("%i to %i\n", paintedtime, endtime);
	while (paintedtime < endtime)
	{
	// if paintbuffer is smaller than DMA buffer
		end = endtime;
		if (endtime - paintedtime > PAINTBUFFER_SIZE)
			end = paintedtime + PAINTBUFFER_SIZE;

		// start any playsounds
		while (1)
		{
			ps = s_pendingplays.next;
			if (ps == &s_pendingplays)
				break;	// no more pending sounds
			if (ps->begin <= paintedtime)
			{
				S_IssuePlaysound (ps);
				continue;
			}

			if (ps->begin < end)
				end = ps->begin;		// stop here
			break;
		}

	// clear the paint buffer
		if (s_rawend < paintedtime)
		{
//			Com_Printf ("clear\n");
			memset(paintbuffer, 0, (end - paintedtime) * sizeof(portable_samplepair_t));
		}
		else
		{	// copy from the streaming sound source
			int		s;
			int		stop;

			stop = (end < s_rawend) ? end : s_rawend;

			for (i=paintedtime ; i<stop ; i++)
			{
				s = i&(MAX_RAW_SAMPLES-1);
				paintbuffer[i-paintedtime] = s_rawsamples[s];
			}
//		if (i != end)
//			Com_Printf ("partial stream\n");
//		else
//			Com_Printf ("full stream\n");
			for ( ; i<end ; i++)
			{
				paintbuffer[i-paintedtime].left =
				paintbuffer[i-paintedtime].right = 0;
			}
		}


	// paint in the channels.
		ch = channels;
		for (i=0; i<MAX_CHANNELS ; i++, ch++)
		{
			ltime = paintedtime;
		
			while (ltime < end)
			{
				if (!ch->sfx || (!ch->leftvol && !ch->rightvol) )
					break;

				// max painting is to the end of the buffer
				count = end - ltime;

				// might be stopped by running out of data
				if (ch->end - ltime < count)
					count = ch->end - ltime;
		
				sc = S_LoadSound (ch->sfx);
				if (!sc)
					break;

				if (count > 0 && ch->sfx)
				{	
					if (sc->width == 1)// FIXME; 8 bit asm is wrong now
						S_PaintChannelFrom8(ch, sc, count,  ltime - paintedtime);
					else
						S_PaintChannelFrom16(ch, sc, count, ltime - paintedtime);
	
					ltime += count;
				}

			// if at end of loop, restart
				if (ltime >= ch->end)
				{
					if (ch->autosound)
					{	// autolooping sounds always go back to start
						ch->pos = 0;
						ch->end = ltime + sc->length;
					}
					else if (sc->loopstart >= 0)
					{
						ch->pos = sc->loopstart;
						ch->end = ltime + sc->length - ch->pos;
					}
					else				
					{	// channel just stopped
						ch->sfx = NULL;
					}
				}
			}
															  
		}

	// transfer out according to DMA format
		S_TransferPaintBuffer(end);
		paintedtime = end;
	}
}

void S_InitScaletable (void)
{
	int		i, j;
	int		scale;

	s_volume->modified = false;
	for (i=0 ; i<32 ; i++)
	{
		scale = i * 8 * 256 * s_volume->value;
		for (j=0 ; j<256 ; j++)
			snd_scaletable[i][j] = ((signed char)j) * scale;
	}
}


#if !(defined __linux__ && defined __i386__)
#if	!id386

void S_PaintChannelFrom8 (channel_t *ch, sfxcache_t *sc, int count, int offset)
{
	int 	data;
	int		*lscale, *rscale;
	unsigned char *sfx;
	int		i;
	portable_samplepair_t	*samp;

	if (ch->leftvol > 255)
		ch->leftvol = 255;
	if (ch->rightvol > 255)
		ch->rightvol = 255;
		
	//ZOID-- >>11 has been changed to >>3, >>11 didn't make much sense
	//as it would always be zero.
	lscale = snd_scaletable[ ch->leftvol >> 3];
	rscale = snd_scaletable[ ch->rightvol >> 3];
	sfx = (signed char *)sc->data + ch->pos;

	samp = &paintbuffer[offset];

	for (i=0 ; i<count ; i++, samp++)
	{
		data = sfx[i];
		samp->left += lscale[data];
		samp->right += rscale[data];
	}
	
	ch->pos += count;
}

#else

__declspec( naked ) void S_PaintChannelFrom8 (channel_t *ch, sfxcache_t *sc, int count, int offset)
{
	__asm {
 push esi
 push edi
 push ebx
 push ebp
 mov ebx,ds:dword ptr[4+16+esp]
 mov esi,ds:dword ptr[8+16+esp]
 mov eax,ds:dword ptr[4+ebx]
 mov edx,ds:dword ptr[8+ebx]
 cmp eax,255
 jna LLeftSet
 mov eax,255
LLeftSet:
 cmp edx,255
 jna LRightSet
 mov edx,255
LRightSet:
 and eax,0F8h
 add esi,20
 and edx,0F8h
 mov edi,ds:dword ptr[16+ebx]
 mov ecx,ds:dword ptr[12+16+esp]
 add esi,edi
 shl eax,7
 add edi,ecx
 shl edx,7
 mov ds:dword ptr[16+ebx],edi
 add eax,offset snd_scaletable
 add edx,offset snd_scaletable
 sub ebx,ebx
 mov bl,ds:byte ptr[-1+esi+ecx*1]
 test ecx,1
 jz LMix8Loop
 mov edi,ds:dword ptr[eax+ebx*4]
 mov ebp,ds:dword ptr[edx+ebx*4]
 add edi,ds:dword ptr[paintbuffer+0-8+ecx*8]
 add ebp,ds:dword ptr[paintbuffer+4-8+ecx*8]
 mov ds:dword ptr[paintbuffer+0-8+ecx*8],edi
 mov ds:dword ptr[paintbuffer+4-8+ecx*8],ebp
 mov bl,ds:byte ptr[-2+esi+ecx*1]
 dec ecx
 jz LDone
LMix8Loop:
 mov edi,ds:dword ptr[eax+ebx*4]
 mov ebp,ds:dword ptr[edx+ebx*4]
 add edi,ds:dword ptr[paintbuffer+0-8+ecx*8]
 add ebp,ds:dword ptr[paintbuffer+4-8+ecx*8]
 mov bl,ds:byte ptr[-2+esi+ecx*1]
 mov ds:dword ptr[paintbuffer+0-8+ecx*8],edi
 mov ds:dword ptr[paintbuffer+4-8+ecx*8],ebp
 mov edi,ds:dword ptr[eax+ebx*4]
 mov ebp,ds:dword ptr[edx+ebx*4]
 mov bl,ds:byte ptr[-3+esi+ecx*1]
 add edi,ds:dword ptr[paintbuffer+0-8*2+ecx*8]
 add ebp,ds:dword ptr[paintbuffer+4-8*2+ecx*8]
 mov ds:dword ptr[paintbuffer+0-8*2+ecx*8],edi
 mov ds:dword ptr[paintbuffer+4-8*2+ecx*8],ebp
 sub ecx,2
 jnz LMix8Loop
LDone:
 pop ebp
 pop ebx
 pop edi
 pop esi
 ret
	}
}

#endif
#endif

void S_PaintChannelFrom16 (channel_t *ch, sfxcache_t *sc, int count, int offset)
{
	int data;
	int left, right;
	int leftvol, rightvol;
	signed short *sfx;
	int	i;
	portable_samplepair_t	*samp;

	leftvol = ch->leftvol*snd_vol;
	rightvol = ch->rightvol*snd_vol;
	sfx = (signed short *)sc->data + ch->pos;

	samp = &paintbuffer[offset];
	for (i=0 ; i<count ; i++, samp++)
	{
		data = sfx[i];
		left = (data * leftvol)>>8;
		right = (data * rightvol)>>8;
		samp->left += left;
		samp->right += right;
	}

	ch->pos += count;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二区三区在线观看 | 欧美一区二区三区在线看| 69成人精品免费视频| 国产视频一区在线播放| 亚洲18色成人| 99久久精品国产网站| 精品国产乱码久久久久久闺蜜| 亚洲色图色小说| 国产成人精品免费网站| 717成人午夜免费福利电影| 中文字幕第一区综合| 寂寞少妇一区二区三区| 欧美日韩二区三区| 亚洲人成网站在线| 成人综合在线视频| xfplay精品久久| 老司机精品视频在线| 欧美少妇一区二区| 中文字幕永久在线不卡| 懂色av一区二区三区免费看| 欧美大片国产精品| 日韩av电影免费观看高清完整版 | 欧美电影一区二区三区| 亚洲欧美日韩国产综合在线| 高清在线观看日韩| 久久在线观看免费| 毛片基地黄久久久久久天堂| 欧美日韩国产高清一区| 亚洲国产另类精品专区| 欧美主播一区二区三区美女| 国产精品国产成人国产三级 | 精品捆绑美女sm三区| 日本不卡123| 欧美一级在线免费| 日韩av网站在线观看| 国产免费成人在线视频| 免费观看在线色综合| 欧美一级xxx| 久久精品二区亚洲w码| 欧美成人女星排行榜| 精品一区二区在线播放| 国产亚洲人成网站| 国产精品18久久久久久久久久久久| 精品国产一区久久| 国产二区国产一区在线观看| 欧美极品xxx| 风间由美性色一区二区三区| 国产精品久久久久久久久果冻传媒| 成人国产电影网| 亚洲伦理在线精品| 欧美日韩在线一区二区| 蜜桃精品在线观看| 久久精品一级爱片| av一区二区不卡| 亚洲一区二区视频| 欧美一区二区黄| 国内精品免费**视频| 国产精品久久毛片av大全日韩| a级精品国产片在线观看| 中文字幕一区二区日韩精品绯色| 91福利国产成人精品照片| 首页亚洲欧美制服丝腿| 精品乱码亚洲一区二区不卡| 不卡的电影网站| 午夜精品久久久久久久久久| 2023国产一二三区日本精品2022| 成人h动漫精品| 亚洲一区二区三区美女| 精品国产自在久精品国产| 99re这里只有精品6| 天堂成人国产精品一区| 久久九九影视网| 欧美午夜精品久久久久久超碰| 日本网站在线观看一区二区三区 | 久久午夜国产精品| 97aⅴ精品视频一二三区| 日本欧美在线看| 中文字幕一区不卡| 日韩精品资源二区在线| 99精品久久只有精品| 日韩av一区二区在线影视| 国产精品麻豆欧美日韩ww| 91精品国产欧美一区二区18| 成人av在线影院| 精品伊人久久久久7777人| 亚洲私人黄色宅男| 久久久三级国产网站| 欧洲国产伦久久久久久久| 国产精品中文字幕一区二区三区| 有码一区二区三区| 欧美国产精品劲爆| 日韩欧美一二三区| 欧美日韩国产一级二级| 国产精品18久久久| 捆绑变态av一区二区三区| 亚洲一区二区黄色| 亚洲三级在线观看| 国产精品网站在线| 精品国产一区二区在线观看| 在线综合视频播放| 欧美日韩一区二区在线观看视频| av在线这里只有精品| 国产剧情一区二区三区| 美国十次了思思久久精品导航| 午夜精品福利视频网站| 亚洲一区二区在线播放相泽| 亚洲欧美二区三区| 国产精品国产成人国产三级| 国产视频不卡一区| 国产亚洲婷婷免费| 久久蜜桃av一区精品变态类天堂| 日韩欧美123| 综合色中文字幕| 欧美极品aⅴ影院| 国产欧美日韩视频一区二区| 精品福利一区二区三区免费视频| 日韩一级高清毛片| 日韩一区二区电影在线| 精品日韩99亚洲| 欧美精品一区二区不卡| 久久久久国产精品免费免费搜索| www精品美女久久久tv| 久久综合狠狠综合久久综合88 | 成人99免费视频| av一二三不卡影片| 色天使色偷偷av一区二区| 91偷拍与自偷拍精品| 91美女在线视频| 欧美日韩大陆在线| 欧美一区国产二区| 精品99一区二区三区| 国产欧美一区二区精品久导航 | 国产高清在线观看免费不卡| 国产风韵犹存在线视精品| 成人激情小说网站| 在线看日本不卡| 欧美一区二区久久| 久久久久久久久99精品| 国产精品色婷婷久久58| 一区二区三区成人| 老司机午夜精品| bt欧美亚洲午夜电影天堂| 欧美日韩在线免费视频| 精品国产凹凸成av人网站| 国产精品国产精品国产专区不片| 亚洲亚洲人成综合网络| 久久99久久99精品免视看婷婷 | 成人三级在线视频| 欧美午夜视频网站| 久久人人爽爽爽人久久久| 亚洲特级片在线| 日本欧美一区二区三区乱码| 处破女av一区二区| 欧美久久久久久久久| 国产清纯白嫩初高生在线观看91| 一区二区高清免费观看影视大全| 久久丁香综合五月国产三级网站| 99天天综合性| 精品国产一区二区三区av性色| 中文字幕亚洲电影| 久久99精品国产.久久久久久 | 欧美亚洲一区二区在线| 欧美精品一区二区在线观看| 国产欧美日韩激情| 亚洲成a人片综合在线| 国产999精品久久久久久绿帽| 欧美精品粉嫩高潮一区二区| 国产精品丝袜久久久久久app| 日韩精品午夜视频| 91丨九色丨蝌蚪富婆spa| 日韩一级视频免费观看在线| 亚洲视频 欧洲视频| 国产乱码精品一区二区三区五月婷 | 国产真实乱偷精品视频免| 欧美艳星brazzers| 中文字幕精品—区二区四季| 久久精品72免费观看| 欧美天堂一区二区三区| 国产精品大尺度| 国产福利不卡视频| 精品国产一区二区三区av性色| 香蕉加勒比综合久久| 成人黄动漫网站免费app| 精品国产乱码久久久久久久 | av男人天堂一区| 久久久久久久久久久99999| 免费久久99精品国产| 欧美视频日韩视频| 一区二区三区资源| aaa亚洲精品| 国产精品色婷婷| 成人国产免费视频| 国产欧美一区二区精品忘忧草| 激情丁香综合五月| 精品国产一区a| 国产一区二区三区在线观看精品 | 26uuu亚洲综合色欧美| 蜜桃久久久久久| 精品久久久三级丝袜| 久久9热精品视频|