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

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

?? g2_x11.c

?? RNA二級結構預測程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*******************************************************************************  Copyright (C) 1998-2001  Ljubomir Milanovic & Horst Wagner**  This file is part of the g2 library****  This library is free software; you can redistribute it and/or**  modify it under the terms of the GNU Lesser General Public**  License as published by the Free Software Foundation; either**  version 2.1 of the License, or (at your option) any later version.****  This library 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**  Lesser General Public License for more details.****  You should have received a copy of the GNU Lesser General Public**  License along with this library; if not, write to the Free Software**  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA******************************************************************************/#include <stdio.h>#include <stdlib.h>#include <stdarg.h>#include <limits.h>#include <math.h>#include <string.h>#include <X11/Xlib.h>#include <X11/Xutil.h>#include "g2.h"#include "g2_device.h"#include "g2_util.h"#include "g2_X11_P.h"#include "g2_X11.h"#include "g2_X11_funix.h"#include "g2_config.h"static int N_X11=0;static g2_X11_device *g2_X11_dev=NULL;/** * \ingroup physdev * \defgroup X11 X11 *//** * * Open a simple X11 window (physical device device). * * \param width window width * \param height window height * \return physical device id * * \ingroup X11 */int g2_open_X11(int width, int height){    return g2_open_X11X(width, height,			10, 10,			NULL, NULL,			NULL, -1, -1);}/** * * Open a X11 window (physical device device). If \a icon_width or \a * icon_height is smaller than 0, the \a icon_data is interpreted as a * file name. * * \param width window width * \param height window height * \param x x position on screen * \param y y position on screen * \param window_name hint for window manager * \param icon_name hint for window manager * \param icon_data icon bitmap (\a icon_width * \a icon_height bits) or file name containing bitmap *                  (if \a icon_width <= 0 or \a icon_height <= 0)  * \param icon_width icon width * \param icon_height icon height * \return physical device id * * \ingroup X11 */int g2_open_X11X(int width, int height,		 int x, int y,		 char *window_name, char *icon_name,		 char *icon_data, int icon_width, int icon_height){    g2_X11_device *xout=NULL;    int pid=-1, i;    char name[32];    int vid;        if(g2_X11_dev==NULL) {	g2_X11_dev=g2_malloc(sizeof(g2_X11_device));	N_X11=1;				  /* first X11 device */	xout=&g2_X11_dev[N_X11-1];	pid=0;    } else {	for(i=0;i<N_X11;i++)			  /* find free place */	    if(g2_X11_dev[i].display==NULL) {		xout=&g2_X11_dev[i];		pid=i;		break;	    }	if(i==N_X11) {	    N_X11++;	    g2_X11_dev=g2_realloc(g2_X11_dev,				  sizeof(g2_X11_device)*N_X11);	    xout=&g2_X11_dev[N_X11-1];	    pid=N_X11-1;	}    }        xout->width=width;			  /* set window size */    xout->height=height;        xout->NofInks=0;			  /* reset inks */    xout->inks=NULL;        vid = g2_register_physical_device(pid, NULL,				      g2_IntCoor, g2_X11_funix,				      1.0, -1.0,				      0.0, height-1);        sprintf(name, "g2: %d", vid);	   /* set window and icon names */    if(window_name==NULL)	window_name=name;    if(icon_name==NULL)	icon_name=name;        g2_X11_init_X11X(pid, width, height,		     x, y,      		     window_name, icon_name,		     icon_data, icon_width, icon_height);        					    /* g2 calls */    g2_allocate_basic_colors(vid);    g2_set_background(vid, 0);    g2_pen(vid, 1);        return vid;}     /* * * Extended version of the InitX11 *                       */int g2_X11_init_X11X(int pid, int width, int height,		     int xposition, int yposition,      		     char *window_name, char *icon_name,		     char *icon_data,		     unsigned int icon_width, unsigned int icon_height){    g2_X11_device *xout=&g2_X11_dev[pid];    Window root;    XSetWindowAttributes wattr;    XEvent event;    Pixmap iconPixmap;    XSizeHints sizehints;    int xhot, yhot, rv;    XColor w_scr, w_exa, r_scr, r_exa;    XClassHint class_hint;    if((xout->display=XOpenDisplay(NULL))==NULL) { 	g2_log(Error, "g2: can't open display\n");	exit(-1);    }    xout->root=RootWindow(xout->display, DefaultScreen(xout->display));    root=xout->root;        wattr.event_mask=ExposureMask;    xout->window=XCreateWindow(xout->display, root,			       xposition, yposition,			       width, height,			       0,			       CopyFromParent, InputOutput, CopyFromParent,			       CWEventMask,			       &wattr);    xout->gc=XCreateGC(xout->display, xout->window,		       0lu, NULL);    xout->colormap=DefaultColormap(xout->display,				   DefaultScreen(xout->display));            XAllocNamedColor(xout->display, xout->colormap,		     "red", &r_scr, &r_exa);    XAllocNamedColor(xout->display, xout->colormap,		     "white", &w_scr, &w_exa);        if(icon_data!=NULL) {	if(icon_width<=0 || icon_height<=0) {	  /* read icon from file */	    rv=XReadBitmapFile(xout->display, xout->window,			       icon_data, &icon_width, &icon_height,			       &iconPixmap, &xhot, &yhot);	} else {				  /* icon is bitmap */	    iconPixmap=XCreatePixmapFromBitmapData(xout->display,						   xout->window,						   icon_data,						   icon_width, icon_height,						   1ul, 0ul, 1);	    rv=BitmapSuccess;	}	switch(rv) {	  case BitmapOpenFailed:	    fputs("g2(OpenXX): bitmap file open failed\n",stderr);	    break;	  case BitmapFileInvalid:	    fputs("g2(OpenXX): bitmap file invalid\n",stderr);	    break;	  case BitmapNoMemory:	    fputs("g2(OpenXX): no enough memeory for bitmap\n",stderr);	    break;	}    } else {					  /* no icon data avail. */	unsigned char bitmapData[] = {	    0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,	    0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,	    0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,	    0x00,0x00,0x00,0x00,0x00,0x80,0x03,0x00,0x00,0x00,0xe0,	    0x0d,0x00,0x00,0x00,0x60,0x0c,0x00,0x00,0x00,0x20,0x18,	    0x00,0x00,0x00,0x00,0x10,0x00,0xf8,0xe3,0x07,0x08,0x00,	    0xfe,0xfa,0x07,0x0c,0x00,0xbf,0x6e,0x07,0x06,0x80,0x0f,	    0xf5,0x00,0x01,0x80,0x05,0x34,0x80,0x09,0xc0,0x03,0x78,	    0xe0,0x18,0x80,0x00,0x70,0xe0,0x1e,0xc0,0x01,0x70,0x70,	    0x1b,0xc0,0x01,0x50,0x00,0x00,0xc0,0x01,0x70,0x00,0x00,	    0xc0,0x00,0x70,0x00,0x00,0x40,0x03,0x38,0x00,0x00,0x80,	    0x05,0x50,0x00,0x00,0x80,0x0a,0x6e,0x00,0x00,0x00,0xfe,	    0x37,0x00,0x00,0x00,0x6a,0x59,0x00,0x00,0x00,0xbc,0x57,	    0x00,0x00,0x00,0xe0,0x50,0x00,0x00,0x00,0x00,0x60,0x00,	    0x00,0x00,0x00,0x78,0x00,0x00,0x00,0x00,0x7e,0x00,0x00,	    0x00,0x7c,0x2b,0x00,0x00,0x00,0xa4,0x1d,0x00,0x00,0x00,	    0xb8,0x06,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,	    0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,	    0x00,0x00};	iconPixmap=XCreatePixmapFromBitmapData(xout->display, xout->window,					       (char*)bitmapData,					       40u, 40u,					       w_scr.pixel, r_scr.pixel,					       1ul);    }    sizehints.x = xposition;    sizehints.y = yposition;    sizehints.min_width = width;    sizehints.max_width = width;    sizehints.min_height = height;    sizehints.max_height = height;    sizehints.flags = PPosition | PMinSize | PMaxSize;    XSetStandardProperties(xout->display, xout->window,			   window_name, icon_name, iconPixmap,			   (char **)NULL, 0, &sizehints);        class_hint.res_name =  "g2";    class_hint.res_class = "G2";    XSetClassHint(xout->display, xout->window, &class_hint);     XMapRaised(xout->display, xout->window);        /*    XSetWindowBackground(xout->display, xout->window, w_scr.pixel); */    XClearWindow(xout->display,xout->window);        g2_X11_paper(pid, NULL, 0);    g2_X11_set_font_size(pid, NULL, 12);						  /* wait expose event */						  /* (no back. store) */    while(!XCheckWindowEvent(xout->display,xout->window,			     ExposureMask,&event))	;    wattr.event_mask=NoEventMask;		  /* set NoEventMask */    wattr.backing_store=Always;			  /* set backing store */    XChangeWindowAttributes(xout->display, xout->window,			    CWEventMask|CWBackingStore,			    &wattr);    xout->dest = xout->window;    xout->backing_pixmap = None;    if(XDoesBackingStore(XDefaultScreenOfDisplay(xout->display))!=Always) {	if(g2_EmulateBackingStore) {	    g2_log(Warning, "g2: Warning! Backing store is not available. Allocating pixmap instead.\n");	    xout->backing_pixmap = XCreatePixmap(xout->display, xout->window,						 xout->width, xout->height,						 DefaultDepth(xout->display, DefaultScreen(xout->display)));	    XSetWindowBackgroundPixmap(xout->display, xout->window,				       xout->backing_pixmap);	  	    XSetForeground (xout->display, xout->gc, w_scr.pixel);          	    XFillRectangle(xout->display, xout->backing_pixmap, xout->gc,			   0, 0, xout->width, xout->height);	    xout->dest = xout->backing_pixmap;	} else {		g2_log(Warning, "g2: Warning! Backing store is not available.\n");	}    }    XFlush(xout->display);    return 0;}int g2_X11_delete(int pid, void *pdp){    g2_X11_device *xout=&g2_X11_dev[pid];    XUnmapWindow(xout->display, xout->window);    if (xout->backing_pixmap != None)	XFreePixmap(xout->display,xout->backing_pixmap);    XDestroyWindow(xout->display, xout->window);    XDestroyWindow(xout->display, xout->root);    XFreeGC(xout->display, xout->gc);    XFreeColormap(xout->display, xout->colormap);    XCloseDisplay(xout->display);    if(xout->inks!=NULL)	g2_free(xout->inks);    xout->width=xout->height=0;    xout->display=NULL;    return 0;}int g2_X11_clear(int pid, void *pdp){    g2_X11_device *xout=&g2_X11_dev[pid];        if (xout->backing_pixmap == None) {	XClearWindow(xout->display,xout->window);    } else {	XSetForeground (xout->display, xout->gc,			xout->background);	XFillRectangle(xout->display, xout->dest, xout->gc,		       0, 0, xout->width, xout->height);    }    g2_X11_flush(pid, pdp);    return 0;}int g2_X11_flush(int pid, void *pdp){    g2_X11_device *xout=&g2_X11_dev[pid];    if( xout->backing_pixmap != None ) {	XCopyArea(xout->display, xout->dest, xout->window, xout->gc,		  0, 0, xout->width, xout->height, 0, 0);    }    XFlush(xout->display);    return 0;}int g2_X11_ink(int pid, void *pdp,	       double red, double green, double blue){    g2_X11_device *xout=&g2_X11_dev[pid];    XColor color;    color.flags=DoRed|DoGreen|DoBlue;    color.red   = (int)(red   * USHRT_MAX);    color.green = (int)(green * USHRT_MAX);    color.blue  = (int)(blue  * USHRT_MAX);    if(XAllocColor(xout->display,xout->colormap,&color)) {	xout->NofInks++;	if(xout->inks==NULL)	    xout->inks=	      (unsigned long *)g2_malloc(xout->NofInks*sizeof(unsigned long));	else	    xout->inks=	      (unsigned long *)g2_realloc((void *)xout->inks,					  xout->NofInks*sizeof(unsigned long));	if(xout->inks==NULL) {	    fputs("g2: not enough memory\n",stderr);	    return -1;	}	xout->inks[xout->NofInks-1]=color.pixel;	return xout->NofInks-1;    } else {	fputs("g2: color is not available\n",stderr);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色一情一乱一乱一91av| 国产成人在线免费观看| 国产成人鲁色资源国产91色综 | 污片在线观看一区二区| 成人高清免费在线播放| 日韩欧美一卡二卡| 夜夜嗨av一区二区三区| 丁香激情综合国产| 日韩亚洲欧美在线| 亚洲成人精品影院| 色婷婷亚洲综合| 亚洲国产成人自拍| 国产一区二区在线视频| 555www色欧美视频| 亚洲图片欧美一区| www.av精品| 国产欧美日韩不卡| 国内精品久久久久影院薰衣草 | 欧美午夜电影在线播放| 欧美韩日一区二区三区四区| 精品一区二区日韩| 欧美一区二区美女| 亚洲电影一级片| 欧美专区日韩专区| 亚洲日本护士毛茸茸| 国产黄色精品网站| wwwwxxxxx欧美| 精品一区精品二区高清| 欧美综合一区二区三区| 夜夜亚洲天天久久| 色域天天综合网| 日韩伦理电影网| 99这里都是精品| 国产欧美一区二区精品性色超碰| 蜜桃av一区二区在线观看 | 国产精品香蕉一区二区三区| 日韩精品一区二区三区中文不卡| 亚洲成人三级小说| 欧美日韩一区小说| 亚洲成人www| 在线观看国产一区二区| 一区二区三区成人| 欧美在线视频全部完| 亚洲综合免费观看高清在线观看| 在线免费观看成人短视频| 亚洲同性gay激情无套| 91丝袜美腿高跟国产极品老师| 国产精品激情偷乱一区二区∴| 波多野结衣一区二区三区| 中文字幕av不卡| 91首页免费视频| 亚洲自拍偷拍九九九| 欧美性大战xxxxx久久久| 亚洲成人福利片| 91精品国产黑色紧身裤美女| 捆绑调教一区二区三区| 精品久久久久av影院| 韩日欧美一区二区三区| 国产香蕉久久精品综合网| 粉嫩一区二区三区性色av| 国产精品久久久久久福利一牛影视| 97se亚洲国产综合在线| 亚洲免费观看高清完整| 欧美午夜精品久久久| 五月婷婷综合在线| 日韩精品影音先锋| 国产成人综合精品三级| 中文字幕色av一区二区三区| 欧美无砖砖区免费| 久久精品99久久久| 国产精品美日韩| 日本精品裸体写真集在线观看| 亚洲第一av色| 久久这里都是精品| 91色porny蝌蚪| 天天亚洲美女在线视频| 2021中文字幕一区亚洲| 成人av在线资源网| 亚洲伊人色欲综合网| 欧美一区二区视频在线观看| 国产精华液一区二区三区| 中文字幕综合网| 欧美一卡2卡3卡4卡| 粉嫩aⅴ一区二区三区四区| 亚洲精品写真福利| 精品国精品国产| 91猫先生在线| 日韩电影在线看| 欧美国产精品中文字幕| 欧美私人免费视频| 国产又黄又大久久| 一区二区三区在线影院| 欧美成人bangbros| 色噜噜狠狠成人中文综合| 人人超碰91尤物精品国产| 国产女主播视频一区二区| 欧美撒尿777hd撒尿| 国产剧情一区二区| 亚洲综合色区另类av| 国内一区二区在线| 宅男噜噜噜66一区二区66| 精品中文字幕一区二区| 亚洲视频一区二区在线| 欧美tk—视频vk| 91久久一区二区| 国产精品一区二区三区乱码| 亚洲综合视频网| 中文在线资源观看网站视频免费不卡 | 91精品国产综合久久精品app | 免费视频最近日韩| 亚洲欧洲www| 久久久久综合网| 欧美三级在线视频| 视频一区欧美精品| 久久久三级国产网站| 欧美日韩一区二区三区不卡| 成人一道本在线| 麻豆一区二区三| 一区二区日韩av| 欧美国产日韩亚洲一区| 日韩视频一区在线观看| 成人av网址在线观看| 国内精品自线一区二区三区视频| 夜夜操天天操亚洲| 国产精品成人在线观看| 日韩手机在线导航| 欧美电影一区二区| 99精品欧美一区二区蜜桃免费 | 亚洲六月丁香色婷婷综合久久 | 制服视频三区第一页精品| 99精品视频中文字幕| 国产老妇另类xxxxx| 五月天亚洲精品| 亚洲综合色网站| 亚洲欧美国产77777| 国产精品久久久久aaaa樱花| 久久日韩粉嫩一区二区三区| 日韩欧美一二区| 91麻豆精品久久久久蜜臀| 欧美午夜一区二区三区免费大片| 白白色 亚洲乱淫| 不卡av在线免费观看| 国产成人精品影院| 国产成人在线免费观看| 精品中文字幕一区二区| 久久99精品久久久久婷婷| 日韩二区在线观看| 午夜精品成人在线视频| 亚洲成av人片一区二区三区| 亚洲乱码国产乱码精品精98午夜| 亚洲三级电影全部在线观看高清| 亚洲国产精品成人久久综合一区| 久久久综合网站| 久久久国产精华| 亚洲精品一区二区三区四区高清| 欧美一级日韩不卡播放免费| 欧美日本韩国一区| 欧美日韩情趣电影| 555www色欧美视频| 日韩午夜在线观看| 日韩美女视频一区二区在线观看| 日韩一区二区三区av| 91精品国产综合久久精品app| 91精品国产手机| 精品国内片67194| 精品成a人在线观看| 精品国产免费一区二区三区香蕉| www国产亚洲精品久久麻豆| 精品裸体舞一区二区三区| 亚洲精品一区二区三区香蕉| 欧美激情在线看| 国产精品国产三级国产专播品爱网| 国产精品久久毛片av大全日韩| 亚洲日本va午夜在线电影| 亚洲精品中文字幕在线观看| 亚洲第一主播视频| 美女尤物国产一区| 久久精品国产亚洲a| 国产成人午夜片在线观看高清观看| 粉嫩嫩av羞羞动漫久久久| 色综合久久88色综合天天免费| 91福利在线看| 欧美一区二区三区日韩| 亚洲精品一区二区三区99| 中文字幕乱码久久午夜不卡| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 欧美一区二区三区男人的天堂| 欧美成人bangbros| 国产精品日产欧美久久久久| 亚洲女女做受ⅹxx高潮| 五月天精品一区二区三区| 国产在线视视频有精品| 成人小视频在线观看| 欧美性一二三区| 精品欧美黑人一区二区三区| 久久久久久麻豆| 日韩美女啊v在线免费观看| 午夜一区二区三区视频| 裸体健美xxxx欧美裸体表演| 国产成人精品综合在线观看|