Arduino-TempHumidity-with-LCD-And-Web-Interface ALLSTEPS

Download as pdf or txt
Download as pdf or txt
You are on page 1of 12

Arduino Temp/Humidity with LCD and Web Interface

let's make

Explore

Login|
Sign

Up

share what you

MAKESHIFT

Create

make >

Intel IoT

Contests

RadioShack

Arduino Temp/Humidity with LCD and Web Interface

Community

by SteveRoy

Black & Decker Fix &

Download Collection I Made it!


9 Steps

Favorite
Share

Repair

I recently helped a client move their office which included setting up a new computer room.
I wanted them to be able to check the temperature and humidity of the room both by checking an
LCD display in the room and also via a web page. I put together an Arduino with a DHT11 sensor,
16x2 LCD display and ENC28J60 Ethernet module. I did the project in stages first getting the
DHT11 portion working using the DHT11 library and examples from Adafruit, then adding an LCD
display and finally adding Ethernet using the EtherCard library and modifying their example code .
This makes troubleshooting a lot easier and I could build/learn the code as I went along. I have
taken code from the various examples provided with the necessary libraries.
This instructable will go through the steps to prototype this.
Note: the DHT11 sensor isn't very accurate - about plus and minus 2 degrees Celsius and 5%
accuracy for humidity. I'll probably be changing to a DHT22 which is plus and minus .5 degrees
Celsius and between 2% and 5% for humidity. The good news is it's an easy change in the code.

Remove these ads by Signing Up

Step 1:
http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (1 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

What you will need:

An Arduino
DHT11 or DHT22 sensor from Adafruit or various ebay vendors
10K resistor for the DHT11 pullup
16x2 LCD display HD44780
10k trimpot for LCD contrast
100 Ohm resistor for the LCD backlight
ENC26J60 Ethernet module or shield
Prototype shield if you use a regular Arduino and ENC28J60 Ethernet shield
hookup wire, breadboard etc for prototyping

Step 2: Wiring up the DHT11

http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (2 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

The DHT11 and DHT12 have 4 pins. Looking at it with the side with square cutouts in it the pins
are from left to right:
+5v
Signal
not used
GND
It also requires a 10k pullup resistor between +5V and Signal
For this project the Signal lead goes to Digital Pin 2 on the Arduino
The images show the DHT11 soldered into a prototype shield with the signal lead going to the
Arduino digital Pin2

Step 3: DHT11 library and test sketch

http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (3 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

Adafruit have a DHT11 library and example code that makes it easy to test the DHT11 and get
values to display on the serial window of the Arduino IDE

Download the library from Adafruit, the link takes you to the "GitHub" page. Look for the zip
file download button.
Unzip the files into your libraries folder. The best place to unzip to is under your "My
Documents\Arduino\Libraries" folder - later if you upgrade the Arduino IDE the library will still
be there.
If you browse to your libraries folder you should see a new folder named DHT-sensorlibrary-master Rename it to DHT
Connect up your Arduino and start the IDE
Look under File -> Examples -> DHT and open DHTtester.
You will need to comment the line startng with #define DHTTYPE DHT22 by
putting a // in front of it and then uncomment the line starting with //#define
DHTTYPE DHT11by removing the two leading //'s.
Upload the sketch then open the serial window. You should see the temperature and humidity
level scrolling. If you breathe onto the sensor you should see the temperature and humidity
rise. It will take a few seconds as the sensor is slow.

In the example sketch the temperature and humidity variables are defines as "float", i.e. they have
decimal places. This can be changed to an "int" to remove the decimal places as they aren't
needed in this project.
Find the lines:
float h = dht.readHumidity();
float t = dht.readTemperature();
and change them to:
int h = dht.readHumidity();
int t = dht.readTemperature();
Upload the sketch and check the results in the serial window. You should see the temperature as
whole rather than decimal numbers.
If you have a working sensor the next step is to connect an LCD display and see the temp and
humidity on it.
Before you go onto the next step you should save the sketch to a folder. This way if you need to
http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (4 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

troubleshoot later you can load the minimal code needed to test the sensor.
My test sketch:

DHT_Test.ino1 KB

Step 4: Wiring Up the LCD

http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (5 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

The LCD has 16 pins, 12 are used.


Pin1 to Ground
Pin 2 to +5V
Pin 3 to 10K trimpot center
Pin 4 (RS) to Arduino Digital Pin 3
Pin 5 (RW) to Ground
Pin 6 (E) to Arduino Digital Pin 4
Pin 7 - Not Used
Pin 8 - Not Used
Pin 9 - Not Used
Pin 10 - Not Used
Pin 11 (D4) to Arduino Digital Pin 5
Pin 12 (D5) to Arduino Digital Pin 6
Pin 13 (D6) to Arduino Digital Pin 7
Pin 14 (D7) to Arduino Digital Pin 8
Pin 15 (Back Light +) to 5v
Pin 16 (Back Light -) to ground via100 Ohm resistor)
One side of the 10K trimpot goes to +5v the other side to ground
See the schematic diagram and pictures.
Note I have flipped the Arduino upside down in the "Fritzing" schematic to match the photo's and
make the wiring neater.

Step 5: LCD test sketch


http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (6 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

The library for the HD44780 compatible LCD displays is included with the latest versions of the
Arduino IDE.

Open the "HelloWorld" test sketch under File -> Examples -> LiquidCrystal
Look for the line:

LiquidCrystal lcd(12, 11, 5, 4, 3, 2);


and change it to:
LiquidCrystal lcd(3, 4, 5, 6, 7, 8);
We need to change the pin assignments as the Ethernet controller we will add later uses pins 11
and 12

Upload the sketch


Adjust the trimpot until you see the display clearly
You should see hello, world! on the top line and numbers counting on the second line
Save the sketch to a folder.

The Arduino website has a good tutorial on LCD displays


It also covers the lcd.begin, the lcd.print, and the lcd.setCursor

LCD_Test.ino1 KB

Step 6: Combining the DHT11 and LCD sketches

If the DHT11 test sketch and the LCD test sketch both work we can combine them.
Load the sketch below.
Upload it to the Arduino - you should now see the temperature and humidity displayed on the LCD
screen.
Again, breathe on the sensor and you should see the temp and humidity change.
If this is working save the sketch and we can move onto setting up the Ethernet.

http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (7 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

DHT11andLCD.ino1 KB

Step 7: Wiring up the ENC28J60 module

I am using an ENC28J60 module for my prototype.


You need to supply 3.3V to this unit.
The pins we use on the module are:
http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (8 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

VCC, GND, CS, SO, SI, SCK


VCC to Arduino Pin 3.3V
GND to Arduino Pin GND
CS to Arduino Digital Pin 10
SI to Arduino Digital Pin 11
SO to Arduino Digital Pin 12
SCK to Arduino Digital Pin 13
The last thing to do is connect a Cat5 patch cable from the RJ45 port to a spare port on your
network router or switch.

Step 8: ENC28J60 Test Sketch and Library

Now that we have our Ethernet module wired we can test it with an example sketch.
Like the DHT11 we need to download ans install a library for it as it is not the "official" Arduino
Ethernet module (the WizNet W5100 is). The old library for the ENC28J60 is called EtherShield
and development has stopped for this library. The new library is called EtherCard and is available
on GitHub.
Like the DHT11 library you need to:
Download the zipped file and then unzip them into your library folder
Rename the folder to EtherCard.
Restart the Arduino IDE so the library will be included.

Load the example sketchrbbb_server

We need to change a couple of lines in the sketch so our IP address will be on the correct subnet
and also change the CS pin assignment from the default of digital pin 8 to digital pin 10.

Look for the line starting with - static byte myip[] and change the IP address to a
unused IP address on your network.
Look for the line:

if (ether.begin(sizeof Ethernet::buffer, mymac) == 0)


and change it to:
if (ether.begin(sizeof Ethernet::buffer, mymac, 10) == 0)
Upload the sketch then open a web browse on your PC and go to the IP address you specified in
the above address. You should see a timer counting.
http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (9 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

If it work then you may want to try some of the other example sketches included with the library.
Just make sure you add the 10 to the ether.begin line as noted above.

Ethernet_Test.ino1 KB

Step 9: Tying it all together

My first attempt at tying the 3 test sketch's together worked, however the Ethernet would often
timeout. So I got some help from Kev_MacD who helped me modify the sketch to get better timing
in my loops.
The posted sketch has comments in it:
http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (10 of 12) [11/16/2014 6:06:46 AM]

Arduino Temp/Humidity with LCD and Web Interface

We added a gateway IP address as I want to be able to view the webpage from outside the LAN you will need to do port forwarding on your router to make this work.
We define global variables for the temp and humidity values
We define variables for 2 timers, one for the sensor read time and one for an animation on the
LCD
The "refresh" value in the webpage code was changed from 1 to 30 to make the refresh 30
seconds vs every second. This line could be removed if you don't want the page to auto refresh or
increased to make the refresh time longer.
Upload the sketch, open a web browser and go to the IP address. You should see the
temperature and humidity the same as what's on the LCD display. The LCD should also have an
animation showing on the bottom right of the display.
In future version I hope to change the LCD to a 1.8" TFT colour display with an NTP clock so I can
see the timw, temp and humidity on a larger easy to read screen. I welcome comments and
feedback on this Instructable.

Final_Sketch.ino3 KB

We have a be nice comment


policy.
Please be positive and constructive.

http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (11 of 12) [11/16/2014 6:06:46 AM]

I Made it! Add Images

Make Comment

Arduino Temp/Humidity with LCD and Web Interface

http://www.instructables.com/id/Arduino-TempHumidity-with-LCD-and-Web-Interface/?ALLSTEPS (12 of 12) [11/16/2014 6:06:46 AM]

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy