㈠ 帮我修改个51单片机机消除抖动c语言程序;
你好!在key函数内加上延时就能防止抖动,num 是按键返回的键值
㈡ 单片机 按键作为外部中断的输入,怎么使用软件防抖动c语言,谢谢。
出个偏招,一般按键时间比抖动时间长吧,你先设置为上升沿触发,中断进入后记个标志,再把中断设置为下降沿触发,这样按键松开时又触发一次,再记个标志。然后又设置上升沿。完成一次按键捕获
㈢ 问一个关于单片机按键延时防抖方面的问题,使用软件防抖(汇编、C语言均可)!
设置个短延时,来防抖动就可以了。
如if(a==1)
{
delay(5);
if(a==1)
{b}
}
㈣ c语言按键抖动问题
第一,中断函数里面不能喂狗,本来看门狗也是一个高级别的中断,比定时器的优先级高,自然你的中断时间就不对了。
第二,你的是飞思卡尔的单片机吧,貌似单片机的IO口有数据方向寄存器,先要把按键的端口设置为输入,如果没有的话,默认引脚都会是高电平,所以你说检测松开能检测到,其实是端口一直是高电平。
只能帮你这么多,我没用过你这款单片机,猜一下是128不?另外按键去抖动用普通的delay函数就可以,何必搞中断,中断本来就是件麻烦事,对程序运行效果影响很大。
㈤ 单片机键盘去抖动c语言程序!!!
使用这个到板子里面:
#include <reg52.h>
sbit ADDR0 = P1^0;
sbit ADDR1 = P1^1;
sbit ADDR2 = P1^2;
sbit ADDR3 = P1^3;
sbit ENLED = P1^4;
sbit KEY1 = P2^4;
sbit KEY2 = P2^5;
sbit KEY3 = P2^6;
sbit KEY4 = P2^7;
unsigned char code LedChar[] = { //数码管显示字符转换表0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8,0x80, 0x90, 0x88, 0x83, 0xC6, 0xA1, 0x86, 0x8E};
void delay();
void main(){
bit keybuf = 1; //按键值暂存,临时保存按键的扫描值
bit backup = 1; //按键值备份,保存前一次的扫描值
unsigned char cnt = 0; //按键计数,记录按键按下的次数
ENLED = 0; //选择数码管 DS1 进行显示
ADDR3 = 1;
ADDR2 = 0;
ADDR1 = 0;
ADDR0 = 0;
P2 = 0xF7; //P2.3 置 0,即 KeyOut1 输出低电平
P0 = LedChar[cnt]; //显示按键次数初值
while (1){
keybuf = KEY4; //把当前扫描值暂存
if (keybuf != backup){ //当前值与前次值不相等说明此时按键有动作
delay(); //延时大约 10ms
if (keybuf == KEY4){ //判断扫描值有没有发生改变,即按键抖动
if (backup == 0){ //如果前次值为 0,则说明当前是弹起动作
cnt++; //按键次数+1
//只用 1 个数码管显示,所以加到 10 就清零重新开始
if (cnt >= 10){
cnt = 0;
}
P0 = LedChar[cnt]; //计数值显示到数码管上
}
backup = keybuf; //更新备份为当前值,以备进行下次比较
}
}
}
}/* 软件延时函数,延时约 10ms */
void delay(){
unsigned int i = 1000;
while (i--);
}
㈥ C语言的按键开关防抖程序~
两个思路:
第一个是,若有按键按下,添加延迟程序,延迟过后若按键还是按下,则判断为确定按下
第二个是,若你用的硬件有中断,则用中断。中断设置为下降沿有效(低电平有效的话就是出现一次低电平就中断一次,达不到防抖效果)。
㈦ 单片机C语言代码问题 这个按键消抖是如何实现的
因为按键动作接触的时间比起芯片处理所需的时间周期多得去,而其他因素引起的抖动却没有这种特性,所以往往用多次重复或保持较长时间周期来确定是抖动还是按键动作;按键动作可能保持会有成千上万个周期。
㈧ 问一个关于C语言的问题:什么是“防抖动”
单片机里用到的?用c语言编写单片机按键程序时有去抖方法,就是检测电平后延时一小段时间再检测电平,若持续不变则按键有效。这是为按键抖动产生误差信号设计的
㈨ 谁能帮忙用c语言编写一个消抖程序
是按键消抖吗?
一般是先检测按键,然后等10到20ms后,再检测一下,输出键值。