Elektroda.pl
Elektroda.pl
X
Proszę, dodaj wyjątek dla www.elektroda.pl do Adblock.
Dzięki temu, że oglądasz reklamy, wspierasz portal i użytkowników.

DS18B20 na D1 mini Pro - wiele czujników

maroo78 01 Gru 2019 23:41 72 0
  • #1
    maroo78
    Poziom 9  
    Witam.

    W zasadzie jestem kompletnie ciemny - sklejam z tego co po sieci znajdę i coś tam działa. Chciałbym poniższy program zmodyfikować tak abym mógł dodawać konkretne czujniki ze swoimi adresami i wyświetlać ich odczyt pod konkretną nazwą - np. Temp.Salon: ... Adresy czujników mam bo załączony program wyświetla każdy czujnik w monitorze. Odczyty z konkretnych sensorów pod definiowaną nazwą planuję wyświetlać sekwencyjnie na OLED 64x48- ale mam nadzieję ze z tym sobie poradzę.

    Ogólnie wyrzucił bym wykrywanie jaki chip siedzi w sensorze, wszystkie mam DS18B20 z adresem 28 ...

    Dalsza kwestia po uporaniu się z powyższym, jak w Blynk odczytywać konkretne sensory - na tą chwilę umiem odczytać sensor z każdej płytki poprzez wybranie własnie płytki. A jak kilkoma na 1 płytce?

    Ps. uzywam delay by nie sypać temperaturami jak z rękawa - zapewne nie jest to dobre rozwiązanie, zresztą determinuje ono czas reakcji w komunikacji pomiędzy D1 a Blynk - więc to co wysyłam też jest z takim opóźnieniem realizowane - jak to ogarnąć, najpewniej jakimś rodzajem licznika?

    W propozycjach proszę o komentarze do poszczególnych lini, ułatwia to ogarnianie i zrozumienie.

    Program:
    #define BLYNK_PRINT Serial // Enables Serial Monitor
    #include <SPI.h>
    #include <ESP8266WiFi.h>
    #include <BlynkSimpleEsp8266.h>
    #include <OneWire.h>

    OneWire ds(D4); // on wemos pin D2 (a 4.7K resistor is necessary) make sure you change this from the original pin 10 to an unused pin.

    char auth[] = "bla bla bla"; // Termometr test Auth Token here. (see Step 3 above)
    // char auth[] = "bla bla bla"; // Termometr2 Put your Auth Token here. (see Step 3 above)
    // char auth[] = "bla bla bla"; // D1 Mini Pro Put your Auth Token here. (see Step 3 above)

    // Your WiFi credentials.
    // Set password to "" for open networks.
    char ssid[] = "bla bla bla";
    char pass[] = "bla bla bla";


    void setup()
    {
    // Debug console
    Serial.begin(9600);

    Blynk.begin(auth, ssid, pass);
    }

    void loop()
    {
    Blynk.run(); // All the Blynk Magic happens here...

    // You can inject your own code or combine it with other sketches.
    // Check other examples on how to communicate with Blynk. Remember
    // to avoid delay() function!

    delay(10000); // tego nie powinno tu być ;)
    byte i;
    byte present = 0;
    byte type_s;
    byte data[12];
    byte addr[8];
    float celsius, fahrenheit;

    if ( !ds.search(addr)) {
    Serial.println("No more addresses.");
    Serial.println(" ========================================== ");
    Serial.println();
    ds.reset_search();
    delay(250);
    return;
    }

    Serial.print("ROM =");
    for ( i = 0; i < 8; i++) {
    Serial.write(' ');
    Serial.print(addr[i], HEX);
    }

    if (OneWire::crc8(addr, 7) != addr[7]) {
    Serial.println("CRC is not valid!");
    return;
    }
    Serial.println();

    // the first ROM byte indicates which chip
    switch (addr[0]) {
    case 0x28:
    Serial.println(" Chip = DS18B20");
    type_s = 0;
    break;
    default:
    Serial.println("Device is not a DS18x20 family device.");
    return;
    }

    ds.reset();
    ds.select(addr);
    ds.write(0x44, 1); // start conversion, with parasite power on at the end

    delay(1000); // maybe 750ms is enough, maybe not
    // we might do a ds.depower() here, but the reset will take care of it.

    present = ds.reset();
    ds.select(addr);
    ds.write(0xBE); // Read Scratchpad

    Serial.print(" Data = ");
    Serial.print(present, HEX);
    Serial.print(" ");
    for ( i = 0; i < 9; i++) { // we need 9 bytes
    data[i] = ds.read();
    Serial.print(data[i], HEX);
    Serial.print(" ");
    }
    Serial.print(" CRC=");
    Serial.print(OneWire::crc8(data, 8), HEX);
    Serial.println();

    // Convert the data to actual temperature
    // because the result is a 16 bit signed integer, it should
    // be stored to an "int16_t" type, which is always 16 bits
    // even when compiled on a 32 bit processor.
    int16_t raw = (data[1] << 8) | data[0];
    if (type_s) {
    raw = raw << 3; // 9 bit resolution default
    if (data[7] == 0x20) {
    // "count remain" gives full 12 bit resolution
    raw = (raw & 0xFFF0) + 12 - data[6];
    }
    } else {
    byte cfg = (data[4] & 0x60);
    // at lower res, the low bits are undefined, so let's zero them
    if (cfg == 0x00) raw = raw & ~7; // 9 bit resolution, 93.75 ms
    else if (cfg == 0x20) raw = raw & ~3; // 10 bit res, 187.5 ms
    else if (cfg == 0x40) raw = raw & ~1; // 11 bit res, 375 ms
    //// default is 12 bit resolution, 750 ms conversion time
    }
    celsius = (float)raw / 16.0;
    fahrenheit = celsius * 1.8 + 32.0;
    Serial.print(" Temperature = ");
    Serial.print(celsius);
    Serial.print(" °C, ");
    Serial.print(fahrenheit);
    Serial.println(" Fahrenheit");
    Blynk.virtualWrite(V6, celsius);



    Bardzo bym prosił o pomoc w zmianach z pełnymi objaśnieniami co/jak/dlaczego.

    Pozdrawiam