Étape 3 : Code pour mesurer la température :
Permet de démarrer avec le code de particules maintenant.
Lorsque vous utilisez le module détecteur avec l’arduino, nous incluons des bibliothèques application.h et spark_wiring_i2c.h. Bibliothèque « application.h » et spark_wiring_i2c.h contient les fonctions qui facilitent la communication i2c entre le capteur et la particule.
Le code de toute particule est donné ci-dessous pour la commodité de l’utilisateur :
#include<application.h> #include<spark_wiring_i2c.h> // STS21 I2C address is 0x4A(74)#define addr 0x4Afloat cTemp = 0.0; void setup() { // Set variable Particle.variable("i2cdevice", "STS21"); Particle.variable("cTemp", cTemp); // Initialise I2C communication as MASTER Wire.begin(); // Start serial communication, set baud rate = 9600 Serial.begin(9600); delay(300);} void loop() { unsigned int data[2]; // Start I2C Transmission Wire.beginTransmission(addr); // Select no hold master Wire.write(0xF3); // End I2C Transmission Wire.endTransmission(); delay(500); // Request 2 bytes of data Wire.requestFrom(addr, 2); // Read 2 bytes of data if (Wire.available() == 2) { data[0] = Wire.read(); data[1] = Wire.read(); } // Convert the data int rawtmp = data[0] * 256 + data[1]; int value = rawtmp & 0xFFFC; cTemp = -46.85 + (175.72 * (value / 65536.0)); float fTemp = cTemp * 1.8 + 32; // Output data to dashboard Particle.publish("Temperature in Celsius : ", String(cTemp)); Particle.publish("Temperature in Fahrenheit: ", String(fTemp)); delay(1000); }
Particle.variable() fonction crée les variables afin de stocker la sortie du capteur et Particle.publish() fonction affiche la sortie sur le tableau de bord du site.
La sortie du capteur est montrée dans l’image ci-dessus pour votre référence.