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

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

?? graphic.c

?? 基于s3c2410gui(圖形用戶界面)應用程序源碼!
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * $Id: graphic.c,v 1.2 1999/11/12 13:03:26 till Exp $ * * Graphics primitive drawing functions * derived from: graphic.c Pixy Graphic Library * derived from: lissa.c: Graphics demos * * Copyright (C) 2001  Chen Yang <support@hhcn.com> * Copyright (C) 1999  Till Krech <till@snafu.de> * Copyright (C) 1998  Kenneth Albanowski <kjahds@kjahds.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * The code in this file is partially based on Kenneth Albanowskis work * for the lissa graphics demo. *//******************Notice*********************************** * The Default Font size for ASCII Font is 8x16 * The Default Font size of Chinese Font is 16x16 ***********************************************************/#include <sys/types.h>#include <sys/stat.h>#include <linux/fb.h>#include <stdio.h>#include <unistd.h>#include <fcntl.h>#include <sys/mman.h>#include "mathf.h"#include "font_8x16.h"#include "gui.h"/*Define the correct Chinese Font File Path*/#define CHINESE_FONT_FILE "hanzi"#define ScreenHeight 320#define ScreenWidth 240typedef struct {    unsigned short height;    unsigned char data[0];} Pattern;const Pattern _BlackPattern ={  1,    {~0}};const Pattern _WhitePattern ={  1,  { 0 }};const Pattern _DarkGreyPattern ={  2,  {    (unsigned char)0x55555555,    (unsigned char)0xCCCCCCCC  }};const Pattern _LightGreyPattern ={  4,  {    (unsigned char)0x88888888,    (unsigned char)0x00000000,    (unsigned char)0x22222222,    (unsigned char)0x00000000,  }};const Pattern _MicroPengPattern ={  16,  {    0x3c,0x7e,0x56,0xaa,0x86,0x4e,0x7b,0xc3,0x83,0x83,0xc3,0xc7,0xbd,0x99,0x99,    0xff  }};static const Pattern *patterns[] = {  /* This must correspond to the enum in pixy.h! */  &_BlackPattern,  &_WhitePattern,  &_DarkGreyPattern,  &_LightGreyPattern,  &_MicroPengPattern,};//unsigned char getbit[8]={0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01}static short masktab[]={0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};static int screen_fd=-1;FILE *C_Font;unsigned char * screen_ptr=(unsigned char*)(0x0400),*E_Font=(unsigned char*)(0x8500);static short screen_width=240,screen_height=320;static short WinSX,WinSY,WinEX,WinEY;static unsigned short X,Y,Color,P_Index,Mode=MODE_SRC;//CopyMode pixy_copy_mode = Mode_SRC;inline void setpixel(short x, short y, short color){    if ((x<0) || (x>=screen_width) || (y<0) || (y>=screen_height))	return;    {	       	unsigned short * loc = screen_ptr + ((y * screen_width*2 + x*2 ));	/*if (color){		*loc =0xff;*(loc+1)=0xff;	}else{		*loc = 0x0;*(loc+1)=0x0;	}*/	*loc=color;    }}/* Abrash's take on the simplest Bresenham line-drawing algorithm.  * * This isn't especially efficient, as we aren't combining the bit-mask * logic and addresses with the line drawing code, never mind higher * level optimizations like run-length slicing, etc. * */static inline void draw_xish_line(short x, short y, short dx, short dy, short xdir,unsigned short color){	short dyX2=dy+dy;	short dyX2mdxX2=dyX2-(dx+dx);	short error=dyX2-dx;		setpixel(x, y, color);	while (dx--) {		if (error >= 0) {			y++;			error += dyX2mdxX2;		} else {			error += dyX2;		}		x += xdir;		setpixel(x,y,color);	//	printf("Color1inline=%d\n",Color);	}}static inline void draw_yish_line(short x, short y, short dx, short dy,short xdir,unsigned short color){	short dxX2=dx + dx;	short dxX2mdyX2=dxX2-(dy+dy);	short error=dxX2-dy;		setpixel(x, y, color);	while (dy--) {		if (error >= 0) {			x+= xdir;			error += dxX2mdyX2;		} else {			error += dxX2;		}		y++;		setpixel(x,y, color);	}}void line(short x1, short y1, short x2, short y2,unsigned short color){	short dx,dy;	if ( y1 > y2) {		short t = y1;		y1 = y2;		y2 = t;		t = x1;		x1 = x2;		x2 = t;	}		dx = x2-x1;	dy = y2-y1;		if (dx > 0) {		if (dx > dy)			draw_xish_line(x1, y1, dx, dy, 1,color);		else			draw_yish_line(x1, y1, dx, dy, 1,color);	} else {		dx = -dx;		if (dx > dy)			draw_xish_line(x1, y1, dx, dy, -1,color);		else			draw_yish_line(x1, y1, dx, dy, -1,color);	}		}/* One of Abrash's ellipse algorithms  */void ellipse(short x, short y, short a, short b){	short wx, wy;	short thresh;	short asq = a * a;	short bsq = b * b;	short xa, ya;		setpixel(x, y+b, Color);	setpixel(x, y-b, Color);		wx = 0;	wy = b;	xa = 0;	ya = asq * 2 * b;	thresh = asq / 4 - asq * b;		for (;;) {		thresh += xa + bsq;				if (thresh >= 0) {			ya -= asq * 2;			thresh -= ya;			wy--;		}				xa += bsq * 2;		wx++;				if (xa >= ya)		  break;						setpixel(x+wx, y-wy, Color);		setpixel(x-wx, y-wy, Color);		setpixel(x+wx, y+wy, Color);		setpixel(x-wx, y+wy, Color);	}		setpixel(x+a, y, Color);	setpixel(x-a, y, Color);		wx = a;	wy = 0;	xa = (bsq * a) << 1;		ya = 0;	thresh = (bsq >> 2) - bsq * a;		for (;;) {		thresh += ya + asq;				if (thresh >= 0) {			xa -= bsq + bsq;			thresh = thresh - xa;			wx--;		}				ya += asq + asq;		wy++;				if (ya > xa)		  break;		 		setpixel(x+wx, y-wy, Color);		setpixel(x-wx, y-wy, Color);		setpixel(x+wx, y+wy, Color);		setpixel(x-wx, y+wy, Color);	}}/* Composites */void rectangle(short x1, short y1, short x2, short y2,unsigned short color){	line(x1, y1, x2, y1,color);	line(x2, y1, x2, y2,color);	line(x2, y2, x1, y2,color);	line(x1, y2, x1, y1,color);}inline void clip_screen(short in_x, short in_y, short in_w, short in_h, short *out_x, short *out_y, short *out_w, short *out_h) {  short swp;  if (in_w < 0) {    in_x += in_w;    in_w = -in_w;  }  if (in_h < 0) {    in_y += in_h;    in_h = -in_h;  }  if (in_x < 0) {    in_w -= in_x;    in_x = 0;  }  if (in_y < 0) {    in_h -= in_y;    in_y = 0;  }  if (in_w > screen_width) {    in_w = screen_width;  }  if (in_h > screen_height) {    in_h = screen_height;  }  if (in_w < 0) {    in_w = 0;  }  if (in_h < 0) {    in_h = 0;  }  *out_x = in_x;  *out_y = in_y;  *out_w = in_w;  *out_h = in_h;}		void patternfill( short dest_x,		 short dest_y, 		 short w,		 short h,		 unsigned char*dest,		 short dest_units_per_line);void  fillrectangle(short x1, short y1, short x2, short y2){	short x, y, w, h,i,j;	//clip_screen(x1, y1, x2-x1, y2-y1, &x, &y, &w, &h); 	//patternfill(x, y, w, h, screen_ptr, screen_width>>3);        for(i=x1;i<x2;i++)	for(j=y1;j<y2;j++)		{setpixel(i, j, Color);  			}}void  fillrect(short x1, short y1, short x2, short y2){        short x, y, w, h;        clip_screen(x1, y1, x2-x1, y2-y1, &x, &y, &w, &h);        patternfill(x, y, w, h, screen_ptr, screen_width>>3);}void bitblt(		 short src_x,		 short src_y,		 short w,		 short h,		 short dest_x,		 short dest_y, 		 unsigned char *src,		 short src_units_per_line, 		 unsigned char *dest,		 short dest_units_per_line		 ) {  /* 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;    /* goto line y */  src += src_y * src_units_per_line;  dest += dest_y * dest_units_per_line;    /* goto UNIT-offset x */  src += src_x >>3;  dest += dest_x >>3;  /* determine number of affected units per line */    dest_n = ((dest_x + w + 8 - 1) >>3) - (dest_x >>3);  /* determine PIXEL-offsets */  src_off = src_x & 7;  dest_off = dest_x & 7;  dx = dest_off - src_off;    /* make masks to mask out untouchable destination */  dest_beg_mask = ~((unsigned char)(-1) >> dest_off);  dest_end_mask = (unsigned char)(-1) >> ((dest_off + w) & 7);  if (dest_end_mask == (unsigned char)(-1)) {    /* bit stupid */    dest_end_mask = 0;  }  //printf("dx=%d\n", dx);  //dump_unit("dest_beg_mask", dest_beg_mask);  //dump_unit("dest_end_mask", dest_end_mask);  for (y = 0; y < h; y++) {    // process one line    register unsigned char *sp;    register unsigned char *dp;    register unsigned char mask = 0;    register unsigned char left, right;    unsigned char s, d;    sp = src;    dp = dest;    for (x = 0; x < dest_n; x++, sp++, dp++) {      // process one unit      if (dx < 0) {	// first, don't care about masks	left = *sp << (-dx);	right = *(sp+1) >> (8 + dx);      } else if (dx > 0) {	// first, don't care about masks	left = *(sp-1) << (8-dx);	right = *(sp) >> (dx);      } else {	left = *sp;	right = 0;      }      s = left | right;      // 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);    }    src += src_units_per_line;    dest += dest_units_per_line;  }}void patternfill( short dest_x,		 short dest_y, 		 short w,		 short h,		 unsigned char*dest,		 short dest_units_per_line)  {    /* 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);  printf("sc_ptr=%x\n",screen_ptr);  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 XY_clearscreen(unsigned short x1,unsigned short y1,unsigned short x2,unsigned short y2){unsigned short i=0, h_y=y2-y1+1,w_x=x2-x1+1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产在线看一区| 久久aⅴ国产欧美74aaa| 欧美激情在线一区二区| 久久精品一区二区三区四区| 亚洲精品一区在线观看| 国产亚洲一二三区| 国产日韩成人精品| 中文字幕欧美三区| 中文字幕一区二区日韩精品绯色| 国产精品天天摸av网| 亚洲欧美偷拍另类a∨色屁股| 国产精品国产三级国产有无不卡| 亚洲天堂免费在线观看视频| 亚洲日本欧美天堂| 五月婷婷激情综合| 久久福利视频一区二区| 国产成a人无v码亚洲福利| 成人app软件下载大全免费| 色哟哟欧美精品| 91精品国产色综合久久不卡蜜臀| 91精品国产综合久久香蕉麻豆| 日韩欧美中文字幕精品| 国产农村妇女毛片精品久久麻豆| 日韩毛片视频在线看| 五月婷婷另类国产| 国产成人av福利| 在线视频一区二区免费| 日韩美一区二区三区| 国产精品久线观看视频| 日韩黄色片在线观看| 国产一区二区导航在线播放| 色综合久久久久久久| 欧美一区二区三区免费观看视频| 久久久久99精品一区| 一区二区三区鲁丝不卡| 久久91精品国产91久久小草 | 欧美精品 日韩| 国产视频一区在线播放| 亚瑟在线精品视频| 不卡欧美aaaaa| 欧美一激情一区二区三区| 亚洲婷婷综合久久一本伊一区| 日韩国产欧美在线观看| 成人一级视频在线观看| 欧美一区永久视频免费观看| 国产精品电影一区二区| 久久疯狂做爰流白浆xx| 欧美三级欧美一级| 日韩美女精品在线| 国产成人在线色| 欧美一级黄色录像| 亚洲国产精品麻豆| 91视频国产观看| 国产视频一区在线播放| 日韩va亚洲va欧美va久久| 一本大道久久a久久综合| 国产精品乱码一区二区三区软件| 美女免费视频一区二区| 欧美精品xxxxbbbb| 午夜精品福利久久久| 91成人在线观看喷潮| 亚洲特黄一级片| 成人黄色av电影| 亚洲国产高清不卡| 国产99久久久久| 欧美激情一区二区三区全黄| 国产乱国产乱300精品| 精品国产99国产精品| 久久疯狂做爰流白浆xx| 日韩精品一区二区三区视频| 麻豆国产一区二区| 精品美女一区二区| 国产一区二三区| 久久久久9999亚洲精品| 成人综合在线网站| 中文字幕一区在线观看| 97国产一区二区| 亚洲一区二区不卡免费| 欧美日韩国产乱码电影| 日本亚洲视频在线| 欧美成人三级电影在线| 国产精品 日产精品 欧美精品| 久久精品在这里| 成人v精品蜜桃久久一区| 国产精品白丝在线| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 亚洲免费资源在线播放| 精品一区二区免费视频| 久久这里只有精品6| 国产mv日韩mv欧美| 亚洲欧美色综合| 欧美精品久久一区二区三区| 老司机精品视频一区二区三区| 久久久久久亚洲综合| proumb性欧美在线观看| 亚洲黄网站在线观看| 日韩欧美国产一区在线观看| 国产精品538一区二区在线| 亚洲欧洲制服丝袜| 欧美一级黄色大片| 国产suv精品一区二区三区| 一区二区三区在线免费视频| 777xxx欧美| 风间由美一区二区av101| 亚洲与欧洲av电影| 欧美电影免费观看高清完整版在| 成人爱爱电影网址| 肉丝袜脚交视频一区二区| 欧美韩国日本一区| 欧美年轻男男videosbes| 国产高清不卡一区| 亚洲成人av在线电影| 国产精品三级av| 欧美一级高清大全免费观看| 成人av小说网| 久久99精品久久久久久久久久久久| 亚洲欧洲国产专区| 日韩欧美亚洲一区二区| 92国产精品观看| 精品一区二区在线免费观看| 亚洲欧美日韩国产另类专区| 精品免费国产一区二区三区四区| 91在线高清观看| 国产传媒欧美日韩成人| 日韩精品成人一区二区三区| 亚洲日穴在线视频| 久久午夜国产精品| 欧美肥大bbwbbw高潮| 色美美综合视频| 成人网男人的天堂| 国产99久久久精品| 精品无人码麻豆乱码1区2区| 亚洲3atv精品一区二区三区| 亚洲视频在线一区观看| 亚洲国产精品国自产拍av| 精品国产乱码久久久久久夜甘婷婷 | 欧美国产一区在线| 日韩视频免费观看高清完整版| 在线观看一区不卡| 色婷婷亚洲综合| 色一情一伦一子一伦一区| 99久久久久久99| av激情综合网| 成人av资源在线| 国产成人啪午夜精品网站男同| 久久激五月天综合精品| 免费看欧美美女黄的网站| 天天av天天翘天天综合网色鬼国产| 亚洲精品视频免费看| 亚洲天堂网中文字| 最新不卡av在线| 亚洲精选一二三| 一区二区三区四区五区视频在线观看 | 欧美性色综合网| 色哟哟一区二区在线观看| 91蝌蚪porny成人天涯| 99久久伊人精品| 99精品视频中文字幕| 日本道色综合久久| 在线观看日韩电影| 在线综合亚洲欧美在线视频| 日韩一区二区三区在线视频| 精品噜噜噜噜久久久久久久久试看| 精品国一区二区三区| 国产日韩欧美精品综合| 日本一区二区三区在线不卡| 国产精品久久久久天堂| 亚洲一区在线观看视频| 日韩精品电影在线| 国内精品久久久久影院薰衣草| 国产精品 欧美精品| 色婷婷综合视频在线观看| 欧美精品丝袜久久久中文字幕| 日韩一区二区在线观看| 国产欧美va欧美不卡在线 | 欧美性感一类影片在线播放| 欧美片网站yy| 久久久国产精品午夜一区ai换脸| 国产精品麻豆视频| 天堂av在线一区| 国产精品白丝jk黑袜喷水| 91亚洲精品久久久蜜桃网站| 欧美日韩一区二区三区视频| 26uuu国产在线精品一区二区| 综合激情成人伊人| 日韩高清中文字幕一区| 成人综合婷婷国产精品久久蜜臀 | 欧美区视频在线观看| 久久新电视剧免费观看| 亚洲主播在线观看| 韩国欧美一区二区| 欧美性videosxxxxx| 国产婷婷色一区二区三区在线| 亚洲网友自拍偷拍| 成人性生交大合| 精品久久久久久久久久久久久久久久久| 国产精品人妖ts系列视频| 六月婷婷色综合| 欧美日本在线视频| 亚洲女爱视频在线|