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

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

?? finalcd.h.bak

?? 薔介紹單片機的彩色液晶顯示器開發里程。手把手
?? BAK
?? 第 1 頁 / 共 2 頁
字號:
//液晶顯示基本函數
/***********************************************************************
公司名稱:  泰克通信
模 塊 名: 液晶顯示基本函數                 LCD 型號:NHC-01 
創 建 人:        輸入輸出模塊組            日期:2004-03-17
修 改 人:        輸入輸出模塊組            日期:2004-03-23 
功能描述: 1、液晶的基本讀寫操作
           2、畫點、線、矩形、圓        
其他說明: 本程序在atmag128和nhc-01上調試通過
版 本:    alpha 0.01
**********************************************************************/
#include "chardata.h"
#define ada (*(volatile unsigned char*) 0x1118)//外部存儲器地址映射,ada是讀寫地址
#define adb (*(volatile unsigned char*) 0x111a)//adb是橫坐標
#define adc (*(volatile unsigned char*) 0x1119)//adc是縱坐標


//延時函數
void delay_1ms(void);//延時一毫秒
void delay(unsigned int n);//延時n毫秒

//液晶讀寫操作函數
void write(unsigned char x ,unsigned char y, unsigned char buffer1, unsigned char buffer2, unsigned char buffer3);//液晶輸入程序
void read(unsigned char x,unsigned char y,char *b1,char *b2,char *b3);//讀取一個字節位的數據

//液晶基本的畫線、清屏等操作
void point(unsigned int x,unsigned char y,unsigned char color);// 在任意位置顯示一個點的顏色
void clrall(char color);//清屏操作
void juxing(char x1,char y1,char x2,char y2,char color);//填充矩形
void cycle(char x,char y,unsigned int rad,char color);//以(x,y)為圓心,rad為半徑,用color填充這個區域

//畫直線算法,包含了兩種特殊直線
void line(char x1,char y1,char x2,char y2,char color);//在(x1,y1)、(x2,y2)兩點間畫直線
void linex(char x1,char y1,char x2,char y2,char color);//在(x1,y1)、(x2,y2)兩點間畫直線(畫船專用直線,可以不覆蓋掉經維度線)
void xuline(char x1,char y1,char x2,char y2,char color);//在(x1,y1)、(x2,y2)兩點間畫虛線

//液晶上的漢字、字符顯示
void hz_write(char x,char y,const unsigned char *hz,char color);//將輸入的黑白格式轉換為給lcd可以識別的彩色字模,這里的X值為點的位橫作標其值為0~39
void hanzi(char x,char y,const unsigned char *hz,char color,char bs);//按照列位置顯示任意大小顏色的字符,這里的X值為點的位橫作標其值為0~39
void lettershow(char x,char y,char *hz,char color);//按照列位置顯示任意大小顏色的字符,這里的X值為點的位橫作標其值為0~39
void showchar(char x,char y,char a,char letter,char color);//在任意位置顯示a所表示的值,這里的X值為點的位橫作標其值為0~39
void showchars(char x,char y,char *a,char color);//在任意位置顯示字符串a所表示的值,這里的X值為點的位橫作標其值為0~39
void showsmallmun(char x,char y,char *a,char color);//顯示4*8的數字串,這里的X值為點的位橫作標其值為0~39
void showallhz(void);//顯示液晶上所有的漢字


/******液晶的基本輸入輸出,一次寫入或讀出橫向八個點*******/

void write (unsigned char x ,unsigned char y, unsigned char buffer1, unsigned char buffer2, unsigned char buffer3)
{ 
   
   DDRA=0xff;//a口為輸出,即向外部輸出數據
   adb=x;//向外部存儲器送橫作標地址0~39
   adc=y;//向外部存儲器送縱作標地址0~239
   ada=buffer1;//向該點陣寫入三個顏色值
   ada=buffer2;
   ada=buffer3;
}

void read(unsigned char x,unsigned char y,char *b1,char *b2,char *b3)
{
   DDRA=0x00;//a口為輸入,即讀取外部數據
   adb=x;
   adc=y;
   *b1=ada;//將該點陣的三個顏色值分別讀取出來
   *b2=ada;
   *b3=ada;
}

/**************畫任意坐標上的一個點*******************/
void point(unsigned int x,unsigned char y,unsigned char color)
{       unsigned int temp;
        char buffer1,buffer2,buffer3;
        temp=x%8;//判斷該點是屬于該字節位的第幾個點
        x=x/8;
        read((char)x,y,&buffer1,&buffer2,&buffer3);

	if(temp==0)//該字節位的第一個點,將buffer1最高三位修改為color的值
	   {  
	      buffer1 &= 0x1f;
	      buffer1 |=(color<<5);
	   }
	else if (temp==1)//該字節位的第2個點,將buffer1的3、4、5三位修改為color的值
	   {
	      buffer1 &= 0xe3;
	      buffer1 |=(color<<2);
	   }
	else if (temp==2)//該字節位的第3個點,將buffer1最低2位和buffer2的最高位修改為color的值
	   {
	      buffer1 &= 0xfc;
	      buffer1 |=(color>>1);
	      buffer2 &= 0x7f;
	      buffer2 |=(color<<7);
	   }
	else if (temp==3)//該字節位的第4個點,將buffer2的5、6、7三位修改為color的值
	   {
	      buffer2 &= 0x8f;
	      buffer2 |=(color<<4);
	   }
	else if (temp==4)//該字節位的第5個點,將buffer2的2、3、4三位修改為color的值
	   {
	      buffer2 &= 0xf1;
	      buffer2 |=(color<<1);
	   }
	else if (temp==5)//該字節位的第6個點,將buffer2最低位和buffer3的最高兩位修改為color的值
	   {
	      buffer2 &= 0xfe;
	      buffer2 |=(color>>2);
	      buffer3 &= 0x3f;
	      buffer3 |=(color<<6);
	   }
	else if (temp==6)//該字節位的第7個點,將buffer3的4、5、6三位修改為color的值
	   {
	      buffer3 &= 0xc7;
	      buffer3 |=(color<<3);
	   }
	else if (temp==7)//該字節位的第8個點,將buffer3最低三位修改為color的值
	   {
	      buffer3 &= 0xf8;
	      buffer3 |= color;
	   }
        write ((char)x,y,buffer1,buffer2,buffer3);
}



/*********************用某種顏色清屏**************/


void clrall(char color)
{
      char buffer1=0,buffer2=0,buffer3=0;
      char i,j;
      buffer1 |=(color<<5);
      buffer1 |=(color<<2);
      buffer1 |=(color>>1);
      buffer2 |=(color<<7);
      buffer2 |=(color<<4);
      buffer2 |=(color<<1);
      buffer2 |=(color>>2);
      buffer3 |=(color<<6);
      buffer3 |=(color<<3);
      buffer3 |= color;//將三個buffer的值都修改為相應顏色的值
      for(i=0;i<40;i++)
      {
      	for(j=0;j<240;j++)
      	{
      		write(i,j,buffer1,buffer2,buffer3);
      	}
      }
}

/***********************用某種顏色畫矩形***************************/
void juxing(char x1,char y1,char x2,char y2,char color)
{ 
      char buffer1=0,buffer2=0,buffer3=0;
      char i,j;
      buffer1 |=(color<<5);
      buffer1 |=(color<<2);
      buffer1 |=(color>>1);
      buffer2 |=(color<<7);
      buffer2 |=(color<<4);
      buffer2 |=(color<<1);
      buffer2 |=(color>>2);
      buffer3 |=(color<<6);
      buffer3 |=(color<<3);
      buffer3 |= color;
      for(i=x1;i<=x2;i++)
      {
      	for(j=y1;j<=y2;j++)
      	{
      		write(i,j,buffer1,buffer2,buffer3);
      	}
      }
}

/**************兩點間畫帶顏色直線*******************/
void line(char x1,char y1,char x2,char y2,char color)
{
	char x,y;
	unsigned int dx,dy;
	if(x1>x2)
	{
		x=x2;
		y=y2;
		x2=x1;
		y2=y1;
		x1=x;
		y1=y;
	}//保證(x,y)從最靠近屏幕左側開始開始。
    point(x1,y1,color);
	x=x1;
	y=y1;
	dx=x2-x1;
		if(dx==0)//直線與y軸平行
	{
		if(y1<y2)
		{
			for(;y<=y2;y++)//沿y1畫點到y2成直線
			   point(x,y,color);
		}
		else
		{
			for(;y>=y2;y--)//沿y2畫點到y1成直線
			   point(x,y,color);
	        }
	}
	else if(y1==y2)//直線與X軸平行
	{
		if(x>x1)
		{
			for(;x<=x2;x++)//沿x1畫點到x2成直線
			   point(x,y,color);
		}
		else
		{
			for(;x>=x2;x--)//沿x2畫點到x1成直線
			   point(x,y,color);
		}
	}
	else if(y1<y2)//直線與x軸夾角小于90°
	{
	    dy=y2-y1;

		while(x<=x2&&y<=y2)
		{
			point(x,y,color);
			if(dx*(y-y1)<dy*(x-x1))//保證所畫直線盡量和所求直線靠近
			    y++;
			else x++;
			
	        }
	}
	else if(y1>y2)//直線于y軸夾角大于90°
	{
	    dy=y1-y2;
		while(x<=x2&&y>=y2)
		{
			point(x,y,color);
			if(dx*(y1-y)<dy*(x-x1))//保證所畫直線盡量和所求直線靠近
			    y--;
			else x++;
			
	        }
	}
}
/******************兩點間畫虛線**********************/
void xuline(char x1,char y1,char x2,char y2,char color)
{
	char x,y;
	unsigned int dx,dy;
	if(x1>x2)
	{
		x=x2;
		y=y2;
		x2=x1;
		y2=y1;
		x1=x;
		y1=y;
	}//保證(x,y)從最靠近屏幕左側開始開始。
    point(x1,y1,color);
	x=x1;
	y=y1;
	dx=x2-x1;
		if(dx==0)//直線與y軸平行
	{
		if(y1<y2)
		{
			for(;y<=y2;y++)
			{
			   if(y%3!=0)//每畫兩點空出一點
			       point(x,y,color);
			}
		}
		else
		{
			for(;y>=y2;y--)
			{
			   if(y%3!=0)
			       point(x,y,color);
			}
	        }
	}
	else if(y1==y2)//直線與X軸平行
	{
		if(x>x1)
		{
			for(;x<=x2;x++)
			{
				if(x%3!=0)//每畫兩點空出一點
				point(x,y,color);
			}
		}
		else
		{
			for(;x>=x2;x--)
			{
				if(x%3!=0)
				point(x,y,color);
			}
		}
	}
	else if(y1<y2)//直線與x軸夾角小于90°
	{
	    dy=y2-y1;

		while(x<=x2&&y<=y2)
		{
			if(x%3!=0)
			point(x,y,color);
			if(dx*(y-y1)<dy*(x-x1))//保證所畫直線盡量和所求直線靠近
			    y++;
			else x++;
			
	        }
	}
	else if(y1>y2)//直線于y軸夾角大于90°
	{
	    dy=y1-y2;
		while(x<=x2&&y>=y2)
		{
			if(x%3!=0)
			point(x,y,color);
			if(dx*(y1-y)<dy*(x-x1))//保證所畫直線盡量和所求直線靠近
			    y--;
			else x++;
			
	        }
	}
}
/**************兩點間畫帶顏色直線,畫船專用,避免維度線被覆蓋*******************/
void linex(char x1,char y1,char x2,char y2,char color)
{
	char x,y;
	unsigned int dx,dy;
	if(x1>x2)
	{
		x=x2;
		y=y2;
		x2=x1;
		y2=y1;
		x1=x;
		y1=y;
	}//保證(x,y)從最靠近屏幕左側開始開始。
    if(y1>120)//畫的該點不在維度線上,則畫該點
	{
	 		if((y1-120)%40!=0&&x1%40!=0)
				point(x1,y1,color);
	}
	else
	{
	        if((120-y1)%40!=0&&x1%40!=0)
				point(x1,y1,color);
	}
	x=x1;
	y=y1;
	dx=x2-x1;
		if(dx==0)//直線與y軸平行
	{
		if(y1<y2)
		{
			for(;y<=y2;y++)
			{
			       if(y>120)
				   {
	 			   			if((y-120)%40!=0&&x%40!=0)
							point(x,y,color);
					}
					else
					{
	        		 		if((120-y)%40!=0&&x%40!=0)
							point(x,y,color);
					}
			}
		}
		else
		{
			for(;y>=y2;y--)
			{
			       if(y>120)
				   {
	 			   			if((y-120)%40!=0&&x%40!=0)
							point(x,y,color);
					}
					else
					{
	        		 		if((120-y)%40!=0&&x%40!=0)
							point(x,y,color);
					}
			}
	    }
	}
	else if(y1==y2)//直線與X軸平行
	{
		if(x1<x2)
		{
			for(;x<=x2;x++)
			{
			       if(y>120)
				   {
	 			   			if((y-120)%40!=0&&x%40!=0)
							point(x,y,color);
					}
					else
					{
	        		 		if((120-y)%40!=0&&x%40!=0)
							point(x,y,color);
					}
			}
		}
		else
		{
			for(;x>=x2;x--)
			{
			       if(y>120)
				   {
			       if(y>120)
				   {
	 			   			if((y-120)%40!=0&&x%40!=0)
							point(x,y,color);
					}
					else
					{
	        		 		if((120-y)%40!=0&&x%40!=0)
							point(x,y,color);
					}
					}
					else
					{
			       if(y>120)
				   {
	 			   			if((y-120)%40!=0&&x%40!=0)
							point(x,y,color);
					}
					else
					{
	        		 		if((120-y)%40!=0&&x%40!=0)
							point(x,y,color);
					}
					}
			}
		}
	}
	else if(y1<y2)//直線與x軸夾角小于90°
	{
	    dy=y2-y1;

		while(x<=x2&&y<=y2)
		{
			if(y>120)
			{
	 			   	if((y-120)%40!=0&&x%40!=0)
					point(x,y,color);
			}
			else
			{
	        		 if((120-y)%40!=0&&x%40!=0)
					point(x,y,color);
			}
			if(dx*(y-y1)<dy*(x-x1))//保證所畫直線盡量和所求直線靠近
			    y++;
			else x++;
			
	        }
	}
	else if(y1>y2)//直線于y軸夾角大于90°
	{
	    dy=y1-y2;
		while(x<=x2&&y>=y2)
		{
			if(y>120)
			{
	 			   	if((y-120)%40!=0&&x%40!=0)
					point(x,y,color);
			}
			else
			{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
51久久夜色精品国产麻豆| 色婷婷综合久久久中文字幕| av电影在线不卡| 欧美视频精品在线观看| 欧美国产综合色视频| 免费日韩伦理电影| 在线看不卡av| 中文字幕一区二区视频| 国产毛片精品视频| 日韩精品影音先锋| 肉肉av福利一精品导航| 91黄色免费版| 亚洲免费观看高清完整版在线观看| 国产精品18久久久久久久久 | 免费成人结看片| 一本久久a久久精品亚洲| 国产精品人成在线观看免费| 激情综合亚洲精品| 欧美成人在线直播| 蜜臀av一级做a爰片久久| 911精品产国品一二三产区| 亚洲一级二级在线| 欧美日韩成人综合天天影院| 午夜伦理一区二区| 欧美精品丝袜中出| 天堂在线一区二区| 678五月天丁香亚洲综合网| 亚洲成人免费视频| 中文字幕成人在线观看| 国产一区日韩二区欧美三区| 日韩精品一区二| 狠狠色丁香婷婷综合久久片| 久久人人爽爽爽人久久久| 国产亚洲欧美日韩在线一区| 极品美女销魂一区二区三区免费| 欧美r级电影在线观看| 精品中文字幕一区二区| 精品sm在线观看| 国产精品69毛片高清亚洲| 国产拍揄自揄精品视频麻豆| av一二三不卡影片| 一区二区欧美在线观看| 欧美日韩综合在线免费观看| 日本在线不卡视频一二三区| 精品久久久久久久久久久久久久久久久 | 色婷婷精品久久二区二区蜜臀av| 国产精品久久久久久久久免费相片 | 亚洲人成网站色在线观看| 久久er精品视频| 欧美视频一区在线| 日本在线不卡视频| 久久久av毛片精品| 91亚洲精华国产精华精华液| 一区二区三区丝袜| 精品欧美一区二区三区精品久久| 国产成人aaaa| 亚洲一区二区视频| 一区二区三区四区蜜桃| 欧美一区二区播放| av影院午夜一区| 青青草原综合久久大伊人精品优势 | 成人激情免费电影网址| 亚洲成人动漫av| 欧美激情在线免费观看| 欧美午夜电影网| 国产精品88888| 性久久久久久久久久久久| 久久先锋影音av鲁色资源网| 色噜噜久久综合| 韩国女主播一区| 91福利在线播放| 亚洲小说欧美激情另类| 久久嫩草精品久久久久| 欧美特级限制片免费在线观看| 久久精品国产久精国产爱| 亚洲区小说区图片区qvod| 日韩免费在线观看| 色老头久久综合| 国产一区二区三区黄视频| 亚洲高清不卡在线| 国产午夜精品一区二区三区视频| 欧美精品1区2区3区| 99精品一区二区三区| 国产在线看一区| 日本欧美一区二区| 亚洲精品乱码久久久久久| 中文字幕乱码一区二区免费| 欧美v日韩v国产v| 欧美日韩卡一卡二| 99精品国产热久久91蜜凸| 国产自产高清不卡| 美女爽到高潮91| 丝袜美腿一区二区三区| 伊人婷婷欧美激情| 亚洲欧美日韩一区二区| 日产国产高清一区二区三区| 国产精品国产三级国产a | 精品一区二区三区免费播放| 亚洲曰韩产成在线| 亚洲精品你懂的| 亚洲天堂av一区| 亚洲视频中文字幕| 国产精品乱码久久久久久| 国产欧美日韩中文久久| 久久精品欧美一区二区三区不卡 | 国产欧美日韩三区| 26uuu国产一区二区三区| 日韩欧美一区二区在线视频| 欧美精品久久久久久久久老牛影院| 色国产综合视频| 日本韩国欧美国产| 欧美性受xxxx| 91精品蜜臀在线一区尤物| 3d动漫精品啪啪一区二区竹菊| 日本一区二区电影| 这里只有精品99re| 在线成人午夜影院| 91精品国产一区二区三区| 日韩一二三区视频| 日韩女优电影在线观看| 欧美大片国产精品| 久久蜜桃av一区精品变态类天堂| 国产欧美一区二区在线| 中文字幕一区二区三区av| 一区二区三区四区在线免费观看| 亚洲制服欧美中文字幕中文字幕| 亚洲国产人成综合网站| 日本一道高清亚洲日美韩| 久久99久久久久| 成人性生交大片免费看在线播放| 91原创在线视频| 欧美精品三级在线观看| 欧美成人三级电影在线| 国产精品午夜在线| 亚洲夂夂婷婷色拍ww47 | 欧美不卡激情三级在线观看| 久久久久久久免费视频了| 亚洲色大成网站www久久九九| 亚洲成a人v欧美综合天堂下载 | 日韩欧美电影在线| 日韩欧美国产一区二区三区 | 成人激情开心网| 欧美午夜一区二区三区免费大片| 91精品国产一区二区三区香蕉| 久久蜜桃av一区二区天堂| 亚洲欧美综合在线精品| 免费观看久久久4p| 99re这里只有精品6| 日韩欧美精品三级| 日韩理论片在线| 麻豆精品视频在线| 91麻豆精品秘密| 欧美精品一区二区三区四区 | 国产米奇在线777精品观看| 成人免费毛片aaaaa**| 欧美日韩免费不卡视频一区二区三区| 欧美成人猛片aaaaaaa| 亚洲天堂av老司机| 国产精品伊人色| 欧美一级在线视频| 洋洋av久久久久久久一区| 国产精品一二一区| 欧美一区二区高清| 一区二区理论电影在线观看| 高清av一区二区| 欧美一区二区精品在线| 亚洲一区二区三区四区在线免费观看| 韩国三级电影一区二区| 欧美日韩国产天堂| 亚洲免费在线观看| 成人精品一区二区三区中文字幕| 555www色欧美视频| 亚洲黄网站在线观看| 成人白浆超碰人人人人| 2020国产精品久久精品美国| 性做久久久久久| 欧美综合欧美视频| 亚洲激情欧美激情| 91在线小视频| 中文字幕一区av| 成人高清伦理免费影院在线观看| 26uuu精品一区二区| 另类小说综合欧美亚洲| 欧美精品在线观看播放| 亚洲国产综合在线| 精品视频在线视频| 亚洲一二三四区| 在线视频一区二区三| 亚洲精品欧美二区三区中文字幕| heyzo一本久久综合| 国产精品高清亚洲| www.欧美精品一二区| 亚洲欧洲韩国日本视频| av毛片久久久久**hd| 中文字幕在线不卡| 91小视频免费看| 一片黄亚洲嫩模| 欧美三级一区二区| 青娱乐精品在线视频| 欧美大片免费久久精品三p |