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

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

?? graphic.c

?? GUI例程
?? C
?? 第 1 頁 / 共 2 頁
字號:
    /* todo: clip */  register char dx;  unsigned short x,y;  unsigned char src_off, dest_off;  short dest_n;  unsigned char dest_beg_mask, dest_end_mask;  const Pattern *pattern = patterns[P_Index];    /* goto line y */  dest += dest_y * dest_units_per_line;    /* goto UNIT-offset x */  dest += dest_x / 8;  /* determine number of affected units per line */    dest_n = (dest_x + w + 8 - 1) / 8 - dest_x / 8;  /* determine PIXEL-offsets */  dest_off = dest_x % 8;    /* make masks to mask out untouchable destination */  dest_beg_mask = ~((unsigned char)(-1) >> dest_off);  dest_end_mask = (unsigned char)(-1) >> ((dest_off + w) % 8);  if (dest_end_mask == (unsigned char)(-1)) {    /* bit stupid */    dest_end_mask = 0;  }    for (y = 0; y < h; y++) {    // process one line    register unsigned char *dp;    register unsigned char mask = 0;    unsigned char s=pattern->data[(dest_y+y)%pattern->height], d;    dp = dest;    for (x = 0; x < dest_n; x++, dp++) {      // combine with destination      switch (Mode) {      case MODE_SRC:      default:	d = s;	break;      case MODE_NOT_SRC:	d = ~s;	break;      case MODE_SRC_OR_DST:	d = *dp | s;	break;      case MODE_SRC_AND_DST:	d = *dp & s;	break;      case MODE_SRC_XOR_DST:	d = *dp ^ s;	break;      case MODE_NOT_SRC_OR_DST:	d = *dp | ~s;	break;      case MODE_NOT_SRC_AND_DST:	d = *dp & ~s;	break;      case MODE_NOT_SRC_XOR_DST:	d = *dp ^ ~s;	break;      case MODE_SRC_OR_NOT_DST:	d = ~*dp | s;	break;      case MODE_SRC_AND_NOT_DST:	d = ~*dp & s;	break;      case MODE_SRC_XOR_NOT_DST:	d = ~*dp ^ ~s;	break;      }      mask = 0;      if (x == 0) {	mask |= dest_beg_mask;      }      if (x == dest_n-1) {	mask |= dest_end_mask;      }      *dp = (*dp & mask) | (d & ~mask);    }    dest += dest_units_per_line;  }}short initgraph(void){  struct fb_var_screeninfo screeninfo;    screen_fd = open("/dev/fb0", O_RDWR);  if (screen_fd == -1)   	{      perror("Unable to open frame buffer device /dev/fb0");      return 0;	 }  if (ioctl(screen_fd, FBIOGET_VSCREENINFO, &screeninfo)==-1) {      perror("Unable to retrieve framebuffer information");      return 0;          }  //screen_width = screeninfo.xres_virtual;  screen_width = 240;//screeninfo.xres_virtual;  //screen_height = screeninfo.yres_virtual;  screen_height = 320;//screeninfo.yres_virtual;  //lyk modified it  //E_Font	= (unsigned char*)(screeninfo.english_font);  //printf("E_Font Address %x %x\n",E_Font,screeninfo.english_font);  //if(!E_Font) 	  //E_Font=(unsigned char*)(0x8804);	  //E_Font=(unsigned char*)(0x8812);   E_Font=fontdata_8x16;//(unsigned char*)(0x0004a690);  screen_ptr = mmap(NULL, ((screen_height * screen_width*2)/4096+1)*4096, PROT_READ|PROT_WRITE, /*0*/MAP_SHARED, screen_fd, 0);   if (screen_ptr==MAP_FAILED) {              perror("Unable to mmap frame buffer");	      close(screen_fd);	      return 0;       }    C_Font=fopen(CHINESE_FONT_FILE,"rb");    if(!C_Font)  	{	 perror("Unable to open Chinese font file");	 close(screen_fd);	 return 0;	}  Color=1;	    return 1;}void closegraph(){  if(screen_fd!=-1) {	close(screen_fd);  }  if(C_Font)	  fclose(C_Font);}void clearscreen(){	memset(screen_ptr,0,screen_width*screen_height*2);}void draw_xbm(short sx, short sy, short width, short height, char* pixel){	short i, j, k, t,l=(width>>=3)*height,m,wid=screen_width>>3;	short d,off;	char *loc=screen_ptr+(off=((sy*screen_width+sx)>>3));          for(k=0,i=0;i<height;i++,k+=wid)          for(j=0;(j<width)&&(j<20);j++) 	{	      d=0;	      for(m=0;m<8;m++)	        if(pixel[k+j]&masktab[m]) d|=masktab[7-m];	      t=k+j;              if((t+off)>=3200) return;	      loc[t]=d;			       	    	}}void draw_bmp(short sx, short sy, short rwidth, short height, char* pixel){	short i, j, k, t,l=rwidth*height,m;	int off,d;	char *loc=screen_ptr+(off=((sy*screen_width+sx)>>3));	//printf("drawing bmp.\n");         for(t=0,k=0,i=0;i<height;i++,k+=screen_width>>3,t+=rwidth)          for(j=0;(j<rwidth)&&(j<20);j++) 	{	      m=k+j;              if(m+off>=3200) 	//	if(m+off>=4000)      	      		return;	      loc[m]=pixel[t+j];			       	    	}	 //printf("draw_bmp finished.\n");}void ShowBMP(char *filename,short x,short y){  BMPHEAD bm;  int tmpi;    FILE *fp=fopen(filename,"rb");  char *buf,c;  int i,j,t,width;  long size;  //printf("showing BMP KEYBORAD.\n");  if(!fp) return;  //printf("freading...\n");  fread(&bm,1,sizeof(BMPHEAD),fp);  //printf("fread finished.\n");	  /*buf = (char*)&bm;  for(tmpi=0;tmpi<sizeof(BMPHEAD);tmpi++)	  printf("%02x ",buf[tmpi]);  printf("\n");  for(tmpi=0;tmpi<sizeof(BMPHEAD);tmpi+=2)	  printf("%04x  ",*((short *)(buf+tmpi)) );  printf("\n");  for(tmpi=0;tmpi<sizeof(BMPHEAD);tmpi+=4)	  printf("%08x      ",*((long *)(buf+tmpi)) );  printf("\n");*/  buf=(char*)&bm.bits;  c=buf[0];  buf[0]=buf[1];  buf[1]=c;  if(bm.bits!=0x100)        {         fclose(fp);         printf("\ngraphic: Unsupported color bitmap\n");         return;        }  //printf("exchange width\n");  //printf("graphic:width=%08x\n",bm.width);  bm.width = 160;  /*buf=(char*)&bm.width;  c=buf[0];  buf[0]=buf[3];  buf[3]=c;  c=buf[1];  buf[1]=buf[2];  buf[2]=c;  printf("graphic:width=%08x\n",bm.width);  */  //printf("exchange height\n");  bm.height = 60;  /*  buf=(char*)&bm.height;  c=buf[0];  buf[0]=buf[3];  buf[3]=c;  c=buf[1];  buf[1]=buf[2];  buf[2]=c;  */  width=(bm.width+7)>>3;  if(width&3)   width+=(4-(width&3));  //printf("bmphead=%d",sizeof(BMPHEAD));  //printf("width=%d,bm.height=%ld,size=%ld\n",width,bm.height,width*bm.height);  buf=(char*)malloc(size=(width*bm.height));  //printf("malloc ok\n");    //fread(&i,1,8,fp);  //fread(buf,1,100,fp);  //lyk  //fread(buf,1,8,fp);  //fread(buf,1,1,fp);  //lseek(fp,8,1);  fread(buf,1,size,fp);  fclose(fp);  //printf("entering loop...\n");  for(i=0;i<(bm.height>>1); i++)    for(t=i*width,j=0;j<width;j++)        {         c=buf[t+j]^0xff;          buf[t+j]=buf[size-width-t+j]^0xff;         buf[size-width-t+j]=c;       }  //printf("loop finished.\n");  draw_bmp(x,y,width,bm.height,buf);  free(buf);}void V_scroll_screen(short height) //Up/Down Scroll{   short dir=(height<0);	   if(dir) height=-height;	      if(height<screen_height) 	{    short nBytes=(screen_width>>3)*height,    	  nCount=(screen_width>>3)*(screen_height-height);	    if(dir)  //Down Scroll	    {	    memmove(screen_ptr+nBytes,screen_ptr,nCount);	    memset(screen_ptr,0,nBytes);	    }	    else     //Up Scroll	    {	    memmove(screen_ptr,screen_ptr+nBytes,nCount);	    memset(screen_ptr+nCount,0,nBytes);    	    }	}   else     clearscreen();	   }void H_scroll_screen(short width) //Left Scroll{ short dir=(width<0);  if(dir) width=-width;  if(width<screen_width) {   if(width&7)   //Check whether it is byte aligned  {  short nCount=screen_width*screen_height>>3;  static unsigned char mskr[]={0,1,3,7,0xf,0x1f,0x3f,0x7f},	  	       mskl[]={0,0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe},		       buf[3200];  unsigned char /*buf,*/c,flag=0,d;  short start=(width>>3),length=(width&7),i,j,wid=(screen_width>>3),off;    memcpy(buf,screen_ptr,nCount);  if(dir)  {  for(off=0,j=0;j<screen_height;j++,off+=wid)  {   for(flag=0,i=wid-1;i>=start;i--)   {	d=c=*(buf+off+i);	c<<=length;	if(flag) c|=(flag>>(8-length));	flag=d&mskl[length];	*(buf+off+i)=c;   }  if(start)    for(i=wid-start;i<wid;i++)    {	*(buf+off+i)=0;    }  }  }  else  for(off=0,j=0;j<screen_height;j++,off+=wid)  {   for(flag=0,i=start;i<wid;i++)   {	d=c=*(buf+off+i);	c>>=length;	if(flag) c|=(flag<<(8-length));	flag=d&mskr[length];	*(buf+off+i)=c;   }  if(start)    for(i=0;i<start;i++)    {	*(buf+off+i)=0;    }  }  memcpy(screen_ptr,buf,nCount);   } else  {    short i,j=0,wid=screen_width>>3;        width>>=3;    for(i=0;i<screen_height;i++,j+=wid)    {	    memmove(screen_ptr+j+width,screen_ptr+j,wid-width);	    memset(screen_ptr+j,0,width);    }  } } else   clearscreen();}void textout(short x,short y,unsigned char *buf){  int i,j,count=strlen(buf);  short k,l,m=screen_width>>3;  char pixel[32];  //printf("screen_height=%d\n",screen_height);#ifdef FONT  if(!font) {		puts("Please Init Chinese Enviroment First!");                return;           }#endif      for(i=0;i<count;)  {	 // printf("gui:i=%d,count=%d\n",i,count);   if(y>=screen_height)         {	memmove(screen_ptr,screen_ptr+320,2880);        memset(screen_ptr+2880,0,320);	y-=16;       }      if((buf[i]>=161)&&(buf[i+1]>=161))   {	//int nHeadCount;	//char cTmp;       j=((buf[i]-161)*94+(buf[i+1]-161))<<5;       fseek(C_Font,j,SEEK_SET);       fread(pixel,32,1,C_Font);       //Yongkui Lu changed it to fit the small head problem from Big head problem.       /*for(nHeadCount=0;nHeadCount<32;nHeadCount+=2)       {	       cTmp=pixel[nHeadCount];	       pixel[nHeadCount]=pixel[nHeadCount+1];	       pixel[nHeadCount+1]=cTmp;       }*/       draw_bmp(x,y,2,16,pixel);       x+=16;  	              if(x>=screen_width) {                              y+=16;                             x=0;                           }       i+=2;      }    else     {      //Yongkui Lu add it to fit the small head problem!      //int iTmp=i;//backup i      //printf("gui:i=%d,count=%d,buf[%d]=%c\n",i,count,i,buf[i]);      /*if(i%2==0){	      i++;      }else{	      i--;      }*/      if(buf[i]=='\n') {	      		k=(y*screen_width+x)>>3;			l=(screen_width-x)>>3;	      		for(j=0;j<16;j++,k+=m)			  memset(screen_ptr+k,0,l);	      		x=0;y+=16;	           			}      else      {	      draw_bmp(x,y,1,16,E_Font+(buf[i]<<4));		      x+=8;      }      //i=iTmp; //load from backup      i++;      /*iTmp=i;//backup i      if(i%2==0){	      i++;      }else{	      i--;      }      if(buf[i]=='\n') {	      		k=(y*screen_width+x)>>3;			l=(screen_width-x)>>3;	      		for(j=0;j<16;j++,k+=m)			  memset(screen_ptr+k,0,l);	      		x=0;y+=16;	           			}      else      {	      draw_bmp(x,y,1,16,E_Font+(buf[i]<<4));		      x+=8;      }      i=iTmp; //load from backup      i++;*/     }  }}void setmode(CopyMode mode){  Mode=mode;}CopyMode getmode(void)	{  return Mode;	}void setcolor(short color){  Color=color;}UINT getcolor(void){	return Color;}void setfillpattern(PatternIndex index){  P_Index=index;	}PatternIndex getfillpattern(void){  return P_Index;	}void moveto(short x,short y){	X=x;Y=y;}void lineto(short x,short y){	line(x,y,X,Y);	X=x;Y=y;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品成人在线观看| 在线观看网站黄不卡| 亚洲人精品一区| 欧美α欧美αv大片| 欧美综合一区二区三区| 激情丁香综合五月| 亚洲高清在线精品| 综合久久久久久久| 国产天堂亚洲国产碰碰| 欧美丰满少妇xxxxx高潮对白| 成人爽a毛片一区二区免费| 美日韩黄色大片| 亚洲高清视频在线| 中文字幕在线观看不卡视频| 精品国产一区二区三区久久影院 | 日韩vs国产vs欧美| 日韩午夜在线播放| 在线看日韩精品电影| 国产成人av一区二区| 日韩精品一卡二卡三卡四卡无卡| 亚洲精品水蜜桃| 国产精品欧美经典| 国产亚洲成av人在线观看导航| 91精品国产欧美一区二区| 欧美性猛片xxxx免费看久爱| 91丨porny丨在线| 成人黄色片在线观看| 国产成人av自拍| 国产美女娇喘av呻吟久久| 日韩电影一二三区| 天天影视涩香欲综合网| 亚洲国产精品天堂| 亚洲一级片在线观看| 亚洲国产精品久久人人爱蜜臀| 亚洲精品高清视频在线观看| 最新欧美精品一区二区三区| 日本一区二区三区国色天香| 色综合天天综合网天天狠天天| 日本怡春院一区二区| 亚洲尤物视频在线| 亚洲成人资源网| 亚洲不卡一区二区三区| 亚洲一区二区美女| 亚洲成av人片在线观看| 亚洲 欧美综合在线网络| 亚洲成a人片在线观看中文| 亚洲午夜国产一区99re久久| 亚洲成人综合在线| 青娱乐精品视频在线| 午夜激情一区二区三区| 日日嗨av一区二区三区四区| 日本免费在线视频不卡一不卡二 | 99久久夜色精品国产网站| 国产99一区视频免费 | 在线国产电影不卡| 欧美日韩成人一区| 日韩精品一区在线| 欧美激情自拍偷拍| 亚洲黄色在线视频| 日本午夜精品视频在线观看| 久久99久国产精品黄毛片色诱| 精品久久一二三区| 亚洲第一av色| 日韩高清一级片| 奇米一区二区三区| 国产成人在线网站| 91在线精品一区二区| 欧美亚洲国产一区二区三区va | 亚洲精品在线一区二区| 中文av一区二区| 一区二区三区在线观看欧美| 日韩国产精品91| 丰满亚洲少妇av| 欧美无砖砖区免费| 亚洲精品在线网站| 亚洲男帅同性gay1069| 免费观看在线综合| 国产成人午夜精品5599| 一本一道波多野结衣一区二区| 欧美久久一区二区| 国产午夜精品久久久久久久 | 日韩电影在线一区| 丰满白嫩尤物一区二区| 欧美精品视频www在线观看 | 久久成人18免费观看| 欧美老年两性高潮| 欧美成人免费网站| 国产精品久久看| 久久爱另类一区二区小说| 99久久精品情趣| 精品国产乱码久久久久久影片| 亚洲精品久久久蜜桃| 国产精品1024| 91精品午夜视频| 一区二区三区四区不卡视频| 国产在线日韩欧美| 欧美午夜一区二区三区免费大片| 国产婷婷一区二区| 伦理电影国产精品| 欧美性猛片xxxx免费看久爱| 天天综合网天天综合色| 国产69精品一区二区亚洲孕妇| 欧美电影在哪看比较好| 亚洲免费观看高清完整版在线观看 | eeuss鲁片一区二区三区| 5566中文字幕一区二区电影| 精品动漫一区二区三区在线观看| 亚洲最新视频在线播放| 国产高清亚洲一区| 欧美一区二区免费观在线| 亚洲免费色视频| 成人精品一区二区三区四区 | 国产毛片精品国产一区二区三区| 色一情一伦一子一伦一区| 日本一区二区三区在线不卡 | 本田岬高潮一区二区三区| 欧美成人在线直播| 日韩av一区二| 欧美日韩一区二区三区高清 | 一区二区三区不卡视频| 成人免费av网站| 国产网站一区二区三区| 激情丁香综合五月| 精品美女被调教视频大全网站| 午夜在线电影亚洲一区| 欧美亚洲国产bt| 亚洲免费观看高清完整版在线观看熊 | 久久66热re国产| 欧美精品日韩综合在线| 亚洲成a人在线观看| 欧美在线短视频| 亚洲6080在线| 欧美丰满少妇xxxxx高潮对白| 亚洲成人一二三| 欧美系列日韩一区| 午夜精品在线看| 欧美一级久久久久久久大片| 美国欧美日韩国产在线播放| 日韩欧美黄色影院| 精品一区二区在线视频| 久久综合久久综合久久综合| 国产精品一区二区黑丝| 国产亚洲午夜高清国产拍精品 | 精品国产3级a| 国产电影精品久久禁18| 国产农村妇女精品| a4yy欧美一区二区三区| 亚洲男女一区二区三区| 色婷婷久久一区二区三区麻豆| 夜夜爽夜夜爽精品视频| 在线播放欧美女士性生活| 蜜臂av日日欢夜夜爽一区| 精品国偷自产国产一区| 风间由美一区二区三区在线观看| 中文字幕在线观看一区| 欧洲一区二区三区免费视频| 午夜精品久久久久久久| 日韩欧美色电影| 岛国一区二区在线观看| 亚洲欧美日韩电影| 欧美精品在线观看一区二区| 久久精品国产网站| 欧美激情综合网| 欧美色图第一页| 乱一区二区av| 国产精品免费网站在线观看| 一本色道久久综合亚洲aⅴ蜜桃| 天天综合网天天综合色| 久久久久久毛片| 欧美优质美女网站| 美女看a上一区| 国产精品国产馆在线真实露脸| 欧美日韩国产乱码电影| 韩国v欧美v日本v亚洲v| 亚洲免费毛片网站| 日韩精品一区二区三区在线观看| 国产成人免费9x9x人网站视频| 亚洲欧美经典视频| 欧美一区二区在线观看| caoporm超碰国产精品| 久久精品日产第一区二区三区高清版 | 久久综合九色综合欧美亚洲| gogo大胆日本视频一区| www.日韩在线| 午夜影院在线观看欧美| 中文字幕第一区二区| 91精品久久久久久久久99蜜臂| 东方aⅴ免费观看久久av| 午夜影视日本亚洲欧洲精品| 国产午夜精品一区二区| 欧美乱熟臀69xxxxxx| 99久久精品情趣| 激情综合色综合久久综合| 亚洲精品国产一区二区精华液| 26uuu另类欧美亚洲曰本| 在线视频国内一区二区| 国产精品系列在线播放| 日本不卡视频一二三区| 一区二区激情小说| 中文乱码免费一区二区|