一、输入/输出端口GPIO编程一—(02)、操控LCD1602显现~~废话不多说了~~直接上图~~然后是程序~~MDK1_2.c//——————————————————————————//这个当然是主函数了#i
一—(02)、操控LCD1602显现~~
然后是程序~~
MDK1_2.c
//——————————————————————————
//这个当然是主函数了
#include“lpc210x.h”
#include“macroandconst.h”
#include“delay.h”
#include“lcdinit.h”
//——————————————————————————
//很让人蛋疼~~这儿形似不能加上const~~
//怎么会呈现这种状况呢~~等下次遇到了再处理~~
uchar TItle0[]=“Designed by ”;
uchar TItle1[]=“_JusTIn”;
//——————————————————————————
//端口初始化函数
void port_init()
{
PINSEL0=0X00000000;//一切引脚衔接至GPIO
PINSEL1=0X00000000;
IODIR=0X000007FF;//设置为输出~~当然,假如你要读LCD1602里面的数据~~那就有输出有输入呗~~
//自己再改动吧~~
}
int main()
{
port_init();
lcd_init();
lcd_display_string(0,0,TItle0,12);
lcd_display_string(1,7,title1,7);
while(1);
}
LcdInit.c
//——————————————————————————
//LCD初始化函数~~For ARM
//这儿也包含了LCD的显现函数
#include“lpc210x.h”
#include“macroandconst.h”
#include“delay.h”
#include“bit.h”
//——————————————————————————
//RS、RW、EN引脚凹凸电平的界说
//这儿不一定非要这么写,我也是因为曾经用过ATMEGA16,这样写方便了许多,可是这儿因为IOSET、IOCLR的寄存器写1有用,写0无效
//所以底子不必忧虑~~所以也是能够直接赋值的~~
//还有,这儿有个很重要的问题便是! SET_BIT() 不管是把引脚拉高或许置低,都要用到
//你懂得~~只要在IOSET、IOCLR寄存器写1才干到达置1和清零的效果
#define lcd_rs_1 SET_BIT(IOSET,8)//数据指令挑选
#define lcd_rs_0 SET_BIT(IOCLR,8)
#define lcd_rw_1 SET_BIT(IOSET,9)//读写指令挑选
#define lcd_rw_0 SET_BIT(IOCLR,9)
#define lcd_en_1 SET_BIT(IOSET,10)//使能信号
#define lcd_en_0 SET_BIT(IOCLR,10)
//——————————————————————————
#define busy(1《《7)//忙检测
//——————————————————————————
//忙检测函数
void lcd_check_busy()
{
IOCLR=0xff;//把数据口都拉低
IODIR=0x700;//这儿设置RS、RW、E为输出口,数据口为输进口
lcd_rs_0;
lcd_rw_1;
while(IOPIN&busy) //IOPIN反映了外部环境对器材的影响,也便是检测PB7是否为0。假如为0则中止while循环~~
{
lcd_en_0;
delay_1ms();
lcd_en_1;
delay_1ms();
}
lcd_en_0;
IODIR=0x7ff;//设置RS、RW、E和数据口都为输出口
}
//——————————————————————————
//LCD写数据函数
void lcd_write_data(uchar dat)
{
lcd_check_busy();
lcd_rs_1;
lcd_rw_0;
IOCLR=0xff;//先要清零
IOSET=dat;//再送数据
lcd_en_1;
delay_1ms();
lcd_en_0;
}
//——————————————————————————
//LCD写指令函数
//其间flag的效果是为0不进行忙检测,为非0则进行忙检测
void lcd_write_command(uchar com,uchar flag)
{
if(flag)
lcd_check_busy();
lcd_rs_0;
lcd_rw_0;
IOCLR=0xff;//先要清零,也便是将引脚都拉低
IOSET=com;//然后再送数据
lcd_en_1;
delay_1ms();//送一个延时
lcd_en_0;//锁存
}
//——————————————————————————
//LCD初始化函数
void lcd_init()
{
lcd_write_command(0x38,0); //8位数据传送,两行显现,5*7字形,不检测忙信号
delay_nms(5);
lcd_write_command(0x38,0);
delay_nms(5);
lcd_write_command(0x38,0);
delay_nms(5);
lcd_write_command(0x38,1);//8位数据传送,两行显现,5*7字形,检测忙信号
lcd_write_command(0x08,1);//封闭显现,检测忙信号
lcd_write_command(0x01,1);//清屏,检测忙信号delay_1ms();
lcd_write_command(0x06,1);//显现光标右移设置,检测忙信号
lcd_write_command(0x0c,1);//显现屏翻开,光标不显现,不闪耀,检测忙信号
}
//——————————————————————————
//LCD显现一个字节函数
voidlcd_display_char(uchar row,uchar add,uchar dat)
{
switch(row)
{
case 0:
lcd_write_command(0x80+add,1);
lcd_write_data(dat);
break;
//——————————————————————————
case 1:
lcd_write_command(0x80+0x40+add,1);
lcd_write_data(dat);
break;
default:
break;
}
}
//——————————————————————————
//LCD显现多个字节函数
voidlcd_display_string(uchar row,uchar add,uchar *s,uchar num)
{
uchar i;
switch(row)
{
case 0:
lcd_write_command(0x80+add,1);
for(i=0;i{
lcd_write_data(s[i]);
}
break;
//——————————————————————————
case 1:
lcd_write_command(0x80+0x40+add,1);
for(i=0;i{
lcd_write_data(s[i]);
}
break;
default:
break;
}
}
.h文件不必发了~~肯定会~~
然后便是
Delay.c
//——————————————————————————
//测验软件延时和写位运算的~~
#include“lpc210x.h”
#include“macroandconst.h”
//——————————————————————————
#define xtal 12//晶振的频率,单位MHz,是能够改动的~~
//——————————————————————————
//延时1ms函数
void delay_1ms()
{
uint32 i;
for(i=1;i《(uint32)(xtal*143-2);i++)
;
}
//——————————————————————————
//延时nms函数
void delay_nms(uint32 n)
{
uint32 i=0;
while(i{
delay_1ms();
i++;
}
}
顺便把位操作的问价发一下吧~~
感觉仍是挺有用的~~
bit.h
#ifndef__bit_h
#define__bit_h
//——————————————————————————
#include“lpc210x.h”
//——————————————————————————
#define CPL_BIT(x,y)(x^=(1《#define CLR_BIT(x,y)(x&=~(1《#define SET_BIT(x,y)(x|=(1《#define GET_BIT(x,y)(x&(1《#endif