標題: GY-906紅外測溫MLX90614源碼與資料 [打印本頁]

作者: 筱豆先生    時間: 2018-6-27 21:56
標題: GY-906紅外測溫MLX90614源碼與資料
GY906紅外測溫模塊資料


MLX90614 系列紅外測溫模塊的原理及應用
南京航空航天大學  曾德志
摘要:  MLX90614 系列模塊是一組通用的紅外測溫模塊。在出廠前該模塊已進行校驗及線
性化,具有非接觸、體積小、精度高,成本低等優(yōu)點。被測目標溫度和環(huán)境溫度能通過單通
道輸出,并有兩種輸出接口,適合于汽車空調(diào)、室內(nèi)暖氣、家用電器、手持設備以及醫(yī)療設
備應用等。本文以MLX90614AAA為例介紹其原理和應用。

1 引言
一般來說,測溫方式可分為接觸式和非接觸式,接觸式測溫只能測量被測物體與測溫傳
感器達到熱平衡后的溫度,所以響應時間長,且極易受環(huán)境溫度的影響;而紅外測溫是根據(jù)
被測物體的紅外輻射能量來確定物體的溫度,不與被測物體接觸,具有影響動被測物體溫度
分布場,溫度分辨率高、響應速度快、測溫范圍廣、不受測溫上限的限制、穩(wěn)定性好等特點,
近年來在家庭自動化、汽車電子、航空和軍事上得到越來越廣泛的應用。


單片機源程序如下:
  1. #include"at89x52.h"
  2. #include"intrins.h"
  3. //************************************
  4. #define  uint  unsigned int
  5. #define  uchar unsigned char
  6. #define  Nack_counter  10
  7. //************** 端口定義**************
  8. //LCD 控制線接口
  9. uchar flag1;
  10. sbit  RS=P0^7;
  11. sbit  RW=P0^6;
  12. sbit  LCDE=P0^5;
  13. //mlx90614 端口定義
  14. sbit  SCL=P1^6;// 時鐘線
  15. sbit  SDA=P1^7;// 數(shù)據(jù)線
  16. //************ 數(shù)據(jù)定義****************
  17. bdata uchar flag;//可位尋址數(shù)據(jù)
  18. sbit bit_out=flag^7;
  19. sbit bit_in=flag^0;
  20. uchar DataH,DataL,Pecreg;
  21. //************ 函數(shù)聲明*****************************************
  22. void   start_bit();                 //MLX90614 發(fā)起始位子程序
  23. void   stop_bit();                 //MLX90614發(fā)結(jié)束位子程序
  24. uchar  rx_byte(void);              //MLX90614 接收字節(jié)子程序
  25. void   send_bit(void);             //MLX90614發(fā)送位子程序
  26. void   tx_byte(uchar dat_byte);     //MLX90614 接收字節(jié)子程序
  27. void   receive_bit(void);           //MLX90614接收位子程序
  28. void   delay(uint N);              //延時程序
  29. uint   memread(void);             // 讀溫度數(shù)據(jù)
  30. void   init1602(void);        //LCD 初始化子程序
  31. void   chk_busy_flg(void);         //LCD 判斷忙子程序
  32. void   dis_cmd_wrt(uchar cmd);     //LCD 寫命令子程序
  33. void   dis_dat_wrt(uchar dat);       //LCD 寫數(shù)據(jù)子程序
  34. void   display(uint Tem);           // 顯示子程序
  35. //*************主函數(shù)*******************************************
  36. void main()
  37. {
  38. uint Tem;
  39. //函數(shù)部分
  40. SCL=1;SDA=1;_nop_();
  41. _nop_();_nop_();_nop_();
  42. SCL=0;
  43. delay(1000);
  44. SCL=1;
  45. init1602();
  46. while(1)
  47. {
  48.    Tem=memread();
  49.    display(Tem);
  50.    delay(20);
  51. }
  52. }
  53. //*********輸入轉(zhuǎn)換并顯示*********
  54. void display(uint Tem)
  55. {
  56. uint T,a,b;
  57. T=Tem*2;
  58.   dis_cmd_wrt(0x01);//清屏
  59. if(T>=27315)
  60. {
  61.    T=T-27315;
  62.    a=T/100;
  63.    b=T-a*100;
  64. //---------------------------
  65.    if(a>=100)
  66.    {
  67.     dis_dat_wrt(0x30+a/100);
  68.     a=a%100;
  69.     dis_dat_wrt(0x30+a/10);
  70.     a=a%10;
  71.     dis_dat_wrt(0x30+a);
  72.    }
  73.    else if(a>=10)
  74.    {
  75.     dis_dat_wrt(0x30+a/10);
  76.     a=a%10;
  77.     dis_dat_wrt(0x30+a);
  78.    }
  79.    else
  80.    {
  81.     dis_dat_wrt(0x30+a);
  82.    }
  83.    dis_dat_wrt(0x2e);// 顯示點
  84.    //---------------------------
  85.   if(b>=10)
  86.   {
  87.     dis_dat_wrt(0x30+b/10);
  88. //    b=b%10;
  89. //    dis_dat_wrt(0x30+b);
  90.   }
  91.   else
  92.   {
  93.     dis_dat_wrt(0x30);
  94. //    dis_dat_wrt(0x30+b);
  95.   }
  96. }
  97. //==========
  98. else
  99. {
  100.   T=27315-T;
  101.   a=T/100;
  102.     b=T-a*100;
  103.   dis_dat_wrt(0x2d);
  104. //--------------------------
  105.   if(a>=10)
  106.   {
  107.     dis_dat_wrt(0x30+a/10);
  108.     a=a%10;
  109.     dis_dat_wrt(0x30+a);
  110.   }
  111.   else
  112.   {
  113.     dis_dat_wrt(0x30+a);
  114.   }
  115.   dis_dat_wrt(0x2e);//顯示點
  116. //--------------------------
  117.   if(b>=10)
  118.   {
  119.     dis_dat_wrt(0x30+b/10);
  120.     b=b%10;
  121.     dis_dat_wrt(0x30+b);
  122.   }
  123.   else
  124.   {
  125.     dis_dat_wrt(0x30);
  126.     dis_dat_wrt(0x30+b);
  127.   }
  128. }
  129. }

  130. //************************************
  131. void   start_bit(void)
  132. {
  133.    SDA=1;
  134.    _nop_();_nop_();_nop_();_nop_();_nop_();
  135.    SCL=1;
  136.    _nop_();_nop_();_nop_();_nop_();_nop_();
  137.    SDA=0;
  138.    _nop_();_nop_();_nop_();_nop_();_nop_();
  139.    SCL=0;
  140.    _nop_();_nop_();_nop_();_nop_();_nop_();

  141. }
  142. //------------------------------
  143. void   stop_bit(void)
  144. {

  145.    SCL=0;
  146.    _nop_();_nop_();_nop_();_nop_();_nop_();
  147.    SDA=0;
  148.    _nop_();_nop_();_nop_();_nop_();_nop_();
  149.    SCL=1;
  150.    _nop_();_nop_();_nop_();_nop_();_nop_();
  151.    SDA=1;
  152. }
  153. //--------- 發(fā)送一個字節(jié)---------
  154. void  tx_byte(uchar dat_byte)
  155. {
  156.    char i,n,dat;
  157.    n=Nack_counter;
  158. TX_again:
  159.    dat=dat_byte;
  160.    for(i=0;i<8;i++)
  161.    {
  162.      if(dat&0x80)
  163.       bit_out=1;
  164.      else
  165.       bit_out=0;
  166.      send_bit();
  167.      dat=dat<<1;
  168.    }
  169.    
  170.       receive_bit();
  171.    if(bit_in==1)
  172.    {
  173.     stop_bit();
  174.     if(n!=0)
  175.     {n--;goto Repeat;}
  176.     else
  177.      goto exit;
  178.    }
  179.    else
  180.     goto exit;
  181. Repeat:
  182.     start_bit();
  183.     goto TX_again;
  184. exit: ;
  185. }
  186. //-----------發(fā)送一個位---------
  187. void  send_bit(void)
  188. {
  189.   if(bit_out==0)
  190.   
  191.        SDA=0;
  192.   else
  193.      SDA=1;
  194.   _nop_();
  195.   SCL=1;
  196.   _nop_();_nop_();_nop_();_nop_();
  197.   _nop_();_nop_();_nop_();_nop_();
  198.   SCL=0;
  199.   _nop_();_nop_();_nop_();_nop_();
  200.   _nop_();_nop_();_nop_();_nop_();
  201. }
  202. //---------- 接收一個字節(jié)--------
  203. uchar rx_byte(void)
  204. {
  205.   uchar i,dat;
  206.   dat=0;
  207.   for(i=0;i<8;i++)
  208.   {
  209.     dat=dat<<1;
  210.     receive_bit();
  211.     if(bit_in==1)
  212.      dat=dat+1;
  213.   }
  214.   send_bit();
  215.   return dat;
  216. }

  217. //---------- 接收一個位----------
  218. void receive_bit(void)
  219. {
  220.   SDA=1;bit_in=1;
  221.   SCL=1;
  222.   _nop_();_nop_();_nop_();_nop_();
  223.   _nop_();_nop_();_nop_();_nop_();
  224.   bit_in=SDA;
  225.   _nop_();
  226.   SCL=0;
  227.   _nop_();_nop_();_nop_();_nop_();
  228.   _nop_();_nop_();_nop_();_nop_();
  229. }
  230. //------------ 延時--------------
  231. void   delay(uint N)
  232. {
  233.   uint i;
  234.   for(i=0;i<N;i++)
  235.   
  236.      _nop_();
  237. }
  238. //------------------------------
  239. uint memread(void)
  240. {
  241.   start_bit();
  242.   tx_byte(0xB4);  //Send SlaveAddress ==============================
  243.   //tx_byte(0x00);
  244.   tx_byte(0x07);  //Send Command
  245.   //------------
  246.   start_bit();
  247.   tx_byte(0x01);
  248.   bit_out=0;
  249.   DataL=rx_byte();
  250.   bit_out=0;
  251.   DataH=rx_byte();
  252.   bit_out=1;
  253.   Pecreg=rx_byte();
  254.   stop_bit();
  255.   return(DataH*256+DataL);
  256. }
  257. //******************LCD 顯示子函數(shù)***********************
  258. void init1602(void)        // 初始化LCD
  259. {
  260.    dis_cmd_wrt(0x01);
  261.    dis_cmd_wrt(0x0c);
  262.    dis_cmd_wrt(0x06);
  263.    dis_cmd_wrt(0x38);
  264.    
  265.    }

  266. void chk_busy_flg(void) //LCD 忙標志判斷
  267. {
  268.    flag1=0x80;
  269.   while(flag1&0x80)
  270. {
  271.    P2=0xff;
  272.    RS=0;
  273.    RW=1;
  274.    LCDE=1;
  275. ……………………

  276. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

所有資料51hei提供下載:
GY-906紅外測溫MLX90614資料.rar (2.26 MB, 下載次數(shù): 527)






作者: 123#!    時間: 2019-4-12 15:12
芯片接到51單片機,需要在控制口加上拉電阻么
作者: mems    時間: 2020-2-17 19:58
mark一下
作者: cooleaf    時間: 2020-2-19 17:07
支持一下,感謝分享!
作者: at-king    時間: 2020-3-7 10:53
MARK一下.
作者: cwgyyj    時間: 2020-3-7 16:02
大俠,溫度讀出來0XFF,是哪里的問題!時序?qū)α撕茉敿,因該沒有錯!
作者: 世事莫太貪2020    時間: 2020-3-19 10:54
MARK一下.
作者: fafaaaa    時間: 2020-4-7 01:05
我想問一下,這個是最基本的測溫并且在顯示屏上顯示溫度嗎?沒有其他的功能了吧,比如超出上下限溫度范圍就會報警的功能,求大神回答一下呀!
作者: l976864147    時間: 2020-4-23 15:34
感謝分享
作者: xnhtao    時間: 2020-4-26 09:35
好漂亮,如果再配上電路圖就更完美了。
作者: 芒果椰子精    時間: 2020-4-27 10:04
感謝分享
作者: 3180415053    時間: 2020-5-18 11:11
fafaaaa 發(fā)表于 2020-4-7 01:05
我想問一下,這個是最基本的測溫并且在顯示屏上顯示溫度嗎?沒有其他的功能了吧,比如超出上下限溫度范圍就 ...

這個只需要加模塊就行,可以自己弄
作者: sensiblebobo    時間: 2020-6-6 21:32
請問各位大佬,為什么ARDUINO CODE里面的測試程序編譯時會出現(xiàn)如下報錯:
Arduino:1.8.12 (Windows 10), 開發(fā)板:"Arduino Uno"

C:\Users\15595\AppData\Local\Temp\cczEVT9j.ltrans0.ltrans.o: In function `global constructors keyed to 65535_0_mlxtest.ino.cpp.o.1887':

<artificial>:(.text.startup+0x5e): undefined reference to `Adafruit_MLX90614::Adafruit_MLX90614(unsigned char)'

C:\Users\15595\AppData\Local\Temp\cczEVT9j.ltrans0.ltrans.o: In function `setup':

C:\Users\15595\Desktop\工程實踐\GY-906\GY-906\ARDUINO CODE\MLX90614\examples\mlxtest/mlxtest.ino:32: undefined reference to `Adafruit_MLX90614::begin()'

C:\Users\15595\AppData\Local\Temp\cczEVT9j.ltrans0.ltrans.o: In function `loop':

C:\Users\15595\Desktop\工程實踐\GY-906\GY-906\ARDUINO CODE\MLX90614\examples\mlxtest/mlxtest.ino:36: undefined reference to `Adafruit_MLX90614::readAmbientTempC()'

C:\Users\15595\Desktop\工程實踐\GY-906\GY-906\ARDUINO CODE\MLX90614\examples\mlxtest/mlxtest.ino:37: undefined reference to `Adafruit_MLX90614::readObjectTempC()'

collect2.exe: error: ld returned 1 exit status

exit status 1

頭文件里的函數(shù)明明都定義好了啊
作者: 初學51000    時間: 2020-6-20 12:47
對后期的學習非常有用
作者: 浪跡塵中    時間: 2020-6-20 15:27
怎樣通過紅外傳感器實現(xiàn)測體溫呢
作者: xw836833095    時間: 2020-7-7 16:11
我按照這個GY906紅外測溫的代碼分享,實現(xiàn)了一下我的測溫裝置,LCD1602一直顯示382.1,我想請問各位大佬問題可能出在哪了呢?
作者: cyrs    時間: 2020-7-24 14:25
如何連接液晶屏32x24的
作者: JingXia_wang    時間: 2020-11-4 08:54
xw836833095 發(fā)表于 2020-7-7 16:11
我按照這個GY906紅外測溫的代碼分享,實現(xiàn)了一下我的測溫裝置,LCD1602一直顯示382.1,我想請問各位大佬問 ...

請問您解決了嗎
我也是一直顯示同樣的數(shù),不管紅外測溫儀連沒連都一樣
作者: 冷月楓    時間: 2021-1-14 11:09
JingXia_wang 發(fā)表于 2020-11-4 08:54
請問您解決了嗎
我也是一直顯示同樣的數(shù),不管紅外測溫儀連沒連都一樣

對的,我的也是這樣,大佬們解決了嗎

作者: suibh9    時間: 2021-3-4 06:05
冷月楓 發(fā)表于 2021-1-14 11:09
對的,我的也是這樣,大佬們解決了嗎

這個程序這么顯示,八成是電壓不夠,你是不是只用串口供電帶了一個測溫模塊,一個1602,一個51
。。。。那帶不動,加個正兒八經(jīng)的電源試試

作者: seal80    時間: 2021-8-9 14:12
mark,學習




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1