//包含头文件:
#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("%s\r\n",LCD_displaybuf);
hkb_08b_flag =3;//测量结束
}
else if(USART2_RX_BUF[4] == 0xA0)//测量正在进行,读取输出气压
{
if((USART2_RX_BUF[5]&0xf0)==0)
{
printf("无心跳\r\n");
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,"输出气压为:%d\r\n", 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("测量不到脉搏,请重新测量\r\n");
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("气袋没绑好,请重新测量\r\n");
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("测量结果有误,请重新测量\r\n");
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("进入超压保护,请重新测量\r\n");
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("测量中移动说话,请重新测量\r\n");
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("测量结果有误,请检查供电是否正常\r\n");
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;
}
}
}