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

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

?? contigsc.c

?? Wolf 3D official source code.
?? C
?? 第 1 頁 / 共 2 頁
字號:
// WL_SCALE.C

#include "WL_DEF.H"
#pragma hdrstop

#define OP_RETF	0xcb

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

						  GLOBALS

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

t_compscale far *scaledirectory[MAXSCALEHEIGHT+1];
long			fullscalefarcall[MAXSCALEHEIGHT+1];

int			maxscale,maxscaleshl2;

byte far	*scalermemory;
byte _seg	*endscalermemory;
long		freescalermemory;


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

						  LOCALS

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

unsigned BuildCompScale (int height, byte far *code);

int			stepbytwo;

//===========================================================================

/*
==============
=
= BadScale
=
==============
*/

void far BadScale (void)
{
	Quit ("BadScale called!");
}


/*
==========================
=
= SetupScaling
=
==========================
*/

long SetupScaling (int maxscaleheight)
{
	int		i,x,y;
	byte	far *dest;
	unsigned	seg,ofs;
	long	size;


	maxscaleheight/=2;			// one scaler every two pixels

	maxscale = maxscaleheight-1;
	maxscaleshl2 = maxscale<<2;

	dest = scalermemory;

//
// build the compiled scalers
//
	stepbytwo = viewheight/2;	// save space by double stepping

	for (i=1;i<=maxscaleheight;i++)
	{
		seg = FP_SEG(dest);
		ofs = (FP_OFF(dest)+15)&~15;
		dest = MK_FP(seg+ofs/16,0);

		scaledirectory[i] = (t_compscale far *)dest;
		size = BuildCompScale (i*2,dest);
		dest += size;

		if ((byte huge *)dest-(byte huge *)scalermemory > MAXSCALERMEMORY)
			Quit ("Compiled scalars exceeded allocated space!");

		if (i>=stepbytwo)
			i+= 2;
	}

//
// get far call addresses
//
	for (i=1;i<=maxscaleheight;i++)
	{
		fullscalefarcall[i] = (long)scaledirectory[i] + scaledirectory[i]->codeofs[0];
		if (i>=stepbytwo)
		{
			scaledirectory[i+1] = scaledirectory[i];
			fullscalefarcall[i+1] = (long)scaledirectory[i] + scaledirectory[i]->codeofs[0];
			scaledirectory[i+2] = scaledirectory[i];
			fullscalefarcall[i+2] = (long)scaledirectory[i] + scaledirectory[i]->codeofs[0];
			i+=2;
		}
	}
	scaledirectory[0] = scaledirectory[1];
	fullscalefarcall[0] = fullscalefarcall[1];

//
// check for oversize wall drawing
//
	for (i=maxscaleheight;i<MAXSCALEHEIGHT;i++)
		fullscalefarcall[i] = (long)BadScale;

	seg = FP_SEG(dest);
	ofs = (FP_OFF(dest)+15)&~15;
	endscalermemory = (void _seg *)(seg+ofs/16);
	size = (byte huge *)dest-(byte huge *)scalermemory;
	freescalermemory = MAXSCALERMEMORY-16-size;

	return size;
}

//===========================================================================

/*
========================
=
= BuildCompScale
=
= Builds a compiled scaler object that will scale a 64 tall object to
= the given height (centered vertically on the screen)
=
= height should be even
=
= Call with
= ---------
= DS:SI		Source for scale
= ES:DI		Dest for scale
=
= Calling the compiled scaler only destroys AL
=
========================
*/

unsigned BuildCompScale (int height, byte far *code)
{
	t_compscale 	far *work;

	int			i;
	long		fix,step;
	unsigned	src,totalscaled,totalsize;
	int			startpix,endpix,toppix;

	work = (t_compscale far *)code;

	step = ((long)height<<16) / 64;
	code = &work->code[0];
	toppix = (viewheight-height)/2;
	fix = 0;

	for (src=0;src<=64;src++)
	{
		startpix = fix>>16;
		fix += step;
		endpix = fix>>16;

		if (endpix>startpix)
			work->width[src] = endpix-startpix;
		else
			work->width[src] = 0;

//
// mark the start of the code
//
		work->codeofs[src] = FP_OFF(code);

//
// compile some code if the source pixel generates any screen pixels
//
		startpix+=toppix;
		endpix+=toppix;

		if (startpix == endpix || endpix < 0 || startpix >= viewheight || src == 64)
			continue;

	//
	// mov al,[si+src]
	//
		*code++ = 0x8a;
		*code++ = 0x44;
		*code++ = src;

		for (;startpix<endpix;startpix++)
		{
			if (startpix >= viewheight)
				break;						// off the bottom of the view area
			if (startpix < 0)
				continue;					// not into the view area

		//
		// mov [es:di+heightofs],al
		//
			*code++ = 0x26;
			*code++ = 0x88;
			*code++ = 0x85;
			*((unsigned far *)code)++ = startpix*SCREENBWIDE;
		}

	}

//
// retf
//
	*code++ = 0xcb;

	totalsize = FP_OFF(code);

	return totalsize;
}


/*
=======================
=
= ScaleLine
=
= linescale should have the high word set to the segment of the scaler
=
=======================
*/

extern	int			slinex,slinewidth;
extern	unsigned	far *linecmds;
extern	long		linescale;
extern	unsigned	maskword;

byte	mask1,mask2,mask3;


void near ScaleLine (void)
{
asm	mov	cx,WORD PTR [linescale+2]
asm	mov	es,cx						// segment of scaler

asm	mov bp,WORD PTR [linecmds]
asm	mov	dx,SC_INDEX+1				// to set SC_MAPMASK

asm	mov	bx,[slinex]
asm	mov	di,bx
asm	shr	di,2						// X in bytes
asm	add	di,[bufferofs]
asm	and	bx,3
asm	shl	bx,3
asm	add	bx,[slinewidth]				// bx = (pixel*8+pixwidth)
asm	mov	al,BYTE [mapmasks3-1+bx]	// -1 because pixwidth of 1 is first
asm	mov	ds,WORD PTR [linecmds+2]
asm	or	al,al
asm	jz	notthreebyte				// scale across three bytes
asm	jmp	threebyte
notthreebyte:
asm	mov	al,BYTE PTR ss:[mapmasks2-1+bx]	// -1 because pixwidth of 1 is first
asm	or	al,al
asm	jnz	twobyte						// scale across two bytes

//
// one byte scaling
//
asm	mov	al,BYTE PTR ss:[mapmasks1-1+bx]	// -1 because pixwidth of 1 is first
asm	out	dx,al						// set map mask register

scalesingle:

asm	mov	bx,[ds:bp]					// table location of rtl to patch
asm	or	bx,bx
asm	jz	linedone					// 0 signals end of segment list
asm	mov	bx,[es:bx]
asm	mov	dl,[es:bx]					// save old value
asm	mov	BYTE PTR es:[bx],OP_RETF	// patch a RETF in
asm	mov	si,[ds:bp+4]				// table location of entry spot
asm	mov	ax,[es:si]
asm	mov	WORD PTR ss:[linescale],ax	// call here to start scaling
asm	mov	si,[ds:bp+2]				// corrected top of shape for this segment
asm	add	bp,6						// next segment list

asm	mov	ax,SCREENSEG
asm	mov	es,ax
asm	call ss:[linescale]				// scale the segment of pixels

asm	mov	es,cx						// segment of scaler
asm	mov	BYTE PTR es:[bx],dl			// unpatch the RETF
asm	jmp	scalesingle					// do the next segment


//
// done
//
linedone:
asm	mov	ax,ss
asm	mov	ds,ax
return;

//
// two byte scaling
//
twobyte:
asm	mov	ss:[mask2],al
asm	mov	al,BYTE PTR ss:[mapmasks1-1+bx]	// -1 because pixwidth of 1 is first
asm	mov	ss:[mask1],al

scaledouble:

asm	mov	bx,[ds:bp]					// table location of rtl to patch
asm	or	bx,bx
asm	jz	linedone					// 0 signals end of segment list
asm	mov	bx,[es:bx]
asm	mov	cl,[es:bx]					// save old value
asm	mov	BYTE PTR es:[bx],OP_RETF	// patch a RETF in
asm	mov	si,[ds:bp+4]				// table location of entry spot
asm	mov	ax,[es:si]
asm	mov	WORD PTR ss:[linescale],ax	// call here to start scaling
asm	mov	si,[ds:bp+2]				// corrected top of shape for this segment
asm	add	bp,6						// next segment list

asm	mov	ax,SCREENSEG
asm	mov	es,ax
asm	mov	al,ss:[mask1]
asm	out	dx,al						// set map mask register
asm	call ss:[linescale]				// scale the segment of pixels
asm	inc	di
asm	mov	al,ss:[mask2]
asm	out	dx,al						// set map mask register
asm	call ss:[linescale]				// scale the segment of pixels
asm	dec	di

asm	mov	es,WORD PTR ss:[linescale+2] // segment of scaler
asm	mov	BYTE PTR es:[bx],cl			// unpatch the RETF
asm	jmp	scaledouble					// do the next segment


//
// three byte scaling
//
threebyte:
asm	mov	ss:[mask3],al
asm	mov	al,BYTE PTR ss:[mapmasks2-1+bx]	// -1 because pixwidth of 1 is first
asm	mov	ss:[mask2],al
asm	mov	al,BYTE PTR ss:[mapmasks1-1+bx]	// -1 because pixwidth of 1 is first
asm	mov	ss:[mask1],al

scaletriple:

asm	mov	bx,[ds:bp]					// table location of rtl to patch
asm	or	bx,bx
asm	jz	linedone					// 0 signals end of segment list
asm	mov	bx,[es:bx]
asm	mov	cl,[es:bx]					// save old value
asm	mov	BYTE PTR es:[bx],OP_RETF	// patch a RETF in
asm	mov	si,[ds:bp+4]				// table location of entry spot

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天天亚洲美女在线视频| 日韩精品一区二区三区在线| 666欧美在线视频| 亚洲国产高清在线观看视频| 视频在线观看一区| 99精品黄色片免费大全| 日韩免费高清av| 亚洲一区二区三区美女| 成人一级片在线观看| 在线成人午夜影院| 亚洲精品视频观看| 风间由美一区二区av101| 91麻豆精品国产| 樱花影视一区二区| 国产精品综合二区| 欧美一区二区在线观看| 日韩伦理电影网| 国产福利一区二区三区视频在线 | 老司机午夜精品| 欧美色图免费看| 亚洲精品国产无套在线观| 国产成人超碰人人澡人人澡| 日韩一二三区视频| 五月婷婷综合在线| 在线欧美小视频| 综合欧美一区二区三区| 国产成a人亚洲精品| 亚洲精品在线观| 久久国产尿小便嘘嘘尿| 欧美日韩不卡一区二区| 亚洲一区二区偷拍精品| 91天堂素人约啪| 国产精品不卡一区二区三区| 国产伦精品一区二区三区在线观看| 日韩欧美一区在线观看| 首页国产欧美日韩丝袜| 欧美精品色一区二区三区| 亚洲曰韩产成在线| 欧洲国内综合视频| 亚洲一区二区偷拍精品| 欧美体内she精高潮| 一级特黄大欧美久久久| 在线观看日韩高清av| 一区二区三区日韩精品| 色狠狠av一区二区三区| 亚洲精品免费在线播放| 色乱码一区二区三区88| 亚洲精品大片www| 91久久精品一区二区三区| 一区二区在线观看免费| 一本大道久久a久久综合婷婷| 亚洲人妖av一区二区| 色综合天天综合给合国产| 亚洲欧美偷拍三级| 在线中文字幕一区| 亚洲午夜在线观看视频在线| 欧美三级在线看| 日韩av一二三| 久久亚洲一区二区三区四区| 国产激情一区二区三区桃花岛亚洲| 国产亚洲成av人在线观看导航| 国产精品一线二线三线精华| 国产午夜精品在线观看| 成人深夜在线观看| 亚洲欧美色一区| 欧美日韩国产首页| 麻豆精品精品国产自在97香蕉| 欧美大肚乱孕交hd孕妇| 国产福利一区在线观看| 亚洲特级片在线| 欧美日韩高清一区二区不卡| 蜜桃久久av一区| 国产亚洲欧洲一区高清在线观看| 99精品欧美一区二区蜜桃免费 | 欧美精品一区二| 国产不卡视频一区二区三区| 亚洲色大成网站www久久九九| 在线亚洲高清视频| 日本成人在线视频网站| 久久色在线视频| 91视频一区二区| 婷婷成人激情在线网| 欧美精品一区二区三区一线天视频| 国产69精品久久777的优势| 亚洲另类中文字| 制服丝袜一区二区三区| 国产精品69久久久久水密桃| 亚洲少妇屁股交4| 3d成人h动漫网站入口| 国产精品一级在线| 一区二区三国产精华液| 欧美mv日韩mv国产网站| 91在线国内视频| 日本欧洲一区二区| 中文字幕 久热精品 视频在线| 91豆麻精品91久久久久久| 久久成人久久爱| 亚洲精选一二三| 欧美大片日本大片免费观看| 91热门视频在线观看| 免费精品视频在线| 综合婷婷亚洲小说| 欧美tk—视频vk| 欧美中文字幕不卡| 国产精品自产自拍| 亚洲va国产天堂va久久en| 久久久蜜桃精品| 欧美二区乱c少妇| 波多野结衣欧美| 免费观看在线综合色| 亚洲欧美另类综合偷拍| 精品久久久久久久久久久院品网| 91官网在线观看| 国产成人免费视频网站 | 综合电影一区二区三区| 日韩免费性生活视频播放| 91在线免费视频观看| 国产在线不卡视频| 日韩中文字幕1| 亚洲视频你懂的| 久久久久久久综合狠狠综合| 精品视频在线免费看| 不卡的看片网站| 久久99这里只有精品| 亚洲高清免费视频| 中文字幕一区二区三区不卡| 精品免费国产一区二区三区四区| 欧美丝袜丝nylons| 99re在线精品| 国产成都精品91一区二区三| 久久国内精品自在自线400部| 亚洲成av人片在线观看无码| 日韩美女啊v在线免费观看| 亚洲精品一区二区三区香蕉| 欧美日韩精品一区二区三区蜜桃 | 色欧美片视频在线观看在线视频| 国产精品性做久久久久久| 日韩不卡一区二区三区| 夜夜嗨av一区二区三区四季av| 国产精品网站一区| 久久久久久97三级| 精品裸体舞一区二区三区| 制服丝袜中文字幕一区| 欧美日韩精品一区二区在线播放| 91捆绑美女网站| 99久久综合狠狠综合久久| 国产成人在线免费观看| 国内精品国产成人国产三级粉色 | 亚洲午夜激情网站| 亚洲精品综合在线| 中文字幕亚洲精品在线观看| 国产欧美日本一区二区三区| 久久综合九色综合欧美亚洲| 日韩欧美一区中文| 日韩欧美精品在线视频| 日韩美女一区二区三区四区| 在线播放视频一区| 91麻豆精品国产无毒不卡在线观看| 欧美体内she精高潮| 欧美三级电影网| 欧美日韩中文一区| 欧美精品精品一区| 欧美色区777第一页| 欧美夫妻性生活| 日韩一区二区在线看| 51午夜精品国产| 日韩欧美综合一区| 久久亚洲综合色| 欧美激情一区在线| 国产精品福利一区| 一区二区三区在线视频观看| 一区二区三区四区乱视频| 亚洲综合在线电影| 亚洲福利视频一区二区| 三级欧美在线一区| 免费观看在线色综合| 精品影院一区二区久久久| 国产主播一区二区三区| 国产成人免费xxxxxxxx| 成人免费视频app| 91同城在线观看| 欧美日韩国产bt| 欧美本精品男人aⅴ天堂| 久久亚洲精精品中文字幕早川悠里| 国产欧美日韩另类一区| 中文字幕一区二区视频| 亚洲午夜影视影院在线观看| 亚洲va欧美va国产va天堂影院| 蜜桃精品视频在线| 成人综合在线视频| 色综合久久久久综合体| 欧美久久久久久蜜桃| 欧美大片在线观看一区二区| 欧美经典一区二区| 亚洲精品免费播放| 日韩精品久久理论片| 国产另类ts人妖一区二区| 色综合久久中文综合久久97| 777色狠狠一区二区三区| 久久久久久黄色|