【蓝桥杯】基于STM32G431模块总结

本文详细描述了一个基于STM32的嵌入式系统设计,涉及LED控制、按键检测、ADC转换、I2C通信的24C02EEPROM读写、LCD显示、定时器功能(包括PWM、占空比测量、频率计算和方波输出)、以及RTC时间日期管理。
摘要由CSDN通过智能技术生成

目录

 一.LED部分

二.按键部分 

三.ADC部分 

四.基于IIC的24c02读写部分(EEPROM)

 五.LCD显示部分

 六.定时器部分

1.定时器中断回调

2. PWM输出改变频率和占空比

3.输入捕获测量占空比和频率(利用主从模式) 

 4.方波输出回调

七.RTC部分


 一.LED部分


uint8_t ucled;

void LED_Disp(uint8_t ucLed)
{
	/***将所有的灯熄灭***/
	HAL_GPIO_WritePin(GPIOC,0xff00, GPIO_PIN_SET);
	HAL_GPIO_WritePin(GPIOD, GPIO_PIN_2, GPIO_PIN_SET);		
	HAL_GPIO_WritePin(GPIOD, GPIO_PIN_2, GPIO_PIdouN_RESET);
	/***根据ucLed的数值点亮相应的灯***/
	HAL_GPIO_WritePin(GPIOC, ucLed<<8, GPIO_PIN_RESET);
	HAL_GPIO_WritePin(GPIOD, GPIO_PIN_2, GPIO_PIN_SET);		
	HAL_GPIO_WritePin(GPIOD, GPIO_PIN_2, GPIO_PIN_RESET);		
}
/***使用 |= 和 &= 在更改指定led时不会影响到其他led***/
	if (led1_flag) 
	{ 	/***LED1常亮***/
		ucled |= 0x01;
	}
	else 
	{	/***有开就要有关,不然亮了关不掉***/
		ucled &= ~0x01;
	}
/***led以某一频率闪烁***/
	if (uwTick - ledTick < 500) return;
		ledTick = uwTick;
			if (flag) 
		{  //以某频率闪烁 (0.5s)  
			ucled ^= 0x02;
		}
		else 
		{
			ucled &= ~0x02;
		}
		
/***led亮几秒后熄灭
某种情况flag = 1 后 
cnt = 0;
***/
	if (flag) 
	{  //点亮几秒后熄灭 (5s)
		ucled |= 0x04;
	}
	else 
	{
		ucled &= ~0x04;
	}
//SysTick_Handler函数
{
	cnt++;
	if (cnt == 5000) 
	{
		flag = 0;
	}
}

/***led流水灯***/
//led处理程序
	if (led_flag) 
	{  //led流水灯 (0.2s)  5-8
		ucled |= ( 0x10 << led);
	}
	else
	{
		ucled &= ~( 0x10 << led);
	}


//SysTick_Handler函数
{
	led_cnt++;
	if (led_cnt == 200) 
	{   //0.2s
		led1_cnt = 0;
		if (led == 3) 
		{
			led = 0;
		}
		else 
		{
			led++;
		}
	}
}


void Led_Proc(void)
{
	if((uwTick -  uwTick_Led_Set_Point)<200)	return;
		uwTick_Led_Set_Point = uwTick;

	LED_Disp(ucLed);
}

二.按键部分 


uint8_t Key_Scan(void)
{
	uint8_t unKey_Val = 0;
	
	if(HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_0) == GPIO_PIN_RESET)
		unKey_Val = 1;

	if(HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_1) == GPIO_PIN_RESET)
		unKey_Val = 2;

	if(HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_2) == GPIO_PIN_RESET)
		unKey_Val = 3;
	
	if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0) == GPIO_PIN_RESET)
		unKey_Val = 4;	
	
	return unKey_Val;
}
uint8_t ucKey_Val, unKey_Down, ucKey_Up, ucKey_Old;

void Key_Proc(void)
{
	if((uwTick -  uwTick_Key_Set_Point)<50)	return;
		uwTick_Key_Set_Point = uwTick;

	ucKey_Val = Key_Scan();
	unKey_Down = ucKey_Val & (ucKey_Old ^ ucKey_Val); 
	ucKey_Up = ~ucKey_Val & (ucKey_Old ^ ucKey_Val);	
	ucKey_Old = ucKey_Val;

	switch(key_down)
	{
		case 1:
		uwTick_key_long_short = uwTick ;
	}
	if(key_up == 1)
	{
			if((uwTick -uwTick_key_long_short) > 2000)//长按
		{
			
	
		}
		else//短按
		{
	
		
		}
					
	}

}

三.ADC部分 



/***校准函数***/
HAL_ADCEx_Calibration_Start(&hadc)

double get_adc(ADC_HandleTypeDef *pin)
{
	uint32_t adc_val;
	HAL_ADC_Start(pin);
	adc_val=HAL_ADC_GetValue(pin);
	return adc_val*3.3/4096;
}


四.基于IIC的24c02读写部分(EEPROM)

/***写***/
void iic_24c02_write(uint8_t *pucBuf, uint8_t ucAddr, uint8_t ucNum)
{
	I2CStart();
	I2CSendByte(0xa0);
	I2CWaitAck();
	
	I2CSendByte(ucAddr);	
	I2CWaitAck();
	
	while(ucNum--)
	{
		I2CSendByte(*pucBuf++);
		I2CWaitAck();	
	}
	I2CStop();
	delay1(500);	
}
/***读***/
void iic_24c02_read(uint8_t *pucBuf, uint8_t ucAddr, uint8_t ucNum)
{
	I2CStart();
	I2CSendByte(0xa0);
	I2CWaitAck();
	
	I2CSendByte(ucAddr);	
	I2CWaitAck();
	
	I2CStart();
	I2CSendByte(0xa1);
	I2CWaitAck();
	
	while(ucNum--)
	{
		*pucBuf++ = I2CReceiveByte();
		if(ucNum)
			I2CSendAck();	
		else
			I2CSendNotAck();
	}
	I2CStop();	
}

 五.LCD显示部分

/***屏幕只能显示20,再加一个\0***/
uint8_t lcd_disp[21];
void Lcd_Proc(void)
{
	if((uwTick -  uwTick_Lcd_Set_Point)<100)	return;
		uwTick_Lcd_Set_Point = uwTick;
	

	sprintf((char *)Lcd_Disp_String, "TEST CODE:%02X",ucLed);
	LCD_DisplayStringLine(Line9, Lcd_Disp_String);			

}

六.串口部分

//串口部分
void Usart_Proc(void)
{
	if((uwTick -  uwTick_Usart_Set_Point)<1000)	return;
	uwTick_Usart_Set_Point = uwTick;

}
/*串口1  PA9--TX PA10--RX
Asynchronous 异步 
synchronous 同步
接收中断要先打开
*/
HAL_UART_Receive_IT(&huart1,&rxdat,1);

char rxdata[30];
uint8_t rxdat;
uint8_t  rx_pointer;
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *hurat)
{
	rxdata[rx_pointer++]=rxdat;
	HAL_UART_Receive_IT(&huart1,&rxdat,1);
}

 六.定时器部分

1.定时器中断回调


/***
定时器中断回调
要先使能中断
***/
HAL_TIM_Base_Start_IT(&htim6);
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
		if(htim->Instance==TIM6)
	{
			if(++counter == 10)
		{
			counter = 0;
			sprintf(str, "Hello,world.\r\n");
			HAL_UART_Transmit(&huart1,(unsigned char *)str, strlen(str), 50);	
		}
	}
	HAL_TIM_Base_Start_IT(&htim6);
}

2. PWM输出改变频率和占空比

/***PWM输出***/
HAL_TIM_PWM_Start(&htim3,TIM_CHANNEL_1);	//PA6
HAL_TIM_PWM_Start(&htim17,TIM_CHANNEL_1);		//PA7

/***改变频率或者占空比***/
__HAL_TIM_PRESCALER ();//设置预分频系数,定时器工作的频率
__HAL_TIM_SET_AUTORELOAD() //在运行时改变ARR的值,改变波形周期和频率
_HAL_TIM_SetCompare (&htim3,TIM_CHANNEL_1,100);//设置占空比,即CCR

3.输入捕获测量占空比和频率(利用主从模式) 

/***输入捕获测量占空比和频率***/
/***
因为f = 1000000/一个周期计数
所以f = 1000000/PWM_T_Count
duty = t/T
slave mode:  reset  触发后自动清零
trigger:channel 1 TI1FP1
trigger:channel 2 TI1FP2
要先使能捕获中断
***/
HAL_TIM_Base_Start(&htim2); 
HAL_TIM_IC_Start_IT(&htim2,TIM_CHANNEL_1);		 
HAL_TIM_IC_Start_IT(&htim2,TIM_CHANNEL_2);		
void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim)
{
	  if(htim->Instance==TIM2)
	{
			if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_1)
		{
			PWM_T_Count =  HAL_TIM_ReadCapturedValue(htim,TIM_CHANNEL_1)+1;
			PWM_Duty = (float)PWM_D_Count/PWM_T_Count;
		}
			else if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_2)
		{
			PWM_D_Count =  HAL_TIM_ReadCapturedValue(htim,TIM_CHANNEL_2)+1;
		}			
	}	
}

 4.方波输出回调

/***方波输出回调函数***/
 HAL_TIM_OC_Start_IT(&htim15,TIM_CHANNEL_1);
void HAL_TIM_OC_DelayElapsedCallback(TIM_HandleTypeDef *htim)
{
		if(htim->Instance==TIM15)
	{
			if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_1)
		{			
			 __HAL_TIM_SET_COMPARE(htim,TIM_CHANNEL_1,(__HAL_TIM_GetCounter(htim)+500));//1Khz
		}
	}
}

七.RTC部分

//RTC部分
/***
必须两个都要读取,先时间后日期
使用外部时钟分频系数为125、6000
***/

extern RTC_HandleTypeDef hrtc;

RTC_TimeTypeDef H_M_S_Time;
RTC_DateTypeDef Y_M_D_Date;

HAL_RTC_GetTime(&hrtc, &H_M_S_Time, RTC_FORMAT_BIN);
HAL_RTC_GetDate(&hrtc, &Y_M_D_Date, RTC_FORMAT_BIN);

### 回答1: 蓝桥杯是全国性的计算机大赛,旨在提高大学生的计算机技术水平和创新能力。嵌入式STM32G431是一款嵌入式芯片,具有高性能和低功耗的特点。第十二届第一场省赛停车计费系统是蓝桥杯的一道工程题目,要求参赛选手设计一个停车场计费系统。 停车计费系统是指通过嵌入式技术实现对车辆进入和离开停车场的自动检测、计时和计费的系统。对于这个题目,参赛选手可以根据题目要求,使用STM32G431芯片设计一个具有以下功能的系统: 1. 车辆进入检测:使用车辆传感器检测车辆的进入,触发计时。 2. 车辆离开检测:使用车辆传感器检测车辆的离开,停止计时。 3. 计时功能:使用内部时钟模块获取进入和离开的时间,并计算停车时间。 4. 计费功能:根据停车时间,按照一定的计费规则进行计费。 5. 显示功能:使用液晶显示屏显示当前的停车信息,如车牌号、停车时间、费用等。 6. 数据存储功能:使用闪存等储存介质将停车数据进行存储,以便后续的数据分析和查询。 设计一个停车计费系统涉及到硬件设计和软件编程两个方面。硬件方面,参赛选手需要选择合适的传感器、显示屏、存储介质等,以及设计电路和接口进行连接。软件方面,需要使用C语言或者汇编语言编写程序,对芯片进行编程,实现各项功能。 通过此次比赛,选手们可以锻炼嵌入式系统的设计能力和编程能力,了解实际应用中嵌入式系统的工作原理和应用场景。同时,也能提升对STM32G431芯片的理解和运用能力。这对于培养嵌入式技术人才,推动物联网技术的发展都具有积极意义。 ### 回答2: 蓝桥杯是面向计算机爱好者的智力竞赛,而嵌入式STM32G431是一款嵌入式系统开发板。第十二届第一场省赛的停车计费系统真题工程,则是要求参赛选手设计并实现一个能够进行停车计费的系统。 停车计费系统是一种用于自动计费和管理停车场的系统。这个系统可以通过识别车辆的进出以及停车的时间,自动计算并收费。在这个工程中,选手需要使用嵌入式STM32G431开发板以及相关的硬件和软件,来设计一个能够实现停车计费功能的系统。 首先,选手需要使用传感器或摄像头来实现车辆进出的检测。当车辆进入或离开停车场时,传感器会发出信号并通过STM32G431进行检测。接着,选手需要编程实现识别车辆的算法,以便能够识别不同的车辆。当车辆停放时,系统会通过计时器记录停车的时间。 然后,选手需要编写计费算法,根据停车的时间来计算费用。这个算法可以根据停车场的规则来确定费用的计算方式,例如按小时计费或按照不同的时间段采用不同的费率。 最后,选手还需要设计一个界面,使得系统能够与用户进行交互。用户可以通过该界面查询停车费用,并进行付款。同时,选手还需要保证系统的稳定性和安全性,确保数据的准确性和保密性。 总而言之,蓝桥杯嵌入式STM32G431第十二届第一场省赛停车计费系统真题工程要求选手使用硬件和软件开发能力,设计并实现一个完整的停车计费系统。这需要选手具备嵌入式系统开发、传感器技术、算法设计和界面设计等多方面的知识和技能。 ### 回答3: 蓝桥杯嵌入式stm32g431——第十二届第一场省赛停车计费系统真题工程是一个基于STM32G431开发板的停车计费系统设计题目。该系统的主要功能是实现停车场的车辆进入、出场的计费管理。 首先,该系统需要实现一个车辆进入检测的功能。当车辆进入停车场时,系统会通过传感器检测到车辆的到达,并记录下进入的时间。 然后,系统需要实现一个车辆出场的功能。当车辆准备离开停车场时,系统会通过传感器检测到车辆的离开,并记录下离开的时间。 接下来,系统需要计算车辆停留的时间。通过进入时间和离开时间的差值计算得出车辆停留的时长。 最后,系统需要计算停车费用。根据停车场的计费规则,根据车辆停留的时长计算出停车费用,并将费用显示在屏幕上。 在实现上述功能的过程中,需要运用STM32G431开发板的各种功能和模块,包括GPIO口、定时器、中断、串口通信等。通过编写相应的代码,实现按钮的控制、传感器检测、时间的计算以及屏幕的显示等功能。 该项目的设计需要考虑多种情况,比如车辆重复进入出场、车辆进入出场顺序错乱等,要充分考虑这些异常情况并进行相应的处理。在代码编写过程中,还需注意代码的优化和资源的合理利用,以提高系统的性能和效率。 通过完成这个项目的设计与实现,可以加深对STM32G431嵌入式系统的了解和应用,并提升嵌入式系统开发的能力。同时,也能锻炼自己的逻辑思维、问题解决能力和团队合作精神。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

放牛的守护神_

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

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

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

打赏作者

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

抵扣说明:

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

余额充值