ESP8266 and Visuino: Wi-Fi Network Scanner

by BoianM in Circuits > Arduino

13178 Views, 41 Favorites, 0 Comments

ESP8266 and Visuino: Wi-Fi Network Scanner

ESP8266 and Visuino: Wi-Fi Network Scanner

ESP8266 modules are great low cost stand alone controllers with built in Wi-Fi. In this Instructable I will show you how you can easily make a Wi-Fi network scanner with an ESP8266.

In the Instructable, I will use NodeMCU module version 0.9. The NodeMCU is the easiest way to program and experiment with ESP8266 controllers. This Instructable however can easily be done with any other module ESP8266, even ESP-01.

Components

56b548f145bceb6f82000171.jpeg

One NodeMCU ESP8266 board (I used NodeMCU 0.9, but any other ESP8266 will work)

Start Visuino, and Select the ESP8266 Board Type

SelectBoard.png
ESP8266.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!

If you have not done follow the steps in this Instructable to setup the Arduino IDE to program ESP 8266!

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 "NodeMCU ESP-12" as shown on Picture 2

In Visuino: Add Scan Wi-Fi Operation

OperationsClick.png
OperationsAdd1.png
OperationsAdd2.png
  1. In the Object Inspector expand the "Modules" property, then the "WiFi" sub-property (Picture 1)
  2. In the Object Inspector select the "Operations" property and click on the "..." button next to its value (Picture 1)
  3. In the "Operations" dialog, select the "Scan WiFi Networks" item from the list on the right (Picture 2)
  4. Click on the "+" button (Picture 2) on the left to add one ScanNetworks item (Picture 3)
  5. Close the "Operations" dialog

In Visuino: Add and Connect Clock Generator Component

ComponentClock.png
ComponentClockConnect.png
  1. Type "clock" in the Filter box of the Component Toolbox then select the "Clock Generator" component (Picture 1), and drop it in the design area
  2. Connect the "Out" pin of the ClockGenerator1 component to the "Scan" input pin of the "Modules.WiFi.Operations[0]" item of the "

    NodeMCU ESP-12" component (Picture 2)

In Visuino: Add and Connect Detect Edge and Text Value Components

ComponentEdge.png
ComponentTextValue.png
ComponentTextValueConnect1.png
ComponentTextValueConnect2.png
ComponentTextValueConnect3.png

We need to print the header text when the scanning starts. The "Scanning" pin will generate clock even every time it changes value from False to True and back. To generate event only when it changes from False to True, we need to use Detect Edge component.

  1. Type "edge" in the Filter box of the Component Toolbox then select the "Detect Edge" component (Picture 1), and drop it in the design area
  2. Type "text" in the Filter box of the Component Toolbox then select the "Text Value" component (Picture 2), and drop it in the design area
  3. Connect the "Scanning" output pin of the "Modules.WiFi.Operations[0]" item of the "NodeMCU ESP-12" component to the "In" pin of the DetectEdge1 component (Picture 3)
  4. Connect the "Out" output pin of the DetectEdge1 component to the "In" input pin of the TextValue1 component (Picture 4)
  5. Connect the "Out" output pin of the TextValue1 component to the "In" input pin of the "Serial[ 0 ]" channel of the "NodeMCU ESP-12" component (Picture 5)

In Visuino: Set the Text for the TextValue1 Component

ComponentTextValueOpen.png
ComponentTextValueText.png
  1. Select the TextValue1 component (Picture 1)
  2. In the Object Inspector select the "Value" property and click on the "..." button (Picture 1)
  3. In the "Value" editor type:
    ""
    "Scan"
    "-----------------"

    (Picture 2)
  4. Click on the OK button to close the dialog

In Visuino: Add Formatted Text Component and Elements

ComponentFormattedText.png
ComponentFormattedTextTools.png
ComponentFormattedTextAdd1.png
ComponentFormattedTextAdd2.png
ComponentFormattedTextAdd3.png
ComponentFormattedTextProperty.png

We will use Formatted Text component to format and print each detected Wi-Fi Hot Spot information line.

  1. Type "text" in the Filter box of the Component Toolbox then select the "Formatted Text" component (Picture 1), and drop it in the design area
  2. Click on the "Tools" button of the FormattedText1 component (Picture 2)
  3. In the Elements editor, Select the Text Element on the right, and click on the "+" button on the left to add one of them (Picture 3, and 4)
  4. In the Elements editor, Select the Integer Element on the right, and click 2 times on the "+" button on the left to add 2 of them (Picture 4, and 5), then close the Elements editor
  5. In the Object Inspector, set the value of the Text property of the FormattedText1 component to "SSID: "%0" Signal: %1 Channel %2" (Picture 6). The %0 will be replaced with the value from TextElement1, %1 will be replaced with the value from IntegerElement1, and %2 will be replaced with the value from IntegerElement2

In Visuino: Connect the Formatted Text Component

ComponentFormattedTextConnect1.png
ComponentFormattedTextConnect2.png
ComponentFormattedTextConnect3.png
ComponentFormattedTextConnect4.png
ComponentFormattedTextConnect5.png
  1. Connect the "SSID" output pin of the " Modules.WiFi.Operations[0]" item of the "NodeMCU ESP-12" component to the "In" pin of the TextElement1 of the FormattedText1 component (Picture 1)
  2. Connect the "Signal Strenght" output pin of the "

    Modules.WiFi.Operations[0]" item of the "NodeMCU ESP-12" component to the "In" pin of the IntegerElement1 of the FormattedText1 component (Picture 2)

  3. Connect the "Channel" output pin of the "

    Modules.WiFi.Operations[0]" item of the "NodeMCU ESP-12" component to the "In" pin of the IntegerElement2 of the FormattedText1 component (Picture 3)

  4. Connect the "FoundNetwork" output pin of the "Modules.WiFi.Operations[0]" item of the "NodeMCU ESP-12" component to the "Clock" input pin of the FormattedText1 component (Picture 4)
  5. Connect the "Out" output pin of the FormattedText1 component to the "In" input pin of the "Serial[ 0 ]" channel of the "NodeMCU ESP-12" component (Picture 5)

Generate, Compile, and Upload the Arduino Code

GenerateCtopped.png
ArduinoIDE.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. Connect the NodeMCU module with USB cable to the computer
  3. Select the board type and serial port as I have shown you in this Inctructable
  4. Make sure you have installed the latest staging version of the ESP support! The stable release does not have some of the latest features, and you will have errors when you try to compile!
  5. In the Arduino IDE, click on the Upload button, to compile and upload the code (Picture 2)

And Play...

ESP8266 and Visuino: Wi-Fi Network Scanner
SerialTerminal.png
VisuinoDiagramCrop.png

Congratulations! You have made a Wi-Fi scanner.

The Video shows the connected and powered up project.

If you open Serial Terminal in the Arduino IDE or Visuino, you will see the Wi-Fi hot-spots discovered by the NodeMCU, their strength, and their channel (Picture 1)

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