标题: GY-271+QMC5883L电子指南针 磁场检测资料程序 [打印本页]

作者: benlyl    时间: 2024-1-10 21:53
标题: GY-271+QMC5883L电子指南针 磁场检测资料程序
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)





欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1