久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3217|回復: 1
打印 上一主題 下一主題
收起左側

GY-271 hmc5883l資料 手冊 單片機例程分享

[復制鏈接]
跳轉到指定樓層
樓主
分享一下GY-271 HMC5883L的資料 手冊 單片機例程 希望對需要的老哥們有幫助!!!


單片機源程序如下:
  1. #include "reg52.h"
  2. #include "intrins.h"
  3. #include "math.h"
  4. #include "iic.h"
  5. #include "lcd.h"
  6. #include "stdio.h"



  7. u8 ge=0,shi=0,bai=0,qian=0,wan=0;          //顯示變量            
  8. u8 BUF[8]=0;                                                  //數據緩沖區

  9. //******************************顯示在LCD的數據取位********************************//
  10. void Conversion(u16 temp_data)  
  11. {  
  12.     wan=temp_data/10000+0x30 ;
  13.     temp_data=temp_data%10000;   //取余運算
  14.         qian=temp_data/1000+0x30 ;
  15.     temp_data=temp_data%1000;    //取余運算
  16.     bai=temp_data/100+0x30   ;
  17.     temp_data=temp_data%100;     //取余運算
  18.     shi=temp_data/10+0x30    ;
  19.     temp_data=temp_data%10;      //取余運算
  20.     ge=temp_data+0x30;         
  21. }


  22. void main()
  23. {
  24. //        u16 i;
  25.         int X=0,Y=0,Z=0;
  26.         double Angle_XY=0,Angle_XZ=0,Angle_YZ=0;        
  27.     Delay_ms(200);
  28.         Init_Lcd();
  29.         Init_QMC5883();
  30.         Delay_ms(300);
  31.         while(1)            
  32.         {
  33.                 Multiple_Read_QMC5883();                                      //連續讀取三軸角度數據,存儲在BUF中
  34.                 //---------顯示XY軸
  35.                 X=BUF[1] << 8 | BUF[0]; //Combine MSB and LSB of X Data output register  最高有效位
  36.                 Y=BUF[3] << 8 | BUF[2]; //Combine MSB and LSB of Y Data output register
  37.                 Z=BUF[5] << 8 | BUF[4]; //Combine MSB and LSB of Z Data output register
  38.                
  39.                 if(X>0x7fff)X-=0xffff;         
  40.                 if(Y>0x7fff)Y-=0xffff;
  41.                 if(Z>0x7fff)Z-=0xffff;         
  42.                
  43.                 Display_One_Char(0,0,'Q');
  44.                 Display_One_Char(1,0,'M');
  45.                 Display_One_Char(2,0,'C');
  46.                 Display_One_Char(3,0,'5');
  47.                 Display_One_Char(4,0,'8');
  48.                 Display_One_Char(5,0,'8');
  49.                 Display_One_Char(6,0,'3');

  50.                 Angle_XY= atan2((double)Y,(double)X) * (180 / 3.14159265) + 180; //計算XY平面角度
  51.                 Angle_XY*=10;
  52.                 Conversion(Angle_XY);       //計算XY平面角度數據和顯示
  53.                 Display_One_Char(8,0,'X');
  54.                 Display_One_Char(9,0,'Y');
  55.                 Display_One_Char(10,0,':');
  56.                 Display_One_Char(11,0,qian);
  57.                 Display_One_Char(12,0,bai);
  58.                 Display_One_Char(13,0,shi);
  59.                 Display_One_Char(14,0,'.');
  60.                 Display_One_Char(15,0,ge);
  61.                
  62.                 Angle_XZ= atan2((double)Z,(double)X) * (180 / 3.14159265) + 180; //計算XZ平面角度
  63.                 Angle_XZ*=10;
  64.                 Conversion(Angle_XZ);       //計算XZ平面角度數據和顯示
  65.                 Display_One_Char(0,1,'X');
  66.                 Display_One_Char(1,1,'Z');
  67.                 Display_One_Char(2,1,':');
  68.                 Display_One_Char(3,1,qian);
  69.                 Display_One_Char(4,1,bai);
  70.                 Display_One_Char(5,1,shi);
  71.                 Display_One_Char(6,1,'.');
  72.                 Display_One_Char(7,1,ge);
  73.                
  74.                 Angle_YZ= atan2((double)Z,(double)Y) * (180 / 3.14159265) + 180; //計算YZ平面角度
  75.                 Angle_YZ*=10;
  76.                 Conversion(Angle_YZ);       //計算YZ平面角度數據和顯示
  77.                 Display_One_Char(8,1,'Y');
  78.                 Display_One_Char(9,1,'Z');
  79. ……………………

  80. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼
  1. //***************************************
  2. // HMC5883 51串口測試程序
  3. // 使用單片機STC89C51
  4. // 晶振:11.0592M
  5. // 顯示:PC串口
  6. // 編譯環境 Keil uVision2
  7. // 參考宏晶網站24c04通信程序
  8. // 時間:2011年3月1日
  9. //****************************************
  10. #include  <REG51.H>       
  11. #include  <math.h>    //Keil library  
  12. #include  <stdio.h>   //Keil library       
  13. #include  <INTRINS.H>
  14. #define   uchar unsigned char
  15. #define   uint  unsigned int       
  16. //使用的端口,請按照以下接線
  17. #define DataPort P0        //LCD1602數據端口
  18. sbit        SCL=P1^0;      //IIC時鐘引腳定義
  19. sbit        SDA=P1^1;      //IIC數據引腳定義


  20. #define        SlaveAddress   0x3C          //定義器件5883在IIC總線中的從地址
  21. typedef unsigned char BYTE;
  22. typedef unsigned short WORD;

  23. BYTE BUF[8];                         //接收數據緩存區             
  24. uchar ge,shi,bai,qian,wan;           //顯示變量
  25. int  dis_data;                       //變量
  26. //************

  27. //************
  28. void delay(unsigned int k);
  29. void Init_HMC5883(void);            //初始化5883
  30. void conversion(uint temp_data);

  31. void  Single_Write_HMC5883(uchar REG_Address,uchar REG_data);   //單個寫入數據
  32. //uchar Single_Read_HMC5883(uchar REG_Address);                   //單個讀取內部寄存器數據
  33. void  Multiple_Read_HMC5883();                                  //連續的讀取內部寄存器數據
  34. //以下是模擬iic使用函數-------------
  35. void Delay5us();
  36. void Delay5ms();
  37. void HMC5883_Start();
  38. void HMC5883_Stop();
  39. void HMC5883_SendACK(bit ack);
  40. bit  HMC5883_RecvACK();
  41. void HMC5883_SendByte(BYTE dat);
  42. BYTE HMC5883_RecvByte();
  43. void HMC5883_ReadPage();
  44. void HMC5883_WritePage();
  45. //-----------------------------------

  46. //*********************************************
  47. //串口初始化
  48. //9600 bps @ 11.059 MHz
  49. void init_uart()
  50. {
  51.         TMOD=0x21;                               
  52.         TH1=0xfd;                               
  53.         TL1=0xfd;                               
  54.         SCON=0x50;
  55.         PS=1;      //串口中斷設為高優先級別
  56.         TR0=1;           //啟動定時器                       
  57.         TR1=1;
  58.         ET0=1;     //打開定時器0中斷                       
  59.         ES=1;       
  60. }

  61. //*********串口數據發送******************
  62. void  SeriPushSend(uchar send_data)
  63. {
  64.     SBUF=send_data;  
  65.         while(!TI);TI=0;          
  66. }
  67. //*********************************************************
  68. void conversion(uint temp_data)  
  69. {  
  70.     wan=temp_data/10000+0x30 ;
  71.     temp_data=temp_data%10000;   //取余運算
  72.         qian=temp_data/1000+0x30 ;
  73.     temp_data=temp_data%1000;    //取余運算
  74.     bai=temp_data/100+0x30   ;
  75.     temp_data=temp_data%100;     //取余運算
  76.     shi=temp_data/10+0x30    ;
  77.     temp_data=temp_data%10;      //取余運算
  78.     ge=temp_data+0x30;        
  79. }

  80. /*******************************/
  81. void delay(unsigned int k)       
  82. {                                               
  83. unsigned int i,j;                               
  84. for(i=0;i<k;i++)
  85. {                       
  86. for(j=0;j<121;j++)                       
  87. {;}}                                               
  88. }
  89.        

  90. /**************************************
  91. 延時5微秒(STC90C52RC@12M)
  92. 不同的工作環境,需要調整此函數,注意時鐘過快時需要修改
  93. 當改用1T的MCU時,請調整此延時函數
  94. **************************************/
  95. void Delay5us()
  96. {
  97.     _nop_();_nop_();_nop_();_nop_();
  98.     _nop_();_nop_();_nop_();_nop_();
  99.         _nop_();_nop_();_nop_();_nop_();
  100.         _nop_();_nop_();_nop_();_nop_();
  101.     _nop_();_nop_();_nop_();_nop_();
  102. }

  103. /**************************************
  104. 延時5毫秒(STC90C52RC@12M)
  105. 不同的工作環境,需要調整此函數
  106. 當改用1T的MCU時,請調整此延時函數
  107. **************************************/
  108. void Delay5ms()
  109. {
  110.     WORD n = 560;

  111.     while (n--);
  112. }

  113. /**************************************
  114. 起始信號
  115. **************************************/
  116. void HMC5883_Start()
  117. {
  118.     SDA = 1;                    //拉高數據線
  119.     SCL = 1;                    //拉高時鐘線
  120.     Delay5us();                 //延時
  121.     SDA = 0;                    //產生下降沿
  122.     Delay5us();                 //延時
  123.     SCL = 0;                    //拉低時鐘線
  124. }

  125. /**************************************
  126. 停止信號
  127. **************************************/
  128. void HMC5883_Stop()
  129. {
  130.     SDA = 0;                    //拉低數據線
  131.     SCL = 1;                    //拉高時鐘線
  132.     Delay5us();                 //延時
  133.     SDA = 1;                    //產生上升沿
  134.     Delay5us();                 //延時
  135. }

  136. /**************************************
  137. 發送應答信號
  138. 入口參數:ack (0:ACK 1:NAK)
  139. **************************************/
  140. void HMC5883_SendACK(bit ack)
  141. {
  142.     SDA = ack;                  //寫應答信號
  143.     SCL = 1;                    //拉高時鐘線
  144.     Delay5us();                 //延時
  145.     SCL = 0;                    //拉低時鐘線
  146.     Delay5us();                 //延時
  147. }

  148. /**************************************
  149. 接收應答信號
  150. **************************************/
  151. bit HMC5883_RecvACK()
  152. {
  153.     SCL = 1;                    //拉高時鐘線
  154.     Delay5us();                 //延時
  155.     CY = SDA;                   //讀應答信號
  156.     SCL = 0;                    //拉低時鐘線
  157.     Delay5us();                 //延時

  158.     return CY;
  159. }

  160. /**************************************
  161. 向IIC總線發送一個字節數據
  162. **************************************/
  163. void HMC5883_SendByte(BYTE dat)
  164. {
  165.     BYTE i;

  166.     for (i=0; i<8; i++)         //8位計數器
  167.     {
  168.         dat <<= 1;              //移出數據的最高位
  169.         SDA = CY;               //送數據口
  170.         SCL = 1;                //拉高時鐘線
  171.         Delay5us();             //延時
  172.         SCL = 0;                //拉低時鐘線
  173.         Delay5us();             //延時
  174.     }
  175.     HMC5883_RecvACK();
  176. }

  177. /**************************************
  178. 從IIC總線接收一個字節數據
  179. **************************************/
  180. BYTE HMC5883_RecvByte()
  181. {
  182.     BYTE i;
  183.     BYTE dat = 0;

  184.     SDA = 1;                    //使能內部上拉,準備讀取數據,
  185.     for (i=0; i<8; i++)         //8位計數器
  186.     {
  187.         dat <<= 1;
  188.         SCL = 1;                //拉高時鐘線
  189.         Delay5us();             //延時
  190.         dat |= SDA;             //讀數據               
  191.         SCL = 0;                //拉低時鐘線
  192.         Delay5us();             //延時
  193.     }
  194.     return dat;
  195. }

  196. //***************************************************

  197. void Single_Write_HMC5883(uchar REG_Address,uchar REG_data)
  198. {
  199.     HMC5883_Start();                  //起始信號
  200.     HMC5883_SendByte(SlaveAddress);   //發送設備地址+寫信號
  201.     HMC5883_SendByte(REG_Address);    //內部寄存器地址,請參考中文pdf
  202.     HMC5883_SendByte(REG_data);       //內部寄存器數據,請參考中文pdf
  203.     HMC5883_Stop();                   //發送停止信號
  204. }
  205. /*
  206. //********單字節讀取內部寄存器*************************
  207. uchar Single_Read_HMC5883(uchar REG_Address)
  208. {  uchar REG_data;
  209.     HMC5883_Start();                          //起始信號
  210.     HMC5883_SendByte(SlaveAddress);           //發送設備地址+寫信號
  211.     HMC5883_SendByte(REG_Address);                   //發送存儲單元地址,從0開始       
  212.     HMC5883_Start();                          //起始信號
  213.     HMC5883_SendByte(SlaveAddress+1);         //發送設備地址+讀信號
  214.     REG_data=HMC5883_RecvByte();              //讀出寄存器數據
  215.         HMC5883_SendACK(1);   
  216.         HMC5883_Stop();                           //停止信號
  217.     return REG_data;
  218. }
  219. */
  220. //******************************************************
  221. //
  222. //連續讀出HMC5883內部角度數據,地址范圍0x3~0x5
  223. //
  224. //******************************************************
  225. void Multiple_read_HMC5883(void)
  226. {   uchar i;
  227.     HMC5883_Start();                          //起始信號
  228.     HMC5883_SendByte(SlaveAddress);           //發送設備地址+寫信號
  229.     HMC5883_SendByte(0x03);                   //發送存儲單元地址,從0x3開始       
  230.     HMC5883_Start();                          //起始信號
  231.     HMC5883_SendByte(SlaveAddress+1);         //發送設備地址+讀信號
  232.          for (i=0; i<7; i++)                      //連續讀取6個地址數據,存儲中BUF
  233.     {
  234.         BUF[i] = HMC5883_RecvByte();          //BUF[0]存儲0x32地址中的數據
  235.         if (i == 6)
  236.         {
  237.            HMC5883_SendACK(1);                //最后一個數據需要回NOACK
  238.         }
  239.         else
  240.         {
  241.           HMC5883_SendACK(0);                //回應ACK
  242.        }
  243.    }
  244.     HMC5883_Stop();                          //停止信號
  245.     Delay5ms();
  246. }

  247. //初始化HMC5883,根據需要請參考pdf進行修改****
  248. void Init_HMC5883()
  249. {
  250.      Single_Write_HMC5883(0x02,0x00);  //
  251.          Single_Write_HMC5883(0x01,0xE0);  //
  252. }
  253. //*********************************************************
  254. //主程序********
  255. //*********************************************************
  256. void main()
  257. { // bit sign_bit;

  258.    unsigned int i;
  259.    int x,y,z;
  260.    double angle;


  261.    delay(100);                       
  262.    init_uart();
  263.    Init_HMC5883();

  264.   while(1)            //循環
  265.   {

  266.     Multiple_Read_HMC5883();      //連續讀出數據,存儲在BUF中
  267.         x = BUF[0] << 8 | BUF[1];
  268.     y = BUF[4] << 8 | BUF[5];
  269.         z = BUF[2] << 8 | BUF[3];
  270.     angle= atan2((double)y,(double)x) * (180 / 3.14159265) + 180; // angle in degrees
  271.     conversion(angle);       //計算數據和顯示

  272.     SeriPushSend(bai);
  273.     SeriPushSend(shi);
  274.         SeriPushSend(ge);

  275.         SeriPushSend(0x0d);
  276.         SeriPushSend(0x0a);

  277.     for (i=0;i<10000;i++);   //延時                  
  278.   }
  279. }

復制代碼


所有資料51hei提供下載:
GY-271 QMC5883L電子指南針羅盤模塊 三軸磁場傳感器(1).zip (3.18 MB, 下載次數: 33)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

沙發
ID:578562 發表于 2019-7-9 21:38 | 只看該作者
請問樓主用LCD顯示出來是三個方向的角度嗎
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 精品不卡 | 九九久久国产精品 | 久久成人免费视频 | 日本aa毛片a级毛片免费观看 | 成人激情视频免费在线观看 | 无吗视频 | 久久久www成人免费精品 | 伊人一区| 亚洲成人高清 | 精品一区二区久久久久久久网站 | 精品国产91 | 免费成人在线网站 | 欧美精品tv| 亚洲在线观看视频 | 久久99精品久久久久久青青日本 | 亚洲成人一区二区 | 欧美精品一区在线发布 | 91免费观看视频 | 黄色毛片一级 | 亚洲一区二区成人 | 日日综合 | 欧美一区二区视频 | 久久人人爽人人爽人人片av免费 | 欧美日韩国产精品一区 | 国产69精品久久99不卡免费版 | 国产日产久久高清欧美一区 | 久久精品国产亚洲 | 在线视频一区二区 | 日日日日日日bbbbb视频 | 亚洲免费视频一区 | 日日操天天射 | 国产欧美一区二区精品久导航 | 日韩一区二区免费视频 | 国产成人精品一区二区三区 | 一级片在线观看 | 久久99精品久久久 | 精品亚洲视频在线 | 欧美一级在线观看 | 九九热国产精品视频 | 亚洲精品视频久久 | 午夜精品一区二区三区在线观看 |