/*按键扫描函数*/
#define key_port P1
unsigned char Keyscan(void){
unsigned char temp;
temp = key_port;
temp &=0xf0;
if(temp != 0xf0){ //检测按键是否被按下
delay_ms(5);
temp = key_port;
temp &= 0xf0;
if(temp != 0xf0){ //再次确认按键是否被按下
switch(temp){
case 0xe0:
return '1';
break;
case 0xd0:
return '2';
break;
case 0xb0:
return '3';
break;
case 0x70:
return '4';
break;
default:
break;
}
}
}
}
有四个按键,使用的是P1口高四位,
满意回复
+10
明显的BUG,
不是每个回路都有返回值
编译应该都有警告的
+5
把return改为给一个变量赋值,在最后返回变量的值比如
switch(temp){
case 0xe0:
num=1;
...
+5
好吧,我更新的有点慢,不妨贴出你的判断的函数来分析下
+5
基础问题没有搞清楚
每个回路(条件分支)都必须返回一个明确的值,
你这明显只考虑了有按键正确按下的情况返回值是正确的,没有按键按下呢,返回的其实是未 ...
+5
KEIL的switch编译有时候出现莫名奇妙的问题,试用
if()
{}
else if ()
{}
else if()
{}
else
{}
代替看看?
+5
+2
+2
没有按键,返回扫描到的初始键值,另外,建议放到定时器中,使用状态机。
+2
每个端口都有接按键的高低电平检测的话,只要检测该端口不就好了吗??
还需要用switch case吗
+2
建议用状态机写按键扫描函数