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

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

?? finalcd.h

?? 薔介紹單片機的彩色液晶顯示器開發里程。手把手
?? H
?? 第 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一区二区三区免费野_久草精品视频
综合欧美一区二区三区| 久久精品99久久久| 成人app软件下载大全免费| 国产欧美日韩综合精品一区二区| 精品视频一区二区不卡| 91视频91自| 99视频有精品| 99re这里只有精品首页| caoporen国产精品视频| eeuss鲁片一区二区三区在线观看| 韩国视频一区二区| 国产盗摄女厕一区二区三区| 黑人巨大精品欧美一区| 国产精品一区二区x88av| 精品综合久久久久久8888| 国产一区二区在线影院| 国产精品一区二区无线| av一二三不卡影片| 日本高清无吗v一区| 欧美日韩国产精选| 精品国产青草久久久久福利| 久久精品亚洲国产奇米99| 国产蜜臀97一区二区三区| 亚洲视频在线一区| 偷拍日韩校园综合在线| 久久成人免费电影| 成人综合激情网| 欧美最猛黑人xxxxx猛交| 这里只有精品99re| 国产亚洲欧美中文| 亚洲激情五月婷婷| 奇米影视一区二区三区| 国产精品一品二品| 欧洲一区二区av| 精品日韩99亚洲| 中文字幕免费在线观看视频一区| 亚洲综合久久久| 激情都市一区二区| 色婷婷av一区二区三区gif| 欧美一区二区三区人| 国产精品伦理一区二区| 五月天视频一区| 成人免费高清视频在线观看| 欧美日韩大陆在线| 国产精品欧美一区喷水| 日本欧美一区二区三区乱码| 国产欧美日韩一区二区三区在线观看| 亚洲欧美视频在线观看视频| 精品嫩草影院久久| 亚洲免费在线看| 亚洲天堂精品视频| 国产欧美一区二区精品婷婷 | 欧洲av在线精品| 精品国产91久久久久久久妲己| 亚洲国产精品成人综合| 性欧美疯狂xxxxbbbb| av在线综合网| 久久色.com| 免费观看30秒视频久久| 欧美性色综合网| 中文字幕av一区二区三区高| 久久se这里有精品| 911国产精品| 亚洲妇熟xx妇色黄| 欧美自拍偷拍一区| 日韩美女视频19| 精品一区二区三区视频| 欧洲av在线精品| 一区二区三区日韩精品视频| 成人免费视频国产在线观看| 亚洲精品一线二线三线| 美日韩一区二区| 欧美电影在线免费观看| 亚洲小说春色综合另类电影| 色婷婷久久久亚洲一区二区三区 | 国产精品乱子久久久久| 激情伊人五月天久久综合| 91精品国产综合久久婷婷香蕉| 亚洲成人免费视频| 欧美美女一区二区三区| 午夜激情综合网| 欧美狂野另类xxxxoooo| 天堂av在线一区| 欧美一区二区三区四区在线观看 | 国产日韩欧美精品综合| 国产精品综合一区二区| 国产女人aaa级久久久级 | 亚洲精品国产一区二区精华液 | 国产精品伦理一区二区| 国产激情偷乱视频一区二区三区 | 成人免费观看视频| 国产精品色噜噜| 国产目拍亚洲精品99久久精品 | 国产精品不卡在线| 99久久精品国产一区| 亚洲精品乱码久久久久久日本蜜臀| caoporn国产一区二区| 一区二区三区在线高清| 91麻豆精品久久久久蜜臀 | 久久噜噜亚洲综合| 成人免费毛片片v| 亚洲国产综合91精品麻豆| 欧美精品一级二级三级| 国产一区二区三区在线观看精品 | 欧美精品久久99| 激情综合色丁香一区二区| 中文字幕国产一区| 欧美性欧美巨大黑白大战| 免费不卡在线观看| 国产精品污网站| 欧美日韩一区成人| 国产精品123| 亚洲小说春色综合另类电影| 日韩欧美久久一区| 精品中文av资源站在线观看| 欧美唯美清纯偷拍| 久久综合色综合88| av福利精品导航| 欧美亚洲日本国产| 激情图片小说一区| 亚洲国产欧美另类丝袜| 久久精品一区二区三区四区| 欧美日韩综合在线| 国产精品一卡二| 日韩在线卡一卡二| 自拍偷拍国产亚洲| 欧美tk—视频vk| 欧美性视频一区二区三区| 国产精品亚洲第一| 日韩精品电影在线| 亚洲靠逼com| 国产欧美日韩综合精品一区二区| 欧美日韩视频在线一区二区| 成人av电影在线观看| 日本欧美在线看| 亚洲成年人影院| 亚洲三级在线播放| 国产欧美日韩精品在线| 欧美电视剧在线看免费| 欧美日韩一区二区三区不卡| av午夜一区麻豆| 国产麻豆视频一区| 久久电影国产免费久久电影| 亚洲成人一区在线| 亚洲综合图片区| 亚洲激情综合网| 亚洲视频网在线直播| √…a在线天堂一区| 中文字幕精品—区二区四季| 久久男人中文字幕资源站| 欧美一区二区视频免费观看| 欧美日韩国产一级片| 欧美日韩国产高清一区| 欧美色大人视频| 欧美日韩一级黄| 欧美日韩大陆一区二区| 欧美在线free| 欧美日韩精品一区二区三区| 欧洲一区二区三区免费视频| 91高清在线观看| 精品视频1区2区| 日本午夜精品视频在线观看 | 亚洲精品在线观看网站| 中文字幕乱码亚洲精品一区| 日韩一区二区三区高清免费看看 | 日韩欧美自拍偷拍| 欧美一区欧美二区| 日韩一区二区免费高清| 日韩女同互慰一区二区| 日韩精品中文字幕在线不卡尤物| 日韩一级黄色大片| 久久老女人爱爱| 亚洲日本在线观看| 亚洲精品欧美激情| 天天色综合成人网| 精品一区二区在线视频| 国产白丝网站精品污在线入口| 成人高清免费观看| 日本高清不卡视频| 日韩一区二区三免费高清| 精品国产91乱码一区二区三区 | 亚洲一卡二卡三卡四卡无卡久久| 亚洲丝袜另类动漫二区| 亚洲h动漫在线| 激情五月激情综合网| jlzzjlzz欧美大全| 欧美日韩在线三级| 精品久久国产老人久久综合| 中文字幕中文字幕中文字幕亚洲无线 | 136国产福利精品导航| 亚洲已满18点击进入久久| 麻豆精品精品国产自在97香蕉 | 一本到不卡免费一区二区| 欧美日韩三级在线| 国产欧美日韩在线视频| 丝袜美腿亚洲一区二区图片| 国产福利精品一区二区| 欧美日韩免费电影| 欧美激情在线一区二区| 日韩和欧美一区二区三区|