我正在为8051编写一个程序,该程序使用2个开关执行两个不同的命令。即,当按下开关1(s1 == 1)时,它将执行动作1;而当按下开关2(s2 == 1)时,它将执行动作2。
例如,我要实现的目标是,当执行动作1时,如果按下开关2,它将中断动作1并执行动作2。相反的情况也是如此。
下面是我的程序代码。
#define seg P2
#define leds P3
sbit buzzer at P2_7_bit;
sbit s1 at P1_0_bit;
sbit s2 at P1_7_bit;
unsigned char pattern1[]={0x80,0x40,0x20,0x10,0x8,0x4,0x2,0x1};
unsigned char pattern2[]={0x1,0x2,0x4,0x8,0x10,0x20,0x40,0x80};
unsigned char pattern3[]={0x81,0xC3,0xE7,0xFF,0xE7,0xC3,0x81};
unsigned char pattern4[]={0x1,0x3,0x7,0xF,0x1F,0x3F,0x7F,0xFF};
unsigned char pattern5[]={0x99,0x66};
const int t1 = 600;
const int t2 = 150;
int j,k,pb1,pb2;
void main()
{
seg=0x0;
leds=0;
buzzer=0;
s1=s2=0;
while(1)
{
if(s1==1)
{
for(j=0; j<1; j++)
{
seg=0x06; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x6F; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x77; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x3F; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x6F; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x39; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x3F; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x3F; delay_ms(t1); seg=0x0; delay_ms(t2);
seg=0x06; delay_ms(t1); seg=0x0; delay_ms(t2);
}
}
if(s2==1)
{
seg=0x3F;
for(j=0; j<2; j++)
{
for(k=0; k<8; k++)
{
leds=pattern1[k]; delay_ms(250);
}
buzzer=1; delay_ms(2000);
buzzer=0;
}
for(j=0; j<3; j++)
{
for(k=0; k<8; k++)
{
leds=pattern2[k]; delay_ms(250);
}
buzzer=1; delay_ms(2000);
buzzer=0;
}
for(j=0; j<4; j++)
{
for(k=0; k<7; k++)
{
leds=pattern3[k]; delay_ms(250);
}
buzzer=1; delay_ms(2000);
buzzer=0;
}
for(j=0; j<5; j++)
{
for(k=0; k<8; k++)
{
leds=pattern4[k]; delay_ms(250);
}
buzzer=1; delay_ms(2000);
buzzer=0;
}
for(j=0; j<10; j++)
{
for(k=0; k<2; k++)
{
leds=pattern5[k]; delay_ms(250);
}
buzzer=1; delay_ms(2000);
buzzer=0;
}
seg=0x0;
leds=0x0;
}
}
}
答案 0 :(得分:0)
建议
每个开关都驱动相同的外部中断
当发生中断时,请重置中断标志,以便立即响应来自任一开关的另一个中断。
然后确定(通过几个GPIO输入)按下了哪个开关
另一个细节。请确保由于开关触点“颤振”而使开关输入“去抖动”,以免由于一次开关激活而不会引发多个中断。
然后启动与该开关相关的功能的执行。
除非两个函数之一退出,否则永远不要退出中断处理程序函数
当中断最终退出时,然后返回最初被中断的功能