找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

GY-271 HMC5883L模塊測試程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:127035 發(fā)表于 2016-12-19 23:44 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
GY-271 HMC5883L模塊資料

所有內(nèi)容打包下載:
GY-271 HMC5883L模塊測試軟件與代碼.rar (4.07 MB, 下載次數(shù): 41)

部分源碼預(yù)覽:
  1. //***************************************
  2. // HMC5883 IIC測試程序
  3. // 使用單片機STC89C51
  4. // 晶振:11.0592M
  5. // 顯示:LCD1602
  6. // 編譯環(huán)境 Keil uVision2
  7. // 參考宏晶網(wǎng)站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數(shù)據(jù)端口
  18. sbit        SCL=P1^0;      //IIC時鐘引腳定義
  19. sbit        SDA=P1^1;      //IIC數(shù)據(jù)引腳定義
  20. sbit    LCM_RS=P2^0;   //LCD1602命令端口               
  21. sbit    LCM_RW=P2^1;   //LCD1602命令端口               
  22. sbit    LCM_EN=P2^2;   //LCD1602命令端口

  23. #define        SlaveAddress   0x3C          //定義器件在IIC總線中的從地址
  24. typedef unsigned char BYTE;
  25. typedef unsigned short WORD;

  26. BYTE BUF[8];                         //接收數(shù)據(jù)緩存區(qū)             
  27. uchar ge,shi,bai,qian,wan;           //顯示變量
  28. int  dis_data;                       //變量

  29. void delay(unsigned int k);
  30. void InitLcd();
  31. void Init_HMC5883(void);            //初始化5883

  32. void WriteDataLCM(uchar dataW);
  33. void WriteCommandLCM(uchar CMD,uchar Attribc);
  34. void DisplayOneChar(uchar X,uchar Y,uchar DData);
  35. void conversion(uint temp_data);

  36. void  Single_Write_HMC5883(uchar REG_Address,uchar REG_data);   //單個寫入數(shù)據(jù)
  37. uchar Single_Read_HMC5883(uchar REG_Address);                   //單個讀取內(nèi)部寄存器數(shù)據(jù)
  38. void  Multiple_Read_HMC5883();                                  //連續(xù)的讀取內(nèi)部寄存器數(shù)據(jù)
  39. //以下是模擬iic使用函數(shù)-------------
  40. void Delay5us();
  41. void Delay5ms();
  42. void HMC5883_Start();
  43. void HMC5883_Stop();
  44. void HMC5883_SendACK(bit ack);
  45. bit  HMC5883_RecvACK();
  46. void HMC5883_SendByte(BYTE dat);
  47. BYTE HMC5883_RecvByte();
  48. void HMC5883_ReadPage();
  49. void HMC5883_WritePage();
  50. //-----------------------------------

  51. //*********************************************************
  52. void conversion(uint temp_data)  
  53. {  
  54.     wan=temp_data/10000+0x30 ;
  55.     temp_data=temp_data%10000;   //取余運算
  56.         qian=temp_data/1000+0x30 ;
  57.     temp_data=temp_data%1000;    //取余運算
  58.     bai=temp_data/100+0x30   ;
  59.     temp_data=temp_data%100;     //取余運算
  60.     shi=temp_data/10+0x30    ;
  61.     temp_data=temp_data%10;      //取余運算
  62.     ge=temp_data+0x30;        
  63. }

  64. /*******************************/
  65. void delay(unsigned int k)       
  66. {                                               
  67. unsigned int i,j;                               
  68. for(i=0;i<k;i++)
  69. {                       
  70. for(j=0;j<121;j++)                       
  71. {;}}                                               
  72. }
  73. /*******************************/
  74. void WaitForEnable(void)       
  75. {                                       
  76. DataPort=0xff;               
  77. LCM_RS=0;LCM_RW=1;_nop_();
  78. LCM_EN=1;_nop_();_nop_();
  79. while(DataPort&0x80);       
  80. LCM_EN=0;                               
  81. }                                       
  82. /*******************************/
  83. void WriteCommandLCM(uchar CMD,uchar Attribc)
  84. {                                       
  85. if(Attribc)WaitForEnable();       
  86. LCM_RS=0;LCM_RW=0;_nop_();
  87. DataPort=CMD;_nop_();       
  88. LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  89. }                                       
  90. /*******************************/
  91. void WriteDataLCM(uchar dataW)
  92. {                                       
  93. WaitForEnable();               
  94. LCM_RS=1;LCM_RW=0;_nop_();
  95. DataPort=dataW;_nop_();       
  96. LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  97. }               
  98. /***********************************/
  99. void InitLcd()                               
  100. {                       
  101. WriteCommandLCM(0x38,1);       
  102. WriteCommandLCM(0x08,1);       
  103. WriteCommandLCM(0x01,1);       
  104. WriteCommandLCM(0x06,1);       
  105. WriteCommandLCM(0x0c,1);
  106. }                       
  107. /***********************************/
  108. void DisplayOneChar(uchar X,uchar Y,uchar DData)
  109. {                                               
  110. Y&=1;                                               
  111. X&=15;                                               
  112. if(Y)X|=0x40;                                       
  113. X|=0x80;                       
  114. WriteCommandLCM(X,0);               
  115. WriteDataLCM(DData);               
  116. }                                               

  117. /**************************************
  118. 延時5微秒(STC90C52RC@12M)
  119. 不同的工作環(huán)境,需要調(diào)整此函數(shù),注意時鐘過快時需要修改
  120. 當(dāng)改用1T的MCU時,請調(diào)整此延時函數(shù)
  121. **************************************/
  122. void Delay5us()
  123. {
  124.              _nop_();_nop_();_nop_();_nop_();
  125.              _nop_();_nop_();_nop_();_nop_();
  126.         _nop_();_nop_();_nop_();_nop_();
  127.         _nop_();_nop_();_nop_();_nop_();
  128.               _nop_();_nop_();_nop_();_nop_();
  129.         _nop_();_nop_();_nop_();_nop_();
  130.         _nop_();_nop_();_nop_();_nop_();
  131.              _nop_();_nop_();_nop_();_nop_();

  132. }

  133. /**************************************
  134. 延時5毫秒(STC90C52RC@12M)
  135. 不同的工作環(huán)境,需要調(diào)整此函數(shù)
  136. 當(dāng)改用1T的MCU時,請調(diào)整此延時函數(shù)
  137. **************************************/
  138. void Delay5ms()
  139. {
  140.     WORD n = 560;

  141.     while (n--);
  142. }

  143. /**************************************
  144. 起始信號
  145. **************************************/
  146. void HMC5883_Start()
  147. {
  148.     SDA = 1;                    //拉高數(shù)據(jù)線
  149.     SCL = 1;                    //拉高時鐘線
  150.     Delay5us();                 //延時
  151.     SDA = 0;                    //產(chǎn)生下降沿
  152.     Delay5us();                 //延時
  153.     SCL = 0;                    //拉低時鐘線
  154. }

  155. /**************************************
  156. 停止信號
  157. **************************************/
  158. void HMC5883_Stop()
  159. {
  160.     SDA = 0;                    //拉低數(shù)據(jù)線
  161.     SCL = 1;                    //拉高時鐘線
  162.     Delay5us();                 //延時
  163.     SDA = 1;                    //產(chǎn)生上升沿
  164.     Delay5us();                 //延時
  165. }

  166. /**************************************
  167. 發(fā)送應(yīng)答信號
  168. 入口參數(shù):ack (0:ACK 1:NAK)
  169. **************************************/
  170. void HMC5883_SendACK(bit ack)
  171. {
  172.     SDA = ack;                  //寫應(yīng)答信號
  173.     SCL = 1;                    //拉高時鐘線
  174.     Delay5us();                 //延時
  175.     SCL = 0;                    //拉低時鐘線
  176.     Delay5us();                 //延時
  177. }

  178. /**************************************
  179. 接收應(yīng)答信號
  180. **************************************/
  181. bit HMC5883_RecvACK()
  182. {
  183.     SCL = 1;                    //拉高時鐘線
  184.     Delay5us();                 //延時
  185.     CY = SDA;                   //讀應(yīng)答信號
  186.     SCL = 0;                    //拉低時鐘線
  187.     Delay5us();                 //延時

  188.     return CY;
  189. }

  190. /**************************************
  191. 向IIC總線發(fā)送一個字節(jié)數(shù)據(jù)
  192. **************************************/
  193. void HMC5883_SendByte(BYTE dat)
  194. {
  195.     BYTE i;

  196.     for (i=0; i<8; i++)         //8位計數(shù)器
  197.     {
  198.         dat <<= 1;              //移出數(shù)據(jù)的最高位
  199.         SDA = CY;               //送數(shù)據(jù)口
  200.         SCL = 1;                //拉高時鐘線
  201.         Delay5us();             //延時
  202.         SCL = 0;                //拉低時鐘線
  203.         Delay5us();             //延時
  204.     }
  205.     HMC5883_RecvACK();
  206. }

  207. /**************************************
  208. 從IIC總線接收一個字節(jié)數(shù)據(jù)
  209. **************************************/
  210. BYTE HMC5883_RecvByte()
  211. {
  212.     BYTE i;
  213.     BYTE dat = 0;

  214.     SDA = 1;                    //使能內(nèi)部上拉,準(zhǔn)備讀取數(shù)據(jù),
  215.     for (i=0; i<8; i++)         //8位計數(shù)器
  216.     {
  217.         dat <<= 1;
  218.         SCL = 1;                //拉高時鐘線
  219.         Delay5us();             //延時
  220.         dat |= SDA;             //讀數(shù)據(jù)               
  221.         SCL = 0;                //拉低時鐘線
  222.         Delay5us();             //延時
  223.     }
  224.     return dat;
  225. }

  226. //***************************************************

  227. void Single_Write_HMC5883(uchar REG_Address,uchar REG_data)
  228. {
  229.     HMC5883_Start();                  //起始信號
  230.     HMC5883_SendByte(SlaveAddress);   //發(fā)送設(shè)備地址+寫信號
  231.     HMC5883_SendByte(REG_Address);    //內(nèi)部寄存器地址,請參考中文pdf
  232.     HMC5883_SendByte(REG_data);       //內(nèi)部寄存器數(shù)據(jù),請參考中文pdf
  233.     HMC5883_Stop();                   //發(fā)送停止信號
  234. }

  235. //********單字節(jié)讀取內(nèi)部寄存器*************************
  236. uchar Single_Read_HMC5883(uchar REG_Address)
  237. {  uchar REG_data;
  238.     HMC5883_Start();                          //起始信號
  239.     HMC5883_SendByte(SlaveAddress);           //發(fā)送設(shè)備地址+寫信號
  240.     HMC5883_SendByte(REG_Address);                   //發(fā)送存儲單元地址,從0開始       
  241.     HMC5883_Start();                          //起始信號
  242.     HMC5883_SendByte(SlaveAddress+1);         //發(fā)送設(shè)備地址+讀信號
  243.     REG_data=HMC5883_RecvByte();              //讀出寄存器數(shù)據(jù)
  244.         HMC5883_SendACK(1);   
  245.         HMC5883_Stop();                           //停止信號
  246.     return REG_data;
  247. }
  248. //******************************************************
  249. //
  250. //連續(xù)讀出HMC5883內(nèi)部角度數(shù)據(jù),地址范圍0x3~0x5
  251. //
  252. //******************************************************
  253. void Multiple_read_HMC5883(void)
  254. {   uchar i;
  255.     HMC5883_Start();                          //起始信號
  256.     HMC5883_SendByte(SlaveAddress);           //發(fā)送設(shè)備地址+寫信號
  257.     HMC5883_SendByte(0x03);                   //發(fā)送存儲單元地址,從0x3開始       
  258.     HMC5883_Start();                          //起始信號
  259.     HMC5883_SendByte(SlaveAddress+1);         //發(fā)送設(shè)備地址+讀信號
  260.          for (i=0; i<6; i++)                      //連續(xù)讀取6個地址數(shù)據(jù),存儲中BUF
  261.     {
  262.         BUF[i] = HMC5883_RecvByte();          //BUF[0]存儲數(shù)據(jù)
  263.         if (i == 5)
  264.         {
  265.            HMC5883_SendACK(1);                //最后一個數(shù)據(jù)需要回NOACK
  266.         }
  267.         else
  268.         {
  269.           HMC5883_SendACK(0);                //回應(yīng)ACK
  270.        }
  271.    }
  272.     HMC5883_Stop();                          //停止信號
  273.     Delay5ms();
  274. }

  275. //初始化HMC5883,根據(jù)需要請參考pdf進行修改****
  276. void Init_HMC5883()
  277. {
  278.      Single_Write_HMC5883(0x02,0x00);  //
  279. }
  280. //*********************************************************
  281. //主程序********
  282. //*********************************************************
  283. void main()
  284. { // bit sign_bit;
  285.    unsigned int i;
  286.    int x,y,z;
  287.    double angle;

  288.    delay(500);                       
  289.    InitLcd();
  290.    Init_HMC5883();
  291.   while(1)            //循環(huán)
  292.   {
  293.     Multiple_Read_HMC5883();      //連續(xù)讀出數(shù)據(jù),存儲在BUF中
  294. //---------顯示X軸
  295.     x=BUF[0] << 8 | BUF[1]; //Combine MSB and LSB of X Data output register
  296.     z=BUF[2] << 8 | BUF[3]; //Combine MSB and LSB of Z Data output register
  297.     y=BUF[4] << 8 | BUF[5]; //Combine MSB and LSB of Y Data output register

  298.     angle= atan2((double)y,(double)x) * (180 / 3.14159265) + 180; // angle in degrees
  299.     angle*=10;
  300.     conversion(angle);       //計算數(shù)據(jù)和顯示
  301.         DisplayOneChar(2,0,'A');
  302.     DisplayOneChar(3,0,':');
  303.     DisplayOneChar(4,0,qian);
  304.     DisplayOneChar(5,0,bai);
  305.     DisplayOneChar(6,0,shi);
  306.     DisplayOneChar(7,0,'.');
  307.         DisplayOneChar(8,0,ge);

  308.     for (i=0;i<10000;i++);   //延時                  
  309.   }
  310. }
復(fù)制代碼


評分

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

查看全部評分

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

使用道具 舉報

沙發(fā)
ID:142559 發(fā)表于 2017-8-1 15:01 | 只看該作者
能詳細(xì)介紹一下他采集的原理嗎?
回復(fù)

使用道具 舉報

板凳
ID:399735 發(fā)表于 2018-9-18 21:53 | 只看該作者
看看是不是 好資料
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

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

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