一个按键控制LED闪烁与关闭(外部中断)

来源:

单片机简单程序_zhjysx的博客-CSDN博客https://blog.csdn.net/zhjysx/category_11558658.html

目录

作用:

思路:

仿真原理图

头文件

延时函数

外部中断开启程序

主函数

外部中断函数


作用:

用一个开关切换LED闪烁模式以及关闭。

思路:

设置一个初始值为1的变量count,只有当count=1时,LED才会闪烁,当按键按下,即触发外部中断,count=~count,LED熄灭。


仿真原理图


头文件

#include <STC8.H>
#include <intrins.h>
sbit LED=P1^0;
char count=1;

延时函数

void Delay1000ms()		//@11.0592MHz
{
	unsigned char i, j, k;

	_nop_();
	i = 8;
	j = 1;
	k = 243;
	do
	{
		do
		{
			while (--k);
		} while (--j);
	} while (--i);
}

外部中断开启程序

void open_out(){
    EA=1;//打开中断总开关
	EX0=1;//打开外部中断INT0
	IT0=1;//下降沿触发
}

打开EA总开关,打开外部中断INT0,设置为下降沿触发

注意:IT0=0为低电平触发模式,设置此模式,按下按键时可能会导致多次触发


主函数

void main(){
	open_out();
	while(1){
		if(count==1){
			LED=~LED;
            Delay1000ms();
		}
		else{
		  LED=1;//当count不为1时,LED熄灭。count的状态由外部中断改变
		}
	} 
}

在主函数中声明外部中断开启函数,设置变量count=1时,LED闪烁,当count不是1时,LED熄灭。count的值将在外部中断中改变。


外部中断函数

void timer() interrupt 0{
  count=~count;
}

按键按下,即触发外部中断,变量count=~count。


仿真:ff外部中断控制LED闪烁.zip-嵌入式文档类资源-CSDN文库https://download.csdn.net/download/zhjysx/73126187

  • 7
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,这是一个常见的嵌入式系统应用场景,可以按照以下步骤实现: 1. 配置定时器 首先,需要配置一个定时器,可以选择TIM2,TIM3等定时器。在初始化定时器时,需要设置定时器的预分频系数,以及计数器的自动重载值和工作模式等参数。例如,设置TIM2为1ms的定时器: ```c RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; TIM_TimeBaseStructure.TIM_Prescaler = 72 - 1; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseStructure.TIM_Period = 1000 - 1; TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_Cmd(TIM2, ENABLE); ``` 2. 配置按键中断 接着,需要配置一个外部中断,以便按键按下时可以触发中断,并执行相应的操作。在初始化外部中断时,需要设置中断触发方式(上升沿/下降沿/双边沿触发)、中断优先级、以及使能中断等参数。例如,配置PA0引脚上的按键为下降沿触发中断: ```c GPIO_InitTypeDef GPIO_InitStructure; EXTI_InitTypeDef EXTI_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_DOWN; GPIO_Init(GPIOA, &GPIO_InitStructure); SYSCFG_EXTILineConfig(EXTI_PortSourceGPIOA, EXTI_PinSource0); EXTI_InitStructure.EXTI_Line = EXTI_Line0; EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt; EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising_Falling; EXTI_InitStructure.EXTI_LineCmd = ENABLE; EXTI_Init(&EXTI_InitStructure); NVIC_InitStructure.NVIC_IRQChannel = EXTI0_1_IRQn; NVIC_InitStructure.NVIC_IRQChannelPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); ``` 3. 实现中断服务函数 当按键被按下时,会触发中断服务函数,可以在中断服务函数中执行相应的操作。例如,每次按键按下时,LED闪烁一次: ```c void EXTI0_1_IRQHandler(void) { if (EXTI_GetITStatus(EXTI_Line0) != RESET) { LED_Toggle(); EXTI_ClearITPendingBit(EXTI_Line0); } } ``` 4. 控制LED闪烁 最后,可以在定时器的中断服务函数中控制LED闪烁。例如,每100ms改变一次LED的状态: ```c void TIM2_IRQHandler(void) { if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { LED_Toggle(); TIM_ClearITPendingBit(TIM2, TIM_IT_Update); } } ``` 这样,当按键按下时,LED闪烁一次,而定时器中断服务函数会每100ms改变一次LED的状态,从而实现LED闪烁

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

㉨㉨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值