找回密码
 立即注册

QQ登录

只需一步,快速开始

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

很全的Leadiy-M3C陀螺仪资料与STM32源程序

[复制链接]
跳转到指定楼层
楼主
希望有更好的可以一起分享上来




单片机源程序如下:
  1. /*********************************
  2. LEADIY-M3测试程序示例V2.2
  3. 作者: Colin
  4. 版权所有:  深圳市软芯微电子科技有限公司
  5. 芯片型号:  stm32f103CB
  6. *************************************/

  7. #include "string.h"
  8. #include "stm32f10x.h"
  9. #include "sys.h"
  10. #include "usart.h"
  11. #include "delay.h"
  12. #include "drv_Uart.h"


  13. int16_t Gyro[3], Acc[3], Angle[3], Mag[3];
  14. int32_t Altitude, Pressure;
  15. float Temper, GyroDPS[3], AccG[3], MagGauss[3], AngleDeg[3];


  16. /*读两个字节组成一个16位数*/
  17. int16_t ReadW(void)
  18. {
  19. unsigned char BufC;
  20. int16_t BufW;
  21.    
  22.   BufC = uartRead();
  23.   BufW = (uint16_t)BufC;
  24.   BufC = uartRead();
  25.   BufW = (int16_t)(((uint16_t)BufC  << 8) | BufW);
  26.   return BufW;
  27. }


  28. int main(void)
  29. {
  30. unsigned char BufC;
  31. uint16_t BufW;

  32.   /* 系统初始化*/
  33.   systemInit();

  34.   delay_ms(300);
  35.   printf("LEADIY-M3 TEST V2\r\n");

  36.   while (1)
  37.   {
  38.     if(uartAvailable()) //检测是否收到LEADIY-M3数据
  39.     {  
  40.       BufC = uartRead(); //读一个字节
  41.       if((BufC==0xA7)){  //判断是否为帧 头
  42.         BufC = uartRead(); //读一个字节
  43.         if (BufC==0x7A) { //判断是否为帧头
  44.           BufC = uartRead(); //读一个字节
  45.           switch(BufC) //帧类型判断
  46.           {
  47.             case 0x70: //标识为角速度帧
  48.               BufC = uartRead(); //帧长度,可不用
  49.               BufC = uartRead(); //效验位
  50.               Gyro[0] = ReadW();      //X轴
  51.               Gyro[1] = ReadW();      //Y轴
  52.               Gyro[2] = ReadW();      //Z轴

  53.               /*GYRO的量程为2000度每秒*/
  54.               /* 得到以"dps" ("度/秒")为单位的角速度值*/
  55.               GyroDPS[0] = (float)Gyro[0]*4/16.4;
  56.               GyroDPS[1] = (float)Gyro[1]*4/16.4;
  57.               GyroDPS[2] = (float)Gyro[2]*4/16.4;

  58.               printf("GYRO X:%d  Y:%d  Z:%d\r\n", Gyro[0], Gyro[1], Gyro[2]);
  59.               printf("GyroDPS X: %.2f, Y: %.2f, Z: %.2f\r\n", GyroDPS[0], GyroDPS[1], GyroDPS[2]);
  60.               break;
  61.             case 0x71: //标识为加速度帧
  62.               BufC = uartRead(); //帧长度,可不用
  63.               BufC = uartRead(); //效验位
  64.               Acc[0] = ReadW();      //X轴
  65.               Acc[1] = ReadW();      //Y轴
  66.               Acc[2] = ReadW();      //Z轴

  67.               /*ACC的量程为8G*/
  68.               /*得到以"g"为单位的加速度*/
  69.               AccG[0] = (float)Acc[0] / 4096;
  70.               AccG[1] = (float)Acc[1] / 4096;
  71.               AccG[2] = (float)Acc[2] / 4096;
  72.               printf("ACC X:%d  Y:%d  Z:%d\r\n", Acc[0], Acc[1], Acc[2]);
  73.               printf("AccG X:%.2f  Y:%.2f  Z:%.2f\r\n", AccG[0], AccG[1], AccG[2]);
  74.               break;
  75.             case 0x72: //标识为姿态帧
  76.               BufC = uartRead(); //帧长度,可不用
  77.               BufC = uartRead(); //效验位
  78.               Angle[0] = ReadW();   //X轴角度(横滚)
  79.               Angle[1] = ReadW();   //Y轴角度(俯仰)
  80.               Angle[2] = ReadW();   //Z轴角度(偏航)

  81.               AngleDeg[0] = (float)Angle[0] / 100;
  82.               AngleDeg[1] = (float)Angle[1] / 100;
  83.               AngleDeg[2] = (float)Angle[2] / 100;
  84.               if (AngleDeg[2]<0) AngleDeg[2] += 360; //将航向值转化到0---360度区间
  85.               printf("ANGLE X:%d  Y:%d  Z:%d \r\n", Angle[0], Angle[1], Angle[2]);
  86.               printf("AngleDeg X:%.2f  Y:%.2f  Z:%.2f \r\n", AngleDeg[0], AngleDeg[1], AngleDeg[2]);
  87.               break;
  88.             case 0x73: //标识为 地磁帧
  89.               BufC = uartRead(); //帧长度,可不用
  90.               BufC = uartRead(); //效验位
  91.               Mag[0] = ReadW();   //X轴
  92.               Mag[1] = ReadW();   //Y轴
  93.               Mag[2] = ReadW();   //Z轴

  94.               /*地磁设置为2.5Ga*/
  95.               /*得到以"Gauss"为单位的地磁*/
  96.               MagGauss[0] = (float)Mag[0] / 660;
  97.               MagGauss[1] = (float)Mag[1] / 660;
  98.               MagGauss[2] = (float)Mag[2] / 660;
  99.               printf("Mag X:%d  Y:%d  Z:%d \r\n", Mag[0], Mag[1], Mag[2]);
  100.               printf("MagGauss X:%.2f  Y:%.2f  Z:%.2f \r\n", MagGauss[0], MagGauss[1], MagGauss[2]);
  101.               break;
  102.             case 0x74: //标识为温度、气压帧
  103.               BufC = uartRead(); //帧长度,可不用
  104.               BufC = uartRead(); //效验位
  105.               Temper = ReadW() / 10;   //X轴
  106.               BufW = ReadW();   //气压低16位
  107.               Pressure = (int32_t)(((uint32_t)(ReadW() << 16))|BufW);
  108.               printf("Temperature(Degree):%.2f  Pressure(Pa):%d \r\n", Temper, Pressure);
  109.               break;
  110.             case 0x75: // 标识为高度帧
  111.               BufC = uartRead(); //帧长度,可不用
  112.               BufC = uartRead(); //效验位
  113.               BufW = ReadW();   //高度低16位

  114.               /*得到以"CM"为单位的海拔高度*/
  115.               Altitude = (int32_t)(((uint32_t)(ReadW() << 16))|BufW);
  116.               printf("Altitude(cm):%d \r\n", Altitude);
  117.               break;
  118.             default:  break;
  119.           }
  120.         }
  121.       }
  122.     }
  123.   }

  124. }


复制代码

所有资料51hei提供下载:
陀螺仪资料.rar (1.09 MB, 下载次数: 23)




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

使用道具 举报

沙发
ID:102665 发表于 2019-9-2 10:12 | 只看该作者
好资料,正需要!!!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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