找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1231|回復(fù): 6
打印 上一主題 下一主題
收起左側(cè)

求指導(dǎo)編寫這個單片機(jī)鍵盤掃描程序的思路

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:1015398 發(fā)表于 2022-4-3 14:33 來自觸屏版 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
由于本論壇禁止直接求程序,禁止伸手黨,所以向大家請教一下大致的實現(xiàn)方法與思路,理清頭緒后我自己來寫程序去實現(xiàn),謝謝大家

8CAAAB06-5B84-4297-9AD6-ED6001E77F1F.png (149.23 KB, 下載次數(shù): 39)

8CAAAB06-5B84-4297-9AD6-ED6001E77F1F.png
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:401564 發(fā)表于 2022-4-4 13:02 | 只看該作者
"由于本論壇禁止直接求程序,禁止伸手黨,所以向大家請教一下大致的實現(xiàn)方法與思路,理清頭緒后我自己來寫程序去實現(xiàn)"這句話是從哪里復(fù)制來的,我怎么老是看到?
網(wǎng)上隨便找一個鍵盤掃描的教程,跟著認(rèn)真看,基本就有思路了
回復(fù)

使用道具 舉報

板凳
ID:161164 發(fā)表于 2022-4-4 16:22 | 只看該作者
那句話是admin加的

思路就是
1. 控制P14~P17輸出高電平,P10~P13輸出低電平
2. 看看P14~P17有沒有被拉低,有去3,沒有去1
3. 延時消抖,看看P14~P17有沒有被拉低,有去4,沒有去1
4. 記下哪一腳被拉低,然后控制P10~P13輸出高電平,P14~P17輸出低電平
5. 看看P10~P13有沒有被拉低,有去6,沒有去1
6. 延時消抖,看看P14~P17有沒有被拉低,有去7,沒有去1
7. 記下哪一腳被拉低,然后結(jié)合第4步的記錄,找出哪一鍵被按下


回復(fù)

使用道具 舉報

地板
ID:776619 發(fā)表于 2022-4-4 21:53 | 只看該作者
1。先低位輸出四個0,即0XF0:1111 0000.
2.有按鍵時讀它的值,比如是第一個鍵:這時讀出的數(shù)是0xE0:1110 0000.
3.馬上把低四位輸出為1.這時記住了是第一列有鍵了。即0XEF:1110 1111.
4.這時鍵還在按著,讀入它的值,這時讀得的數(shù)是0XEE:1110 1110.
5.根據(jù)這個零的組合行列可以知是第一個鍵被按下了。
6.同樣類推,第二個鍵的話最后得到的是0XED:1110 1101.
7.如此類推4X4十六個鍵就可以得出了。鍵16的值為0X77:0111 0111
反正是讀出的數(shù)兩個零在不同位得一個鍵。

回復(fù)

使用道具 舉報

5#
ID:776619 發(fā)表于 2022-4-4 21:57 | 只看該作者
第三步是把讀出的值 或運(yùn)算0X0F就行。
回復(fù)

使用道具 舉報

6#
ID:776619 發(fā)表于 2022-4-4 22:00 | 只看該作者
也就是按鍵期間讀兩次鍵值,第一次讀出的值用來低位全部為1后馬上輸出,再讀第二次才是能得到正確的鍵位。
回復(fù)

使用道具 舉報

7#
ID:624769 發(fā)表于 2022-4-4 22:03 | 只看該作者
Y_G_G 發(fā)表于 2022-4-4 13:02
"由于本論壇禁止直接求程序,禁止伸手黨,所以向大家請教一下大致的實現(xiàn)方法與思路,理清頭緒后我自己來寫程序 ...

大多 疑似直接求程序的 帖子, 會由版主 手動添加這句話。
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表