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

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

?? lcd_320x240.c

?? 三星2440LCD測試驅動源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
	
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	//rLPCSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
}

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

/**************************************************************
320×240 16Bpp TFT LCD移動觀察窗口
**************************************************************/
static 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移動觀察窗口
**************************************************************/
static void MoveViewPort(void)
{
    int vx=0,vy=0,vd=1;

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

    while(1)
    {
    	switch(getkey())
    	{
    	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;
		}
	//printf("vx=%3d,vy=%3d\n",vx,vy);
	Lcd_MoveViewPort(vx,vy);
    }
}

/**************************************************************
320×240 16Bpp TFT LCD單個象素的顯示數據輸出
**************************************************************/
static 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全屏填充特定顏色單元或清屏
**************************************************************/
static 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
**************************************************************/
static 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屏幕上用顏色填充一個矩形
**************************************************************/
static 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屏幕上指定坐標點畫一個指定大小的圖片
**************************************************************/
static 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 ;
    	}
    }

//本圖片顯示是倒過來的,是旋轉了180度的顯示方式	
   /* for( y = l ; y > 0 ; y-- )
    {
    	for( x = h ; x > 0 ; 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 Test_Lcd_Tft_320X240( void )
{
	Uart_Printf("\nTest 320*240 TFT LCD !\n");

	Lcd_Port_Init();
	LTV350QV_Power_ON();
	Lcd_Init();
 	Lcd_EnvidOnOff(1);		//turn on vedio
	Lcd_ClearScr(0xffff);		//fill all screen with white
	
	Glib_FilledRectangle( LCD_BLANK, LCD_BLANK, ( LCD_XSIZE_TFT_320240 - LCD_BLANK ), ( LCD_YSIZE_TFT_320240 - LCD_BLANK ),0x0000);	
	Delay(100000);
	Glib_FilledRectangle( (LCD_BLANK*2), (LCD_BLANK*2 + V_BLACK*0), (C_RIGHT), (LCD_BLANK*2 + V_BLACK*1),0x001f);	
	Delay(100000);
	Glib_FilledRectangle( (LCD_BLANK*2), (LCD_BLANK*2 + V_BLACK*1), (C_RIGHT), (LCD_BLANK*2 + V_BLACK*2),0x07e0);	
	Delay(100000);
	Glib_FilledRectangle( (LCD_BLANK*2), (LCD_BLANK*2 + V_BLACK*2), (C_RIGHT), (LCD_BLANK*2 + V_BLACK*3),0xf800);	
	Delay(100000);
	Glib_FilledRectangle( (LCD_BLANK*2), (LCD_BLANK*2 + V_BLACK*3), (C_RIGHT), (LCD_BLANK*2 + V_BLACK*4),0xffe0);	
	Delay(100000);
	Glib_FilledRectangle( (LCD_BLANK*2), (LCD_BLANK*2 + V_BLACK*4), (C_RIGHT), (LCD_BLANK*2 + V_BLACK*5),0xf81f);	
	Delay(100000);
	Glib_FilledRectangle( (LCD_BLANK*2), (LCD_BLANK*2 + V_BLACK*5), (C_RIGHT), (LCD_BLANK*2 + V_BLACK*6),0x07ff);	
   	Delay(100000);
//	Lcd_ClearScr(0x00);		//fill all screen with black

    while(1)
    {
    	//Paint_Bmp( 0,0,240,320, flower_240_320) ;		//paint a bmp
        //Delay(1000);
    	
    	
    	Paint_Bmp( 0,0,320,240, flower_320_240) ;		//paint a bmp
    	Delay(1000);
    }
    
    while(1);
}
//*************************************************************

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人丝袜视频网| 日韩一区二区电影在线| 成人激情综合网站| 国产精品99久久久久久久女警 | 蜜臀久久99精品久久久画质超高清| 国产精品丝袜久久久久久app| 久久嫩草精品久久久精品一| 久久免费美女视频| 国产农村妇女精品| 国产精品久久精品日日| 亚洲色图19p| 亚洲综合精品自拍| 五月天亚洲婷婷| 日韩av一二三| 国产酒店精品激情| 福利一区在线观看| 97se亚洲国产综合自在线 | 精品国产一区二区在线观看| 欧美一区午夜视频在线观看| 欧美一级片免费看| 欧美精品一区二区在线播放 | 日日夜夜一区二区| 麻豆国产91在线播放| 国产一区二区三区日韩| 成人午夜电影久久影院| 色婷婷久久一区二区三区麻豆| 欧美专区亚洲专区| 欧美成人乱码一区二区三区| 久久精品欧美一区二区三区不卡 | 中文字幕+乱码+中文字幕一区| 亚洲色欲色欲www| 亚洲电影一级黄| 国内外精品视频| 91麻豆免费观看| 日韩一区二区中文字幕| 国产精品久久久久久久岛一牛影视 | 欧美一区二区人人喊爽| 欧美国产亚洲另类动漫| 亚洲在线视频一区| 另类小说一区二区三区| 不卡视频一二三四| 日韩一区二区影院| 亚洲人成亚洲人成在线观看图片 | 国产99精品国产| 欧美性淫爽ww久久久久无| 欧美一级xxx| 亚洲人xxxx| 免费xxxx性欧美18vr| 不卡av在线网| 欧美一区二区三区在线视频| 国产精品国产三级国产aⅴ中文| 成人精品国产一区二区4080| 在线一区二区三区做爰视频网站| 日韩一区二区在线看片| 亚洲欧美国产77777| 久久se精品一区二区| 欧洲精品视频在线观看| 久久久久国色av免费看影院| 无码av中文一区二区三区桃花岛| 国产99一区视频免费| 制服.丝袜.亚洲.中文.综合| 最新不卡av在线| 国模无码大尺度一区二区三区| 色噜噜狠狠色综合欧洲selulu| 久久久久国产精品厨房| 日韩av在线发布| 91福利小视频| 中日韩av电影| 精品一区二区三区免费| 欧美三级视频在线观看| 亚洲欧洲精品一区二区精品久久久| 久久69国产一区二区蜜臀| 欧美系列日韩一区| 18欧美亚洲精品| 国产不卡视频在线观看| 日韩免费视频一区二区| 调教+趴+乳夹+国产+精品| 色综合久久久久网| 亚洲欧洲av在线| 国产成人精品aa毛片| 精品久久久久久久久久久久久久久久久 | 精品国产一区二区三区忘忧草| 亚洲资源中文字幕| 一本大道久久a久久综合婷婷| 国产欧美视频在线观看| 国产又黄又大久久| 日韩小视频在线观看专区| 午夜精品在线视频一区| 在线视频一区二区三| 一区二区三区在线免费播放| 99久久精品国产麻豆演员表| 国产精品网站在线| 国产xxx精品视频大全| 久久久久久久久久久久电影| 久久99久久精品| 日韩精品一区国产麻豆| 日本aⅴ亚洲精品中文乱码| 欧美日韩视频专区在线播放| 亚洲一区二区三区四区在线免费观看| 成人福利视频网站| 国产精品美女久久久久久久久| 国产精品888| 中文字幕乱码一区二区免费| 成人美女视频在线观看18| 国产精品国产a| 99久久精品国产一区二区三区 | 另类小说图片综合网| 欧美电影免费观看完整版| 蜜臀国产一区二区三区在线播放| 欧美一区二区三区日韩| 蜜臀久久99精品久久久久宅男 | 精品国产乱码久久久久久浪潮| 美女网站在线免费欧美精品| 欧美一级精品大片| 精品亚洲porn| 国产日产欧产精品推荐色| 成人高清免费在线播放| 亚洲乱码国产乱码精品精98午夜| 色婷婷一区二区三区四区| 香蕉成人伊视频在线观看| 日韩欧美你懂的| 国产91精品一区二区麻豆亚洲| 中文字幕在线不卡视频| 在线观看www91| 免费看日韩a级影片| 精品88久久久久88久久久| 成人一区二区三区中文字幕| 一区二区三区不卡视频| 欧美精品日韩一本| 久久99久久精品| 中文字幕亚洲综合久久菠萝蜜| 欧美日韩国产综合一区二区三区| 免费精品视频在线| 国产欧美一区视频| 色乱码一区二区三区88| 免费观看在线色综合| 国产片一区二区三区| 欧美自拍丝袜亚洲| 激情小说亚洲一区| 日韩美女视频一区| 欧美一区三区二区| www.一区二区| 日韩高清中文字幕一区| 国产亚洲一区二区三区四区| 色婷婷精品久久二区二区蜜臀av| 日韩影院精彩在线| 中文字幕电影一区| 666欧美在线视频| 懂色av一区二区三区蜜臀 | 在线看一区二区| 久久国产麻豆精品| 亚洲欧美日韩系列| 欧美xxxxx裸体时装秀| 91视视频在线观看入口直接观看www | 在线成人小视频| 成人午夜av电影| 日本亚洲电影天堂| 亚洲免费av在线| 久久久久一区二区三区四区| 欧美日韩国产中文| 不卡av在线免费观看| 久久精品72免费观看| 一区二区三区精品久久久| 欧美精品一区男女天堂| 欧美久久高跟鞋激| www.欧美精品一二区| 麻豆精品视频在线| 亚洲电影中文字幕在线观看| 中文成人av在线| 精品乱码亚洲一区二区不卡| 欧美精品在线观看播放| av中文字幕亚洲| 国产福利一区二区| 青青草一区二区三区| 亚洲综合色网站| 国产精品国产三级国产普通话蜜臀| 日韩美女一区二区三区四区| 91福利精品视频| 波多野结衣在线aⅴ中文字幕不卡| 久久精品999| 日韩精彩视频在线观看| 一区二区三区免费看视频| 国产精品久久久久一区二区三区 | 日本成人在线不卡视频| 亚洲午夜精品久久久久久久久| 综合久久久久久| 国产精品视频一二| 久久久久久久久久久久久久久99 | 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 一区二区三区在线观看动漫| 中文字幕不卡在线观看| 2021中文字幕一区亚洲| 精品久久一区二区| 日韩欧美卡一卡二| 日韩视频中午一区| 日韩免费一区二区| 日韩精品一区二区三区视频播放 | 久久精品综合网| 久久欧美中文字幕| 久久婷婷久久一区二区三区|