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

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

?? rw_x11.c

?? 著名游戲quake2原代碼最新版本(vc6.0可以編譯的)
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*****************************************************************************/

/*
** SWimp_Init
**
** This routine is responsible for initializing the implementation
** specific stuff in a software rendering subsystem.
*/
int SWimp_Init( void *hInstance, void *wndProc )
{

	vid_xpos = ri.Cvar_Get ("vid_xpos", "3", CVAR_ARCHIVE);
	vid_ypos = ri.Cvar_Get ("vid_ypos", "22", CVAR_ARCHIVE);

// open the display
	dpy = XOpenDisplay(0);
	if (!dpy)
	{
		if (getenv("DISPLAY"))
			Sys_Error("VID: Could not open display [%s]\n",
				getenv("DISPLAY"));
		else
			Sys_Error("VID: Could not open local display\n");
	}

// catch signals so i can turn on auto-repeat

	{
		struct sigaction sa;
		sigaction(SIGINT, 0, &sa);
		sa.sa_handler = TragicDeath;
		sigaction(SIGINT, &sa, 0);
		sigaction(SIGTERM, &sa, 0);
	}

	return true;
}

/*
** SWimp_InitGraphics
**
** This initializes the software refresh's implementation specific
** graphics subsystem.  In the case of Windows it creates DIB or
** DDRAW surfaces.
**
** The necessary width and height parameters are grabbed from
** vid.width and vid.height.
*/
static qboolean SWimp_InitGraphics( qboolean fullscreen )
{
	int pnum, i;
	XVisualInfo template;
	int num_visuals;
	int template_mask;
	Window root;

	srandom(getpid());

	// free resources in use
	SWimp_Shutdown ();

	// let the sound and input subsystems know about the new window
	ri.Vid_NewWindow (vid.width, vid.height);

//	XAutoRepeatOff(dpy);

// for debugging only
	XSynchronize(dpy, True);

// check for command-line window size
	template_mask = 0;

#if 0
// specify a visual id
	if ((pnum=COM_CheckParm("-visualid")))
	{
		if (pnum >= com_argc-1)
			Sys_Error("VID: -visualid <id#>\n");
		template.visualid = Q_atoi(com_argv[pnum+1]);
		template_mask = VisualIDMask;
	}

// If not specified, use default visual
	else
#endif
	{
		int screen;
		screen = XDefaultScreen(dpy);
		template.visualid =
			XVisualIDFromVisual(XDefaultVisual(dpy, screen));
		template_mask = VisualIDMask;
	}

// pick a visual- warn if more than one was available
	x_visinfo = XGetVisualInfo(dpy, template_mask, &template, &num_visuals);
	if (num_visuals > 1)
	{
		printf("Found more than one visual id at depth %d:\n", template.depth);
		for (i=0 ; i<num_visuals ; i++)
			printf("	-visualid %d\n", (int)(x_visinfo[i].visualid));
	}
	else if (num_visuals == 0)
	{
		if (template_mask == VisualIDMask)
			Sys_Error("VID: Bad visual id %d\n", template.visualid);
		else
			Sys_Error("VID: No visuals at depth %d\n", template.depth);
	}

#if 0
	printf("Using visualid %d:\n", (int)(x_visinfo->visualid));
	printf("	screen %d\n", x_visinfo->screen);
	printf("	red_mask 0x%x\n", (int)(x_visinfo->red_mask));
	printf("	green_mask 0x%x\n", (int)(x_visinfo->green_mask));
	printf("	blue_mask 0x%x\n", (int)(x_visinfo->blue_mask));
	printf("	colormap_size %d\n", x_visinfo->colormap_size);
	printf("	bits_per_rgb %d\n", x_visinfo->bits_per_rgb);
#endif

	x_vis = x_visinfo->visual;
	root = XRootWindow(dpy, x_visinfo->screen);

// setup attributes for main window
	{
	   int attribmask = CWEventMask  | CWColormap | CWBorderPixel;
	   XSetWindowAttributes attribs;
	   Colormap tmpcmap;
	   
	   tmpcmap = XCreateColormap(dpy, root, x_vis, AllocNone);
	   
	   attribs.event_mask = X_MASK;
	   attribs.border_pixel = 0;
	   attribs.colormap = tmpcmap;

// create the main window
		win = XCreateWindow(dpy, root, (int)vid_xpos->value, (int)vid_ypos->value, 
			vid.width, vid.height, 0, x_visinfo->depth, InputOutput, x_vis, 
			attribmask, &attribs );
		XStoreName(dpy, win, "Quake II");

		if (x_visinfo->class != TrueColor)
			XFreeColormap(dpy, tmpcmap);
	}

	if (x_visinfo->depth == 8)
	{
	// create and upload the palette
		if (x_visinfo->class == PseudoColor)
		{
			x_cmap = XCreateColormap(dpy, win, x_vis, AllocAll);
			XSetWindowColormap(dpy, win, x_cmap);
		}

	}

// create the GC
	{
		XGCValues xgcvalues;
		int valuemask = GCGraphicsExposures;
		xgcvalues.graphics_exposures = False;
		x_gc = XCreateGC(dpy, win, valuemask, &xgcvalues );
	}

	XMapWindow(dpy, win);
	XMoveWindow(dpy, win, (int)vid_xpos->value, (int)vid_ypos->value);

// wait for first exposure event
	{
		XEvent event;
		exposureflag = false;
		do
		{
			HandleEvents();
		} while (!exposureflag);
	}
// now safe to draw

// even if MITSHM is available, make sure it's a local connection
	if (XShmQueryExtension(dpy))
	{
		char *displayname;
		doShm = true;
		displayname = (char *) getenv("DISPLAY");
		if (displayname)
		{
			char *d = displayname;
			while (*d && (*d != ':')) d++;
			if (*d) *d = 0;
			if (!(!strcasecmp(displayname, "unix") || !*displayname))
				doShm = false;
		}
	}

	if (doShm)
	{
		x_shmeventtype = XShmGetEventBase(dpy) + ShmCompletion;
		ResetSharedFrameBuffers();
	}
	else
		ResetFrameBuffer();

	current_framebuffer = 0;
	vid.rowbytes = x_framebuffer[0]->bytes_per_line;
	vid.buffer = x_framebuffer[0]->data;

//	XSynchronize(dpy, False);

	X11_active = true;

	return true;
}

/*
** SWimp_EndFrame
**
** This does an implementation specific copy from the backbuffer to the
** front buffer.  In the Win32 case it uses BitBlt or BltFast depending
** on whether we're using DIB sections/GDI or DDRAW.
*/
void SWimp_EndFrame (void)
{
// if the window changes dimension, skip this frame
#if 0
	if (config_notify)
	{
		fprintf(stderr, "config notify\n");
		config_notify = 0;
		vid.width = config_notify_width & ~7;
		vid.height = config_notify_height;
		if (doShm)
			ResetSharedFrameBuffers();
		else
			ResetFrameBuffer();
		vid.rowbytes = x_framebuffer[0]->bytes_per_line;
		vid.buffer = x_framebuffer[current_framebuffer]->data;
		vid.recalc_refdef = 1;				// force a surface cache flush
		Con_CheckResize();
		Con_Clear_f();
		return;
	}
#endif

	if (doShm)
	{
		if (x_visinfo->depth == 16)
			st2_fixup( x_framebuffer[current_framebuffer], 0, 0, vid.width, vid.height);
		else if (x_visinfo->depth == 24)
			st3_fixup( x_framebuffer[current_framebuffer], 0, 0, vid.width, vid.height);
		if (!XShmPutImage(dpy, win, x_gc,
			x_framebuffer[current_framebuffer], 0, 0, 0, 0, vid.width, vid.height, True))
			Sys_Error("VID_Update: XShmPutImage failed\n");
		oktodraw = false;
		while (!oktodraw) 
			HandleEvents();
		current_framebuffer = !current_framebuffer;
		vid.buffer = x_framebuffer[current_framebuffer]->data;
		XSync(dpy, False);
	}
	else
	{
		if (x_visinfo->depth == 16)
			st2_fixup( x_framebuffer[current_framebuffer], 0, 0, vid.width, vid.height);
		else if (x_visinfo->depth == 24)
			st3_fixup( x_framebuffer[current_framebuffer], 0, 0, vid.width, vid.height);
		XPutImage(dpy, win, x_gc, x_framebuffer[0], 0, 0, 0, 0, vid.width, vid.height);
		XSync(dpy, False);
	}
}

/*
** SWimp_SetMode
*/
rserr_t SWimp_SetMode( int *pwidth, int *pheight, int mode, qboolean fullscreen )
{
	rserr_t retval = rserr_ok;

	ri.Con_Printf (PRINT_ALL, "setting mode %d:", mode );

	if ( !ri.Vid_GetModeInfo( pwidth, pheight, mode ) )
	{
		ri.Con_Printf( PRINT_ALL, " invalid mode\n" );
		return rserr_invalid_mode;
	}

	ri.Con_Printf( PRINT_ALL, " %d %d\n", *pwidth, *pheight);

	if ( !SWimp_InitGraphics( false ) ) {
		// failed to set a valid mode in windowed mode
		return rserr_invalid_mode;
	}

	R_GammaCorrectAndSetPalette( ( const unsigned char * ) d_8to24table );

	return retval;
}

/*
** SWimp_SetPalette
**
** System specific palette setting routine.  A NULL palette means
** to use the existing palette.  The palette is expected to be in
** a padded 4-byte xRGB format.
*/
void SWimp_SetPalette( const unsigned char *palette )
{
	int i;
	XColor colors[256];

	if (!X11_active)
		return;

    if ( !palette )
        palette = ( const unsigned char * ) sw_state.currentpalette;
 
	for(i=0;i<256;i++) {
		st2d_8to16table[i]= xlib_rgb16(palette[i*4], palette[i*4+1],palette[i*4+2]);
		st2d_8to24table[i]= xlib_rgb24(palette[i*4], palette[i*4+1],palette[i*4+2]);
	}

	if (x_visinfo->class == PseudoColor && x_visinfo->depth == 8)
	{
		for (i=0 ; i<256 ; i++)
		{
			colors[i].pixel = i;
			colors[i].flags = DoRed|DoGreen|DoBlue;
			colors[i].red = palette[i*4] * 257;
			colors[i].green = palette[i*4+1] * 257;
			colors[i].blue = palette[i*4+2] * 257;
		}
		XStoreColors(dpy, x_cmap, colors, 256);
	}
}

/*
** SWimp_Shutdown
**
** System specific graphics subsystem shutdown routine.  Destroys
** DIBs or DDRAW surfaces as appropriate.
*/
void SWimp_Shutdown( void )
{
	int i;

	if (!X11_active)
		return;

	if (doShm) {
		for (i = 0; i < 2; i++)
			if (x_framebuffer[i]) {
				XShmDetach(dpy, &x_shminfo[i]);
				free(x_framebuffer[i]);
				shmdt(x_shminfo[i].shmaddr);
				x_framebuffer[i] = NULL;
			}
	} else if (x_framebuffer[0]) {
		free(x_framebuffer[0]->data);
		free(x_framebuffer[0]);
		x_framebuffer[0] = NULL;
	}

	XDestroyWindow(	dpy, win );

//	XAutoRepeatOn(dpy);
//	XCloseDisplay(dpy);

	X11_active = false;
}

/*
** SWimp_AppActivate
*/
void SWimp_AppActivate( qboolean active )
{
}

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

/*
================
Sys_MakeCodeWriteable
================
*/
void Sys_MakeCodeWriteable (unsigned long startaddr, unsigned long length)
{

	int r;
	unsigned long addr;
	int psize = getpagesize();

	addr = (startaddr & ~(psize-1)) - psize;

//	fprintf(stderr, "writable code %lx(%lx)-%lx, length=%lx\n", startaddr,
//			addr, startaddr+length, length);

	r = mprotect((char*)addr, length + startaddr - addr + psize, 7);

	if (r < 0)
    		Sys_Error("Protection change failed\n");

}

/*****************************************************************************/
/* KEYBOARD                                                                  */
/*****************************************************************************/

Key_Event_fp_t Key_Event_fp;

void KBD_Init(Key_Event_fp_t fp)
{
	Key_Event_fp = fp;
}

void KBD_Update(void)
{
// get events from x server
	HandleEvents();
}

void KBD_Close(void)
{
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国精产品一区一区三区mba视频| 欧美午夜精品久久久久久超碰| 欧美精品电影在线播放| 一二三区精品福利视频| 91丨国产丨九色丨pron| 亚洲三级小视频| 欧美亚洲一区三区| 日本视频一区二区三区| 欧美电视剧在线观看完整版| 国产一区二区三区av电影 | 色综合中文综合网| 久热成人在线视频| 26uuu久久综合| 99久久国产免费看| 亚洲国产你懂的| 日韩午夜在线播放| a美女胸又www黄视频久久| 亚洲伦理在线免费看| 日韩一区二区视频在线观看| 国产一区二区中文字幕| 中文字幕不卡三区| 在线不卡中文字幕| 国产成人精品亚洲日本在线桃色| 亚洲欧美日韩国产一区二区三区 | 欧美日韩国产电影| 国产一区免费电影| 一区二区三区久久久| 欧美精品色一区二区三区| 国产乱子伦视频一区二区三区 | 欧美欧美欧美欧美| 国产二区国产一区在线观看| 亚洲午夜在线电影| 久久综合精品国产一区二区三区| 在线精品亚洲一区二区不卡| 蜜臀av性久久久久蜜臀av麻豆| 亚洲国产成人在线| 91精品国产免费| 在线观看日韩一区| 极品少妇一区二区三区精品视频| 国产精品久久久久影视| 91精品蜜臀在线一区尤物| av不卡在线观看| 精品一区二区综合| 亚洲一区中文日韩| 国产精品国产三级国产普通话三级| 欧美日韩一区二区三区高清 | 日韩美女啊v在线免费观看| 91精品国产色综合久久久蜜香臀| 成人激情av网| 韩国三级电影一区二区| 亚洲不卡一区二区三区| 专区另类欧美日韩| 久久久综合视频| 日韩欧美一级精品久久| 日本黄色一区二区| 国产成人免费网站| 看电视剧不卡顿的网站| 三级精品在线观看| 亚洲精品五月天| 中文字幕中文字幕一区| 国产午夜亚洲精品羞羞网站| 欧美一级日韩不卡播放免费| 欧美日韩情趣电影| 在线观看视频91| 在线视频综合导航| 色综合一区二区三区| 成人动漫一区二区在线| 高清日韩电视剧大全免费| 国产一区二区三区视频在线播放| 免费人成黄页网站在线一区二区| 亚洲成av人片在线观看无码| 亚洲午夜免费视频| 一区二区免费在线播放| 亚洲精品视频在线观看网站| 中文字幕一区二区三区精华液| 国产日韩欧美精品电影三级在线| 欧美mv日韩mv国产网站| 日韩一区二区三区在线视频| 日韩午夜电影av| 精品美女在线播放| 国产亚洲一区字幕| 久久久亚洲精品石原莉奈| 2023国产精品| 国产精品免费丝袜| 亚洲欧美国产三级| 亚洲最大色网站| 亚洲r级在线视频| 肉肉av福利一精品导航| 理论电影国产精品| 国内精品伊人久久久久av一坑| 狠狠色2019综合网| 国产成人av影院| av资源网一区| 在线播放亚洲一区| 欧美一二三四区在线| 欧美精品一区二区精品网| 欧美激情一二三区| 亚洲黄色免费电影| 美女视频黄 久久| 国产精品综合一区二区| 92精品国产成人观看免费| 欧美精品一区男女天堂| 久久综合五月天婷婷伊人| 国产欧美日产一区| 一个色综合av| 久久电影国产免费久久电影| 粉嫩aⅴ一区二区三区四区五区| 色综合婷婷久久| 3d成人动漫网站| 久久九九99视频| 一区二区视频免费在线观看| 青青草97国产精品免费观看| 韩国精品主播一区二区在线观看 | 欧美日韩国产综合一区二区| 日韩精品一区二区三区中文不卡 | 91老师片黄在线观看| 91精品一区二区三区在线观看| 久久久影院官网| 亚洲va国产天堂va久久en| 国产老妇另类xxxxx| 91在线视频网址| 欧美mv日韩mv亚洲| 一区二区三区毛片| 国产一区二区在线影院| 欧美性猛片xxxx免费看久爱 | 中文字幕亚洲成人| 奇米色一区二区三区四区| 成人aa视频在线观看| 欧美日韩电影在线播放| 欧美激情一区二区三区在线| 午夜精品福利一区二区蜜股av| 国产精品自拍在线| 欧美人与性动xxxx| 中文字幕欧美一区| 国产资源精品在线观看| 欧美天堂亚洲电影院在线播放| 2020日本不卡一区二区视频| 亚洲第一福利视频在线| av欧美精品.com| 久久综合精品国产一区二区三区| 亚洲线精品一区二区三区| 大胆欧美人体老妇| 久久综合国产精品| 免费高清视频精品| 欧美区视频在线观看| 一区二区三区精品视频| 国产成人在线电影| 精品va天堂亚洲国产| 爽好多水快深点欧美视频| 97久久精品人人做人人爽| 中文字幕欧美激情| 国产91丝袜在线播放九色| 欧美成人a在线| 日本不卡一区二区三区高清视频| 欧洲精品在线观看| 亚洲美女屁股眼交3| av中文字幕不卡| 国产精品福利一区| 高清在线不卡av| 亚洲国产精品精华液2区45| 国产精品99久久久| 日本一区二区综合亚洲| 韩国女主播一区| 久久精品一级爱片| 狠狠久久亚洲欧美| 久久综合久久99| 成人妖精视频yjsp地址| 国产亚洲女人久久久久毛片| 国产不卡视频在线播放| 国产偷v国产偷v亚洲高清| 国产精品系列在线播放| 中文字幕av资源一区| 99久久精品免费看国产 | 欧美体内she精高潮| 亚洲精品欧美在线| 欧洲一区二区av| 婷婷久久综合九色国产成人 | 日本一区免费视频| 成人av电影在线网| 中文字幕日韩av资源站| 91高清视频在线| 亚洲成在线观看| 欧美一区二区美女| 韩国av一区二区三区| 国产欧美一区二区精品秋霞影院| 风间由美中文字幕在线看视频国产欧美| 久久婷婷成人综合色| 成人性生交大合| 亚洲美女电影在线| 欧美日韩一级黄| 激情综合色播激情啊| 国产精品久久久久7777按摩| 91久久精品日日躁夜夜躁欧美| 亚洲高清免费一级二级三级| 欧美一区二区在线不卡| 国产一区二区美女诱惑| 综合激情成人伊人| 日韩欧美激情一区| 成人午夜激情片| 午夜精品久久一牛影视|