找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3916|回复: 2
打印 上一主题 下一主题
收起左侧

BOX_FDC2214配套资料下载(含51单片机与stm32源码)

[复制链接]
跳转到指定楼层
楼主
FDC2214资料


所有资料51hei提供下载:
BOX_FDC2214配套资料(2).rar (4.94 MB, 下载次数: 91)


文件列表:
串口助手和驱动\
BoxTechFDC2214串口转接模块使用手册.pdf
FDC2214-q1-官方文档.pdf
FDC2214中文手册-技术盒子翻译.pdf
FDC2214模块原理图.pdf
STC51Client-FDC2214串口转接模块例程.rar
STM32Client-FDC2214串口转接模块例程.rar
看资料之前首先看我哦.pdf

单片机源程序如下:
  1. #include "stc15wxxx.h"
  2. #include <my_typedef.h>
  3. #include "client_task.h"
  4. //如果自己移植,需要更换"stc15wxxx.h"头文件
  5. sbit LED = P1^1;

  6. void FDC_Set(ClientID , uint16_t fdc_data);

  7. uint32_t ch_data[4]={0};//通道数据
  8. uint8_t rx_buff[20] ={0};//接收BUFF
  9. uint8_t tx_buff[4] ={0};//发送BUFF

  10. void main(void)
  11. {
  12.         LED = 0;

  13. /*******配置串口(STC15W408AS单片机) 如果自己移植,需要更改此配置保证波特率为115200*******************/
  14.         SCON = 0x50;                //8位数据,可变波特率
  15.         AUXR |= 0x01;                //串口1选择定时器2为波特率发生器
  16.         AUXR |= 0x04;                //定时器2时钟为Fosc,即1T

  17.         AUXR1 |= 0X40; //切换串口到3.6 3.7

  18.         T2L = 0xB8;                //设定定时初值
  19.         T2H = 0xFF;                //设定定时初值
  20.         AUXR |= 0x10;                //启动定时器2
  21.         ES = 1;                  //使能串口1中断
  22.         EA = 1;

  23. /**************************/
  24.         //配置时按照下面配置即可、、具体使用"client_task.h"头文件内有详细说明
  25.         FDC_Set(reset_device, BOXEnable);//复位芯片
  26.         FDC_Set(clk_src, Clk_src_internal);//选用内部时钟
  27.         FDC_Set(autoscan, BOXEnable);
  28.         FDC_Set(sleep, BOXDisable);//退出睡眠模式 复位后一定要退出睡眠模式
  29.         while(1)
  30.         {

  31.         }       
  32. }

  33. uint16_t StartRx =0;
  34. void serial() interrupt 4
  35. {
  36.         uint8_t Res =0;
  37.        
  38.         if(RI)//判断是否为接收中断           (如果自己移植,修改此处的接收中断条件判断)
  39.         {//是
  40.                 Res = SBUF;//读取本次接收到的一个字节数据  (如果自己移植,修改此处的数据读取)
  41.                
  42.                 if(StartRx)//如果标记了已经开始接收帧数据
  43.                 {       
  44.                         rx_buff[StartRx -1] = Res;//接收帧数据
  45.                        
  46.                         if((StartRx -1) >= 17)
  47.                         {//接收完毕
  48.                                
  49.                                 if(rx_buff[16] != 0x55)//判断帧尾是否为 0x55,是则存储通道数据;否则舍弃本次接收,直接退出
  50.                                 {
  51.                                         return;

  52.                                 }
  53.                                 else
  54.                                 {//合成通道数据
  55.                                         LED = ~LED;
  56.                                         //此处接收的数据为传感器采集的原始数据,同学们可自行转换为电容值
  57.                                         ch_data[0] = (rx_buff[0]<<24) + (rx_buff[1]<<16) + (rx_buff[2]<<8) + rx_buff[3];
  58.                                         ch_data[1] = (rx_buff[4]<<24) + (rx_buff[5]<<16) + (rx_buff[6]<<8) + rx_buff[7];
  59.                                         ch_data[2] = (rx_buff[8]<<24) + (rx_buff[9]<<16) + (rx_buff[10]<<8) + rx_buff[11];
  60.                                         ch_data[3] = (rx_buff[12]<<24) + (rx_buff[13]<<16) + (rx_buff[14]<<8) + rx_buff[15];
  61.                                 }
  62.                                 StartRx = 0;//标记复位
  63.                         }
  64.                         StartRx ++;//标记递增 为接收下一字节数据做准备
  65.                 }
  66.                 if((Res == 0x76))        //如果是帧头且未开始接收通道数据
  67.                         StartRx = 1;//标记 下一次进入中断开始接收帧数据

  68.                 RI = 0;        //清除中断标志         (如果自己移植,修改此处的中断标志清零)
  69.   }
  70. }

  71. void FDC_Set(ClientID ID, uint16_t fdc_data)
  72. {
  73.         uint8_t i;
  74.         tx_buff[0] = 0x56;
  75.         tx_buff[1] = (uint8_t)(ID);
  76.         tx_buff[2] = (uint8_t)(fdc_data >> 8);
  77.         tx_buff[3] = (uint8_t)(fdc_data);
  78.         tx_buff[4] = 0x55;
  79.         for(i=0;i< 5; i++)
  80.         {
  81.                 SBUF = tx_buff[i];
  82.                 while (!TI);
  83.                 TI = 0;
  84.         }
  85. }
复制代码


stm32源码:

  1. #include <stm32f4xx.h>
  2. #include "delay.h"
  3. #include "oled.h"
  4. #include "client_task.h"
  5. void Nvic_Init(void);
  6. void USART1_Configuration(void);
  7. void FDC_Set(ClientID ID, uint16_t data);
  8.        
  9. uint32_t ch_data[4]={0};//通道数据
  10. uint8_t rx_buff[32] ={0};//接收缓冲
  11. uint8_t tx_buff[5] ={0};//发送缓冲
  12. int main(void)
  13. {
  14.         delay_ms(1000);
  15.         USART1_Configuration();//配置串口1
  16.         Nvic_Init();
  17.        
  18.         OLED_Init();
  19.         OLED_ShowString(0,0,"CH0:",16);
  20.         OLED_ShowString(0,2,"CH1:",16);
  21.         OLED_ShowString(0,4,"CH2:",16);
  22.         OLED_ShowString(0,6,"CH3:",16);

  23.         delay_ms(1000);
  24.         //配置时按照下面配置即可、、具体使用"client_task.h"头文件内有详细说明
  25.         FDC_Set(reset_device, BOXEnable);//复位芯片
  26.         FDC_Set(clk_src, Clk_src_internal);//选用内部时钟
  27.         FDC_Set(sleep, BOXDisable);//退出睡眠模式 复位后一定要退出睡眠模式
  28.         while(1)
  29.         {//显示数据
  30.                 OLED_ShowNum(30,0,ch_data[0],9,16);//OLED显示四个通道的数据
  31.                 OLED_ShowNum(30,2,ch_data[1],9,16);
  32.                 OLED_ShowNum(30,4,ch_data[2],9,16);
  33.                 OLED_ShowNum(30,6,ch_data[3],9,16);
  34.                 delay_ms(50);
  35.         }
  36. }
  37. /*
  38. 波特率一定要设置为115200·
  39. 如果要移植到51上:
  40. 1.把USART_GetITStatus(USART1, USART_IT_RXNE) != RESET这句更改为RI,并在if语句结尾加上RI =0;
  41. 2.把USART_ReceiveData(USART1)更换为SBUF
  42. */
  43. void USART1_IRQHandler(void)
  44. {//串口1中断函数
  45.         uint8_t Res =0;
  46.         static uint8_t StartRx =0;
  47.         if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)//判断是否为接收中断
  48.         {//是
  49.                 Res = USART_ReceiveData(USART1);//读取本次接收到的一个字节数据
  50.                
  51.                 if(StartRx)//如果标记了已经开始接收帧数据
  52.                 {
  53.                         rx_buff[StartRx -1] = Res;//接收帧数据
  54.                        
  55.                         if((StartRx -1) >= 17)
  56.                         {//接收完毕
  57.                                 StartRx = 0;//标记复位
  58.                                 if(rx_buff[16] != 0x55)//判断帧尾是否为 0x55,是则存储通道数据;否则舍弃本次接收,直接退出
  59.                                         return;
  60.                                 else
  61.                                 {//合成通道数据
  62.                                         ch_data[0] = (rx_buff[0] * 16777216) + (rx_buff[1] * 65536) + (rx_buff[2] * 256) + rx_buff[3];
  63.                                         ch_data[1] = (rx_buff[4] * 16777216) + (rx_buff[5] * 65536) + (rx_buff[6] * 256) + rx_buff[7];
  64.                                         ch_data[2] = (rx_buff[8] * 16777216) + (rx_buff[9] * 65536) + (rx_buff[10] * 256) + rx_buff[11];
  65.                                         ch_data[3] = (rx_buff[12] * 16777216) + (rx_buff[13] * 65536) + (rx_buff[14] * 256) + rx_buff[15];
  66.                                 }
  67.                         }
  68.                         StartRx ++;//标记递增 为接收下一字节数据做准备
  69.                 }
  70.                 if((Res == 0x76) && (!StartRx))        //如果是帧头且未开始接收通道数据
  71.                         StartRx = 1;//标记 下一次进入中断开始接收帧数据
  72.   }
  73. }
  74. void FDC_Set(ClientID ID, uint16_t data)
  75. {
  76.         uint8_t i;
  77.         tx_buff[0] = 0x56;
  78.         tx_buff[1] = (uint8_t)(ID);
  79.         tx_buff[2] = (uint8_t)(data >> 8);
  80.         tx_buff[3] = (uint8_t)(data);
  81.         tx_buff[4] = 0x55;
  82.         for(i=0;i< 5; i++)
  83.         {
  84.                 USART_SendData(USART1,tx_buff[i]);
  85.                 while (USART_GetFlagStatus(USART1,USART_FLAG_TC) == RESET);
  86.         }
  87. }

  88. void USART1_Configuration(void)
  89. {
  90.     USART_InitTypeDef usart;
  91.     GPIO_InitTypeDef  gpio;

  92.     RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB | RCC_AHB1Periph_DMA2,ENABLE);
  93.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);

  94.     GPIO_PinAFConfig(GPIOB,GPIO_PinSource6 ,GPIO_AF_USART1);
  95.     GPIO_PinAFConfig(GPIOB,GPIO_PinSource7 ,GPIO_AF_USART1);

  96.     gpio.GPIO_Pin = GPIO_Pin_6 | GPIO_Pin_7;
  97.     gpio.GPIO_Mode = GPIO_Mode_AF;
  98.     gpio.GPIO_OType = GPIO_OType_PP;
  99.     gpio.GPIO_Speed = GPIO_Speed_100MHz;
  100.     gpio.GPIO_PuPd = GPIO_PuPd_NOPULL;
  101.     GPIO_Init(GPIOB,&gpio);

  102.     usart.USART_BaudRate = 115200;
  103.     usart.USART_WordLength = USART_WordLength_8b;
  104.     usart.USART_StopBits = USART_StopBits_1;
  105.     usart.USART_Parity = USART_Parity_No;
  106.     usart.USART_Mode = USART_Mode_Tx | USART_Mode_Rx;//
  107.     usart.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  108.     USART_Init(USART1,&usart);

  109.     USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);//串口空闲中断

  110.     USART_Cmd(USART1,ENABLE);

  111. }

  112. void Nvic_Init(void)
  113. {
  114.         NVIC_InitTypeDef NVIC_InitStructure;//        /* NVIC_PriorityGroup */
  115.    
  116.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);        //优先级分组2:抢占优先级(0-3):相应优先级(0-3)
  117.    
  118.     NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;                //DMA2STR1CH5
  119.     NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;
  120.     NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
  121.     NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  122.     NVIC_Init(&NVIC_InitStructure);
  123. }

复制代码



分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:496595 发表于 2019-3-23 10:52 | 只看该作者
感谢分享
回复

使用道具 举报

板凳
ID:500356 发表于 2019-4-23 13:04 | 只看该作者
不錯喔
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表