Mini Weather Station Using Arduino Nano


Mini Weather Station Using Arduino Nano

Mini Weather Station Using Arduino Nano

This is a simple and fun project with pocket friendly budget.


Introduction

Capturing physical data in real time is always fascinating. In this project you will notonly be able to capture three fundamental physical parameters for weatherpredication viz. temperature, humidity and atmospheric pressure, but also beable to display the real time data on a LCD screen.


Description and Working Principle

The twosensors used in this project are BMP-280 and DHT-11. The former senses thetemperature and atmospheric pressure whereas the later senses the relative humidity.The DHT-11 could have been done with by using BME-280 (it can measure humidityalso) instead of the BMP-280, but if the cost is taken into account then usingthe combination of sensors used here is much more economical for DIY projects.It should also be noticed that although DHT-11 is capable of sensing bothtemperature and humidity, it is used for humidity sensing only because itstemperature sensing resolution is +/-2° compared to +/-.5° for BMP-280. The heart of this project is the Arduino NANOdevelopment board. Here also the NANO board has been chosen over the masspreferred UNO because of its affordable price. A 1.44” ST7735 series TFT LCDscreen is used as the display for our project. A bigger screen has been avoidedhere so that the Arduino NANO is not overloaded.



Circuit and Programming

Acombination of circuit diagram and block diagram has been provided asconveniently as possible to help the makers understand the physicalconfiguration and connection of the components. Tables for pin-out of thecomponents is also provided to make things easier. Going through the diagramand tables one will notice that the 5V and GND pins of the ICSP header onArduino NANO has been utilised for supplying power to the components along withthe on-board power and ground pins. This has been done to do away with anyadditional power source which will make the system bulky.

Coming tothe programming, in the first part an array of libraries have been included tokeep the programming short and simple. Besides the obvious ones, the Wire.h andSPI.h libraries are worth mentioning because Wire.h is the one that allows theArduino to communicate with the I2C/TWI devices such as the BMP-280 and theST7735 LCD and SPI.h provides the serial peripheral interface with the ST7735LCD. In the second part, the sensors are initialized and the layout, fontcolour etc. of the LCD are set up for displaying the data as per ourpreferences. In the final part of our programming, the output from the sensorsare obtained and displayed with a convenient delay between each reading to keepthings stable.


Construction and Testing

In theprototype, the components have been kept modular and connected using jumperwires instead of soldering. This not only allows easy troubleshooting andrepairing but also makes the assemby process hassle free. The device-case hasbeen custom 3D printed for a perfect fit for the components. The case isprovided with proper ventilation in order to expose the sensors to themeasurands and dissipate the heat generated by the system which will otherwiseinterfere with the sensing elements. The device is powered via the same type AUSB to type B mini USB used to program the Arduino. The prototype has beentested indoors at stretch for a few hours using both PC USB port and 5Vsmartphone charger as supply. The results are quite accurate compared withonline meteorological data, considering the production cost and developmenttime.

In conclusion it can be said that this projectis quite economical, useful to say the least, and most importantly, it is funhaving a small and handy weather station that fits right in your pocket.



Bibliography

· Google.com

· Arduino.cc

· Mytectutor.com







POWERED USING SMARTPHONE WALL ADAPTER





POWERED USING SMARTPHONE WALL ADAPTER



CODE

THE CODEC/C++



#include <SPI.h>               //include Serial Peripheral Interface library
#include <Wire.h>              //include Two Wire Interface library
#include <Adafruit_GFX.h>      // include Adafruit graphics library
#include <Adafruit_ST7735.h>   // include Adafruit ST7735 TFT library
#include <Adafruit_BMP280.h>   // include Adafruit BMP280 sensor library
#include "DHT.h"               //include DHTXX sensor library
#define DHTPIN 2               //DHT11 data pin connected to arduino pin D2
#define DHTTYPE DHT11          //specifying the type of DHT sensor used
#define TFT_RST   8            // TFT RST pin is connected to arduino pin D8
#define TFT_CS    10           // TFT CS  pin is connected to arduino pin D9
#define TFT_DC    9            // TFT DC  pin is connected to arduino pin D10
// initialize ST7735 SERIES TFT library
Adafruit_ST7735 tft = Adafruit_ST7735(TFT_CS, TFT_DC, TFT_RST);
 
// define device I2C address: 0x76 or 0x77 (0x77 is the library default address)
#define BMP280_I2C_ADDRESS  0x76
 
Adafruit_BMP280  bmp280;       // initialize Adafruit BMP280 library
DHT dht(DHTPIN, DHTTYPE);      // initialize DHT sensor
 
void setup(void)
{
  dht.begin();                                         // synchronizing DHT sensor
  tft.initR(INITR_144GREENTAB);                        // initialize a ST7735S chip, black tab
  tft.fillScreen(ST77XX_BLACK);                        // setting black background
  tft.drawFastHLine(0, 15 ,  tft.width(), ST77XX_CYAN);// draw horizontal seperation line at position (0, 15)
 
  tft.setTextColor(ST77XX_CYAN, ST77XX_BLACK);         // set text color to white and black background
  tft.setTextSize(1);                                  // setting text size to 1
  //tft.setCursor(4, 0);                               // move cursor to position (4, 0) pixel
  //tft.print("ARDUINO + ST7735 TFT");
  tft.setCursor(25, 5);                                // move cursor to position (25, 5) pixel
  tft.print("WEATHER BUDDY");
 
  // initialize the BMP280 sensor
  if( bmp280.begin(BMP280_I2C_ADDRESS) == 0 )
  {  // connection error or device address wrong!
    tft.setTextColor(ST77XX_RED, ST77XX_CYAN);         // set text color to red and black background
    tft.setTextSize(2);                                // setting text size to 2
    tft.setCursor(5, 76);                              // move cursor to position (5, 76) pixel
    tft.print("Connection");
    tft.setCursor(35, 100);                            // move cursor to position (35, 100) pixel
    tft.print("Error");
    while(1);  // stay here
  }
 
  tft.drawFastHLine(0, 55,  tft.width(), ST77XX_CYAN);  // draw horizontal seperation line at position (0, 55)pixel
  tft.drawFastHLine(0, 95,  tft.width(), ST77XX_CYAN);  // draw horizontal seperation line at position (0, 195)pixel
  tft.setTextColor(ST77XX_RED, ST77XX_BLACK);           // set text color to red and black background
  tft.setCursor(30, 20);                                // move cursor to position (30, 20) pixel
  tft.print("TEMPERATURE ");                            // setting heading for first section
  tft.setTextColor(ST77XX_CYAN, ST77XX_BLACK);          // set text color to cyan and black background
  tft.setCursor(40, 60);                                // move cursor to position (40, 60) pixel
  tft.print("HUMIDITY ");                               // setting heading for second section
  tft.setTextColor(ST77XX_GREEN, ST7735_BLACK);         // set text color to green and black background
  tft.setCursor(40, 100);                               // move cursor to position (40, 100) pixel
  tft.print("PRESSURE ");                               // setting heading for third section 
  tft.setTextSize(2);                                   // setting text size to 2 
}
 
// main loop
void loop()
  {

  char _buffer[8];
  // read temperature, humidity and pressure from the BMP280 sensor
  float temp = bmp280.readTemperature();    // get temperature in °C
  float hum = dht.readHumidity();           // get humidity in rH%
  float pres = bmp280.readPressure();       // get pressure in hPa
 
  // print temperature (in °C)
  if(temp < 0)                              // if temperature < 0
    sprintf( _buffer, "-%02u.%02u", (int)abs(temp), (int)(abs(temp) * 100) % 100 );
  else                                      // if temperature >= 0
    sprintf( _buffer, " %02u.%02u", (int)temp, (int)(temp * 100) % 100 );// setting the value approximation 
  tft.setTextColor(ST77XX_YELLOW, ST77XX_BLACK);  // set text color to yellow and black background
  tft.setCursor(11, 34);                          // move cursor to position (11,34) pixel 
  tft.print(_buffer);                             // print temperature from BMP-280 sensor
  tft.drawCircle(89, 34, 2, ST77XX_YELLOW);       // print the degree symbol ( ° )(can be omitted if * is used instead)
  tft.setCursor(95, 34);                          // move cursor to position (95,34) pixel 
  tft.print("C");                                 // print the Celcius symbol     
 
  // 2: print humidity (in %)
  sprintf( _buffer, "%02u ", (int)(hum));          // setting the value approximation 
  tft.setTextColor(ST77XX_MAGENTA, ST77XX_BLACK);  // set text color to magenta and black background
  tft.setCursor(45, 74);                           // move cursor to position (45,74) pixel
  tft.print(_buffer);                              // print humidity from DHT-11 sensor
  tft.setCursor(75, 74);                           // move cursor to position (75,74) pixel
  tft.print("%");                                  // print the percentage symbol     
 
 
  // 3: print pressure (in hPa)
  sprintf( _buffer, "%04u.%02u", (int)(pres/100), (int)((uint32_t)pres % 100) ); // setting the value approximation 
  tft.setTextColor(ST77XX_ORANGE, ST77XX_BLACK);  // set text color to orange and black background
  tft.setCursor(3, 112);                          // move cursor to position (3,112)pixel      
  tft.print(_buffer);                             // print atmospheric pressure from BMP-280
  tft.setCursor(91, 112);                         // move cursor to position (91,112)pixel
  tft.print("hPa");                               // print unit of atmospheric pressure as hecto pascal
 
  delay(1000);                                    // wait 1 second before taking next sensor reading
 
}


CUSTOM PARTS AND ENCLOSURES

3D PARTS

DOWNLOAD

THIS IS THE STL FILE FOR THE 3D PRINTED PARTS I USED



SCHEMATICS

CIRCUIT DIAGRAM


YOU JUST NEED TO FOLLOW THE WIRING SHOWN.

Circuit diagram 1lwdlrup5p

Thanks PcbWay For Your Support

Apply for sponsorship >>
13800+ Projects Sponsored
Feb 16,2020
3,499 viewsReport item
  • Comments(1)
  • Likes(1)
Upload photo
You can only upload 5 files in total. Each file cannot exceed 2MB. Supports JPG, JPEG, GIF, PNG, BMP
0 / 10000