#define uint unsigned int
#define uchar unsigned char
void delay(uint z)
sbit LE=P1^4
uchar code table[]={
0xfc,0x60,0xda,0xf2,
0x66,0xb6,0xbe,0xe0,
0xfe,0xf6,0xee,0x3e,
0x9c,0x7a,0x9e,0x8e
}
void main()
{
uchar temp
uint num
while(1)
{
P2=0xfe //按键扫描第一行
temp=P2
temp=temp&0xf0
while(temp!=0xf0)
{
delay(10) //消抖
temp=P2
temp=temp&0xf0
while(temp!=0xf0) //再次确认是否有键按下
{
temp=P2
switch(temp)
{
case 0xee:num=0break
case 0xde:num=1break
case 0xbe:num=2break
case 0x7e:num=3break
}
while(temp!=0xf0) //松手检测
{
temp=P2
temp=temp&0xf0
}
delay(10) //消抖
LE=1
P0=table[num]
LE=0
P1=0x0f
}
}
P2=0xfd //按键扫描第二行
temp=P2
temp=temp&0xf0
while(temp!=0xf0)
{
delay(10)
temp=P2
temp=temp&0xf0
while(temp!=0xf0)
{
temp=P2
switch(temp)
{
case 0xed:num=4break
case 0xdd:num=5break
case 0xbd:num=6break
case 0x7d:num=7break
}
while(temp!=0xf0)
{
temp=P2
temp=temp&0xf0
}
delay(10)
LE=1
P0=table[num]
LE=0
P1=0x0f
}
}
P2=0xfb //按键扫描第三行
temp=P2
temp=temp&0xf0
while(temp!=0xf0)
{
delay(10)
temp=P2
temp=temp&0xf0
while(temp!=0xf0)
{
temp=P2
switch(temp)
{
case 0xeb:num=8break
case 0xdb:num=9break
case 0xbb:num=10break
case 0x7b:num=11break
}
while(temp!=0xf0)
{
temp=P2
temp=temp&0xf0
}
delay(10)
LE=1
P0=table[num]
LE=0
P1=0x0f
}
}
P2=0xf7 //按键扫描第四行
temp=P2
temp=temp&0xf0
while(temp!=0xf0)
{
delay(10)
temp=P2
temp=temp&0xf0
while(temp!=0xf0)
{
temp=P2
switch(temp)
{
case 0xe7:num=12break
case 0xd7:num=13break
case 0xb7:num=14break
case 0x77:num=15break
}
while(temp!=0xf0)
{
temp=P2
temp=temp&0xf0
}
delay(10)
LE=1
P0=table[num]
LE=0
P1=0x0f
}
}
}
}
void delay(uint z) //延时子函数
{
uint x
for(zz>0z--)
for(x=1000x>0x--)
}
键盘为4*4矩阵式连接,一共有16个按键。 工作原理为。P1端的低四位为列,高四位行。所先置低四位为低,高四位为高,当有按键按下时高四位就会有某位被拉低。只要判断高四位不为全高就说明有按键按下。判断有按键按下后就要判断是某位按下的,方法为,选将高四位的某一位置低。判断低四位是否有低电平出现。依次对高四位的每位置低并判断低四位出现的低电平。如高四位某位置低后低四某也有出现低电平。这样就能判断出低四位与高四位相连的位某位按键被按下了。通过定义好的编码就可以查出是某个按键被按下了,程序将按键值通过查表并发送到LED上显示。 6位LED为动态扫描方式 。先显示第一位,延时一定时间后在显示第二位依次类推。。。 共有17个按键。按下按键后数码管显示相应的数字,并左移一位。uchar kbscan(void) /*键扫描函数*/{uchar j uchar sccode,recode P2=0x0f /*发0行扫描码*/ if((P2 &0x0f)!= 0x0f) /*若有键按下*/ { dlms() if((P2&0x0f)!= 0x0f) /*逐行扫描初值*/ { sccode=0xfe for(j=4j>0j--){ while((sccode&0x10)!=0){ P2=sccode /*输出行扫描码*/ if((P2&0xf0)!=0xf0) /*本行有键按下*/ { recode=(P2&0xf0)|0x0freturn((~sccode)+(~recode)) /*返回特征字节码*/ } elsesccode=(sccode<<1)|0x01 /*行扫描码做移一位*/ } } } }return(0) /*无键按下,返回0值*/}参考链接: http://www.picavr.com/news/2008-07/6869.htm1、读键程序:读P1。内容对应+、-、TH/TL。
计次数识别TH/TL的长按和短按。
还需要考虑一个设定结束的考虑。
或者长时间无按键,视为设定完成。
2、显示程序:建议另一个定时中断中显示TH、TL的被设定值。
3、定时中断程序:通过IO指示灯翻转
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)