亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
久久国产夜色精品鲁鲁99| 国产精品免费视频观看| 大白屁股一区二区视频| 亚洲欧美日韩国产综合| 日韩欧美一区二区三区在线| 日本韩国欧美三级| 国产91精品入口| 美女视频一区二区三区| 亚洲精品视频在线| 国产日韩欧美a| 日韩精品一区二区三区三区免费| 91传媒视频在线播放| 成人精品视频一区二区三区尤物| 日本人妖一区二区| 亚洲国产日韩精品| 亚洲精品美国一| 国产精品丝袜在线| 国产调教视频一区| 精品国产3级a| 欧美大片在线观看一区二区| 欧美日韩三级一区二区| 日本黄色一区二区| 99r国产精品| 成人小视频在线观看| 国内精品嫩模私拍在线| 青青草国产成人99久久| 午夜亚洲国产au精品一区二区| 国产精品电影一区二区三区| 国产片一区二区| 久久综合久久综合亚洲| 精品噜噜噜噜久久久久久久久试看| 欧美日本免费一区二区三区| 欧美性受xxxx黑人xyx性爽| 成人一区二区三区中文字幕| 国产一区二区福利视频| 精品一区二区久久久| 蜜桃av一区二区三区| 秋霞电影网一区二区| 日本伊人精品一区二区三区观看方式| 亚洲国产视频在线| 亚洲国产欧美在线人成| 性久久久久久久久| 免费看日韩精品| 久久草av在线| 国内成人免费视频| 国产传媒日韩欧美成人| 成人v精品蜜桃久久一区| 成人激情小说网站| aaa亚洲精品一二三区| 色久综合一二码| 欧美在线播放高清精品| 欧美精品自拍偷拍| 日韩美女主播在线视频一区二区三区| 91精品国产综合久久久久久久 | 高清在线不卡av| 波多野结衣中文字幕一区二区三区| 国产91在线看| 91在线无精精品入口| 91久久精品一区二区| 欧美私模裸体表演在线观看| 91精品国产91综合久久蜜臀| 欧美大胆人体bbbb| 国产色综合一区| 自拍偷拍欧美激情| 亚洲国产aⅴ成人精品无吗| 日韩主播视频在线| 国产精品66部| 色综合久久中文综合久久牛| 欧美老肥妇做.爰bbww| 日韩精品资源二区在线| 久久久精品国产免大香伊| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 国产精品久久久久久久久免费相片 | 亚洲国产精品久久久男人的天堂| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产一区二区三区av电影| av爱爱亚洲一区| 91精品国产入口在线| 久久综合色一综合色88| 亚洲色图在线播放| 久久精品噜噜噜成人88aⅴ| 成人v精品蜜桃久久一区| 欧美电影在线免费观看| 欧美激情在线一区二区三区| 玉米视频成人免费看| 狠狠色狠狠色合久久伊人| 91丨porny丨国产| 欧美大黄免费观看| 一区二区三区视频在线观看| 国产做a爰片久久毛片| 色香色香欲天天天影视综合网| 欧美一级精品在线| 亚洲欧美日韩国产中文在线| 六月丁香婷婷色狠狠久久| 色婷婷av一区二区三区软件| 久久亚洲私人国产精品va媚药| 一区二区三区四区高清精品免费观看 | 依依成人精品视频| 九色综合狠狠综合久久| 一本大道久久a久久精品综合| 精品盗摄一区二区三区| 香蕉成人伊视频在线观看| 成人黄色在线看| 精品久久久影院| 亚洲国产另类av| 99在线精品免费| 久久久午夜精品理论片中文字幕| 午夜影院久久久| 色域天天综合网| 久久久久久久免费视频了| 日本最新不卡在线| 欧洲精品一区二区| 亚洲欧洲精品一区二区精品久久久 | 欧美r级电影在线观看| 亚洲福利视频三区| 91久久精品国产91性色tv| 久久精品夜夜夜夜久久| 看电视剧不卡顿的网站| 欧美日韩国产成人在线91| 亚洲综合一二区| 日本黄色一区二区| 亚洲精品午夜久久久| 成人综合婷婷国产精品久久蜜臀| 亚洲精品在线观| 久久电影国产免费久久电影| 91精品国产一区二区三区 | 亚洲美女少妇撒尿| www.av精品| 国产精品久久久久久久久久久免费看| 韩国av一区二区| 久久精品日韩一区二区三区| 国产一区亚洲一区| 久久久精品国产免大香伊| 国产精品18久久久久久久久久久久| 日韩美女视频一区二区在线观看| 日韩av电影免费观看高清完整版在线观看| 欧美视频精品在线观看| 亚洲一区精品在线| 欧美日韩国产精选| 日产精品久久久久久久性色| 日韩一区二区在线观看| 久久综合综合久久综合| 精品国产凹凸成av人网站| 国产精品主播直播| 欧美国产精品专区| 成人午夜视频福利| 成人免费在线视频| 在线免费观看日韩欧美| 亚洲午夜私人影院| 欧美精品 日韩| 日本vs亚洲vs韩国一区三区| 欧美变态凌虐bdsm| 成人高清在线视频| 亚洲在线视频网站| 91精品国产综合久久精品图片 | 亚洲视频一二区| 在线观看国产91| 亚洲午夜久久久久久久久久久| 在线观看91精品国产麻豆| 美女一区二区三区| 国产精品亲子乱子伦xxxx裸| 色综合久久中文综合久久牛| 日韩欧美国产三级电影视频| 麻豆成人久久精品二区三区小说| av不卡一区二区三区| 国产精品欧美久久久久一区二区| 一区二区免费视频| 日韩午夜三级在线| 韩国v欧美v亚洲v日本v| 日本一区二区三级电影在线观看 | 久久精品无码一区二区三区| 福利视频网站一区二区三区| 国产精品国产三级国产a| 日本福利一区二区| 精品亚洲成a人在线观看| 国产女人18水真多18精品一级做| 99久久99久久综合| 美女一区二区视频| 日本一区二区成人在线| 91丨porny丨户外露出| 五月婷婷综合激情| 国产精品视频在线看| 欧美丝袜第三区| 国产一本一道久久香蕉| 国产三级三级三级精品8ⅰ区| 在线精品视频一区二区| 乱一区二区av| ...中文天堂在线一区| 欧美视频完全免费看| 极品销魂美女一区二区三区| 国产精品女同一区二区三区| 欧美日韩视频在线第一区| jizzjizzjizz欧美| 蜜桃视频免费观看一区| 自拍偷自拍亚洲精品播放| 欧美一区二区三区性视频| caoporen国产精品视频| 免费国产亚洲视频| 中文字幕av一区 二区| 欧美一区二区三区在线|