资料编号:140 下面是相关功能视频演示:
140-基于stm32单片机的矩阵键盘按键检测显示Proteus仿真(源码+仿真+全套资料)
功能介绍:该仿真采用stm32单片机,使用Proteus8.9版本进行仿真,采用矩阵键盘进行输入,数码管进行显示,将按键按下的数值显示到数码管上,采用了矩阵键盘扫描检测,下面是该设计的仿真截图:
下面是对程序讲解:
数码管段选:
u8 DSY_CODE[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
下面是延时函数:
void delay1ms(unsigned int n)
{
unsigned int i,j;
for(i=0;i<n;i++)
{
for(j=0;j<123;j++);
}
}
下面是该程序的主函数:
int main(void)
{
u16 KeyNum=0;
KEY_Init(); //初始化与LCD连接的硬件接口
SEG_Init();
while(GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_4)||GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_5)||GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_6)||GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_7)==0)
{
KeyNum=keyscan();
GPIO_Write(GPIOA,DSY_CODE[KeyNum%10]);
GPIO_Write(GPIOC,DSY_CODE[KeyNum/10]);
delay1ms(20);
}
}
下面是按键的初始化函数,用来初始化按键:采用switch语句进行识别判断:
void KEY_Init()
{
GPIO_InitTypeDef GPIO_InitStructer;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
GPIO_InitStructer.GPIO_Pin=GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
GPIO_InitStructer.GPIO_Mode=GPIO_Mode_IPU;
GPIO_Init(GPIOB, &GPIO_InitStructer);
GPIO_InitStructer.GPIO_Pin=GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3;
GPIO_InitStructer.GPIO_Mode=GPIO_Mode_Out_PP;
GPIO_InitStructer.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOB, &GPIO_InitStructer);
}
下面是矩阵键盘的检测函数:
u8 keyscan(void)
{
u16 temp,num;
GPIO_Write(GPIOB,0xf0);
while(1)
{
if(P5==1&& P6==1 && P7==1&& P8==1)
{
key=240;
key_up=1;
}
else if(key_up==1&&(P5==0||P6==0||P7==0||P8==0))
{
// GPIO_ResetBits(GPIOB, GPIO_Pin_0);
// GPIO_SetBits(GPIOB, GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3);
GPIO_Write(GPIOB,0xfe);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
if(temp!=0xf0)
{
delayms(2);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
switch(temp)
{
case 0xe0:num=0x00;break;
case 0xd0:num=0x01;break;
case 0xb0:num=0x02;break;
case 0x70:num=0x03;break;
default:break;
}
}
// GPIO_ResetBits(GPIOB, GPIO_Pin_1);
// GPIO_SetBits(GPIOB, GPIO_Pin_0|GPIO_Pin_2|GPIO_Pin_3);
GPIO_Write(GPIOB,0xfd);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
if(temp!=0xf0)
{
delayms(2);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
switch(temp)
{
case 0xe0:num=0x04;break;
case 0xd0:num=0x05;break;
case 0xb0:num=0x06;break;
case 0x70:num=0x07;break;
default:break;
}
}
// GPIO_ResetBits(GPIOB, GPIO_Pin_2);
// GPIO_SetBits(GPIOB, GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_3);
GPIO_Write(GPIOB,0xfb);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
if(temp!=0xf0)
{
delayms(2);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
switch(temp)
{
case 0xe0:num=0x08;break;
case 0xd0:num=0x09;break;
case 0xb0:num=0x0a;break;
case 0x70:num=0x0b;break;
default:break;
}
}
// GPIO_ResetBits(GPIOB, GPIO_Pin_3);
// GPIO_SetBits(GPIOB, GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2);
GPIO_Write(GPIOB,0xf7);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
if(temp!=0xf0)
{
delayms(2);
temp=GPIO_ReadInputData(GPIOB);
temp&=0xf0;
switch(temp)
{
case 0xe0:num=0x0c;break;
case 0xd0:num=0x0d;break;
case 0xb0:num=0x0e;break;
case 0x70:num=0x0f;break;
default:break;
}
}
return (num);
}
}
}