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

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

?? glib.c

?? 這個2410開發(fā)板的LCD與UART裸跑的測試程序
?? C
字號:
#include "def.h"
#include "lcdlib.h"
#include "glib.h"
#include "lcd.h"


void (*PutPixel)(U32,U32,U32);

void Glib_Init(int type)
{
    switch(type)
    {
    case MODE_STN_1BIT:
    	PutPixel=_PutStn1Bit;
    	break;
    case MODE_STN_2BIT:
       	PutPixel=_PutStn2Bit;
       	break;
    case MODE_STN_4BIT:
        PutPixel=_PutStn4Bit;
        break;
    case MODE_CSTN_8BIT:
    	PutPixel=_PutCstn8Bit;
    	break;   
    case MODE_CSTN_12BIT:
    	PutPixel=_PutCstn12Bit;
    	break;   
    case MODE_TFT_8BIT_240320:
    	PutPixel=_PutTft8Bit_240320;   	
    	break;   
    case MODE_TFT_16BIT_240320:
    	PutPixel=_PutTft16Bit_240320;
    	break;   
    case MODE_TFT_1BIT_640480:
    	PutPixel=_PutTft1Bit_640480;
    	break;   
    case MODE_TFT_8BIT_640480:
    	PutPixel=_PutTft8Bit_640480;
    	break;   
    case MODE_TFT_16BIT_640480:
    	PutPixel=_PutTft16Bit_640480;
    	break;   
    case MODE_TFT_24BIT_640480:
    	PutPixel=_PutTft24Bit_640480;
    	break;   
//--------------------------------------
    case MODE_TFT_1BIT_800600:
    	PutPixel=_PutTft1Bit_800600;
    	break;   
    case MODE_TFT_8BIT_800600:
    	PutPixel=_PutTft8Bit_800600;
    	break;   
    case MODE_TFT_16BIT_800600:
    	PutPixel=_PutTft16Bit_800600;
    	break;   
//--------------------------------------
    default: 
    	break;
    }
}


void _PutStn1Bit(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_STN&& y<SCR_YSIZE_STN)
	frameBuffer1Bit[(y)][(x)/32]=( frameBuffer1Bit[(y)][(x)/32]
	& ~(0x80000000>>((x)%32)*1) ) | ( (c&0x00000001)<< ((32-1-((x)%32))*1) );
}


void _PutStn2Bit(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_STN&& y<SCR_YSIZE_STN)
        frameBuffer2Bit[(y)][(x)/16]=( frameBuffer2Bit[(y)][x/16]
	& ~(0xc0000000>>((x)%16)*2) ) | ( (c&0x00000003)<<((16-1-((x)%16))*2) );
}


void _PutStn4Bit(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_STN&& y<SCR_YSIZE_STN)
        frameBuffer4Bit[(y)][(x)/8]=( frameBuffer4Bit[(y)][x/8]
	& ~(0xf0000000>>((x)%8)*4) ) | ( (c&0x0000000f)<<((8-1-((x)%8))*4) );
}


void _PutCstn8Bit(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_CSTN&& y<SCR_YSIZE_CSTN)
        frameBuffer8Bit[(y)][(x)/4]=( frameBuffer8Bit[(y)][x/4]
	    & ~(0xff000000>>((x)%4)*8) ) | ( (c&0x000000ff)<<((4-1-((x)%4))*8) );
}


void _PutCstn12Bit(U32 x,U32 y,U32 c)
{
    U32 z;
    z=((x)%8);
    if(x<SCR_XSIZE_CSTN&& y<SCR_YSIZE_CSTN)
    {

        if((z%3)!=2)
            frameBuffer12Bit[(y)][(x)*3/8]=
            ( frameBuffer12Bit[(y)][(x)*3/8] & ~(0xfff00000>>(((z/3)*4)+((z)%3)*12) )
		| ( (c&0xfff)<<(20-(((z/3)*4)+((z)%3)*12))) );
        else
        {
            if(z==2)
            {
                frameBuffer12Bit[(y)][(x)*3/8]=( (frameBuffer12Bit[(y)][(x)*3/8]
		    & ~(0xff)) | ((c&0xff0)>>4)  ); 
                frameBuffer12Bit[(y)][((x)*3/8)+1]=( (frameBuffer12Bit[(y)][((x)*3/8)+1]
		    & ~(0xf0000000)) | ((c&0xf)<<28)  );
            }   
            else if(z==5)
            {
                frameBuffer12Bit[(y)][(x)*3/8]=( (frameBuffer12Bit[(y)][(x)*3/8]
	            & ~(0xf)) | ((c&0xf00)>>8)  );
                frameBuffer12Bit[(y)][((x)*3/8)+1]=( (frameBuffer12Bit[(y)][((x)*3/8)+1]
	            & ~(0xff000000)) | ((c&0xff)<<24)  );
            }   
        }
    }
}


void _PutTft8Bit_240320(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_240320 && y<SCR_YSIZE_TFT_240320)
        frameBuffer8BitTft240320[(y)][(x)/4]=( frameBuffer8BitTft240320[(y)][x/4]
        & ~(0xff000000>>((x)%4)*8) ) | ( (c&0x000000ff)<<((4-1-((x)%4))*8) );
}


void _PutTft16Bit_240320(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_240320 && y<SCR_YSIZE_TFT_240320)
        frameBuffer16BitTft240320[(y)][(x)/2]=( frameBuffer16BitTft240320[(y)][x/2]
        & ~(0xffff0000>>((x)%2)*16) ) | ( (c&0x0000ffff)<<((2-1-((x)%2))*16) );
}


void _PutTft1Bit_640480(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_640480 && y<SCR_YSIZE_TFT_640480)
        frameBuffer1BitTft640480[(y)][(x)/32]=( frameBuffer1BitTft640480[(y)][x/32]
	& ~(0x80000000>>((x)%32)*1) ) | ( (c&0x00000001)<< ((32-1-((x)%32))*1) );
}


void _PutTft8Bit_640480(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_640480 && y<SCR_YSIZE_TFT_640480)
        frameBuffer8BitTft640480[(y)][(x)/4]=( frameBuffer8BitTft640480[(y)][x/4]
        & ~(0xff000000>>((x)%4)*8) ) | ( (c&0x000000ff)<<((4-1-((x)%4))*8) );
}


void _PutTft16Bit_640480(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_640480 && y<SCR_YSIZE_TFT_640480)
        frameBuffer16BitTft640480[(y)][(x)/2]=( frameBuffer16BitTft640480[(y)][x/2]
        & ~(0xffff0000>>((x)%2)*16) ) | ( (c&0x0000ffff)<<((2-1-((x)%2))*16) );
}



void _PutTft24Bit_640480(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_640480 && y<SCR_YSIZE_TFT_640480)
        frameBuffer24BitTft640480[(y)][(x)]=( frameBuffer24BitTft640480[(y)][(x)]
        & (0x0) | ( c&0xffffff00)); // | ( c&0x00ffffff)); LSB 
}



void _PutTft1Bit_800600(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_800600 && y<SCR_YSIZE_TFT_800600)
        frameBuffer1BitTft800600[(y)][(x)/32]=( frameBuffer1BitTft800600[(y)][x/32]
	& ~(0x80000000>>((x)%32)*1) ) | ( (c&0x00000001)<< ((32-1-((x)%32))*1) );
}


void _PutTft8Bit_800600(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_800600 && y<SCR_YSIZE_TFT_800600)
        frameBuffer8BitTft800600[(y)][(x)/4]=( frameBuffer8BitTft800600[(y)][x/4]
        & ~(0xff000000>>((x)%4)*8) ) | ( (c&0x000000ff)<<((4-1-((x)%4))*8) );
}


void _PutTft16Bit_800600(U32 x,U32 y,U32 c)
{
    if(x<SCR_XSIZE_TFT_800600 && y<SCR_YSIZE_TFT_800600)
        frameBuffer16BitTft800600[(y)][(x)/2]=( frameBuffer16BitTft800600[(y)][x/2]
        & ~(0xffff0000>>((x)%2)*16) ) | ( (c&0x0000ffff)<<((2-1-((x)%2))*16) );
}


void Glib_Rectangle(int x1,int y1,int x2,int y2,int color)
{
    Glib_Line(x1,y1,x2,y1,color);
    Glib_Line(x2,y1,x2,y2,color);
    Glib_Line(x1,y2,x2,y2,color);
    Glib_Line(x1,y1,x1,y2,color);
}



void Glib_FilledRectangle(int x1,int y1,int x2,int y2,int color)
{
    int i;

    for(i=y1;i<=y2;i++)
	Glib_Line(x1,i,x2,i,color);
}



// LCD display is flipped vertically
// But, think the algorithm by mathematics point.
//   3I2
//   4 I 1
//  --+--   <-8 octants  mathematical cordinate
//   5 I 8
//   6I7
void Glib_Line(int x1,int y1,int x2,int y2,int color)
{
	int dx,dy,e;
	dx=x2-x1; 
	dy=y2-y1;
    
	if(dx>=0)
	{
		if(dy >= 0) // dy>=0
		{
			if(dx>=dy) // 1/8 octant
			{
				e=dy-dx/2;
				while(x1<=x2)
				{
					PutPixel(x1,y1,color);
					if(e>0){y1+=1;e-=dx;}	
					x1+=1;
					e+=dy;
				}
			}
			else		// 2/8 octant
			{
				e=dx-dy/2;
				while(y1<=y2)
				{
					PutPixel(x1,y1,color);
					if(e>0){x1+=1;e-=dy;}	
					y1+=1;
					e+=dx;
				}
			}
		}
		else		   // dy<0
		{
			dy=-dy;   // dy=abs(dy)

			if(dx>=dy) // 8/8 octant
			{
				e=dy-dx/2;
				while(x1<=x2)
				{
					PutPixel(x1,y1,color);
					if(e>0){y1-=1;e-=dx;}	
					x1+=1;
					e+=dy;
				}
			}
			else		// 7/8 octant
			{
				e=dx-dy/2;
				while(y1>=y2)
				{
					PutPixel(x1,y1,color);
					if(e>0){x1+=1;e-=dy;}	
					y1-=1;
					e+=dx;
				}
			}
		}	
	}
	else //dx<0
	{
		dx=-dx;		//dx=abs(dx)
		if(dy >= 0) // dy>=0
		{
			if(dx>=dy) // 4/8 octant
			{
				e=dy-dx/2;
				while(x1>=x2)
				{
					PutPixel(x1,y1,color);
					if(e>0){y1+=1;e-=dx;}	
					x1-=1;
					e+=dy;
				}
			}
			else		// 3/8 octant
			{
				e=dx-dy/2;
				while(y1<=y2)
				{
					PutPixel(x1,y1,color);
					if(e>0){x1-=1;e-=dy;}	
					y1+=1;
					e+=dx;
				}
			}
		}
		else		   // dy<0
		{
			dy=-dy;   // dy=abs(dy)

			if(dx>=dy) // 5/8 octant
			{
				e=dy-dx/2;
				while(x1>=x2)
				{
					PutPixel(x1,y1,color);
					if(e>0){y1-=1;e-=dx;}	
					x1-=1;
					e+=dy;
				}
			}
			else		// 6/8 octant
			{
				e=dx-dy/2;
				while(y1>=y2)
				{
					PutPixel(x1,y1,color);
					if(e>0){x1-=1;e-=dy;}	
					y1-=1;
					e+=dx;
				}
			}
		}	
	}
}



void Glib_ClearScr(U32 c, int type)
{	
    //Very inefficient function.
    int i,j;
    //if((type==MODE_TFT_1BIT_800600)|(type==MODE_TFT_8BIT_800600)|(type==MODE_TFT_16BIT_800600))
    if((type&0x4000)&&(type&0x400))
	for(j=0;j<SCR_YSIZE_TFT_800600;j++)
            for(i=0;i<SCR_XSIZE_TFT_800600;i++)
		        PutPixel(i,j,c);
    //else if((type==MODE_TFT_1BIT_640480)|(type==MODE_TFT_8BIT_640480)|(type==MODE_TFT_16BIT_640480))
    else if((type&0x4000)&&(type&0x200))
	for(j=0;j<SCR_YSIZE_TFT_640480;j++)
            for(i=0;i<SCR_XSIZE_TFT_640480;i++)
		        PutPixel(i,j,c);
    //else if((type==MODE_TFT_1BIT_240320)|(type==MODE_TFT_8BIT_240320)|(type==MODE_TFT_16BIT_240320))
    else if((type&0x4000)&&(type&0x100))
	for(j=0;j<SCR_YSIZE_TFT_240320;j++)
            for(i=0;i<SCR_XSIZE_TFT_240320;i++)
		        PutPixel(i,j,c);
    else if(type&0x2000)
        for(j=0;j<SCR_YSIZE_CSTN;j++)
    	    for(i=0;i<SCR_XSIZE_CSTN;i++)
		        PutPixel(i,j,c);
    else
        for(j=0;j<SCR_YSIZE_STN;j++)
    	    for(i=0;i<SCR_XSIZE_STN;i++)
		        PutPixel(i,j,c);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚欧色一区w666天堂| 午夜精品久久久久久久蜜桃app| 国产精品无码永久免费888| 国产精品全国免费观看高清| 亚洲欧美色一区| 亚洲欧美另类久久久精品2019| 欧美国产激情一区二区三区蜜月| 18欧美乱大交hd1984| 日韩激情一二三区| 国产成人精品免费网站| 在线免费观看日韩欧美| 欧美精品tushy高清| 欧美成人高清电影在线| 精品sm捆绑视频| 亚洲综合在线五月| 国产精品亚洲一区二区三区在线 | 一区二区三区在线视频播放| 美女视频免费一区| 91久久精品一区二区| 久久久久久久久一| 亚洲成人在线网站| 国产91色综合久久免费分享| 在线电影欧美成精品| 国产精品免费视频一区| 免费黄网站欧美| 欧美视频一区二区三区四区| 国产精品久久久久影视| 麻豆国产一区二区| 欧美这里有精品| 国产精品久久久久久久久久免费看 | 亚洲欧美日韩一区| 国产在线精品免费av| 欧美日韩国产经典色站一区二区三区| 国产女同性恋一区二区| 亚洲曰韩产成在线| 91热门视频在线观看| 国产视频一区不卡| 国产精品一品二品| 日韩亚洲欧美中文三级| 午夜精品影院在线观看| 欧美性大战xxxxx久久久| 亚洲色图一区二区三区| av资源网一区| 国产欧美一区在线| 国产乱人伦偷精品视频不卡| 欧美另类z0zxhd电影| 亚洲一区二区三区四区在线| 成人黄动漫网站免费app| 久久精品亚洲国产奇米99| 精品在线一区二区| 欧美一级片在线看| 日本亚洲视频在线| 欧美一区二区三区白人| 午夜精品福利一区二区蜜股av| 在线观看精品一区| 亚洲国产一区二区在线播放| 欧美无人高清视频在线观看| 丝袜亚洲另类欧美综合| 欧美人伦禁忌dvd放荡欲情| 亚洲四区在线观看| 91国偷自产一区二区开放时间| 亚洲免费视频成人| 欧美日本在线观看| 蜜桃一区二区三区四区| 久久夜色精品一区| 风间由美一区二区av101 | 亚洲综合一区二区三区| 欧美影视一区在线| 首页国产欧美久久| 日韩一区二区电影网| 国产精品一区一区三区| 国产精品国产自产拍高清av王其 | 国产精品亚洲一区二区三区妖精| 久久久国产精品麻豆| 96av麻豆蜜桃一区二区| 日本欧美一区二区在线观看| 日韩欧美在线123| 国产98色在线|日韩| 亚洲激情图片一区| 精品国产乱码久久久久久1区2区| 国产99一区视频免费| 亚洲综合色视频| 26uuu另类欧美| 91丨国产丨九色丨pron| 日韩中文字幕麻豆| 久久久久久久国产精品影院| 91猫先生在线| 九九热在线视频观看这里只有精品| 精品国产免费久久| 色网站国产精品| 久久99国产精品麻豆| 亚洲欧洲日韩av| 欧美一区二区三区视频在线| jvid福利写真一区二区三区| 青青草国产精品亚洲专区无| 国产精品久久久久久久久免费相片| 在线播放中文一区| 成人黄色a**站在线观看| 视频一区国产视频| 国产精品久久久久婷婷二区次| 色丁香久综合在线久综合在线观看| 毛片不卡一区二区| 亚洲国产精品自拍| 国产精品久久毛片av大全日韩| 91精品国产美女浴室洗澡无遮挡| 成人毛片视频在线观看| 久久精品国产**网站演员| 亚洲色图欧洲色图婷婷| 欧美成人福利视频| 91视视频在线直接观看在线看网页在线看| 奇米影视在线99精品| 亚洲综合色丁香婷婷六月图片| 欧美国产一区二区| 欧美一卡二卡三卡| 欧美在线观看视频一区二区| 大陆成人av片| 国产呦萝稀缺另类资源| 婷婷亚洲久悠悠色悠在线播放 | 色综合中文字幕| 国产精品538一区二区在线| 亚州成人在线电影| 一区二区三区中文字幕| 成人免费在线观看入口| 久久精品一区二区三区不卡牛牛 | 亚洲美女免费在线| 欧美韩国一区二区| 精品动漫一区二区三区在线观看| 91一区二区在线| www.日韩大片| 国产盗摄精品一区二区三区在线| 偷窥国产亚洲免费视频| 天天爽夜夜爽夜夜爽精品视频| 亚洲国产综合91精品麻豆| 欧美国产日韩精品免费观看| 亚洲精品一区二区三区精华液| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲观看高清完整版在线观看| 亚洲精品欧美激情| 亚洲精品亚洲人成人网| 久久久精品黄色| 亚洲国产精品v| 欧美高清在线一区二区| 国产精品久久久久永久免费观看 | 亚洲成人三级小说| 亚洲自拍欧美精品| 欧美精品一区二区三区蜜臀| 在线亚洲一区二区| 欧美一区二区久久久| 精品成a人在线观看| 亚洲另类春色校园小说| 婷婷中文字幕一区三区| 国产成人精品网址| 欧美日韩精品一区二区天天拍小说 | 精品欧美一区二区在线观看| 久久久久久久久一| 亚洲成人免费看| 国产精品一二三四区| 欧美揉bbbbb揉bbbbb| 亚洲国产精品成人综合| 视频一区免费在线观看| 成人免费黄色在线| 91麻豆精品国产| 亚洲摸摸操操av| 国产综合久久久久久鬼色| 91福利在线观看| 国产天堂亚洲国产碰碰| 日韩av不卡一区二区| 91免费视频大全| 久久精品亚洲乱码伦伦中文| 婷婷久久综合九色综合伊人色| 成人av在线一区二区三区| 欧美一区二区三区免费在线看| 综合网在线视频| 国产精品综合二区| 日韩欧美一区二区免费| 一区二区三区精品在线| 丁香网亚洲国际| 欧美r级在线观看| 亚洲午夜激情av| 91在线观看下载| 久久精品视频在线看| 美女网站在线免费欧美精品| 欧美日韩中文字幕一区二区| 亚洲人成在线播放网站岛国| 国产乱淫av一区二区三区| 欧美一级欧美三级| 午夜精品久久一牛影视| 在线观看国产精品网站| 亚洲蜜桃精久久久久久久| 成熟亚洲日本毛茸茸凸凹| 欧美精品一区二区三区很污很色的| 性做久久久久久久免费看| 91成人免费电影| 亚洲免费观看高清完整版在线 | 69堂精品视频| 亚洲成人黄色小说| 欧美日韩精品一二三区| 亚洲成人av福利| 欧美日韩极品在线观看一区| 亚洲国产你懂的|