![]() |
發(fā)布時間: 2023-5-24 11:22
正文摘要:/******************************************************************** * 文件名 : 獨立按鍵.c * 描述 : 該程序實現(xiàn)獨立按鍵去控制 LED燈 的亮滅,并講訴了對按鍵的處理方 ... |
按鍵加減時出現(xiàn)兩次1的情況通常是由于按鍵抖動引起的。按鍵抖動是指在按下或釋放按鍵時,由于機械性質或電氣接觸不穩(wěn)定等原因,導致按鍵信號在短時間內多次切換狀態(tài)。這種抖動可能會導致單片機在檢測按鍵狀態(tài)時誤認為按鍵被按下了兩次。 為了解決按鍵抖動問題,可以在軟件中使用適當?shù)陌存I消抖算法。一種常用的按鍵消抖方法是使用軟件延時和狀態(tài)判斷的組合。 |
沒細看程序,完按鍵,記得檢測按鍵松開![]() |
188610329 發(fā)表于 2023-5-26 00:05 同意17樓意見,雖然樓主按鍵代碼寫得......,但問題核心不在于此。在于串口初始化函數(shù)被胡亂開啟中斷。眾所周知,T1作為波特率發(fā)生器就得禁止定時器1中斷。否則就可能發(fā)生不可預測的錯誤。按如下設置問題迎刃而解。 void InitUART(void) //9600bps@11.0592MHz { SCON = 0x50; //8位數(shù)據(jù),可變波特率 TMOD |= 0x20; //設置定時器模式 TL1 = 0xFD; //設置定時初始值 TH1 = 0xFD; //設置定時重載值 ET1 = 0; //禁止定時器1中斷 TR1 = 1; //定時器1開始計時 } |
sr861126 發(fā)表于 2023-5-25 08:28 你明白抖動的意思么? 按你的代碼,如果按鍵抖動,應該按一次后,連續(xù)發(fā)出 01,02 甚至還有 03 但是,你是發(fā)兩次 01, 說明,運行了兩次 SBUF = cost, 卻沒有運行兩次 cost++,所以和抖動沒有任何關系。 |
按鍵代碼需要做消抖處理 |
找個例程看看防抖怎么做吧,暫時看是防抖沒做好,或者說沒做防抖 |
A-set 發(fā)表于 2023-5-24 17:23 去掉延時是一樣de |
sr861126 發(fā)表于 2023-5-25 08:43 為什么消不掉呢 |
123456ZXC1 發(fā)表于 2023-5-24 12:29 是抖動,剛上電按下出現(xiàn)抖動,后面按就沒有抖動了 |
huaruolong 發(fā)表于 2023-5-24 18:41 沒有關系,還是抖動的問題 |
188610329 發(fā)表于 2023-5-24 22:21 別人的地方?jīng)]有--,初始時是0,按理說按一次就加1,但是按了2次才加1,后面按就正常按一次加1 |
和按鍵抖動無關, 如果抖動了, 發(fā)送前 肯定會 ++ 或者 -- 一次, 絕對有別的代碼, 所謂的 發(fā)兩次1 是要發(fā) 2 的時候被 -1 了, 看你那個 5 后面 發(fā)了個3 就知道, 肯定有個地方在 - cost |
描述與按鍵代碼不一致,你這代碼近乎長短按,短按響應一次,長按每隔0.5秒重復響應。延時消抖被注釋掉了,移放在不恰當?shù)奈恢谩?/td> |
你這程序是沒copy全,還是就是這樣, SBUF,TI,都沒看到定義。難到不會報錯。另建議key,不要用p3.2,P3.3,p3.4.因為這幾個IO有第二功能,在用這幾個io時就有可能和其他沖突,程序肯定不會報錯,但可能會有莫名奇妙的問題產(chǎn)生。 |
sr861126 發(fā)表于 2023-5-24 15:51 按鍵1消抖后里面的延時去掉看看還有沒有 |
按鍵1的消抖再判斷之后的里面的那個延時去掉看看還有沒有 |
123456ZXC1 發(fā)表于 2023-5-24 12:29 但是后面再按就沒有抖動了,只是初始時有這樣的情況 |
可能是由于按鍵的按下動作引起了按鍵的抖動 |
Powered by 單片機教程網(wǎng)