
{
unsigned char a,b
// for(c=1c>0c--)//这里错了,c是局衫咐传递参数,不能这样用作循环变量桐纯。
while(c--)//这样改塌或就可以了。
for(b=38b>0b--)
for(a=130a>0a--)
}
独立按键式直接用I/O口线构成的单个按键电路,其特点式每个按键单独占用一根I/O口线,每个按键的工作不会影响其他I/O口线的状态。独立式按键电路配置灵活,软件结构简单,但每个按键必须占用一个I/O口线,因此,在按键较多时陪型,I/O口线浪费较大,不宜采用。
独立按键的软件常采用查询式结构。先逐位查询没跟I/O口线的输入状态,如某一根I/O口线输入为低电平,则可确认该I/O口线所对应的按键已按下,然后,再转向该键的功能处理程序。
独立键盘理想的波形是中判按下去时保持低电平,实际上在上升沿和下降沿的过程中(即按键和离键时的一段微小时间)会出现抖动。消抖的方法有两种,一种是通过硬件:在电路上连个电容;另一种是软件消抖,根据经验增加10ms的延时。
扩展资料:
按键分卖乱改类与输入原理:
按键按照结构原理科分为两类,一类是触点式开关按键,如机械式开关、导电橡胶式开关灯另一类是无触点式开关按键,如电气式按键,磁感应按键等。前者造价低,后者寿命长。目前,微机系统中最常见的是触点式开关按键。
在单片机应用系统中,除了复位按键有专门的复位电路及专一的复位功能外,其他按键都是以开关状态来设置控制功能或输入数据的。当所设置的功能键或数字键按下时,计算机应用系统应完成该按键所设定的功能,键信息输入时与软件结构密切相关的过程。
对于一组键或一个键盘,总有一个接口电路与CPU相连。CPU可以采用查询或中断方式了解有无将按键输入,并检查是哪一个按键按下,将该键号送人累加器,然后通过跳转指令转入执行该键的功能程序,执行完成后再返回主程序。
此程序实现独立孙芹按键的检测功能,每次按下按键 key5 时,数码管最后一位显示的数 值加 1,按键同时响蜂鸣器 #include<reg52.h>sbit key5 = P1^4//独立按键 sbit P3_6 = P3^6//蜂鸣器控制端口 unsigned char code BitSet[8] = { 0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf, 0xbf, 0x7f }//用于设置(低电平位选)数码管的位选信号,从低到高对应 8 个数码管 unsigned char code NumberCode[16] = { 0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71, }//用于设置碧凯含(共阴极)数码管的段选信号,从 0~f 共 16 个数值 void delay_ms(unsigned int n) { //软件延时函数,延时 n 毫秒 unsigned int i, jfor(i=ni>0i--) for(j=110j>0j--)} void beep(int n) { int i = nwhile(i>0) { P3_6 = 1delay_ms(1)P3_6 = 0delay_ms(1)i--} } void main() //喇叭连续响 n 毫秒 //向喇叭输入 1000HZ 的方波震荡源 //0.5 毫秒高电平 //0.5 毫秒低电平 { int num=0while(1) { P2=BitSet[7]//选择最低位的数码管 if(key5==0) //判断按键 key5 是否按下 { delay_ms(10)//延时重新判断按键是否按下,延时消除抖动 if(key5==0) { num++//每按下一次显示的数值加 1 beep(200)//喇叭响 200 毫秒 if(num==16) num=0while(!key5)//直到按键释放,悔笑按下时 key5==0,持续循环 } } P0=~NumberCode[num]} } // 2、 此程序实现独立按键的检测功能,key5 和 key6 每次按下按键时,数码管次低位和最 低位显示的数值加 1,按键同时响蜂鸣器 #include<reg52.h>sbit key5 = P1^4sbit key6 = P1^5sbit P3_6 = P3^6unsigned char code BitSet[8] = { 0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf, 0xbf, 0x7f }//用于设置(低电平位选)数码管的位选信号,从低到高对应 8 个数码管 unsigned char code NumberCode[16] = { 0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71, }//用于设置(共阴极)数码管的段选信号,从 0~f 共 16 个数值 void delay_ms(unsigned int n) { //软件延时函数,延时 n 毫秒 unsigned int i, jfor(i=ni>0i--) for(j=110j>0j--)} void beep(int n) { int i = nwhile(i>0) { P3_6 = 1delay_ms(1)P3_6 = 0delay_ms(1)i--} } void main() { int num=0, num2=0while(1) { P2=BitSet[6]//喇叭连续响 n 毫秒 //向喇叭输入 1000HZ 的方波震荡源 //0.5 毫秒高电平 //0.5 毫秒低电平 //选择最低位的数码管 if(key5==0) //判断按键 key5 是否按下 { delay_ms(10)//延时重新判断按键是否按下,延时消除抖动 if(key5==0) { num++//每按下一次显示的数值加 1 beep(100)//喇叭响 100 毫秒 if(num==16) num=0while(!key5) { P2=BitSet[6]//选择次低位的数码管 P0=~NumberCode[num]delay_ms(3)P2=0xff}} } P2=BitSet[7]//选择最低位的数码管 P0=~NumberCode[num2]delay_ms(3)P2=0xff//直到按键释放,按下时 key5==0,持续循环 P0=~NumberCode[num]delay欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)