|
- ;《單片機(jī)矩陣式鍵盤接口技術(shù)及編程》
- ;鍵盤掃描程序:
- ;從以上分析得到單片機(jī)鍵盤掃描程序的流程圖如圖2所示。程序如下
- SCAN: MOV P1,#0FH ;一個(gè)端口(如P1口)就能組成4*4=16個(gè)按鈕 P1.0-P1.3設(shè)置為輸入線,行線P1.4-P.17設(shè)置為輸出線
- MOV A,P1 ; 檢測(cè)當(dāng)前是否有鍵被按下。檢測(cè)的辦法是P1.4-P1.7輸出全“0”,讀取P1.0-P1.3的狀態(tài),
- ANL A,#0FH ; 若P1.0-P1.3為全“1”,則無鍵閉合,不然有鍵閉合。
- CJNE A,#0FH,NEXT1 ; 有鍵閉合,轉(zhuǎn)移去除鍵抖動(dòng)延時(shí)
- SJMP NEXT3 ; 無鍵閉合,轉(zhuǎn)移
- NEXT1: ACALL D20MS ; 延時(shí)20毫秒去除鍵抖動(dòng)
- MOV A,#0EFH ; 若有鍵被按下,應(yīng)識(shí)別出是哪一個(gè)鍵閉合
- NEXT2: MOV R1,A
- MOV P1,A
- MOV A,P1
- ANL A,#0FH ; A里面的值和0F按位進(jìn)行與運(yùn)算!結(jié)果保存到A
- CJNE A,#0FH,KCODE ; 意思就是 2個(gè)數(shù)相比較 不 相等 則跳轉(zhuǎn)
- MOV A,R1
- SETB C ; 使CY=1 (進(jìn)位標(biāo)志置位指令) 把寄存器C置為1
- RLC A ; 即將A的內(nèi)容左移一位,將進(jìn)位位C中的值移到累加器A的最低位,A的最高位移到C里。 #0DFH #0BFH #07FH
- JC NEXT2 ; 如果進(jìn)位C位為1 ,轉(zhuǎn)移
- NEXT3: MOV R0,#00H ; 無效標(biāo)志值
- RET ; 返回
- KCODE: MOV B,#0FBH ;,然后可采用計(jì)算法將閉合鍵的行值和列值轉(zhuǎn)換成所定義的鍵值
- NEXT4: RRC A ;指令就是帶進(jìn)位累加器循環(huán)右移 A的最低位移給C,并且C原來的值移給A的最高位。
- INC B
- JC NEXT4
- MOV A,R1
- SWAP A ;這條指令,將累加器A的高、低4位數(shù)據(jù)交換,也就是低4位數(shù)據(jù)進(jìn)入高4位,高4位數(shù)據(jù)進(jìn)入低4位。
- NEXT5: RRC A
- INC B
- INC B
- INC B
- INC B
- JC NEXT5
- NEXT6: MOV A,P1 ; 為了保證鍵每閉合一次CPU 僅作一次處理,必須卻除鍵釋放時(shí)的抖動(dòng)。
- ANL A,#0FH
- CJNE A,#0FH,NEXT6
- MOV R0,#0FFH ;有效標(biāo)志值
- RET ;返回
復(fù)制代碼 |
|