Hello all i made a mysensors sketch with a DHT sensor and a relay in one node with 3 child devices.
#include <SPI.h>
#include <MySensor.h>
#include <DHT.h>
#define NODE_ID 5 // ID of node
//child ids
#define CHILD_ID_HUM 0
#define CHILD_ID_TEMP 1
#define CHILD_ID_VLIGHT0 2
//pin definitions
#define RELAY_PIN0 4
#define HUMIDITY_SENSOR_DIGITAL_PIN 3
//relay state
#define RELAY_ON 0
#define RELAY_OFF 1
#define NUMBER_OF_RELAYS 1
//sleep timer settings
unsigned long SLEEP_TIME = 1000; // Sleep time var, first read is 0
unsigned long SLEEP_TIME_POST = 60000; // Sleep time var changes to this value after
unsigned long LAST_SLEEP_TIME = millis(); // Sleep time between reads (in milliseconds)
bool state;
//mysensors setup
MySensor gw;
MyMessage msgHum(CHILD_ID_HUM, V_HUM);
MyMessage msgTemp(CHILD_ID_TEMP, V_TEMP);
MyMessage msgLSW0(CHILD_ID_VLIGHT0, V_LIGHT);
//dht setup
DHT dht;
float lastTemp;
float lastHum;
boolean metric = true;
void setup()
{
// Make sure relays are off when starting up
digitalWrite(RELAY_PIN0, RELAY_OFF);
// Then set relay pins in output mode
pinMode(RELAY_PIN0, OUTPUT);
dht.setup(HUMIDITY_SENSOR_DIGITAL_PIN);
// mysensor startup and Send the Sketch Version Information to the Gateway
gw.begin(incomingMessage, AUTO, true);
gw.sendSketchInfo("DHT&relay&button", "1.1");
// Register all sensors to gw (they will be created as child devices)
gw.present(CHILD_ID_HUM, S_HUM);
gw.present(CHILD_ID_TEMP, S_TEMP);
gw.present(CHILD_ID_VLIGHT0, S_LIGHT);
delay(1000);
metric = gw.getConfig().isMetric;
// Set relay to last known state (using eeprom storage)
state = gw.loadState(CHILD_ID_VLIGHT0);
digitalWrite(RELAY_PIN0, state?RELAY_ON:RELAY_OFF);
}
void loop()
{
if (millis() - LAST_SLEEP_TIME > SLEEP_TIME) {
dhtupdate();
LAST_SLEEP_TIME=millis();
if (SLEEP_TIME < SLEEP_TIME_POST) {
SLEEP_TIME=SLEEP_TIME_POST;
}
}
gw.process();
}
void incomingMessage(const MyMessage &message) {
// We only expect one type of message from controller. But we better check anyway.
if (message.isAck()) {
Serial.println("This is an ack from gateway");
}
if (message.type == V_LIGHT) {
if (message.sensor == CHILD_ID_VLIGHT0){
// Change relay state
digitalWrite(RELAY_PIN0, message.getBool()?RELAY_ON:RELAY_OFF);
// Store state in eeprom
gw.saveState(message.sensor, message.getBool());
// Write some debug info
Serial.print("Incoming change for relay1 sensor:");
Serial.print(message.sensor);
Serial.print(", New status: ");
Serial.println(message.getBool());
}
}
}
void dhtupdate() {
float temperature = dht.getTemperature();
if (isnan(temperature)) {
Serial.println("Failed reading temperature from DHT");
} else if (temperature != lastTemp) {
lastTemp = temperature;
if (!metric) {
temperature = dht.toFahrenheit(temperature);
}
gw.send(msgTemp.set(temperature, 1));
Serial.print("T: ");
Serial.println(temperature);
}
float humidity = dht.getHumidity();
if (isnan(humidity)) {
Serial.println("Failed reading humidity from DHT");
} else if (humidity != lastHum) {
lastHum = humidity;
gw.send(msgHum.set(humidity, 1));
Serial.print("H: ");
Serial.println(humidity);
}
}
WHen i upload the sketch i cannot discover device but i do see output in debug. in debug i see the following.
debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;read: 2-2-0 s=1,c=1,t=23,pt=2,l=2,sg=0:95
08:08:16debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;send: 0-0-255-255 s=255,c=3,t=8,pt=1,l=1,sg=0,st=bc:0
08:08:16debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;read and forward: 255-255-255 s=255,c=3,t=7,pt=0,l=0,sg=0:
08:08:14debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;send: 0-0-255-255 s=255,c=3,t=8,pt=1,l=1,sg=0,st=bc:0
08:08:14debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;read and forward: 255-255-255 s=255,c=3,t=7,pt=0,l=0,sg=0:
08:08:12debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;send: 0-0-255-255 s=255,c=3,t=8,pt=1,l=1,sg=0,st=bc:0
08:08:12debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;read and forward: 255-255-255 s=255,c=3,t=7,pt=0,l=0,sg=0:
08:08:10debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;send: 0-0-255-255 s=255,c=3,t=8,pt=1,l=1,sg=0,st=bc:0
08:08:10debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;read and forward: 255-255-255 s=255,c=3,t=7,pt=0,l=0,sg=0:
08:08:08debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;send: 0-0-255-255 s=255,c=3,t=8,pt=1,l=1,sg=0,st=bc:0
08:08:08debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;read and forward: 255-255-255 s=255,c=3,t=7,pt=0,l=0,sg=0:
08:08:06debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;send: 0-0-255-255 s=255,c=3,t=8,pt=1,l=1,sg=0,st=bc:0
08:08:06debug [pimatic-mysensors]: <- I_LOG_MESSAGE 0;0;3;0;9;read and forward: 255-255-255 s=255,c=3,t=7,pt=0,l=0,sg=0:
does somebody has an idea?