STM32测温枪

前段时间有靓仔私聊问我,要关于字节流串口通信的代码,今天根据项目代码进行公示

main主函数

#include <stdio.h>
#include <ctype.h>
#include <stdlib.h>
#include <string.h>
#include "stm32f10x.h"
#include "debug.h"
#include "stm32f10x_it.h"
#include "m3_systick.h"
#include "bsp_key.h"  
#include "ble.h"
#include "led.h"
#include "temp.h"


uint8_t display_meun=0;


typedef struct temp_body
{
  uint8_t onebyte;
  uint8_t twobyte;
  uint8_t threebyte;
  uint8_t fourbyte;
}temp_test;



temp_test mytemp;


void temp_start(temp_test *mytemp);
void temp_send_data(temp_test *mytemp,uint8_t temp_len);

//***************************全局变量**********************************************//
extern char BLE_USART_BUF[256];   //蓝牙串口数据缓冲区
extern uint8_t temp_buffer[9];    //测温串口数据缓冲区

/**
  * @brief  主函数
  * @param  无
  * @retval 无
  */
  

int main(void)
{	
  uint8_t data_flag=0;
  char dud[15]={0};

	
  //环境温度
  static uint16_t environment_temp=0;
  static uint8_t environment_temp_h=0;
  static uint8_t environment_temp_l=0;
  static float final_environment_temp=0;

  //被测物体温度
   uint16_t object_temp=0;
   uint8_t object_temp_h=0;
   uint8_t object_temp_l=0;
   float final_object_temp=0;
  
  //人体温度
   uint16_t body_temp=0;
   uint8_t body_temp_h=0;
   uint8_t body_temp_l=0;
   float final_body_temp=0;
	
  m3_Systick_Init();
  
  LED_GPIO_Config();
	LED_ON;
  
  /*初始化USART1 配置模式为 9600 8-N-1,用于串口调试*/
  Debug_Config(); //串口调试();
  
  /*初始化UART4 配置模式为 9600 8-N-1,中断接收 接收发蓝牙数据*/
	BLE_Init();
	
	/*初始化USART3 配置模式为 9600 8-N-1,中断接收 接收发测温数据*/
  TEMP_Config();  //
	
  while(1)
	{	
		
		
		
		if(strstr(BLE_USART_BUF,"temp")!=NULL)
		{
			data_flag=1;
			sprintf(dud,"temp_on");
			macBLE_Usart(dud);
			memset(dud,'\0',15);
			memset(BLE_USART_BUF,'\0',256);
      LED_ON;
      printf("temp_start\r\n");
		}
		
		//***************条件模式选择*************************//
		//测温的********************************start******************//
		if(data_flag==1)
		{
      temp_start(&mytemp);
      temp_send_data(&mytemp,4);
      printf("%x-%x-%x-%x-%x-%x-%x-%x-%x\r\n",temp_buffer[0],temp_buffer[1],temp_buffer[2],temp_buffer[3],temp_buffer[4],temp_buffer[5],temp_buffer[6],temp_buffer[7],temp_buffer[8]);
  
      //环境温度
      environment_temp_h = temp_buffer[2];
      environment_temp_l = temp_buffer[3];
      environment_temp = environment_temp_h<<8;
      environment_temp |= environment_temp_l;
      final_environment_temp = (float)(environment_temp/10.0f);
    
      //被测物体温度
      object_temp_h = temp_buffer[4];
      object_temp_l = temp_buffer[5];
      object_temp = object_temp_h<<8;
      object_temp |= object_temp_l;
      final_object_temp = (float)(object_temp/10.0f);
      
      //人体温度
      body_temp_h = temp_buffer[6];
      body_temp_l = temp_buffer[7];
      body_temp = body_temp_h<<8;
      body_temp |= body_temp_l;
      final_body_temp = (float)(body_temp/10.0f);
      
      if(final_body_temp>34.0f)
      {        

				printf("%.2f-%.2f-%.2f\r\n",final_environment_temp,final_object_temp,final_body_temp);
				sprintf(dud,"temp:%.2f,%.2f,%.2f",final_environment_temp,final_object_temp,final_body_temp);
				macBLE_Usart(dud);
        LED_OFF;
        data_flag=66;
			}

      printf("temp:%.2f,%.2f,%.2f",final_environment_temp,final_object_temp,final_body_temp);
				
			memset(temp_buffer,'\0',9);
			memset(dud,'\0',15);
			Delay_ms(20);
		}
		
      
      if(data_flag==66)  //缓冲区
      {

        printf("data_flag:66\r\n");
        LED_OFF;
      }		
     
	}	
}



//**************************************测温计***************************************//
//开始测试 5a 01 00 5b
void temp_start(temp_test *mytemp)
{
  mytemp->onebyte = 0x5A;
  mytemp->twobyte = 0x01;
  mytemp->threebyte = 0x00;
  mytemp->fourbyte = 0x5B;
}

void temp_send_data(temp_test *mytemp,uint8_t temp_len)
{
  static uint8_t date=0,i=0;
  for(i=0;i<temp_len;i++)
  {
    date = *(((uint8_t *)&mytemp->onebyte)+i);
    USART_SendData(TEMP_USARTx,date);
    while(USART_GetFlagStatus(TEMP_USARTx,USART_FLAG_TC)!= SET);
  }
}


/*********************************************END OF FILE**********************/

ble部分代码

ble.c

#include "ble.h"
#include <stdio.h>
#include <stdbool.h>
#include <stdarg.h> 
#include <string.h>
#include <math.h>
#include "m3_systick.h"


static void  BLE_USART_Config( void );
static void  BLE_USART_NVIC_Configuration( void );


struct  STRUCT_USARTx_Fram strBLE_Fram_Record = { 0 };


static char *  itoa( int value, char * string, int radix );

/*
 * 函数名:USART2_printf
 * 描述  :格式化输出,类似于C库中的printf,但这里没有用到C库
 * 输入  :-USARTx 串口通道,这里只用到了串口2,即USART2
 *		     -Data   要发送到串口的内容的指针
 *			   -...    其他参数
 * 输出  :无
 * 返回  :无 
 * 调用  :外部调用
 *         典型应用USART2_printf( USART2, "\r\n this is a demo \r\n" );
 *            		 USART2_printf( USART2, "\r\n %d \r\n", i );
 *            		 USART2_printf( USART2, "\r\n %s \r\n", j );
 */
void USART_printf ( USART_TypeDef * USARTx, char * Data, ... )
{
	const char *s;
	int d;   
	char buf[16];

	
	va_list ap;
	va_start(ap, Data);

	while ( * Data != 0 )     // 判断是否到达字符串结束符
	{				                          
		if ( * Data == 0x5c )  //'\'
		{									  
			switch ( *++Data )
			{
				case 'r':							          //回车符
				USART_SendData(USARTx, 0x0d);
				Data ++;
				break;

				case 'n':							          //换行符
				USART_SendData(USARTx, 0x0a);	
				Data ++;
				break;

				default:
				Data ++;
				break;
			}			 
		}
		
		else if ( * Data == '%')
		{									  //
			switch ( *++Data )
			{				
				case 's':										  //字符串
				s = va_arg(ap, const char *);
				
				for ( ; *s; s++) 
				{
					USART_SendData(USARTx,*s);
					while( USART_GetFlagStatus(USARTx, USART_FLAG_TXE) == RESET );
				}
				
				Data++;
				
				break;

				case 'd':			
					//十进制
				d = va_arg(ap, int);
				
				itoa(d, buf, 10);
				
				for (s = buf; *s; s++) 
				{
					USART_SendData(USARTx,*s);
					while( USART_GetFlagStatus(USARTx, USART_FLAG_TXE) == RESET );
				}
				
				Data++;
				
				break;
				
				default:
				Data++;
				
				break;
				
			}		 
		}
		
		else USART_SendData(USARTx, *Data++);
		
		while ( USART_GetFlagStatus ( USARTx, USART_FLAG_TXE ) == RESET );
		
	}
}


/*
 * 函数名:itoa
 * 描述  :将整形数据转换成字符串
 * 输入  :-radix =10 表示10进制,其他结果为0
 *         -value 要转换的整形数
 *         -buf 转换后的字符串
 *         -radix = 10
 * 输出  :无
 * 返回  :无
 * 调用  :被USART2_printf()调用
 */
static char * itoa( int value, char *string, int radix )
{
	int     i, d;
	int     flag = 0;
	char    *ptr = string;

	/* This implementation only works for decimal numbers. */
	if (radix != 10)
	{
		*ptr = 0;
		return string;
	}

	if (!value)
	{
		*ptr++ = 0x30;
		*ptr = 0;
		return string;
	}

	/* if this is a negative value insert the minus sign. */
	if (value < 0)
	{
		*ptr++ = '-';

		/* Make the value positive. */
		value *= -1;
		
	}

	for (i = 10000; i > 0; i /= 10)
	{
		d = value / i;

		if (d || flag)
		{
			*ptr++ = (char)(d + 0x30);
			value -= (d * i);
			flag = 1;
		}
	}

	/* Null terminate the string. */
	*ptr = 0;

	return string;

} /* NCL_Itoa */






/**
  * @brief  初始化BLE用到的 USART
  * @param  无
  * @retval 无
  */
static void BLE_USART_Config ( void )
{
	GPIO_InitTypeDef GPIO_InitStructure;
	USART_InitTypeDef USART_InitStructure;
	
	
	/* config USART clock */
	macBLE_USART_APBxClock_FUN ( macBLE_USART_CLK, ENABLE );
	macBLE_USART_GPIO_APBxClock_FUN ( macBLE_USART_GPIO_CLK, ENABLE );
	
	/* USART GPIO config */
	/* Configure USART Tx as alternate function push-pull */
	GPIO_InitStructure.GPIO_Pin =  macBLE_USART_TX_PIN;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(macBLE_USART_TX_PORT, &GPIO_InitStructure);  
  
	/* Configure USART Rx as input floating */
	GPIO_InitStructure.GPIO_Pin = macBLE_USART_RX_PIN;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
	GPIO_Init(macBLE_USART_RX_PORT, &GPIO_InitStructure);
	
	/* USART1 mode config */
	USART_InitStructure.USART_BaudRate = macBLE_USART_BAUD_RATE;
	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_Rx | USART_Mode_Tx;
	USART_Init(macBLE_USARTx, &USART_InitStructure);
	
	
	/* 中断配置 */
	USART_ITConfig ( macBLE_USARTx, USART_IT_RXNE, ENABLE ); //使能串口接收中断 
	USART_ITConfig ( macBLE_USARTx, USART_IT_IDLE, ENABLE ); //使能串口总线空闲中断 	

	BLE_USART_NVIC_Configuration ();
	
	
	USART_Cmd(macBLE_USARTx, ENABLE);
	
	
}


/**
  * @brief  配置 BLE USART 的 NVIC 中断
  * @param  无
  * @retval 无
  */
static void BLE_USART_NVIC_Configuration ( void )
{
	NVIC_InitTypeDef NVIC_InitStructure; 
	
	
	/* Configure the NVIC Preemption Priority Bits */  
	NVIC_PriorityGroupConfig ( macNVIC_PriorityGroup_x );

	/* Enable the USART2 Interrupt */
	NVIC_InitStructure.NVIC_IRQChannel = macBLE_USART_IRQ;	 
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
	NVIC_Init(&NVIC_InitStructure);

}


void USART3_SendByte(uint8_t ch)
{
	/* 发送一个字节数据到USART */
	USART_SendData(macBLE_USARTx,ch);
		
	/* 等待发送数据寄存器为空 */
	while (USART_GetFlagStatus(macBLE_USARTx, USART_FLAG_TXE) == RESET);	
}


/*****************  发送字符串 **********************/
void USART3_SendString(char *str)
{
	unsigned int k=0;
  do 
  {
      USART3_SendByte(*(str + k));
      k++;
  } while(*(str + k)!='\0');
  
  /* 等待发送完成 */
  while(USART_GetFlagStatus(USART2,USART_FLAG_TC)==RESET)
  {}
}

/*
 * 函数名:BLE_Cmd
 * 描述  :对WF-BLE模块发送AT指令
 * 输入  :cmd,待发送的指令
 *         reply1,reply2,期待的响应,为NULL表不需响应,两者为或逻辑关系
 *         waittime,等待响应的时间
 * 返回  : 1,指令发送成功
 *         0,指令发送失败
 * 调用  :被外部调用
 */
bool BLE_Cmd ( char * cmd, char * reply1, char * reply2, u32 waittime )
{    
	memset(strBLE_Fram_Record .Data_RX_BUF,0,strBLE_Fram_Record .InfBit .FramLength);
	strBLE_Fram_Record .InfBit .FramLength = 0;               //从新开始接收新的数据包
	macBLE_Usart ( "%s", cmd );
	printf ( "%s\r\n", cmd );
	if ( ( reply1 == 0 ) && ( reply2 == 0 ) )                      //不需要接收数据
		return true;
	
	Delay_ms ( waittime );                 //延时
	
	strBLE_Fram_Record .Data_RX_BUF [ strBLE_Fram_Record .InfBit .FramLength ]  = '\0';

	printf ( "%s", strBLE_Fram_Record .Data_RX_BUF );
  
	if ( ( reply1 != 0 ) && ( reply2 != 0 ) )
		return ( ( bool ) strstr ( strBLE_Fram_Record .Data_RX_BUF, reply1 ) || 
						 ( bool ) strstr ( strBLE_Fram_Record .Data_RX_BUF, reply2 ) ); 
 	
	else if ( reply1 != 0 )
		return ( ( bool ) strstr ( strBLE_Fram_Record .Data_RX_BUF, reply1 ) );
	
	else
		return ( ( bool ) strstr ( strBLE_Fram_Record .Data_RX_BUF, reply2 ) );
	
}


/**
  * @brief  BLE初始化函数
  * @param  无
  * @retval 无
  */
void BLE_Init ( void )
{
	
	BLE_USART_Config (); 

}

char BLE_USART_BUF[256] = {0};

/**
  * @brief  This function handles macESP8266_USARTx Handler.
  * @param  None
  * @retval None
  */
void macBLE_USART_INT_FUN ( void )
{	
	uint8_t ucCh;
	static u8 i;
	if( USART_GetITStatus ( macBLE_USARTx, USART_IT_RXNE ) != RESET )
	{
		ucCh  = USART_ReceiveData( macBLE_USARTx );
		BLE_USART_BUF[i++] = ucCh;
	} 
	if( USART_GetITStatus( macBLE_USARTx, USART_IT_IDLE ) == SET )                                         //???????
	{	
		ucCh = USART_ReceiveData( macBLE_USARTx );
		BLE_USART_BUF[i] = '\0';
//		printf("%s\r\n",BLE_USART_BUF);
//		recvDataFromBleCustomerAndProcess(BLE_USART_BUF);
		i = 0;
	}	
}


ble.h

#ifndef _BLE_H_
#define _BLE_H_

#include "stm32f10x.h"
#include <stdio.h>
#include <stdbool.h>
#include <stdarg.h> 
#include <stdbool.h>
#include <math.h>


#if defined ( __CC_ARM   )
#pragma anon_unions
#endif


#define   macNVIC_PriorityGroup_x    NVIC_PriorityGroup_2
void    USART_printf   ( USART_TypeDef * USARTx, char * Data, ... );

/******************************* ESP8266 外部全局变量声明 ***************************/
#define RX_BUF_MAX_LEN     256                                     //最大接收缓存字节数

extern struct  STRUCT_USARTx_Fram                                  //串口数据帧的处理结构体
{
	char  Data_RX_BUF [ RX_BUF_MAX_LEN ];
	
  union {
    __IO u16 InfAll;
    struct {
		  __IO u16 FramLength       :15;                               // 14:0 
		  __IO u16 FramFinishFlag   :1;                                // 15 
	  } InfBit;
  }; 
	
} strBLE_Fram_Record;


//位带操作,实现51类似的GPIO控制功能
//具体实现思想,参考<<CM3权威指南>>第五章(87页~92页).
//IO口操作宏定义
#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2)) 
#define MEM_ADDR(addr)  *((volatile unsigned long  *)(addr)) 
#define BIT_ADDR(addr, bitnum)   MEM_ADDR(BITBAND(addr, bitnum)) 
//IO口地址映射
#define GPIOA_ODR_Addr    (GPIOA_BASE+12) //0x4001080C 
#define GPIOB_ODR_Addr    (GPIOB_BASE+12) //0x40010C0C 
#define GPIOC_ODR_Addr    (GPIOC_BASE+12) //0x4001100C 
#define GPIOD_ODR_Addr    (GPIOD_BASE+12) //0x4001140C 
#define GPIOE_ODR_Addr    (GPIOE_BASE+12) //0x4001180C 
#define GPIOF_ODR_Addr    (GPIOF_BASE+12) //0x40011A0C    
#define GPIOG_ODR_Addr    (GPIOG_BASE+12) //0x40011E0C    

#define GPIOA_IDR_Addr    (GPIOA_BASE+8) //0x40010808 
#define GPIOB_IDR_Addr    (GPIOB_BASE+8) //0x40010C08 
#define GPIOC_IDR_Addr    (GPIOC_BASE+8) //0x40011008 
#define GPIOD_IDR_Addr    (GPIOD_BASE+8) //0x40011408 
#define GPIOE_IDR_Addr    (GPIOE_BASE+8) //0x40011808 
#define GPIOF_IDR_Addr    (GPIOF_BASE+8) //0x40011A08 
#define GPIOG_IDR_Addr    (GPIOG_BASE+8) //0x40011E08 
//IO口操作,只对单一的IO口!
//确保n的值小于16!
#define PAout(n)   BIT_ADDR(GPIOA_ODR_Addr,n)  //输出 
#define PAin(n)    BIT_ADDR(GPIOA_IDR_Addr,n)  //输入 

#define PBout(n)   BIT_ADDR(GPIOB_ODR_Addr,n)  //输出 
#define PBin(n)    BIT_ADDR(GPIOB_IDR_Addr,n)  //输入 

#define PCout(n)   BIT_ADDR(GPIOC_ODR_Addr,n)  //输出 
#define PCin(n)    BIT_ADDR(GPIOC_IDR_Addr,n)  //输入 

#define PDout(n)   BIT_ADDR(GPIOD_ODR_Addr,n)  //输出 
#define PDin(n)    BIT_ADDR(GPIOD_IDR_Addr,n)  //输入 

#define PEout(n)   BIT_ADDR(GPIOE_ODR_Addr,n)  //输出 
#define PEin(n)    BIT_ADDR(GPIOE_IDR_Addr,n)  //输入

#define PFout(n)   BIT_ADDR(GPIOF_ODR_Addr,n)  //输出 
#define PFin(n)    BIT_ADDR(GPIOF_IDR_Addr,n)  //输入

#define PGout(n)   BIT_ADDR(GPIOG_ODR_Addr,n)  //输出 
#define PGin(n)    BIT_ADDR(GPIOG_IDR_Addr,n)  //输入


 
//#define      macBLE_RST_LOW_LEVEL()                       GPIO_ResetBits(macBLE_RST_PORT,macBLE_RST_PIN)
//#define      macBLE_RST_HIGH_LEVEL()                      GPIO_SetBits(macBLE_RST_PORT,macBLE_RST_PIN)
//#define      Read_macBLE_READY()                          GPIO_ReadInputDataBit(macBLE_READY_PORT,macBLE_READY_PIN)
//#define      Read_macBLE_LINK()                           GPIO_ReadInputDataBit(macBLE_LINK_PORT,macBLE_LINK_PIN)

#define      macBLE_RST                                   PBout(9)
#define      macBLE_MODE                                  PBout(8)
#define      macBLE_DISC                                  PBout(7)
#define      macBLE_LINK                                  PBin(6)
/********************************wifi串口配置宏*****************************************/
#define      macBLE_USART_BAUD_RATE                       9600
 
#define      macBLE_USARTx                                UART4
#define      macBLE_USART_APBxClock_FUN                   RCC_APB1PeriphClockCmd
#define      macBLE_USART_CLK                             RCC_APB1Periph_UART4

#define      macBLE_USART_GPIO_APBxClock_FUN              RCC_APB2PeriphClockCmd
#define      macBLE_USART_GPIO_CLK                        RCC_APB2Periph_GPIOC     
#define      macBLE_USART_TX_PORT                         GPIOC   
#define      macBLE_USART_TX_PIN                          GPIO_Pin_10
#define      macBLE_USART_RX_PORT                         GPIOC
#define      macBLE_USART_RX_PIN                          GPIO_Pin_11
#define      macBLE_USART_IRQ                             UART4_IRQn
#define      macBLE_USART_INT_FUN                         UART4_IRQHandler





/*********************************************** ESP8266 函数宏定义 *******************************************/
#define     macBLE_Usart( fmt, ... )               USART_printf ( macBLE_USARTx, fmt, ##__VA_ARGS__ ) 
#define     macPC_Usart( fmt, ... )                printf ( fmt, ##__VA_ARGS__ )    




/****************************************** ESP8266 函数声明 ***********************************************/

void BLE_Init ( void );
void USART3_SendByte(uint8_t ch);
void USART3_SendString(char *str);
bool BLE_Cmd ( char * cmd, char * reply1, char * reply2, u32 waittime );

#endif



测温模块部分

temp.c

#include "temp.h"
#include "debug.h"
 /**
  * @brief  配置嵌套向量中断控制器NVIC
  * @param  无
  * @retval 无
  */
//static void NVIC_Configuration(void)
//{

//}

 /**
  * @brief  USART GPIO 配置,工作参数配置
  * @param  无
  * @retval 无
  */
void TEMP_Config(void)
{
	GPIO_InitTypeDef GPIO_InitStructure;
	USART_InitTypeDef USART_InitStructure;

	// 打开串口GPIO的时钟
	TEMP_USART_GPIO_APBxClkCmd(TEMP_USART_GPIO_CLK, ENABLE);
	
	// 打开串口外设的时钟
	TEMP_USART_APBxClkCmd(TEMP_USART_CLK, ENABLE);

	// 将USART Tx的GPIO配置为推挽复用模式
	GPIO_InitStructure.GPIO_Pin = TEMP_USART_TX_GPIO_PIN;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(TEMP_USART_TX_GPIO_PORT, &GPIO_InitStructure);

  // 将USART Rx的GPIO配置为浮空输入模式
	GPIO_InitStructure.GPIO_Pin = TEMP_USART_RX_GPIO_PIN;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
	GPIO_Init(TEMP_USART_RX_GPIO_PORT, &GPIO_InitStructure);
	
	// 配置串口的工作参数
	// 配置波特率
	USART_InitStructure.USART_BaudRate = TEMP_USART_BAUDRATE;
	// 配置 针数据字长
	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_Rx | USART_Mode_Tx;
	// 完成串口的初始化配置
	USART_Init(TEMP_USARTx, &USART_InitStructure);
	
	// 串口中断优先级配置
	  NVIC_InitTypeDef NVIC_InitStructure;
  
  /* 嵌套向量中断控制器组选择 */
  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  
  /* 配置USART为中断源 */
  NVIC_InitStructure.NVIC_IRQChannel = TEMP_USART_IRQ;
  /* 抢断优先级*/
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  /* 子优先级 */
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
  /* 使能中断 */
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  /* 初始化配置NVIC */
  NVIC_Init(&NVIC_InitStructure);
	
	// 使能串口接收中断
	USART_ITConfig(TEMP_USARTx, USART_IT_RXNE, ENABLE);	
	
 // 使能串口空闲中断
	USART_ITConfig(TEMP_USARTx, USART_IT_IDLE, ENABLE);	
  
	// 使能串口
	USART_Cmd(TEMP_USARTx, ENABLE);	    
}

/重定向c库函数printf到串口,重定向后可使用printf函数
//int fputc(int ch, FILE *f)
//{
//		/* 发送一个字节数据到串口 */
//		USART_SendData(WEIGHT_USARTx, (uint8_t) ch);
//		
//		/* 等待发送完毕 */
//		while (USART_GetFlagStatus(WEIGHT_USARTx, USART_FLAG_TXE) == RESET);		
//	
//		return (ch);
//}

/重定向c库函数scanf到串口,重写向后可使用scanf、getchar等函数
//int fgetc(FILE *f)
//{
//		/* 等待串口输入数据 */
//		while (USART_GetFlagStatus(WEIGHT_USARTx, USART_FLAG_RXNE) == RESET);

//		return (int)USART_ReceiveData(WEIGHT_USARTx);
//}

/*****************  发送一个字节 **********************/
void TEMP_SendByte( USART_TypeDef * pUSARTx, uint8_t ch)
{
	/* 发送一个字节数据到USART */
	USART_SendData(pUSARTx,ch);
		
	/* 等待发送数据寄存器为空 */
	while (USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET);	
}

/****************** 发送8位的数组 ************************/
void TEMP_SendArray( USART_TypeDef * pUSARTx, uint8_t *array, uint16_t num)
{
  uint8_t i;
	
	for(i=0; i<num; i++)
  {
	    /* 发送一个字节数据到USART */
	    TEMP_SendByte(pUSARTx,array[i]);	
  
  }
	/* 等待发送完成 */
	while(USART_GetFlagStatus(pUSARTx,USART_FLAG_TC)==RESET);
}

/*****************  发送字符串 **********************/
void TEMP_SendString( USART_TypeDef * pUSARTx, char *str)
{
	unsigned int k=0;
  do 
  {
      TEMP_SendByte( pUSARTx, *(str + k) );
      printf("%c",*str);
      k++;
  } while(*(str + k)!='\0');
  
  /* 等待发送完成 */
  while(USART_GetFlagStatus(pUSARTx,USART_FLAG_TC)==RESET)
  {}
}

/*****************  发送一个16位数 **********************/
void TEMP_SendHalfWord( USART_TypeDef * pUSARTx, uint16_t ch)
{
	uint8_t temp_h, temp_l;
	
	/* 取出高八位 */
	temp_h = (ch&0XFF00)>>8;
	/* 取出低八位 */
	temp_l = ch&0XFF;
	
	/* 发送高八位 */
	USART_SendData(pUSARTx,temp_h);	
	while (USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET);
	
	/* 发送低八位 */
	USART_SendData(pUSARTx,temp_l);	
	while (USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET);	
}



temp.h

#ifndef __TEMP_H
#define	__TEMP_H


#include "stm32f10x.h"
#include <stdio.h>

/** 
  * 串口宏定义,不同的串口挂载的总线和IO不一样,移植时需要修改这几个宏
	* 1-修改总线时钟的宏,uart1挂载到apb2总线,其他uart挂载到apb1总线
	* 2-修改GPIO的宏
  */
	

// 串口5-UART5
#define  TEMP_USARTx                   USART3
#define  TEMP_USART_CLK                RCC_APB1Periph_USART3
#define  TEMP_USART_APBxClkCmd         RCC_APB1PeriphClockCmd
#define  TEMP_USART_BAUDRATE           9600

// USART GPIO 引脚宏定义
#define  TEMP_USART_GPIO_CLK           (RCC_APB2Periph_GPIOB|RCC_APB2Periph_AFIO)
#define  TEMP_USART_GPIO_APBxClkCmd    RCC_APB2PeriphClockCmd
    
#define  TEMP_USART_TX_GPIO_PORT       GPIOB   
#define  TEMP_USART_TX_GPIO_PIN        GPIO_Pin_10
#define  TEMP_USART_RX_GPIO_PORT       GPIOB
#define  TEMP_USART_RX_GPIO_PIN        GPIO_Pin_11

#define  TEMP_USART_IRQ                USART3_IRQn
#define  TEMP_USART_IRQHandler         USART3_IRQHandler


//#define  HRM_USARTx                   USART3
//#define  HRM_USART_CLK                RCC_APB1Periph_USART3
//#define  HRM_USART_APBxClkCmd         RCC_APB1PeriphClockCmd
//#define  HRM_USART_BAUDRATE           38400

 USART GPIO ?????
//#define  HRM_USART_GPIO_CLK           (RCC_APB2Periph_GPIOB|RCC_APB2Periph_AFIO)
//#define  HRM_USART_GPIO_APBxClkCmd    RCC_APB2PeriphClockCmd
//    
//#define  HRM_USART_TX_GPIO_PORT       GPIOB   
//#define  HRM_USART_TX_GPIO_PIN        GPIO_Pin_10
//#define  HRM_USART_RX_GPIO_PORT       GPIOB
//#define  HRM_USART_RX_GPIO_PIN        GPIO_Pin_11

//#define  HRM_USART_IRQ                USART3_IRQn
//#define  HRM_USART_IRQHandler         USART3_IRQHandler

void TEMP_Config(void);
void TEMP_SendByte( USART_TypeDef * pUSARTx, uint8_t ch);
void TEMP_SendArray( USART_TypeDef * pUSARTx, uint8_t *array, uint16_t num);

void TEMP_SendString( USART_TypeDef * pUSARTx, char *str);
void TEMP_SendHalfWord( USART_TypeDef * pUSARTx, uint16_t ch);

#endif /* __USART_H */

中断代码

/**
  ******************************************************************************
  * @file    Project/STM32F10x_StdPeriph_Template/stm32f10x_it.c 
  * @author  MCD Application Team
  * @version V3.5.0
  * @date    08-April-2011
  * @brief   Main Interrupt Service Routines.
  *          This file provides template for all exceptions handler and 
  *          peripherals interrupt service routine.
  ******************************************************************************
  * @attention
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTI
  
  AL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2011 STMicroelectronics</center></h2>
  ******************************************************************************
  */

/* Includes ------------------------------------------------------------------*/
#include "stm32f10x_it.h"
#include "debug.h"
#include <string.h>
#include <stdlib.h>
#include "m3_systick.h"
#include "temp.h"



/** @addtogroup STM32F10x_StdPeriph_Template
  * @{
  */

/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
/* Private function prototypes -----------------------------------------------*/
/* Private functions ---------------------------------------------------------*/

/******************************************************************************/
/*            Cortex-M3 Processor Exceptions Handlers                         */
/******************************************************************************/

/**
  * @brief  This function handles NMI exception.
  * @param  None
  * @retval None
  */
void NMI_Handler(void)
{
}

/**
  * @brief  This function handles Hard Fault exception.
  * @param  None
  * @retval None
  */
void HardFault_Handler(void)
{
  /* Go to infinite loop when Hard Fault exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles Memory Manage exception.
  * @param  None
  * @retval None
  */
void MemManage_Handler(void)
{
  /* Go to infinite loop when Memory Manage exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles Bus Fault exception.
  * @param  None
  * @retval None
  */
void BusFault_Handler(void)
{
  /* Go to infinite loop when Bus Fault exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles Usage Fault exception.
  * @param  None
  * @retval None
  */
void UsageFault_Handler(void)
{
  /* Go to infinite loop when Usage Fault exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles SVCall exception.
  * @param  None
  * @retval None
  */
void SVC_Handler(void)
{
}

/**
  * @brief  This function handles Debug Monitor exception.
  * @param  None
  * @retval None
  */
void DebugMon_Handler(void)
{
}

/**
  * @brief  This function handles PendSVC exception.
  * @param  None
  * @retval None
  */
void PendSV_Handler(void)
{
}

/**
  * @brief  This function handles SysTick Handler.
  * @param  None
  * @retval None
  */



void SysTick_Handler(void)
{
  TimingDelay_Decrement();
}

int TEMPRx=0;
uint8_t temp_buffer[9]; //»º³åÇø

// ²âδ®¿Ú5ÖжϷþÎñº¯Êý
void TEMP_USART_IRQHandler(void)
{	
  static uint8_t clear=0;
  USART_ClearFlag(TEMP_USARTx,USART_FLAG_TC);
  
	if(USART_GetITStatus(TEMP_USARTx,USART_IT_RXNE)!=Bit_RESET)
	{	
		temp_buffer[TEMPRx++] = TEMP_USARTx->DR;
	}	 
  else if(USART_GetFlagStatus(TEMP_USARTx,USART_FLAG_IDLE)!=Bit_RESET)
  {
    clear=TEMP_USARTx->SR;
    clear=TEMP_USARTx->DR;
    TEMPRx=0;
//    Usart_SendString(DEBUG_USARTx,rece_buffer);
//    printf("%c%c%c%c%c%c%c%c%c%c",weight_buffer[0],weight_buffer[1],weight_buffer[2],weight_buffer[3],weight_buffer[4],weight_buffer[5],weight_buffer[6],weight_buffer[7],weight_buffer[9],weight_buffer[10]);
//    myflag=1;
  }
}




/**
  * @brief  This function handles PPP interrupt request.
  * @param  None
  * @retval None
  */
/*void PPP_IRQHandler(void)
{
}*/

/**
  * @}
  */ 


/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/

demo代码链接:

链接:https://pan.baidu.com/s/16dod5S_lxpwTnI12HvqYPQ 
提取码:8442

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先应该介绍STM32F411RET6的内部温度传感器: 首先此温度传感器主要用于量设备所处环境的周围温度。 当没有使用此温度传感器时,传感器将处于断电模式。 主要的性能: •所支持的温度范围:-40℃到125℃ •量的精度:±1.5℃ 然后是读取芯片内部的温度传感器: ①选择ADC1_IN18作为输入通道。 ②选择一个采样的时间,但必须要大于用户参考手册上所指定的最小采样时间。 ③通过置位ADC_CCR寄存器中的TSVREFE标志位,使得温度传感器从掉电模式唤醒。 ④开始ADC传唤通过置位SWSTART(或者通过外部的触发) ⑤读取ADC数据寄存中的数值 ⑥使用下面的公式来计算温度: Tempereture={(V_SENSE-V25)/Avg_Slope}+25 在这个公式里面: —V25在25℃下的值 —Avg_Slope为给定的温度的斜率 通过查看电气特性手册来获得给定的V25和Avg_Slope的值 注意: 传感器在他能够正确的范围内输出V_SENSE之前,从掉电模式到唤醒有一个起始的时间。同样,ADC的上电也有一个起始的时间,因此为了使这个延时最小化,ADON和TSCREFE标志位可以在同一个时间被置位。 温度传感器的输出电压的改变与温度是呈现出线性关系的。这个线性函数的偏移是依赖于每一个芯片上处理器的不同。 内部温度传感器更加适合与那些用来察觉温度不差异的应用中,而非用于获取绝对的温度值,如果想要获取到精确的温度值,请使用一个外部的温度传感器来代替。 现在是相关的ADC初始化的代码和获取温度代码部分截图: 然后是主函数的读取,并且串口打印出来: 最后是套入用户手册所给出公式计算出的温度的结果: 然后下一步是调试W5500进行网络连接,并把温度数据上传到网络

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值