stm32关于串口接收数据进行指定功能开启的问题

一、字符串如何输入到单片机中?

二、字符串在单片机中如何比较?

三、其他问题。

一、字符串如何输入到单片机中?

通过串口通信以及串口中断的使用我们可以将指定的字符串输送到单片机里面,先来代码:

void uart_init()
{
	//RCC
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1 | RCC_APB2Periph_AFIO, ENABLE);
	//结构体
	GPIO_InitTypeDef GPIO_InitStructure; 
	USART_InitTypeDef USART_InitStructure; 
	NVIC_InitTypeDef NVIC_InitStructure;
	//初试化Pin9
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;   //修改结构体成员变量  
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;  //速度配置
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;  //模式配置 复用推挽输出
	GPIO_Init(GPIOA, &GPIO_InitStructure); //调用函数 进行GPIO初始化

	//初试化Pin10
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;   //修改结构体成员变量  
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;  //速度配置
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;  //模式配置 复用推挽输出
	GPIO_Init(GPIOA, &GPIO_InitStructure); //调用函数 进行GPIO初始化
	
	
	USART_InitStructure.USART_BaudRate = 115200; //波特率
	USART_InitStructure.USART_WordLength = USART_WordLength_8b;//数据位 
	USART_InitStructure.USART_StopBits = USART_StopBits_1; //开始位
	USART_InitStructure.USART_Parity = USART_Parity_No; //校验位
	USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; //硬件控制
	USART_InitStructure.USART_Mode = USART_Mode_Tx | USART_Mode_Rx; 
	USART_Init(USART1, &USART_InitStructure);
	//NVIC 总的中断控制 初始化
	NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;  //通道
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;  //使能
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  //先占优先级
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;   //从优先级, 数字越小优先级越高
	NVIC_Init(&NVIC_InitStructure); //初始化
	
	USART_Cmd(USART1,ENABLE);//串口使能
	USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
}

使用的是GPIOA9和GPIOA10这两个引脚,如果要使用其他的可以看一下数据手册,一系列的初始化完成后,就可以进行串口中断函数的操作,串口以及gpio的使能都需要自己手动打开,NVIC的分组处理放在了main函数里面,接下来写串口回显的函数:

void uart_byte(char data)
{
	USART_SendData(USART1, data);//通过串口1发送函数
	while(   USART_GetFlagStatus(USART1, USART_FLAG_TXE)==RESET    );//接触器为空,跳出语句即等待第一个数据的传输,
}
void uart_send_str(char *str)
{
	while(*str!='\0')//字符串末尾
	{
		uart_byte(*str);//调用上面的函数传输字符串的每一位
		str++;//指针偏移
	}
}

 二、字符串在单片机中如何比较?

如果输入的是一个字符,可以非常轻松的完成字符串的比较,但是如果传入的是字符串的话就比较困难,就目前而言我想到的是使用strcmp函数来比较字符串的区别来打开或关闭指定的功能,但是发现这种方法在我的32机子上面不得行,感觉逻辑没有问题目前我也没有其它的办法,先看一下串口中断处理函数:

char arr[32]={0};
int flag=0;
int rx_flag=0;
void USART1_IRQHandler()
{
	u16 RxData; 
	if( USART_GetITStatus(USART1, USART_IT_RXNE)==SET)
	{
		RxData = USART_ReceiveData(USART1);
		USART_SendData(USART1, RxData);
//		if(RxData == 'a')
//		{
//			led_on();
//		}
//		else if(RxData == 'b')
//		{
//			led_off();
//		}
//		else if(RxData == 'c')
//		{
//			beep_on();
//		}
//		else if(RxData == 'd')
//		{
//			beep_off();
//		}
		
		arr[flag]=RxData;
		
		if(arr[flag]=='!')
		{
			flag=-1;
			rx_flag=1;
		}
		flag++;
		USART_ClearITPendingBit(USART1, USART_IT_RXNE);
	}
}

在代码里面的那一段可以实现输入一个字符从而打开或关闭指定的功能,但当使用数组存放的时候就不可以了,实现代码:

void uart_bd(char *arr)
{
	if(rx_flag == 1)
		{
			if(strcmp(arr,"led!")==0)
			{
				led_on();
			}
			else if(strcmp(arr,"fmq!")==0)
			{
				beep_on();
			}
			else if(strcmp(arr,"gfmq!")==0)
			{
				beep_off();
			}
			else if(strcmp(arr,"gled!")==0)
			{
				led_off();
			}
			rx_flag=0;
		}
}

接下来是mian:

#include "uart.h"
#include "led.h"
#include "beep.h"
extern char arr;
void delay_ms(int ms)
{
	int i=0;
	while(ms--)
		for(i=0;i<8050;i++);
}
int main()
{
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
	uart_init();
	led_init();
	beep_init();
	//int i=0;
	while(1)
	{
		delay_ms(1000);
    uart_send_str("hello wored\r\n");
		delay_ms(1000);
		uart_bd(arr);
	}
}

目前就实现到此阶段,后继在补充

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值