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

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

?? lcd.c

?? ylp2410的bootloader源碼
?? C
字號:
/**************************************************************
The initial and control for 320×240 16Bpp TFT LCD--LTV350QV-F05
**************************************************************/

#include <string.h>
#include "2410addr.h"
#include "2410lib.h"
#include "def.h"
#include "2410slib.h"

#include "LCD.h"
//extern unsigned char xyx_240_320[];	//寬320,高240

volatile unsigned short LCD_BUFER[SCR_XSIZE_TFT_320240][SCR_YSIZE_TFT_320240];

/**************************************************************
320×240 16Bpp TFT LCD數據和控制端口初始化
**************************************************************/
void Lcd_Port_Init(void)
{
    rGPCUP=0xffffffff; // Disable Pull-up register
    rGPCCON=0xaaaa56a9; //Initialize VD[7:0],LCDVF[2:0],VM,VFRAME,VLINE,VCLK,LEND 

    rGPDUP=0xffffffff; // Disable Pull-up register
    rGPDCON=0xaaaaaaaa; //Initialize VD[15:8]
}

/**************************************************************
320×240 16Bpp TFT LCD功能模塊初始化
**************************************************************/
void Lcd_Init(void)
{
	rLCDCON1=(CLKVAL_TFT_320240<<8)|(MVAL_USED<<7)|(3<<5)|(12<<1)|0;
    	// TFT LCD panel,12bpp TFT,ENVID=off
	rLCDCON2 = (VBPD_320240<<24) | (LINEVAL_TFT_320240<<14) | (VFPD_320240<<6) | (VSPW_320240);
	rLCDCON3 = (HBPD_320240<<19) | (HOZVAL_TFT_320240<<8) | (HFPD_320240);
	rLCDCON4 = (13<<8) | (HSPW_320240);
	rLCDCON5 = (1<<11) | (1<<10) | (1<<9) | (1<<8) | (0<<7) | (0<<6) | (1<<3)  |(BSWP<<1) | (HWSWP);
	rLCDSADDR1=(((U32)LCD_BUFER>>22)<<21)|M5D((U32)LCD_BUFER>>1);
	rLCDSADDR2=M5D( ((U32)LCD_BUFER+(SCR_XSIZE_TFT_320240*LCD_YSIZE_TFT_320240*2))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_320240-LCD_XSIZE_TFT_320240)/1)<<11)|(LCD_XSIZE_TFT_320240/1);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rLPCSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
}

/**************************************************************
LCD視頻和控制信號輸出或者停止,1開啟視頻輸出
**************************************************************/
void Lcd_EnvidOnOff(int onoff)
{
    if(onoff==1)
	rLCDCON1|=1; // ENVID=ON
    else
	rLCDCON1 =rLCDCON1 & 0x3fffe; // ENVID Off
}

/**************************************************************
LPC3600 is a timing control logic unit for LTS350Q1-PD1 or LTS350Q1-PD2
**************************************************************/
void Lcd_Lpc3600Enable(void)
{
    rLPCSEL&=~(7);
    rLPCSEL|=(7); // 320240,Enable LPC3600
}    

/**************************************************************
320×240 8Bpp TFT LCD 電源控制引腳使能
**************************************************************/
void Lcd_PowerEnable(int invpwren,int pwren)
{
    //GPG4 is setted as LCD_PWREN
    rGPGUP = rGPGUP|(1<<4); // Pull-up disable
    rGPGCON = rGPGCON|(3<<8); //GPG4=LCD_PWREN
    //Enable LCD POWER ENABLE Function
    rLCDCON5 = rLCDCON5&(~(1<<3))|(pwren<<3);   // PWREN
    rLCDCON5=rLCDCON5&(~(1<<5))|(invpwren<<5);   // INVPWREN
}

/**************************************************************
320×240 8Bpp TFT LCD 顏色初始化
**************************************************************/
void Lcd_Palette_Init(void)
{
    unsigned char cdata, p_red, p_green, p_blue;
    U32 *palette;
    
	//#define PALETTE     0x4d000400    //Palette start address
    palette=(U32 *)PALETTE;
    *palette++=0; //black
    for(cdata=1;cdata<255;cdata++)
    {
		p_red=(cdata & 0xe0);
		p_green=(cdata & 0x1c);
		p_blue=(cdata & 0x03);
    	*palette++=((U32)((p_red<<8)|(p_green<<6)|(p_blue<<3)));
    }
    *palette=0xffff; //white
}

/**************************************************************
320×240 16Bpp TFT LCD移動觀察窗口
**************************************************************/
void Lcd_MoveViewPort(int vx,int vy)
{
    U32 addr;

    SET_IF(); 
	#if (LCD_XSIZE_TFT_320240<32)
    	    while((rLCDCON1>>18)<=1); // if x<32
	#else	
    	    while((rLCDCON1>>18)==0); // if x>32
	#endif
    
    addr=(U32)LCD_BUFER+(vx*2)+vy*(SCR_XSIZE_TFT_320240*2);
	rLCDSADDR1= ( (addr>>22)<<21 ) | M5D(addr>>1);
	rLCDSADDR2= M5D(((addr+(SCR_XSIZE_TFT_320240*LCD_YSIZE_TFT_320240*2))>>1));
	CLR_IF();
}    

/**************************************************************
320×240 16Bpp TFT LCD移動觀察窗口
**************************************************************/
void MoveViewPort(void)
{
    int vx=0,vy=0,vd=1;

    Uart_Printf("\n*Move the LCD view windos:\n");
    Uart_Printf(" press 8 is up\n");
    Uart_Printf(" press 2 is down\n");
    Uart_Printf(" press 4 is left\n");
    Uart_Printf(" press 6 is right\n");
    Uart_Printf(" press Enter to exit!\n");

    while(1)
    {
    	switch(Uart_Getch())
    	{
    	case '8':
	    if(vy>=vd)vy-=vd;    	   	
        break;

    	case '4':
    	    if(vx>=vd)vx-=vd;
    	break;

    	case '6':
                if(vx<=(SCR_XSIZE_TFT_320240-LCD_XSIZE_TFT_320240-vd))vx+=vd;   	    
   	    break;

    	case '2':
                if(vy<=(SCR_YSIZE_TFT_320240-LCD_YSIZE_TFT_320240-vd))vy+=vd;   	    
   	    break;

    	case '\r':
   	    return;

    	default:
	    break;
		}
	Uart_Printf("vx=%3d,vy=%3d\n",vx,vy);
	Lcd_MoveViewPort(vx,vy);
    }
}

/**************************************************************
320×240 16Bpp TFT LCD單個象素的顯示數據輸出
**************************************************************/
void PutPixel(U32 x,U32 y,U32 c)
{
	if ( (x < SCR_XSIZE_TFT_320240) && (y < SCR_YSIZE_TFT_320240) )
	LCD_BUFER[(y)][(x)] = c;
}

/**************************************************************
320×240 16Bpp TFT LCD全屏填充特定顏色單元或清屏
**************************************************************/
void Lcd_ClearScr(U16 c)
{
	unsigned int x,y ;
		
    for( y = 0 ; y < SCR_YSIZE_TFT_320240 ; y++ )
    {
    	for( x = 0 ; x < SCR_XSIZE_TFT_320240 ; x++ )
    	{
			LCD_BUFER[y][x] = c;
    	}
    }
}

/**************************************************************
LCD屏幕顯示垂直翻轉
// 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;
				}
			}
		}	
	}
}

/**************************************************************
在LCD屏幕上畫一個矩形
**************************************************************/
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);
}

/**************************************************************
在LCD屏幕上用顏色填充一個矩形
**************************************************************/
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屏幕上指定坐標點畫一個指定大小的圖片
**************************************************************/
/*
void Paint_Bmp(int x0,int y0,int h,int l,unsigned char bmp[])
{
	int x,y;
	U32 c;
	int p = 0;
	
    for( y = 0 ; y < l ; y++ )
    {
    	for( x = 0 ; x < h ; x++ )
    	{
    		c = bmp[p+1] | (bmp[p]<<8) ;

			if ( ( (x0+x) < SCR_XSIZE_TFT_320240) && ( (y0+y) < SCR_YSIZE_TFT_320240) )
			LCD_BUFER[y0+y][x0+x] = c ;

    		p = p + 2 ;
    	}
    }
}
*/
void Paint_Bmp(int x0,int y0,int h,int l,unsigned char bmp[])
{
	int x,y;
	U32 c;
	int p = 0;
	
    for( x = 0 ; x < h ; x++ )
    {
   		for( y = 0 ; y < l ; y++ )
    	{
    		c = bmp[p+1] | (bmp[p]<<8) ;

			if ( ( (x0+x) < SCR_XSIZE_TFT_320240) && ( (y0+y) < SCR_YSIZE_TFT_320240) )
			LCD_BUFER[x0+x][y0+y] = c ;

    		p = p + 2 ;
    	}
    }
}

/**************************************************************
**************************************************************/
extern unsigned char LOGO[];
extern unsigned char flower1_320_240[];
extern unsigned char girl10[];
extern unsigned char landscape2[];
extern unsigned char sky[];
extern unsigned char test[];
extern unsigned char test1[];
extern unsigned char test2[];
extern unsigned char test3[];
void Test_Lcd_Tft_16Bpp_240_320(void)
{
	//unsigned int x,y ;
	//U32 c;
	
	#define DELAY_TIME		36000

	#ifdef DEBUG
    	Uart_Printf("\nTest LTS350Q1_PE1 & LQ035Q7DB02 (TFT LCD)!\n");
	#endif	
    	printf("\nTest LTS350Q1_PE1 & LQ035Q7DB02 (TFT LCD)!\n");

    Lcd_Port_Init();
    Lcd_Init();

    Lcd_EnvidOnOff(1);		//turn on vedio

	Lcd_ClearScr(0xffff);		//fill all screen with some color
/*	Glib_FilledRectangle( 12, 12, 308, 228,0x0000);		//fill a Rectangle with some color

	Glib_FilledRectangle( 24, 24,296, 88,0x001f);		//fill a Rectangle with some color
	Glib_FilledRectangle( 24, 89,296,152,0x07e0);		//fill a Rectangle with some color
	Glib_FilledRectangle( 24,153,296,216,0xf800);		//fill a Rectangle with some color

	Glib_FilledRectangle( 110, 70, 210, 170,0xf7e0);		//fill a Rectangle with some color
	Glib_FilledRectangle( 130, 90, 190, 150,0x07ff);		//fill a Rectangle with some color
	Glib_FilledRectangle( 150,110, 170, 130,0xf81f);		//fill a Rectangle with some color
*/
	#ifdef DEBUG
    	Uart_Printf( "\nrGPBCON=0x%x\n", rGPBCON );
    	Uart_Printf( "\trGPBUP=0x%x\n", rGPBUP );
    	Uart_Printf( "rGPCCON=0x%x\n", rGPCCON );
    	Uart_Printf( "\trGPCUP=0x%x\n", rGPCUP );
    	Uart_Printf( "rGPDCON=0x%x\n", rGPDCON );
    	Uart_Printf( "\trGPDUP=0x%x\n", rGPDUP );
    	Uart_Printf( "rGPGCON=0x%x\n", rGPGCON );
    	Uart_Printf( "\trGPGUP=0x%x\n\n", rGPGUP );

    	Uart_Printf( "rLCDCON1=0x%x\n", rLCDCON1 );
    	Uart_Printf( "rLCDCON2=0x%x\n", rLCDCON2 );
    	Uart_Printf( "rLCDCON3=0x%x\n", rLCDCON3 );
    	Uart_Printf( "rLCDCON4=0x%x\n", rLCDCON4 );
    	Uart_Printf( "rLCDCON5=0x%x\n\n", rLCDCON5 );

    	Uart_Printf( "rLCDSADDR1=0x%x\n", rLCDSADDR1 );
    	Uart_Printf( "rLCDSADDR2=0x%x\n", rLCDSADDR2 );
    	Uart_Printf( "rLCDSADDR3=0x%x\n\n", rLCDSADDR3 );
    	
    	Uart_Printf( "rLCDINTMSK=0x%x\n", rLCDINTMSK );
    	Uart_Printf( "rLPCSEL=0x%x\n", rLPCSEL );
    	Uart_Printf( "rTPAL=0x%x\n\n", rTPAL );
	#endif	

//	Glib_FilledRectangle( 0, 0,320, 40,0xffff);		//fill a Rectangle with some color

//Lcd_ClearScr(0x3f);
    Paint_Bmp( 0, 0, 320, 240, test1 );		//paint a bmp
    Paint_Bmp( 0, 80, 320, 240, test2 );		//paint a bmp
    Paint_Bmp( 0, 160, 320, 240, test3 );		//paint a bmp

//    Paint_Bmp( 0, 0, 320, 240, LOGO );		//paint a bmp
//Delay(20000);
//    Paint_Bmp( 0, 0, 320, 240, flower1_320_240 );		//paint a bmp
//Delay(20000);
//    Paint_Bmp( 0, 0, 320, 240, girl10 );		//paint a bmp
//Delay(20000);
//    Paint_Bmp( 0, 0, 320, 240, landscape2 );		//paint a bmp
//Delay(20000);
//    Paint_Bmp( 0, 0, 320, 240, sky );		//paint a bmp
//	Glib_FilledRectangle( 0, 200,320, 240,0xffff);		//fill a Rectangle with some color



}
//*************************************************************

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线一区二区| 成人91在线观看| 国产精品福利影院| 欧美精品一二三| 北条麻妃国产九九精品视频| 三级成人在线视频| 亚洲欧洲成人av每日更新| 欧美成人精品1314www| 一本到不卡精品视频在线观看| 黑人巨大精品欧美一区| 亚洲国产精品天堂| 亚洲视频一区二区免费在线观看| 日韩欧美在线1卡| 欧美日韩另类国产亚洲欧美一级| 成人午夜在线播放| 国产美女一区二区| 麻豆91免费观看| 日韩中文字幕麻豆| 亚洲无线码一区二区三区| ●精品国产综合乱码久久久久| 久久综合狠狠综合| 日韩精品中文字幕一区二区三区| 欧美亚洲国产bt| 日本韩国欧美一区| 91首页免费视频| 成人激情av网| 顶级嫩模精品视频在线看| 国产一区福利在线| 国产自产2019最新不卡| 久草中文综合在线| 九一久久久久久| 美女视频黄 久久| 蜜臀国产一区二区三区在线播放| 丝袜美腿高跟呻吟高潮一区| 一区二区成人在线视频 | 自拍偷拍国产精品| 国产日产欧产精品推荐色| 久久综合中文字幕| 久久日一线二线三线suv| 精品免费国产二区三区| 欧美大黄免费观看| 精品国产一区二区亚洲人成毛片| 日韩欧美高清dvd碟片| 日韩精品最新网址| 欧美精品一区二区三区视频| 日韩精品一区二区三区中文精品| 精品国产三级a在线观看| 精品国产污污免费网站入口 | 91精品中文字幕一区二区三区 | 国产精品电影院| 中文字幕一区三区| 亚洲男帅同性gay1069| 亚洲精品欧美专区| 日韩福利视频网| 久久丁香综合五月国产三级网站| 精品在线免费视频| 国产91高潮流白浆在线麻豆| 成人精品视频.| 在线看国产日韩| 91麻豆精品久久久久蜜臀| 欧美v日韩v国产v| 中文字幕av一区二区三区免费看| 中文字幕在线不卡一区二区三区| 亚洲黄色免费电影| 日韩高清不卡一区| 成人免费的视频| 欧美专区亚洲专区| 精品久久国产字幕高潮| 中文字幕一区三区| 日韩精品免费视频人成| 国产一区二区精品久久91| 972aa.com艺术欧美| 这里只有精品免费| 国产女同性恋一区二区| 一区二区三区四区激情| 秋霞成人午夜伦在线观看| 国产一区二区精品久久| 91看片淫黄大片一级在线观看| 欧美人成免费网站| 中文在线免费一区三区高中清不卡| 一区二区三区日韩| 国产露脸91国语对白| 欧美在线不卡一区| www国产精品av| 亚洲自拍另类综合| 国产伦精品一区二区三区免费迷 | 精品日韩一区二区| 亚洲品质自拍视频网站| 蜜桃精品视频在线| 97精品视频在线观看自产线路二| 91麻豆精品国产| 亚洲精选免费视频| 国产一区二区视频在线| 欧美色图12p| 国产精品免费观看视频| 日韩av一区二区三区四区| 成人av在线影院| 精品久久久久久久久久久久包黑料 | 91久久人澡人人添人人爽欧美| 欧美mv日韩mv国产网站| 一区二区三区色| 成人v精品蜜桃久久一区| 日韩一区二区免费视频| 亚洲免费观看高清完整版在线观看熊| 激情av综合网| 717成人午夜免费福利电影| 亚洲男人的天堂网| 成人黄色一级视频| 久久久国产精品不卡| 人人爽香蕉精品| 欧美日韩一级黄| 一区二区三区**美女毛片| 国产传媒一区在线| 美女脱光内衣内裤视频久久影院| 蜜乳av一区二区| 在线看国产日韩| 亚洲欧美成aⅴ人在线观看| 国产精品一区久久久久| 日韩美一区二区三区| 日韩高清国产一区在线| 欧美精品vⅰdeose4hd| 亚洲久本草在线中文字幕| 懂色av一区二区三区蜜臀| 久久精品人人做| 国产伦精品一区二区三区免费| 精品久久久久久久久久久久久久久 | 成人毛片视频在线观看| 国产婷婷色一区二区三区在线| 极品尤物av久久免费看| 精品女同一区二区| 久久精品国产99国产| 91精品国产综合久久福利| 亚洲va在线va天堂| 欧美区在线观看| 免费久久精品视频| 日韩一区二区三区视频在线观看| 日韩电影在线免费看| 91.com在线观看| 另类小说一区二区三区| 精品久久久久久综合日本欧美| 麻豆精品视频在线观看免费| 日韩欧美一区在线观看| 国产自产2019最新不卡| 国产欧美日韩视频一区二区| 成人午夜又粗又硬又大| 亚洲狼人国产精品| 777亚洲妇女| 久久国产免费看| 欧美国产精品一区二区| 99久久综合国产精品| 一区二区三区.www| 欧美二区在线观看| 激情图片小说一区| 国产精品久久久久婷婷二区次| av激情综合网| 亚洲国产视频直播| 日韩一级完整毛片| 国产精品一区二区果冻传媒| 国产精品不卡在线观看| 日本国产一区二区| 蜜芽一区二区三区| 国产精品区一区二区三区| 色综合久久久久综合99| 日韩精品欧美精品| 中文字幕 久热精品 视频在线| 色婷婷久久99综合精品jk白丝| 亚洲高清久久久| 久久久影视传媒| 色婷婷久久一区二区三区麻豆| 日韩欧美国产麻豆| 青青青爽久久午夜综合久久午夜| 精品乱人伦小说| 91丝袜美腿高跟国产极品老师 | 欧美一区二区视频免费观看| 国产真实乱对白精彩久久| 国产精品久久久久久久久图文区| 欧美色爱综合网| 国产一区在线不卡| 亚洲第一在线综合网站| 久久青草欧美一区二区三区| 在线观看日韩电影| 国产福利一区在线观看| 亚洲一区成人在线| 欧美国产综合色视频| 欧美日韩免费在线视频| 国产很黄免费观看久久| 亚洲mv在线观看| 国产欧美va欧美不卡在线| 3atv一区二区三区| 99re在线精品| 国内精品久久久久影院一蜜桃| 亚洲综合999| 国产精品视频在线看| 欧美一区二区观看视频| 91猫先生在线| 国产激情一区二区三区四区| 亚洲观看高清完整版在线观看| 欧美国产日韩亚洲一区| 日韩欧美另类在线| 欧美日韩国产综合一区二区|