找回密码
 立即注册

QQ登录

只需一步,快速开始

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

GY-271+QMC5883L电子指南针 磁场检测资料程序

[复制链接]
跳转到指定楼层
楼主
ID:1108858 发表于 2024-1-10 21:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
GY-271+QMC5883L电子指南针罗盘模块+三轴磁场传感器

单片机源程序如下:
  1. #include "GY273.h"
  2. #include "i2c.h"
  3. #include "delay.h"
  4. #include "math.h"
  5. int16_t data[3];
  6. double gy273_xy_angle,gy273_yz_angle,gy273_xz_angle;
  7. double x,y,z;
  8. void hmc_write_reg(u8 reg,u8 data)
  9. {
  10.         IIC_Start();
  11.         IIC_Send_Byte(WRITE_ADDRESS);
  12.         IIC_Wait_Ack();
  13.         IIC_Send_Byte(reg);
  14.         IIC_Wait_Ack();
  15.         IIC_Send_Byte(data);
  16.         IIC_Wait_Ack();
  17.         IIC_Stop();
  18.         //delay_ms(5);
  19. }

  20. u8 hmc_read_reg(u8 reg)
  21. {
  22.         u8 data;
  23.         IIC_Start();
  24.         IIC_Send_Byte(WRITE_ADDRESS);
  25.         IIC_Wait_Ack();
  26.         IIC_Send_Byte(reg);
  27.         IIC_Wait_Ack();
  28.         IIC_Stop();
  29.         IIC_Start();
  30.         IIC_Send_Byte(READ_ADDRESS);
  31.         IIC_Wait_Ack();
  32.         data=IIC_Read_Byte();
  33.         IIC_NAck();
  34.         IIC_Stop();
  35.         return data;
  36. }

  37. void hmc_read_XYZ(int16_t *data)
  38. {
  39. //        int16_t temp;
  40. //        temp=hmc_read_reg(DATAX_M);
  41. //        *data++=(temp<<8)+hmc_read_reg(DATAX_L);
  42.         *data++=(hmc_read_reg(DATAX_M)<<8)|hmc_read_reg(DATAX_L);       
  43. //        temp=hmc_read_reg(DATAY_M);
  44. //        *data++=(temp<<8)+hmc_read_reg(DATAY_L);
  45.         *data++=(hmc_read_reg(DATAY_M)<<8)|hmc_read_reg(DATAY_L);       
  46. //        temp=hmc_read_reg(DATAZ_M);
  47. //        *data++=(temp<<8)+hmc_read_reg(DATAZ_L);
  48.         *data++=(hmc_read_reg(DATAZ_M)<<8)|hmc_read_reg(DATAZ_L);
  49. //        printf("%f %f %f %f\r\n",x,y,z,angle);
  50. }

  51. void hmc_init(void)
  52. {
  53.         hmc_write_reg(0X0B,0x01);
  54.         hmc_write_reg(0X20,0x40);
  55.         hmc_write_reg(0X21,0x01);
  56.         hmc_write_reg(CONFIGA,0x1D);
  57.         delay_ms(10);
  58. }

  59. void gy273_Work(void){
  60.         hmc_read_XYZ(data);
  61.         gy273_xy_angle=atan2((double)data[0],(double)data[1])*(180 / 3.14159265)+180;
  62.         gy273_yz_angle=atan2((double)data[1],(double)data[2])*(180 / 3.14159265)+180;
  63.         gy273_xz_angle=atan2((double)data[0],(double)data[2])*(180 / 3.14159265)+180;
  64.         x=(double)data[0];
  65.         y=(double)data[1];
  66.         z=(double)data[2];
  67.         delay_ms(100);
  68. }
复制代码

程序.7z (3.12 MB, 下载次数: 15)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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