STM32 代码块总结

F103C8T6 Template

附上f103c8t6模板(正点原子风格):点击下载
在这里插入图片描述
附上一些常用的代码块

HAL

溢出中断

PeriodElapsedCallback

**一般用来点亮运行状态指示灯**
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
  if(htim == &htim7)
  {
    static uint16_t cnt;
    cnt++;
    if(cnt>999)
    {
      cnt = 0;
      HAL_GPIO_TogglePin(D2_GPIO_Port,D2_Pin);    
    }
  }
}

按键

按键–支持一次、多次

**自行布置位置**
#define KEY0_PRES 0
#define KEY1_PRES 1

#define K0 HAL_GPIO_ReadPin(K0_GPIO_Port,K0_Pin)
#define K1 HAL_GPIO_ReadPin(K1_GPIO_Port,K1_Pin)

uint8_t KEY_Scan(uint8_t mode)//0-断按  1-长按
{
    static uint8_t key_up=1;     //按键松开标志
    if(mode==1)key_up=1;    //支持连按
    if(key_up&&(K0==0||K1==0))
    {
        HAL_Delay(10);
        key_up=0;
        if(K0==0)       return KEY0_PRES;
        else if(K1==0)  return KEY1_PRES;       
    }else if(K0==1&&K1==1)key_up=1;
    return 99;   //无按键按下
}

void Key_Proc()
{
  static uint8_t val;
  val = KEY_Scan(0);
  if(val == 0){
  printf("K0\r\n");
  }else if(val == 1){
  printf("K1\r\n");
  }
}

HAL串口

串口

main:
需要:include "string.h"
if(Fu)
 {    
   printf("%s",(char*)Rb);
   memset(Rb,0,sizeof(Rb));
   Fu=0;
   Rc=0;
}

IRQ:
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
  if(huart==&huart1)
  {
    Rb[Rc] = Tp[0];
    Rc++;
    if(0x0a == Tp[0])
    {
      Fu = 1;
    }
    HAL_UART_Receive_IT(&huart1,(uint8_t *)Tp, Tl);
  }   
}     


.h
#define Rl  			1024  	//定义最大接收字节数 200
#define Tl          1
extern uint8_t  Rb[Rl],Rc;      
extern _Bool Fu;         		//接收状态标记	
extern uint8_t Tp[Tl];         

.c
uint8_t  Rb[Rl] = {0},Rc=0;         //数据地址;最大容量
_Bool Fu=0;         		//接收状态标记;实际容量
uint8_t Tp[Tl] = {0};           //接收缓存数组
下面这句放在.c中串口的初始化函数void MX_USARTx_UART_Init(void)的用户编写区域里面:
HAL_UART_Receive_IT(&huart1, (uint8_t *)Tp, Tl);

HAL重定向

不使用micro-Lib

需要:#include "stdio.h"

#if 1
#pragma import(__use_no_semihosting)             
//标准库需要的支持函数                 
struct __FILE 
{ 
	int handle; 
}; 

FILE __stdout;       
//定义_sys_exit()以避免使用半主机模式    
void _sys_exit(int x) 
{ 
	x = x; 
} 
#endif

HAL 串口1重定向

#ifdef __GNUC__
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif
PUTCHAR_PROTOTYPE
{
	HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, 0xFFFF);//注意把&huart1改为自己的stm32使用的串口号
 
	return ch;
}

标准库串口

串口

main:
需要:include "string.h"
if(fu)
{
  fu = 0;
  //处理过程
  Rc= 0;
  memset(Rb,0,sizeof(Rb));
}

.c
char Rb[256] = {0}; 
u8 Rc = 0;
_Bool fu; 

.h
extern char Rb[256];
extern u8 Rc; 
extern _Bool fu;  
  
IRQ:
void USART1_IRQHandler(void)                	//串口1中断服务程序
{
  if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  //接收中断(接收到的数据必须是0x0d 0x0a结尾)
	{
      u8 Res;
      Res = USART_ReceiveData(USART1);	//读取接收到的数据
	  Rb[Rc] = USART_ReceiveData(USART1);
	  if(Res==0x0a)//帧尾
        {
          fu = 1;
        }
        Rc++;
     }
} 
     

Common

字符串判断

字符串判断

if(strstr(Rb,"\"Flag\":1"))//判断是否存在子字符串“Flag“:1 
else if(strstr(Rb,"\"Flag\":0"))//判断是否存在子字符串“Flag”:0
                                //内部双引号需要转义 

标准库重定向

#ifdef __GNUC__
  /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
     set to 'Yes') calls __io_putchar() */
  #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
  #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif /* __GNUC__ */
  
PUTCHAR_PROTOTYPE
{
  /* Place your implementation of fputc here */
  /* e.g. write a character to the USART */
  USART_SendData(USART2, (uint8_t) ch);

  /* Loop until the end of transmission */
  while (USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET)
  {}

  return ch;
}
  • 12
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

动态比特

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

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

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

打赏作者

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

抵扣说明:

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

余额充值