按下接通,鬆開斷開。
一共四個管腳,兩對距離較遠的初始狀態是導通的,按下之後另外兩對才導通。
TXD接P3.0口,RXD接P3.1口
K1,2,3,4分別接的是P31,P30,P32,P33,另一端共地,即按鍵按下時端口會被拉低。
內部結構圖:
輸入1,則輸出1;
輸入0,則輸出0.
(例如輸入1 的時候,非門輸出0,二極管不導通,IO直接從VCC輸出1;輸入0的時候,非門輸出1,二極管導通,IO從GND輸出0)
閉合和斷開時觸電存在抖動現象。
需要軟件消抖處理或者硬件消抖電路(如下圖)
硬件消抖通過RC充放電時間來實現。(成本較高電路較複雜)
一般使用軟件消抖,延時10ms
使用獨立按鍵k1控制led1的狀態反轉,按一下反轉一下,程序如下:
#include<reg51.h>
typedef unsigned char u8;
typedef unsigned int u16;
sbit led=P2^0;//D1
sbit k1=P3^1;//K1
void delay(u16 i)
{
while(i--);
}
void key()
{
if(k1==0)
{
delay(1000);//延時10ms用於消抖
if(k1==0)
{
led=~led;//實現led的狀態反轉
while(!k1); //只有k1=1的時候即鬆開的時候退出
}
}
}
void main()
{
while(1)
{
key();
}
}
使用獨立按鍵k1控制led1反轉,按下時候滅掉,鬆開亮起,程序如下:
#include<reg51.h>
typedef unsigned char u8;
typedef unsigned int u16;
sbit led=P2^0;//D1
sbit k1=P3^1;//K1
void delay(u16 i)
{
while(i--);
}
void key()
{
if(k1==0)
{
delay(1000);//延時10ms用於消抖
if(k1==0)
{
led=~led;//實現led的狀態反轉
while(!k1);//直到鬆開,循環停止,進行後邊的程序
}
}
if(k1==1) //用於鬆開時
{
delay(1000);
if(k1==1)
{
led=~led;
while(k1);//直到閉合,循環停止,進行後邊的程序
}
}
}
void main()
{
while(1)
{
key();
}
}
使用獨立按鍵控制動態數碼管是否顯示,鬆開顯示按下熄滅:
#include<reg51.h>
typedef unsigned char u8;
typedef unsigned int u16;
sbit LSA=P2^2;
sbit LSB=P2^3;
sbit LSC=P2^4;
sbit k1=P3^1;
u8 code smgduanxuan[16]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
void delay(u16 i)
{
while(i--);
}
void saomiao()
{
u8 i;
for(i=0;i<8;i++)
{
switch(i)
{
case 0:LSA=0;LSB=0;LSC=0;break;
case 1:LSA=1;LSB=0;LSC=0;break;
case 2:LSA=0;LSB=1;LSC=0;break;
case 3:LSA=1;LSB=1;LSC=0;break;
case 4:LSA=0;LSB=0;LSC=1;break;
case 5:LSA=1;LSB=0;LSC=1;break;
case 6:LSA=0;LSB=1;LSC=1;break;
case 7:LSA=1;LSB=1;LSC=1;break;
}
P0=smgduanxuan[i];
delay(100);
P0=0x00;
}
}
void main()
{
while(1)
{
saomiao();
while(!k1);//當k1=0即按下時,循環進行,程序不往下進行,從而數碼管熄滅
}
}