Arduino Nano: Ultrasonic Ranger(Ping) Distance I2C 2 X 16 LCD Display With Visuino

by BoianM in Circuits > Arduino

30302 Views, 246 Favorites, 0 Comments

Arduino Nano: Ultrasonic Ranger(Ping) Distance I2C 2 X 16 LCD Display With Visuino

Arduino Nano: Ultrasonic Ranger(Ping) Distance I2C 2 X 16 LCD Display With Visuino

In this Instructable, I will show you how easy it is to connect Ultrasonic Sensor to Arduino and display the distance on a LCD Display.

Components

56c278c6937ddb227e0006f6.jpeg
5682e57f45bceb5b0200115f.jpeg
  1. One Arduino compatible board (I use Arduino Nano, because I have one, but any other will be just fine)
  2. One Ultrasonic Ranger Sensor Module - I used HC-SR04, but US-015, or very much any other will also work
  3. One I2C 16x2 LCD Display (Back side of the LCD with the I2C adapter showed on Picture 2)
  4. One small Breadboard (Any breadboard can be used, or any other way to connect 3 wires together)
  5. 3 Female-Male (Red) jumper wires
  6. 6 Female-Female jumper wires

Connect the LCD Module to the Arduino

DSC02168.JPG
56afb58915be4d97d90016ca.jpeg
56afb5dd45bceb4f86000926.jpeg
  1. Connect Female-Female Ground(Black wire), SDA(Green wire), and SCL(Yellow wire) to the LCD Module (Picture 1)
  2. Connect the Female end of a Female-Male Power(Red wire) to the VCC/Power pin of the LCD Module (Picture 1) , and leave the Male end unconnected
  3. Connect the other end of the Ground wire(Black wire) to Ground pin of the Arduino board(Picture 2)
  4. Connect the other end of the SDA wire(Green wire) to SDA/Analog pin 4 of the Arduino Nano board(Picture 2)
  5. Connect the other end of the SCL wire(Yellow wire) to SCL/Analog pin 5 of the Arduino Nano board(Picture 2)
  6. Connect another Female-Male Power wire(Red wire) to the 5V Power pin of the Arduino board(Picture 2), and leave the Male end unconnected
  7. Picture 3 shows where are the Ground, 5V Power, SDA/Analog pin 4, and SCL/Analog pin 5 pins of the Arduino Nano

Connect the Ultrasonic Ranger to Arduino

56c278e967400c962900078e.jpeg
5695929050e1b652510007ee.jpeg
56c2790750e1b631a3000642.jpeg
56c2877c67400c96290007c9.jpeg
  1. Connect Ground(Black wire), Power(Red wire), Trigger(Brown wire), and Echo(Purple wire) to the Ultrasonic Ranger Sensor Module (Picture 1)
  2. Connect the Male ends of the 3 Power wires(Red wires) - from the Display, the Ultrasonic Ranger Module, and the Arduino together as example with the help of a Breadboard (Picture 2) - In my case I used a small Breadboard
  3. Connect the other end of the Ground wire(Black wire) to Ground pin of the Arduino board(Picture 3)
  4. Connect the other end of the Trigger wire(Brown wire) to Digital pin 2 of the Arduino board(Picture 3)
  5. Connect the other end of the Echo wire(Purple wire) to Digital pin 3 of the Arduino board(Picture 3)
  6. Picture 4 shows in Red where are the Ground, Digital 2, and Digital 3 pins of the Arduino Nano (In Blue are shown the connections made in the previous step)

Start Visuino, and Select the Arduino Board Type

SelectBoard.png
SelectBoard.png

To start programming the Arduino, you will need to have the Arduino IDE installed from here: http://www.arduino.cc/ .

Please be aware that there are some critical bugs in Arduino IDE 1.6.6.

Make sure that you install 1.6.7 or higher, otherwise this Instructable will not work!

The Visuino: https://www.visuino.com also needs to be installed.

  1. Start Visuino as shown in the first picture
  2. Click on the "Tools" button on the Arduino component (Picture 1) in Visuino
  3. When the dialog appears, select Arduino Nano as shown in Picture 2

In Visuino: Add and Connect Ultrasonic Ranger Component

ComponentPing.png
ComponentPingPeriod.png
ComponentPingConnect1.png
ComponentPingConnect2.png
  1. Type "sonic" in the Filter box of the Component Toolbox then select the "Ultrasonic Ranger(Ping)" component (Picture 1), and drop it in the design area
  2. In the Object Inspector set the value of the "PauseTime" property of the UltrasonicRanger1 to 1000 (Picture 2) This will give 1 second period between the measurements, so the LCD display will not be updated too often
  3. Connect the "Ping(Trigger)" pin of the UltrasonicRanger1 component to the "Digital" input pin of the Digital[ 2 ] channel of the Arduino component (Picture 3)
  4. Connect the "Out" pin of the Digital[ 3 ] channel of the Arduino component to the "Echo" input pin of the UltrasonicRanger1 component (Picture 4)

In Visuino: Add LCD Component, and Text Field in It

ComponentLCD.png
ComponentTools.png
ComponentLCDElements1.png
ComponentLCDElements1Prop1.png
  1. Type "lcd" in the Filter box of the Component Toolbox then select the "Liquid Crystal Display (LCD) - I2C" component (Picture 1), and drop it in the design area
  2. Click on the "Tools" button (Picture 2) to open the "Elements" editor (Picture 3)

We will add a Text field with the description of the value:

  1. Add Text field for the Distance description text by select the "Text Field" in the right window of the "Elements" editor, and clicking on the "+" button on the left (Picture 3)
  2. In the Object Inspector set the "Initial Value" property of the element to "Distance:" (Picture 4) - This will specify the text to be displayed

In Visuino: Add, and Setup Analog Value Element to Display the Distance

ComponentLCDElements2.png
ComponentLCDElements2Props1.png
  1. Add Analog field for the Distance value by selecting the "Analog Field" in the right window of the "Elements" editor, and clicking on the "+" button on the left (Picture 1)
  2. In the Object Inspector set the "Precision" property of the element to "2" (Picture 2)
  3. In the Object Inspector set the "Row" property of the element to "1" (Picture 2) - This will specify that the field will be shown in the second row of the Display
  4. In the Object Inspector set the "Width" property of the element to "6" (Picture 2)

In Visuino: Add, and Setup Text Element to Display the Units

ComponentLCDElements3.png
ComponentLCDElements3Prop1.png
ComponentLCDElements3Prop2.png
ComponentLCDElements3Prop3.png
  1. Add Text field for the Units text selecting the "Text Field" in the right window of the "Elements" editor, and clicking on the "+" button (Picture 1)
  2. In the Object Inspector set the "Column" property of the element to "7" (Picture 2)
  3. In the Object Inspector set the "Initial Value" property of the element to "CM" (Picture 3)
  4. In the Object Inspector set the "Row" property of the element to "1" (Picture 3)
  5. Close the Elements editor

In Visuino: Connect the LCD Component

ComponentLCDConnect1.png
ComponentLCDConnect2.png
ComponentLCDConnect3.png
  1. Connect the "Out" pin of the UltrasonicRanger1 component (Picture 1) to the "In" pin of the "Elements.AnalogField1" element of the LiquidCrystalDisplay1 component (Picture 2)
  2. Connect the "Out" pin of the LiquidCrystalDisplay1 component to the to the "In" pin of the I2C channel of the Arduino component (Picture 3)

Generate, Compile, and Upload the Arduino Code

GenerateCtopped.png
Arduino IDE.png
  1. In Visuino, Press F9 or click on the button shown on Picture 1 to generate the Arduino code, and open the Arduino IDE
  2. In the Arduino IDE, click on the Upload button, to compile and upload the code (Picture 2)

And Play...

56c2791a67400c962900078f.jpeg
VisuinoDiagrmCrop.png

Congratulations! You have completed the project.

Picture 1 shows the connected and powered up project. As you can see on the picture the Display will show the Distance to the nearest object from the Ultrasonic Ranger.

On Picture 2 you can see the complete Visuino diagram.
Also attached is the Visuino project, that I created for this Instructable. You can download and open it in Visuino: https://www.visuino.com