完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
这是源程序,怎么把按键按下后蜂鸣器响的程序加进去啊
/* S1 S2 S3 S4分别是123+ S5 S6 S7 S8分别是456- S9 S10 S11 S12分别是789* S13 S14 S15 S16分别是0 CLR = / */ /* 实现两个数的运算,每个数的位数至少可以八位 */ #include typedef unsigned char uint8; typedef unsigned int uint16; ***it rw=P2^5; ***it rs=P2^6; ***it e=P2^7; ***it led=P3^7; ***it been=P2^0; uint8 key,num; uint8 fuhao;//定义具体的那个符号,是加减还是乘除。 uint8 flag; //定义有没有按下符号键,这个是统称 long a,b,c,d; //定义运算数据的第一个和第二个及等于的数变量 uint8 k; //定义小数点后面显示的位数 uint8 biao; void delay1(unsigned int i) ; void beeping() { been= 0; delay1(5); been= 1; delay1(5); } void delay1(unsigned int i) { char j; for(i; i > 0; i--) for(j = 200; j > 0; j--); } uint8 dat1[]={1,2,3,0x2b-0x30, 4,5,6,0x2d-0x30, 7,8,9,0x2a-0x30, 0,0x01-0x30,0x3d-0x30,0x2b-0x30 };//保存显示的数据 void delay(uint16 i) { while(i--); } void lcdwrc(uint8 c) { delay(1000); rs=0; rw=0; e=0; P0=c; e=1; delay(1000); e=0; } void lcdwrd(uint8 dat) { delay(1000); rs=1; rw=0; e=0; P0=dat; e=1; delay(1000); e=0; rs=0; } void lcdinit() { delay(1500); lcdwrc(0x38); delay(500); lcdwrc(0x38); delay(500); lcdwrc(0x38); delay(500); lcdwrc(0x38); lcdwrc(0x08); lcdwrc(0x01); lcdwrc(0x06); lcdwrc(0x0c); key=0; num=0; flag=0; fuhao=0; a=0; b=0; c=0; d=0; biao=0; led=0; } void keyscan() { P1=0xfe; //令第一行为0,然后判断是哪一列按下 if(P1!=0xfe) { delay(1000); if(P1!=0xfe) { key=P1&0xf0; switch(key) { case 0xe0: num=0;;break; //1 case 0xd0: num=1;break; //2 case 0xb0: num=2; break; //3 case 0x70: num=3; break; //加 } } while(P1!=0xfe); if(num==0||num==1||num==2) //确认第一行的数1,2,3 { if(flag==0) //没有按下符号键 { led=1; a=a*10+dat1[num]; } else { led=0; b=b*10+dat1[num]; } } if(num==3) { led=0; flag=1; fuhao=1;//加号+ } lcdwrd(0x30+dat1[num]); } P1=0xfd; //令第二行为0,判断是哪一列按下 if(P1!=0xfd) { delay(1000); if(P1!=0xfd) { key=P1&0xf0; switch(key) { case 0xe0: num=4;break; //4 case 0xd0: num=5;break; //5 case 0xb0: num=6;break; //6 case 0x70: num=7;break; //减— } } while(P1!=0xfd); if(num==4||num==5||num==6) { if(flag==0) //没有按下符号键 { led=1; a=a*10+dat1[num]; } else { led=0; b=b*10+dat1[num]; } } else { flag=1; fuhao=2;//带表减号 } lcdwrd(0x30+dat1[num]); } P1=0xfb; //令第三行为0,判断哪一列按下 if(P1!=0xfb) { delay(1000); if(P1!=0xfb) { key=P1&0xf0; switch(key) { case 0xe0: num=8; break; //7 case 0xd0: num=9;break; //8 case 0xb0: num=10;break; //9 case 0x70: num=11;break; //乘* } } while(P1!=0xfb); if(num==8||num==9||num==10) { if(flag==0) //没有按下符号键 { led=1; a=a*10+dat1[num]; } else { led=0; b=b*10+dat1[num]; } } else { flag=1; fuhao=3;//带表乘号* } lcdwrd(0x30+dat1[num]); } P1=0xf7; //令第四行为0,判断哪一列按下 if(P1!=0xf7) { delay(1000); if(P1!=0xf7) { key=P1&0xf0; switch(key) { case 0xe0: num=12; break; //0 case 0xd0: num=13; break; //清除rst case 0xb0: num=14;break; //等号= case 0x70: num=15;break; //除/ } } while(P1!=0xf7); switch(num) { case 12: if(flag==0) //没有按下符号键 { led=1; a=a*10+dat1[num]; lcdwrd(0x30); } else { led=0; b=b*10+dat1[num]; lcdwrd(0x30); } break; case 13: lcdwrc(0x01); //清屏指令 a=0; b=0; flag=0; fuhao=0; break; case 15: flag=1; fuhao=4; lcdwrd(0x2f);//除号/ break; case 14: if(fuhao==1)//加 { lcdwrc(0x4f+0x80); lcdwrc(0x04);//设置光标左移,屏幕不移动 c=a+b; while(c!=0) //一位一位显示 { lcdwrd(0x30+c%10);//显示结果的最后一位在0x4f的位置 c=c/10;//取前面的结果数据 } lcdwrd(0x3d); //显示等于号= a=0; b=0; flag=0; fuhao=0;//全部清除为0 } if(fuhao==2) //减 { lcdwrc(0x4f+0x80); lcdwrc(0x04);//设置光标左移,屏幕不移动 if(a>b) c=a-b; else c=b-a; while(c!=0) //一位一位显示 { lcdwrd(0x30+c%10);//显示结果的最后一位在0x4f的位置 c=c/10;//取前面的结果数据 } if(a lcdwrd(0x3d); //显示等于号= a=0; b=0; flag=0; fuhao=0;//全部清除为0 } if(fuhao==3)//乘法 { lcdwrc(0x4f+0x80); lcdwrc(0x04);//设置光标左移,屏幕不移动 c=a*b; while(c!=0) //一位一位显示 { lcdwrd(0x30+c%10);//显示结果的最后一位在0x4f的位置 c=c/10;//取前面的结果数据 } lcdwrd(0x3d); //显示等于号= a=0; b=0; flag=0; fuhao=0;//全部清除为0 } if(fuhao==3)//乘法 { lcdwrc(0x4f+0x80); lcdwrc(0x04);//设置光标左移,屏幕不移动 c=a*b; while(c!=0) //一位一位显示 { lcdwrd(0x30+c%10);//显示结果的最后一位在0x4f的位置 c=c/10;//取前面的结果数据 } lcdwrd(0x3d); //显示等于号= a=0; b=0; flag=0; fuhao=0;//全部清除为0 } if(fuhao==4) { k=0; lcdwrc(0x4f+0x80); lcdwrc(0x04);//设置光标左移,屏幕不移动 c=(long)(((float)a/b)*1000);//强制转换为long。 while(c!=0) //一位一位显示 { k++; lcdwrd(0x30+c%10);//显示结果的最后一位在0x4f的位置 c=c/10;//取前面的结果数据 if(k==3) { lcdwrd(0x2e); k=0; } } if(a/b<0) //如果a比b小的话那么除的结果最高位是0 { lcdwrd(0x30); } lcdwrd(0x3d); //显示等号 a=0; b=0; flag=0; fuhao=0;//全部清除为0 } break; } } } void main() { lcdinit(); while(1) { keyscan(); } } |
|
相关推荐
28个回答
|
|
键位扫描KEYSCAN();里面有几组判断,在里面判断几列后面 else
{ led=0; b=b*10+dat1[num]; lcdwrd(0x30); } 这个部分的lcdwrd();后面 |
|
|
|
在这后面直接把蜂鸣器函数附上吗? |
|
|
|
|
|
|
|
首先要确定你的蜂鸣器程序是正确的,就是单独调用这个程序时能正确发声,之后只要把蜂鸣器程序加在按键判断为有效之后就可以了
|
|
|
|
蜂鸣器程序没有问题,现在迷糊的就在按键的判断了,不清楚应该把它放在哪 |
|
|
|
加在判断按键为有效的后面就可以了,不需要判断是什么按键,只要这次按键是有效的就可以。没仔细看你的程序,如果你不是用按键的行列值来判断按键,通常这种方法程序里只有一个地方来判断按键是否有效,而是用每一行或每一列单独判断的话,那就每一个判断按键有效的地方都要加。
|
|
|
|
按键做的太复杂了。后续程序都不好做了。这样,先判断是否有按键存在,存在就响一声。然后再计算按键位置。
这个程序是这样实现的,判断,按键端口是否为0x0f。不是就响一声并且在计算按键。否则,后面的按键值都不用计算了 |
|
|
|
在每一个按键的CASE后面加上beeping()就可以了
|
|
|
|
这样我也试过,蜂鸣器在按键按下的时候会有个通电后的短暂震动,然后就又不响了 |
|
|
|
|
|
|
|
武力戡乱 发表于 2017-3-21 23:34 改程序的话时间来不及了,我还是在那原程序上在调调吧 |
|
|
|
|
|
|
|
首先确认你要使用的是有源蜂鸣器还是无源蜂鸣器,两者的驱动程序差别很大,蜂鸣器提示音一般时长0.2~0.5秒,其驱动程序设计不好会影响其他程序运行速度,看你程序里大量使用delay长延时,运行效率本就不高,如果要在按键扫描程序里插入蜂鸣器提示音,建议把按键扫描程序分解为:按键扫描程序和按键服务程序。按键扫描程序只负责输出键值和产生蜂鸣器提示音,其他功能放在按键服务程序里。如用有源蜂鸣器只要对相应端口使能、延时、关闭即可,如用无源蜂鸣器,需要写一个输出频率2~4KHz,持续时间0.2~0.5秒的振荡程序,在按键扫描程序里加一条使能语句即可。
|
|
|
|
首先确认你要使用的是有源蜂鸣器还是无源蜂鸣器,两者的驱动程序差别很大,蜂鸣器提示音一般时长0.2~0.5秒,其驱动程序设计不好会影响其他程序运行速度,看你程序里大量使用delay长延时,运行效率本就不高,如果要在按键扫描程序里插入蜂鸣器提示音,建议把按键扫描程序分解为:按键扫描程序和按键服务程序。按键扫描程序只负责输出键值和产生蜂鸣器提示音,其他功能放在按键服务程序里。如用有源蜂鸣器只要对相应端口使能、延时、关闭即可,如用无源蜂鸣器,需要写一个输出频率2~4KHz,持续时间0.2~0.5秒的振荡程序,在按键扫描程序里加一条使能语句即可。
|
|
|
|
回复需要审核,请等待通过
|
|
|
|
给你看这个 //函数:Key_Code() //描述:计算键值 //参数:return 键值 static unsigned char Key_Code(void) { unsigned char KC_row=0; unsigned char KC_temp=0; unsigned char KC_key_temp=0; KEY_DB=0xFF; for(KC_row=0;KC_row<4;KC_row++) { KEY_DB=0xFF; KEY_DB=KEY_ROW_Scan[KC_row]; KC_temp=KEY_DB; KC_temp=KC_temp & 0x0F; if (KC_temp!=0x0F) { switch(KC_temp) { case 0x0e: KC_key_temp=0+4*KC_row; break; case 0x0d: KC_key_temp=1+4*KC_row; break; case 0x0b: KC_key_temp=2+4*KC_row; break; case 0x07: KC_key_temp=3+4*KC_row; break; } } } return(KC_key_temp); } 这个可以一步做完的。 行吧。 |
|
|
|
void beeping() { been= 0; delay1(500); been= 1; delay1(500); } 这样再试试 你的蜂鸣器延时时间太短 所以就很短一声就没了 |
|
|
|
|
|
|
|
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
685 浏览 0 评论
使用Keil建立完整的工程,并使用外部中断0触发数码管显示903
1235 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-使用AHT20进行环境监测之AHT20传感器介绍
1175 浏览 0 评论
896 浏览 0 评论
944 浏览 1 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11849 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-3 01:20 , Processed in 1.086548 second(s), Total 80, Slave 70 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号