找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1140|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

GY-271+QMC5883L電子指南針 磁場檢測資料程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:1108858 發(fā)表于 2024-1-10 21:53 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
GY-271+QMC5883L電子指南針羅盤模塊+三軸磁場傳感器

單片機(jī)源程序如下:
  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. }
復(fù)制代碼

程序.7z (3.12 MB, 下載次數(shù): 15)

評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂1 踩
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表