MLX90614 library. Working on both Mbed2 and Mbed5

Dependents:   MLX90614_Demo

Fork of MLX90614 by Hikaru Sugiura

Committer:
masrodjie
Date:
Fri May 04 07:29:44 2018 +0000
Revision:
5:933b7db866c5
Parent:
4:dcd4fe76bd13
Fix library to working on latest Mbed2 & Mbed5

Who changed what in which revision?

UserRevisionLine numberNew contents of line
aquahika 1:4a60d3f1e91e 1 #include "mbed.h"
aquahika 1:4a60d3f1e91e 2
aquahika 1:4a60d3f1e91e 3 //Melexis Infrared Thermometer MLX90614 Library
aquahika 1:4a60d3f1e91e 4
aquahika 1:4a60d3f1e91e 5 //*****************************************************************
aquahika 1:4a60d3f1e91e 6 // Build : 2011-06-08 Hikaru Sugiura
aquahika 1:4a60d3f1e91e 7 // Only read thermo data.
aquahika 1:4a60d3f1e91e 8 //
aquahika 1:4a60d3f1e91e 9 // This program is based on Mr.Mitesh Patel's "mlx90614".
aquahika 1:4a60d3f1e91e 10 // http://mbed.org/users/mitesh2patel/programs/mlx90614/lqnetj
aquahika 1:4a60d3f1e91e 11 //
aquahika 1:4a60d3f1e91e 12 // This program does not check CRC.
aquahika 1:4a60d3f1e91e 13 // If you want to check CRC, please do it your self :)
aquahika 1:4a60d3f1e91e 14 //****************************************************************//
aquahika 1:4a60d3f1e91e 15
aquahika 3:eb618e916622 16 /**An Interface for MLX90614
aquahika 3:eb618e916622 17 *
aquahika 3:eb618e916622 18 * @code
aquahika 2:01d333d06727 19 * //Print temperature data
aquahika 2:01d333d06727 20 * #include "mbed.h"
aquahika 2:01d333d06727 21 * #include "mlx90614.h"
aquahika 2:01d333d06727 22 *
masrodjie 5:933b7db866c5 23 * I2C i2c(PB_9, PB_8); //sda,scl
masrodjie 5:933b7db866c5 24 * MLX90614 thermometer(&i2c, 0x5A);
aquahika 4:dcd4fe76bd13 25 * float temp;
aquahika 2:01d333d06727 26 *
aquahika 2:01d333d06727 27 * void main(void){
aquahika 4:dcd4fe76bd13 28 * if(thermometer.getTemp(&temp)){
aquahika 2:01d333d06727 29 * printf("Temperature : %f \r\n",temp);
aquahika 2:01d333d06727 30 * }
aquahika 2:01d333d06727 31 * wait(0.5);
aquahika 2:01d333d06727 32 *
aquahika 2:01d333d06727 33 * }
aquahika 3:eb618e916622 34 * @endcode
aquahika 3:eb618e916622 35 */
aquahika 2:01d333d06727 36
aquahika 2:01d333d06727 37
aquahika 1:4a60d3f1e91e 38 class MLX90614{
aquahika 1:4a60d3f1e91e 39
aquahika 1:4a60d3f1e91e 40 public:
aquahika 2:01d333d06727 41 /** Create MLX90614 interface, initialize with selected I2C port and address.
aquahika 2:01d333d06727 42 *
aquahika 2:01d333d06727 43 * @param i2c I2C device pointer
masrodjie 5:933b7db866c5 44 * @param addr Device address(default=0x5A)
aquahika 2:01d333d06727 45 */
masrodjie 5:933b7db866c5 46 MLX90614(I2C* i2c,int addr=0x5A);
aquahika 2:01d333d06727 47
aquahika 2:01d333d06727 48 /** Get Temperature data from MLX90614.
aquahika 2:01d333d06727 49 *
aquahika 2:01d333d06727 50 * @param temp_val return valiable pointer
aquahika 2:01d333d06727 51 * @return 0 on success (ack), or non-0 on failure (nack)
aquahika 2:01d333d06727 52 */
aquahika 1:4a60d3f1e91e 53 bool getTemp(float* temp_val);
aquahika 1:4a60d3f1e91e 54
aquahika 1:4a60d3f1e91e 55 private:
aquahika 1:4a60d3f1e91e 56 I2C* i2c;
aquahika 1:4a60d3f1e91e 57 int i2caddress;
aquahika 1:4a60d3f1e91e 58
aquahika 0:9237d31f0d03 59 };