NETBOARD

NETBOARD (3)

Friday, 05 June 2015 08:06

DS18B20 Temperature Logger v1.0

Written by

 




NETBOARD

 

 

 

 

 

s

 

 

 

 

 

#include <UIPEthernet.h>
#include <OneWire.h>

  OneWire  ds(2);  // on pin 2
  byte i;
  byte present = 0;
  byte type_s;
  byte data[12];
  byte addr[8];
  float celsius, fahrenheit;

EthernetServer server = EthernetServer(80);

void setup()
{
  Serial.begin(9600);

  uint8_t mac[6] = {0x00,0x01,0x02,0x03,0x04,0x05};
  IPAddress myIP(192,168,1,189);

  Ethernet.begin(mac,myIP);

  server.begin();
 
 
}

void loop()
{
  size_t size;
 
  if (EthernetClient client = server.available())
    {
      while((size = client.available()) > 0)
        {
          uint8_t* msg = (uint8_t*)malloc(size);
          size = client.read(msg,size);
          Serial.write(msg,size);
          free(msg);
        }
        
      DS1820();
      
      client.println("<?xml version='1.0' encoding='UTF-8'?>");
      client.println("<response>");
      
      client.println("<sensor1>");
      
      // ID
      client.println("<id>");
        for ( i = 0; i < 9; i++) {           // we need 9 bytes
          client.print(addr[i], HEX);
        }
      client.println("</id>");
      
      // Temperature
      client.println("<temp>");
      client.println(celsius);
      client.println("</temp>");
      client.println("</sensor1>");
      
      client.println("<version>");
      client.println("<model>KMtronic DS1820 Temperature Logger</model>");
      client.println("<ver>1.0</ver>");
      client.println("</version>");
      
      client.println("</response>");
      client.stop();
    }
}


void DS1820()
{

 
  if ( !ds.search(addr)) {
    Serial.println("No more addresses.");
    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 0x10:
      Serial.println("  Chip = DS18S20");  // or old DS1820
      type_s = 1;
      break;
    case 0x28:
      Serial.println("  Chip = DS18B20");
      type_s = 0;
      break;
    case 0x22:
      Serial.println("  Chip = DS1822");
      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] == 0x10) {
      // "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(" Celsius, ");
  Serial.print(fahrenheit);
  Serial.println(" Fahrenheit");
}

 

 

 

 

 

 

Tuesday, 09 December 2014 11:22

NETBOARD

Written by

 

NETBOARD

 

RS485

 

 

Tuesday, 21 February 2012 14:59

DINo Internet Ethernet IO board

Written by

 

 

DINo Internet/Ethernet Relay I/O board

( Arduino compatible, fully assembled and tested )

 

 

 

Arduino IDE compatible

Features

• ATMEGA328 Microcontroller
• ENC28J60 Ethernet Controller
• Built-in USB FTDI USB to Serial COM port converter
• Built-in RS-485 converter
• 4 Opto Isolated Digital Inputs
• 4 Relays 220VAC/10Am
• Reset Button
• Code upload via USB with the Bootloader

 

Specification

• Microcontroller - ATmega328
• Power Voltage - 12VDC/1000mA
• Digital Inputs Voltage - 5-24VDC
• Ethernet Controller - ENC28J60
• Digital Input Pins - 4
• Relays - 4
• Flash Memory - 32 KB (ATmega328) of which 2 KB used by bootloader
• SRAM - 2 KB (ATmega328)
• EEPROM - 1 KB (ATmega328)
• Clock Speed - 16 MHz

 

What projects you can realize using this board?

Some ideas ...
• Build a garage door opener with Internet or IPhone
• Control using WEB any high or low voltage equipment
• Build simple home automation and control lamps or other home equipment
• Longing processes and save to WEB server SQL base
• Build long distance 4 lines extender using two board connected directly or using Enthernet
and many more ...

 

 

back to Arduino DINo projects