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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? lcd.c

?? 彩色LCDColor LCDColor LCD
?? C
字號:
#include <string.h>
#include "..\inc\def.h"
#include "..\inc\44b.h"
#include "..\inc\44blib.h"
#include "..\inc\lcdlib.h"
#include "..\inc\glib.h"
#include "..\inc\lcd.h"

void Test_LcdMono(void);
void Test_LcdG4(void);
void Test_LcdG16(void);
void Test_LcdColor(void);

void Test_LcdMono(void)
{
    int i,j;
    Lcd_Init(MODE_MONO);
    Glib_Init(MODE_MONO);
    Uart_Printf("[Mono(1bit/1pixel) LCD Test]: Press Any Key!\n");              

    Glib_ClearScr(0);
    for(j=0;j<LCD_YSIZE;j+=16)
	for(i=0;i<LCD_XSIZE;i+=16)
	    Glib_FilledRectangle(i,j,i+15,j+15,((j+i)/16)%2);
    Uart_Printf("Mono test 1. Press any key!\n");
    Uart_Getch();  	

    Glib_ClearScr(0);
    Glib_FilledRectangle(160,0,319,239,1);
    Uart_Printf("Mono test 2. Press any key!\n");
    Uart_Getch();  	

    Glib_ClearScr(0); 
    Glib_Rectangle(0,0,319,239,1);   // #0
    Glib_Line(0,0,319,239,1);        // 00
    Glib_Line(0,239,319,0,1);

    Glib_Rectangle(0+320,0,319+320,239,1);   // 0#
    Glib_Line(0+320,0,319+320,239,1);        // 00
    Glib_Line(0+320,239,319+320,0,1);
    Glib_FilledRectangle(50+320,50,269+320,189,1);

    Glib_Rectangle(0,0+240,319,239+240,1);   // 00
    Glib_Line(0,0+240,319,239+240,1);        // #0
    Glib_Line(0,239+240,319,0+240,1);
    Glib_FilledRectangle(50,50+240,269,189+240,1);
    
    Glib_Rectangle(0+320,0+240,319+320,239+240,1);   // 00	
    Glib_Line(0+320,0+240,319+320,239+240,1);        // 0#
    Glib_Line(0+320,239+240,319+320,0+240,1);
    Glib_Rectangle(50+320,50+240,269+320,189+240,1);

    Uart_Printf("Virtual Screen Test(Mono). Press any key[ijkm\\r]!\n");
    MoveViewPort(MODE_MONO);

    Lcd_MoveViewPort(0,0,MODE_MONO);
}





void Test_LcdG4(void)
{
    int i,j,k;

    Lcd_Init(MODE_G4);
    Glib_Init(MODE_G4);

    Uart_Printf("[4gray(2bit/1pixel) LCD Test]: Press Any Key!\n");

    Glib_ClearScr(0);


    j=0;
    for(i=0;i<320;i+=80)
        Glib_FilledRectangle(0+i,0,79+i,239,j++);
    Uart_Printf("4 gray mode test 1. Press any key!\n");
    Uart_Getch();  	


    Glib_ClearScr(0);
    j=0;
    for(i=0;i<320;i+=80)
    {
    	Glib_FilledRectangle(0+i,0,79+i,119,j);
    	Glib_FilledRectangle(0+i,120,79+i,239,3-j);
    	j++;
    }
    Uart_Printf("4 gray mode test 2. Press any key!\n");
    Uart_Getch();  	


    Glib_ClearScr(0);
    j=0;
    for(i=0;i<240;i+=60)
    {
    	Glib_FilledRectangle(i,i,i+59,i+59,j);
    	j++;
    }
    Uart_Printf("4 gray mode test 3. Press any key!\n");
    Uart_Getch();  	


    Glib_ClearScr(0);
    k=0;
    for(i=160;i<480;i+=80)
    {
    	for(j=120;j<360;j+=60)
    	{
    	    Glib_FilledRectangle(i,j,i+79,j+59,k%4);
    	    k++;
    	}
    	k+=2;;
    }

    // #0
    // 00
    Glib_Rectangle(0,0,319,239,3);   
    Glib_Line(0,0,319,239,3);        
    Glib_Line(0,239,319,0,3);

    // 0#
    // 00
    Glib_Rectangle(0+320,0,319+320,239,3);          
    Glib_Line(0+320,0,319+320,239,3);        
    Glib_Line(0+320,239,319+320,0,3);

    // 00
    // #0
    Glib_Rectangle(0,0+240,319,239+240,3);          
    Glib_Line(0,0+240,319,239+240,3);        
    Glib_Line(0,239+240,319,0+240,3);

    // 00
    // 0#
    Glib_Line(0+320,0+240,319+320,239+240,3);        
    Glib_Line(0+320,239+240,319+320,0+240,3);
    Glib_Rectangle(50+320,50+240,269+320,189+240,3);

    Uart_Printf("Virtual Screen Test(4 gray). Press any key[ijkm\\r]!\n");
    MoveViewPort(MODE_G4);

    Lcd_MoveViewPort(0,0,MODE_G4);

}




void Test_LcdG16(void)
{
    int i,j,k;

    Lcd_Init(MODE_G16);
    Glib_Init(MODE_G16);

    Uart_Printf("[16 gray(4bit/1pixel) LCD Test]: Press Any Key!\n");

    Glib_ClearScr(0);
    j=0;
    for(i=0;i<320;i+=20)
        Glib_FilledRectangle(0+i,0,19+i,239,j++);
    Uart_Printf("16 gray mode test 1. Press any key!\n");
    Uart_Getch();  	

    Uart_Printf("16 gray color viewing. Press any key 16 times.\n");
    j=0;
    Glib_ClearScr(0);
    for(i=0;i<16;i++)
    {
        Glib_FilledRectangle(0,0,319,239,i);
	Uart_Printf("Color num=%d\n",i);
	Uart_Getch();  	
    }
    
    Glib_ClearScr(0);
    j=0;
    for(i=0;i<320;i+=20)
    {
    	Glib_FilledRectangle(0+i,0,19+i,119,j);
    	Glib_FilledRectangle(0+i,120,19+i,239,15-j);
    	j++;
    }
    Uart_Printf("16 gray mode test 2. Press any key!\n");
    Uart_Getch();  	


    Glib_ClearScr(0);
    j=0;
    for(i=0;i<240;i+=30)
    {
    	Glib_FilledRectangle(i,i,i+29,i+29,j);
    	Glib_FilledRectangle(i+110,i,i+29+110,i+29,j+8);
    	j++;
    }
    
    Uart_Printf("4 gray mode test 3. Press any key!\n");
    Uart_Getch();  	 


    Glib_ClearScr(0);

    k=0;
    for(i=160;i<480;i+=40)
    {
    	for(j=120;j<360;j+=30)
    	{
    	    Glib_FilledRectangle(i,j,i+39,j+29,k%16);
    	    k++;
    	}
    }    
    		    
    // #0		    
    // 00		    
    Glib_Rectangle(0,0,319,239,15);   
    Glib_Line(0,0,319,239,15);        
    Glib_Line(0,239,319,0,15);

    // 0#
    // 00
    Glib_Rectangle(0+320,0,319+320,239,15);
    Glib_Line(0+320,0,319+320,239,15);        
    Glib_Line(0+320,239,319+320,0,15);

    // 00
    // #0
    Glib_Rectangle(0,0+240,319,239+240,15);
    Glib_Line(0,0+240,319,239+240,15);        
    Glib_Line(0,239+240,319,0+240,15);

    // 00
    // 0#
    Glib_Rectangle(0+320,0+240,319+320,239+240,15);
    Glib_Line(0+320,0+240,319+320,239+240,15);     
    Glib_Line(0+320,239+240,319+320,0+240,15);
    Glib_Rectangle(50+320,50+240,269+320,189+240,15);

    Uart_Printf("Virtual Screen Test(16 gray). Press any key[ijkm\\r]!\n");
    MoveViewPort(MODE_G16);

    Lcd_MoveViewPort(0,0,MODE_G16);
}




void Test_LcdColor(void)
{
    int i,j,k;

    rPDATE=rPDATE&~(1<<5)|(1<<5);	//GPE5=H	 
    rPCONE=rPCONE&~(3<<10)|(1<<10);	//GPE5=output
    rPCONC=rPCONC&~(0xff<<8)|(0xff<<8);	//GPC[4:7] => VD[7:4]
    
    Uart_Printf("[(240x3)x320 COLOR STN LCD TEST]\n");
 
    Uart_Printf("     R:0   ...    7 \n");
    Uart_Printf("G:0  B0:1 B0:1 B0:1 \n");
    Uart_Printf("G:.   2:3  2:3  2:3 \n");
    Uart_Printf("G:.  B0:1 B0:1 B0:1 \n");
    Uart_Printf("G:.   2:3  2:3  2:3 \n");
    Uart_Printf("G:.  B0:1 B0:1 B0:1 \n");
    Uart_Printf("G:7   2:3  2:3  2:3 \n");

    Lcd_Init(MODE_COLOR);
    Glib_Init(MODE_COLOR);
    
    Glib_ClearScr(0);
    for(j=0;j<320;j++)
	for(i=0;i<240;i++)
	{   //RRRGGGBB
	    PutPixel( i,j,((i/30)<<5)+((j/40)<<2)+((i/15)&0x1)+(((j/20)&0x1)<<1) );
	}
    Uart_Printf("256 color mode test 1. Press any key!\n");
    Uart_Getch();  	


    Glib_ClearScr(0);
    k=0;
    for(i=160;i<480;i+=20)
    {
    	for(j=120;j<360;j+=15)
    	{
    	    Glib_FilledRectangle(i,j,i+19,j+14,k);
    	    k++;
    	}
    }

    // #0		    
    // 00		    
    Glib_Rectangle(0,0,319,239,255);   
    Glib_Line(0,0,319,239,255);        
    Glib_Line(0,239,319,0,255);

    // 0#
    // 00
    Glib_Rectangle(0+320,0,319+320,239,255);
    Glib_Line(0+320,0,319+320,239,255);        
    Glib_Line(0+320,239,319+320,0,255);

    // 00
    // #0
    Glib_Rectangle(0,0+240,319,239+240,255);
    Glib_Line(0,0+240,319,239+240,255);        
    Glib_Line(0,239+240,319,0+240,255);

    // 00
    // 0#
    Glib_Rectangle(0+320,0+240,319+320,239+240,255);
    Glib_Line(0+320,0+240,319+320,239+240,255);     
    Glib_Line(0+320,239+240,319+320,0+240,255);
    Glib_Rectangle(50+320,50+240,269+320,189+240,255);

    Uart_Printf("Virtual Screen Test(256 color). Press any key[ijkm\\r]!\n");
    MoveViewPort(MODE_COLOR);

    Lcd_MoveViewPort(0,0,MODE_COLOR);

}



void MoveViewPort(int depth)
{
    int vx=0,vy=0,vd;
    vd=(depth==1)*16+(depth==4)*8+(depth==16)*4+(depth==256)*2;
    while(1)
    {
    	switch(Uart_Getch())
    	{
    	case 'i':
	    if(vy>=vd)vy-=vd;    	   	
    	    break;
    	case 'j':
    	    if(vx>=vd)vx-=vd;
    	    break;
    	case 'k':
	    if(vx<=SCR_XSIZE-LCD_XSIZE-vd)vx+=vd;
    	    break;
    	case 'm':
	    if(vy<=(SCR_YSIZE-LCD_YSIZE-vd))vy+=vd;    	   	
    	    break;
    	case '\r':
    	    return;
    	default:
	    break;
	}
	Uart_Printf("vx=%3d,vy=%3d\n",vx,vy);
	Lcd_MoveViewPort(vx,vy,depth);
    }
}



/************************ for only test **********************/

#define BUFFER0_PREPARED	(0)
#define BUFFER1_PREPARED	(1)
#define BUFFER0_USED		(2)
#define BUFFER1_USED		(3)

#define M5D(n) ((n) & 0x1fffff)
#define MVAL			(13)
unsigned int (*frameBuffer256_2)[SCR_XSIZE/4];

void MoveViewPort2(int depth)
{
    int vx=0,vy=0,vd;
    U32 addr;
    char key;
    int state=BUFFER0_USED;
    vd=(depth==1)*16+(depth==4)*8+(depth==16)*4+(depth==256)*2;
    while(1)
    {
    	while(1)
    	{
    	    key=Uart_GetKey();
    	    if(key!=0)break;

   	    if(state==BUFFER1_USED)
    	    {//set the frame buffer as BUFFER1
		state=BUFFER0_PREPARED;
	    	while((rLCDCON1>>22)==0); // if x>64
        	addr=(U32)frameBuffer256+(vx/1)+vy*(SCR_XSIZE/1);
		rLCDSADDR1= (0x3<<27) | ( (addr>>22)<<21 ) | M5D(addr>>1);
	    	// 256-color, LCDBANK, LCDBASEU
		rLCDSADDR2= M5D(((addr+(SCR_XSIZE*LCD_YSIZE))>>1)) | (MVAL<<21);
       	    }

    	    if(state==BUFFER0_USED)
    	    {//set the frame buffer as BUFFER0
		state=BUFFER1_PREPARED;
	    	while((rLCDCON1>>22)==0); // if x>64
        	addr=(U32)frameBuffer256_2+(vx/1)+vy*(SCR_XSIZE/1);
		rLCDSADDR1= (0x3<<27) | ( (addr>>22)<<21 ) | M5D(addr>>1);
	    	// 256-color, LCDBANK, LCDBASEU
		rLCDSADDR2= M5D(((addr+(SCR_XSIZE*LCD_YSIZE))>>1)) | (MVAL<<21);
    	    }
    	    
	    if((rLCDCON1>>22)==0)
	    {
                if(state==BUFFER0_PREPARED)state=BUFFER0_USED;
                if(state==BUFFER1_PREPARED)state=BUFFER1_USED;
            }
    	}
    	
    	switch(key)
    	{
    	case 'i':
	    if(vy>=vd)vy-=vd;    	   	
    	    break;
    	case 'j':
    	    if(vx>=vd)vx-=vd;
    	    break;
    	case 'k':
	    if(vx<=SCR_XSIZE-LCD_XSIZE-vd)vx+=vd;
    	    break;
    	case 'm':
	    if(vy<=(SCR_YSIZE-LCD_YSIZE-vd))vy+=vd;    	   	
    	    break;
    	case '\r':
    	    return;
    	default:
	    break;
	}
	Uart_Printf("vx=%3d,vy=%3d\n",vx,vy);
	Lcd_MoveViewPort(vx,vy,depth);
    }
}




void Test_LcdColor2(void)
{
    int i,j,k;

    rPDATE=rPDATE&~(1<<5)|(1<<5);	//GPE5=H	 
    rPCONE=rPCONE&~(3<<10)|(1<<10);	//GPE5=output
    rPCONC=rPCONC&~(0xff<<8)|(0xff<<8);	//GPC[4:7] => VD[7:4]

    Uart_Printf("[(240x3)x320 Color STN Virtual Screen & 2 Frame Buffers Test]\n");

    Lcd_Init(MODE_COLOR);
    frameBuffer256_2=(unsigned int (*)[SCR_XSIZE/4])malloc(SCR_XSIZE/1*SCR_YSIZE); 

    if((U32)frameBuffer256==0x0)return;
    if((U32)frameBuffer256_2==0x0)return;

    Glib_Init(MODE_COLOR);
    
    Glib_ClearScr(0);

    Glib_ClearScr(0);
    k=0;
    for(i=160;i<480;i+=20)
    {
    	for(j=120;j<360;j+=15)
    	{
    	    Glib_FilledRectangle(i,j,i+19,j+14,k);
    	    k++;
    	}
    }

    // #0		    
    // 00		    
    Glib_Rectangle(0,0,319,239,255);   
    Glib_Line(0,0,319,239,255);        
    Glib_Line(0,239,319,0,255);

    // 0#
    // 00
    Glib_Rectangle(0+320,0,319+320,239,255);
    Glib_Line(0+320,0,319+320,239,255);        
    Glib_Line(0+320,239,319+320,0,255);

    // 00
    // #0
    Glib_Rectangle(0,0+240,319,239+240,255);
    Glib_Line(0,0+240,319,239+240,255);        
    Glib_Line(0,239+240,319,0+240,255);

    // 00
    // 0#
    Glib_Rectangle(0+320,0+240,319+320,239+240,255);
    Glib_Line(0+320,0+240,319+320,239+240,255);     
    Glib_Line(0+320,239+240,319+320,0+240,255);
    Glib_Rectangle(50+320,50+240,269+320,189+240,255);

    for(i=0;i<720/4;i++)
    	for(j=0;j<960;j++)
    	{
    	    frameBuffer256_2[j][i]=frameBuffer256[j][i];
    	}

    Uart_Printf("Virtual Screen Test(256 color). Press any key[ijkm\\r]!\n");
    MoveViewPort2(MODE_COLOR);

    Lcd_MoveViewPort(0,0,MODE_COLOR);

}




?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
555www色欧美视频| 最近日韩中文字幕| 日韩欧美亚洲国产精品字幕久久久| 99精品国产91久久久久久 | 国产精品综合二区| 天天操天天色综合| 一区二区在线观看不卡| 日本一二三不卡| 久久久久99精品国产片| 日韩欧美成人午夜| 91精品视频网| 欧美日本一道本| 成人性生交大合| 久久er99精品| 日韩中文字幕av电影| 日韩成人av影视| 亚洲欧美日韩国产综合| 国产精品伦一区| 成人免费一区二区三区视频| 亚洲国产精品v| 国产精品久久午夜夜伦鲁鲁| 亚洲国产成人私人影院tom| 国产精品人成在线观看免费| 国产欧美日韩另类视频免费观看| 国产三级精品视频| 国产精品日产欧美久久久久| 亚洲欧美在线aaa| 亚洲视频免费观看| 亚洲自拍偷拍图区| 亚洲黄色录像片| 亚洲精品国产一区二区三区四区在线 | 精东粉嫩av免费一区二区三区| 美国三级日本三级久久99| 久久66热偷产精品| 国产精品系列在线观看| 成人深夜视频在线观看| 成人h精品动漫一区二区三区| 91在线观看高清| 欧美三级视频在线| 欧美一级高清片在线观看| 精品国产露脸精彩对白| 久久久电影一区二区三区| 欧美高清一级片在线观看| 亚洲美女在线国产| 亚洲.国产.中文慕字在线| 久久超碰97中文字幕| 成人丝袜高跟foot| 在线观看www91| 欧美一三区三区四区免费在线看| 精品国产一二三| 久久久亚洲高清| 国产亚洲视频系列| 亚洲图片另类小说| 亚洲成人av一区二区| 日本 国产 欧美色综合| 国内精品视频一区二区三区八戒 | 精品久久久久99| 国产精品久久夜| 石原莉奈一区二区三区在线观看| 国产老妇另类xxxxx| 色视频欧美一区二区三区| 欧美一区二区美女| 国产精品久99| 午夜视频在线观看一区二区 | 国产精品久线观看视频| 亚洲国产日韩一区二区| 狠狠色丁香久久婷婷综合_中| 成人app网站| 7777精品伊人久久久大香线蕉完整版 | 色琪琪一区二区三区亚洲区| 日韩欧美中文一区二区| 国产精品久久久久久久裸模 | 日本欧美在线看| av中文一区二区三区| 91精品国产综合久久小美女| 国产综合久久久久久鬼色| 色香蕉久久蜜桃| 国产人久久人人人人爽| 六月丁香婷婷久久| 在线亚洲+欧美+日本专区| 国产精品久久久久久久久果冻传媒| 午夜精品在线视频一区| youjizz久久| 精品国产91亚洲一区二区三区婷婷| 国产欧美一区二区精品性| 蜜桃av一区二区在线观看| 在线欧美日韩精品| 国产精品精品国产色婷婷| 激情综合网av| 日韩一二在线观看| 亚洲18色成人| 欧美优质美女网站| 亚洲视频中文字幕| 美女在线视频一区| 欧美一区二区三区在线看| 亚洲三级电影网站| 国产成人在线影院| 日韩欧美激情四射| 天天综合日日夜夜精品| 91在线国产观看| 国产欧美日本一区视频| 精品一区二区在线看| 在线不卡a资源高清| 亚洲欧洲日本在线| 高清在线观看日韩| 裸体在线国模精品偷拍| 欧美日韩中文国产| 亚洲欧美在线aaa| 丁香啪啪综合成人亚洲小说 | 国产精品久久久久一区| 国产一区二区三区免费在线观看| 欧美一区二区三区四区视频| 午夜精品福利久久久| 欧美视频三区在线播放| 亚洲日本电影在线| 欧美午夜一区二区| 亚洲三级电影网站| 国产精品123| 亚洲欧美日韩一区二区 | 亚洲欧洲国产日韩| 波多野结衣一区二区三区 | 91免费看视频| 亚洲久草在线视频| 一本一本久久a久久精品综合麻豆| 日韩美女久久久| 欧美综合一区二区三区| 一区二区三区免费观看| 欧洲亚洲国产日韩| 亚洲国产精品视频| 在线观看亚洲一区| 婷婷丁香久久五月婷婷| 91精品免费在线| 精品无人码麻豆乱码1区2区| 91精品国产色综合久久不卡蜜臀 | 国产成人在线影院| 欧美经典一区二区三区| 成人一区二区三区在线观看| 中文字幕在线不卡一区| 色综合久久久久| 亚洲国产一区二区a毛片| 欧美日韩精品专区| 亚洲一区在线视频| 欧美一区二区福利在线| 国内精品免费**视频| 欧美韩国日本不卡| 欧洲精品一区二区三区在线观看| 亚洲高清久久久| 精品国产伦一区二区三区免费| 国产精品影音先锋| 中文字幕一区视频| 欧美在线观看禁18| 久久综合综合久久综合| 国产日本一区二区| 色婷婷一区二区三区四区| 天堂成人免费av电影一区| 日韩精品一区二区三区四区视频 | 欧美日韩一级二级| 精品一区二区精品| 1000精品久久久久久久久| 91国内精品野花午夜精品 | 国产成人综合精品三级| 亚洲人成网站精品片在线观看| 一本大道久久a久久精品综合| 亚洲国产裸拍裸体视频在线观看乱了| 欧美性淫爽ww久久久久无| 久久精品国产成人一区二区三区| 国产精品福利电影一区二区三区四区| 欧美午夜精品免费| 国产一区二区三区黄视频| 亚洲视频图片小说| 精品欧美乱码久久久久久1区2区| 99国内精品久久| 久久精品99国产精品| 国产精品福利一区二区三区| 日韩一区二区高清| 91网站在线观看视频| 精品一区二区免费| 亚洲午夜久久久久久久久久久| 久久日一线二线三线suv| 91在线视频观看| 国产乱人伦偷精品视频免下载| 亚洲婷婷综合久久一本伊一区| 欧美一区二区三区视频免费播放 | 国产黑丝在线一区二区三区| 亚洲成人av一区| 国产精品久久久久久久久快鸭| 日韩欧美国产精品| 欧洲亚洲国产日韩| 国产成人h网站| 久久精品国产秦先生| 亚洲国产精品天堂| 亚洲欧洲成人自拍| 久久人人97超碰com| 欧美日韩一二三区| 国产盗摄一区二区| 亚洲国产wwwccc36天堂| 久久久久国产精品麻豆| 欧美精品视频www在线观看| 99精品视频一区二区三区| 国产精品一区在线观看乱码|