基于STM32的血压传感器主程序

来源:本站
导读:目前正在解读《基于STM32的血压传感器主程序》的相关信息,《基于STM32的血压传感器主程序》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《基于STM32的血压传感器主程序》的详细说明。
简介:基于HKB_08B,对血压检测,以及语音播报,液晶显示血压数值,下文是血压传感器传感器主程序

//包含头文件:

#include "main.h"

#include "systick.h"

#include "usart_printf.h"

#include "hkb_08b.h"

#include "lcd.h"

#include "gui.h"

#include "xfs5152.h"

///////////////////////////////////////////////

///////////////////////////////////////////////

//宏定义区

#define USART_REC_LEN 64 //定义最大接收字节数

///////////////////////////////////////////////

///////////////////////////////////////////////

//全局变量声明区

u8 USART2_RX_BUF[USART_REC_LEN]; //接收缓冲,最大USART_REC_LEN个字节.末字节为换行符

u16 USART2_RXcnt=0;//接收字节计数

u16 USART2_RXsize=0;//接收字节个数

u16 USART2_RXflag=0;//接收完成标志

u8 hkb_08b_start_cmd[5] = {0xFF,0xC0,0x03,0xA3,0xA0}; //HKB-08B启动命令

u8 hkb_08b_stop_cmd[5] = {0xFF,0xC0,0x03,0xA4,0xA1}; //HKB-08B停止命令

u8 hkb_08b_flag = 0;

short BloodPressure_value_int16;//血压值

///////////////////////////////////////////////

///////////////////////////////////////////////

//函数说明:串口2初始化函数

//输入:u32 bound:配置波特率

//输出:无

//备注:无

///////////////////////////////////////////////

void uart2_init(u32 bound)

{

//GPIO端口设置

GPIO_InitTypeDef GPIO_InitStructure;

USART_InitTypeDef USART_InitStructure;

NVIC_InitTypeDef NVIC_InitStructure;

RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); //使能USART3时钟

//USART2_TX GPIOA.2

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; //PA.2

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出

GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.2

//USART2_RX GPIOA.3初始化

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;//PA3

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空输入

GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.3

//Usart2 NVIC 配置

NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;//抢占优先级3

NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //子优先级3

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道使能

NVIC_Init(&NVIC_InitStructure); //根据指定的参数初始化VIC寄存器

//USART 初始化设置

USART_InitStructure.USART_BaudRate = bound;//串口波特率

USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式

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(USART2, &USART_InitStructure); //初始化串口2

USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//开启串口接受中断

USART_Cmd(USART2, ENABLE); //使能串口2

}

///////////////////////////////////////////////

//函数说明:串口2中断服务程序

//输入:无

//输出:无

//备注:无

///////////////////////////////////////////////

void USART2_IRQHandler(void)

{

u8 Res;

if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) //接收中断

{

Res =USART_ReceiveData(USART2); //读取接收到的数据

if(USART2_RXflag==0)//接收未完成

{

USART2_RX_BUF[USART2_RXcnt++]=Res;

if(USART2_RXcnt>(USART_REC_LEN-1))//判断接收长度是否超限

{

USART2_RXcnt=0;

}

if(USART2_RXcnt==1)//判断同步字节0xff

{

if(Res!=0xff)

{

USART2_RXcnt=0;

}

}

else if(USART2_RXcnt==3)//获取数据包长度

{

USART2_RXsize=Res+2;

}

else if((USART2_RXcnt>3)&&(USART2_RXsize==USART2_RXcnt))//接受完一包数据

{

USART2_RXflag=1;

USART2_RXcnt=0;

}

}

}

}

///////////////////////////////////////////////

//函数说明:启动测量函数

//输入:无

//输出:无

//备注:无

///////////////////////////////////////////////

void hkb_08b_start(void)

{

u16 i = 0;

for(i=0; i<5; i++)

{

USART_SendData(USART2,hkb_08b_start_cmd[i]); // 向串口3发送数据

while(USART_GetFlagStatus(USART2,USART_FLAG_TC)!=SET);//等待发送结束

}

}

///////////////////////////////////////////////

//函数说明:停止测量函数

//输入:无

//输出:无

//备注:无

///////////////////////////////////////////////

void hkb_08b_stop(void)

{

u16 i = 0;

for(i=0; i<5; i++)

{

USART_SendData(USART2,hkb_08b_stop_cmd[i]); // 向串口3发送数据

while(USART_GetFlagStatus(USART2,USART_FLAG_TC)!=SET);//等待发送结束

}

}

///////////////////////////////////////////////

//函数说明:初始化HKB-08B

//输入:无

//输出:无

//备注:无

///////////////////////////////////////////////

void HKB_08B_Init(void)

{

uart2_init(115200); //初始化串口3

}

///////////////////////////////////////////////

//函数说明:HKB-08B打印测量值

//输入:无

//输出:无

//备注:无

///////////////////////////////////////////////

void HKB_08B_Convert(void)

{

u16 OutputPressure = 0;//输出气压值

u16 DiastolicBloodPressure = 0;//舒张压值

u16 SystolicBloodPressure = 0;//收缩压值

u8 HeartRate = 0;//心率值

LCD_clearString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,640,(ROW_SIZE+WORD_SIZE));

if(USART2_RX_BUF[4] == 0xAC)//测量结束,读取最终数据

{

DiastolicBloodPressure = (USART2_RX_BUF[7]<<8)+USART2_RX_BUF[8];

SystolicBloodPressure = ((USART2_RX_BUF[5]&0x7f)<<8)+USART2_RX_BUF[6];

HeartRate = USART2_RX_BUF[9];

sprintf((char*)LCD_displaybuf,"舒张压:%d 收缩压:%d 心率:%d",DiastolicBloodPressure,SystolicBloodPressure,HeartRate);

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,600,WORD_SIZE,WORD_SIZE,LCD_displaybuf,COLOR_VALUE);

sprintf((char*)LCD_displaybuf,"您的舒张压为:%d 收缩压为:%d 心率为:%d",DiastolicBloodPressure,SystolicBloodPressure,HeartRate);

XFS_FrameInfo(LCD_displaybuf);

delay_ms(100);

while(RDY != 0);

printf("%srn",LCD_displaybuf);

hkb_08b_flag =3;//测量结束

}

else if(USART2_RX_BUF[4] == 0xA0)//测量正在进行,读取输出气压

{

if((USART2_RX_BUF[5]&0xf0)==0)

{

printf("无心跳rn");

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,"无心跳",RED);

}

OutputPressure = ((USART2_RX_BUF[5]&0x0f)<<8)+USART2_RX_BUF[6];

BloodPressure_value_int16 = OutputPressure;

sprintf((char*)LCD_displaybuf,"输出气压为:%drn", OutputPressure);

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,LCD_displaybuf,RED);

}

else if(USART2_RX_BUF[4] == 0xAD)

{

if(USART2_RX_BUF[5] == 0)

{

printf("测量不到脉搏,请重新测量rn");

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,"测量不到脉搏,请重新测量",RED);

}

if(USART2_RX_BUF[5] == 1)

{

printf("气袋没绑好,请重新测量rn");

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,"气袋没绑好,请重新测量",RED);

}

if(USART2_RX_BUF[5] == 2)

{

printf("测量结果有误,请重新测量rn");

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,"测量结果有误,请重新测量",RED);

}

if(USART2_RX_BUF[5] == 3)

{

printf("进入超压保护,请重新测量rn");

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,"进入超压保护,请重新测量",RED);

}

if(USART2_RX_BUF[5] == 4)

{

printf("测量中移动说话,请重新测量rn");

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,"测量中移动说话,请重新测量",RED);

}

hkb_08b_flag = 3;//测量结束

}

else//设备出错

{

hkb_08b_stop();//发送结束指令

delay_ms(100);

printf("测量结果有误,请检查供电是否正常rn");

LCD_ShowString(24+WORD_SIZE*4,24+(WORD_SIZE+ROW_SIZE)*1,400,WORD_SIZE,WORD_SIZE,"测量结果有误,请检查供电是否正常",RED);

hkb_08b_flag = 3;//测量结束

}

}

///////////////////////////////////////////////

//函数说明:HKB-08B测量处理函数

//输入:无

//输出:无

//备注:无

///////////////////////////////////////////////

void HKB_08B_Measure_handle(void)

{

if(hkb_08b_flag==1)//接收到开始测量命令

{

hkb_08b_stop();//发送结束指令

delay_ms(100);

USART2_RXflag=0;

hkb_08b_start();//发送开始指令

hkb_08b_flag = 2;//HKB-08B运行标志位置1

}

if(hkb_08b_flag==2) //HKB-08B正在测量中

{

if(USART2_RXflag!=0)

{

HKB_08B_Convert();

if(hkb_08b_flag==3)//测量完成

{

hkb_08b_flag = 0;//设备空闲中

}

USART2_RXflag=0;

}

}

}

提醒:《基于STM32的血压传感器主程序》最后刷新时间 2024-03-14 00:52:28,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《基于STM32的血压传感器主程序》该内容的真实性请自行鉴别。