内容对应+、-、TH/TL。
计次数识别TH/TL的长按和短按。
还需要考虑一个设定结束的考虑。
或者长时间无按键,视为设定完成。
2、显示程序:建议另一个定时中断中显示TH、TL的被设定值。
3、定时中断程序:通过IO指示灯翻转
#include <reg51.h>#include <intrins.h>
sbit SPK=P3^4 //SPK定义为P3口的第4位,就是驱动蜂鸣器的那个脚
sbit JDQ=P3^5 //JDQ定义为P3口的第5位,就是驱动继电器的那个脚
code unsigned char table[]=
{0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,
0x77,0x7c,0x39,0x5e,0x79,0x71}
//共阴数码管 0-9 a-f 表
code unsigned char key_tab[17]={0xed,0x7e,0x7d,0x7b,
0xbe,0xbd,0xbb,0xde,
0xdd,0xdb,0x77,0xb7,
0xee,0xd7,0xeb,0xe7,0XFF}//========================此数组为键盘编码,
//本人采用类式类似电话按键的编码方式,方便以后设计
// 1 2 3 a 0x01 0x02 0x03 0x0a
// 4 5 6 b 对应16进制码: 0x04 0x05 0x06 0x0b
// 7 8 9 d 0x07 0x08 0x09 0x0d
// * 0 # f 0x0c 0x00 0x0e 0x0f
//打个比方,如果你按下0键,P0口读到数据为0xed
//如果你按下2键,P0口读到数据为0x7d,按下9键为0xdb,
//我们将读到的P0口数据经过查表法就能得到相应的16进制码
//键盘的读取,我们采用分时扫描
unsigned char l_tmpdate[8]={0,0,0,0,0,0,0,0}//定义数组变量
unsigned char l_key=0x0 //定义变量,存放键值
unsigned char l_keyold=0xFF //做为按键松开否的凭证
void ReadKey(void) //扫描键盘 获取键值
void delay()//延时子函数,5个空指令
void display(unsigned char *lp,unsigned char lc)//数字的显示函数;lp为指向数组的地址,lc为显示的个数
//这个函数在第二节用过不用再说了吧!
void main(void) //入口函数
{
while(1){
ReadKey() //调用键盘扫描
display(&l_key,1) //输出显示获取的键值码
if(l_key==0x0e) //这里我们检测是否按了0x0e键,
JDQ=0 //是,我们就驱动继电器打开
if(l_key==0x0c) //检测是否按下了0x0c键,
JDQ=1 //是,我们就驱动继电器断开
}
}
void ReadKey(void) //读键盘值
{
unsigned char i,j,key
//分三个部份来理解,
//第一部份,用扫描来读取键盘,
j=0xfe
key=0xff //设定初值
for (i=0i<4i++){
P0=j //P0口低4位循环输出0,扫描键盘
//leday()
if ((P0&0xf0)!=0xf0){ //如果有键按下,P0口高4位不会全为1,
key=P0 //读取P0口,退出循环,否则循环下次
break
}
j=_crol_(j,1) //此函数功能为左循环移位
}
//第二部份,检测是否干扰或按键放开
if (key==0xff){ //如果读取不到P0口的值,比如是干扰或是键盘又松开,我们做相应复位,返回
l_keyold=0xff
SPK=1 //按键有松开,停止蜂鸣器响
return
}
else
SPK=0 //打开蜂鸣器
//第三部份,检测是新按键按下,获取新的键盘编码值
if(l_keyold!=key){ //检测按键放开否,如果一样表明没放开,不做处理,不一样表时另一个键按下做编码转换
l_keyold=key //获取键码做为放开下次的凭证
for(i=0i<17i++){ //查表获得相应的16进制值存放l_key变量中
if (key==key_tab[i]){
l_key=i
break
}
}
}
//程序运行到这里,就表明有键值被读取存放于l_key变量中,主程序就可以检测此变量做相应外理,
//此时我们回到主程序
}
void display(unsigned char *lp,unsigned char lc)//显示
{
unsigned char i //定义变量
P2=0 //端口2为输出
P1=P1&0xF8 //将P1口的前3位输出0,对应138译门输入脚,全0为第一位数码管
for(i=0i<lci++){ //循环显示
P2=table[lp[i]] //查表法得到要显示数字的数码段
delay() //延时5个空指令
if(i==7) //检测显示完8位否,完成直接退出,不让P1口再加1,否则进位影响到第四位数据
break
P2=0 //清0端口,准备显示下位
P1++ //下一位数码管
}
}
void delay(void) //空5个指令
{
_nop_()_nop_()_nop_()_nop_()_nop_()
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)