Monday, 5 September 2016

Build a WiFi Controlled Robot with the ESP8266


featured copy








Building your own mobile robot is becoming easier and easier, thanks to excellent ready-to-use robotic platforms. A good example of such platform is the Adafruit Mini Robot Chassis kit, which comes with a nice robot chassis, two servo motors with wheels and a support-wheel. This makes it the perfect base for all your mobile robot projects.
On the other hand, you now can buy powerful & cheap microcontrollers like the ESP8266 WiFi chip, which is not only easy to use but also comes with onboard WiFi connectivity. That’s a chip I used a lot on this website to build home automation projects, but it is also the perfect chip to control robots remotely from your computer or mobile device. In this project, we are going to build a WiFi controlled mobile robot based on the ESP8266. At the end of this tutorial, you will be able to control your own mobile robot from your computer, right from your favourite web browser. Let’s dive in!

Hardware & Software Requirements

We are first going to see what components are needed to build this project. First, you will of course need a robot platform. I used the Adafruit mini robot rover chassis as the platform, as it’s really convenient to use along with the ESP8266 WiFi chip. It also comes with servomotors and wheels, so you don’t have to buy those components separately.
Then, to actually control the robot, I used the Adafruit ESP8266 feather board, along with the Adafruit Motor FeatherWing board to control the motors. To connect both boards, I used the Adafruit FeatherWing doubler board.
Finally, to power the robot, I used two different power sources. I used a 3.7V LiPo battery to power the ESP8266 WiFi board, and a 4 x AA battery pack with 1.2V batteries to power the motors of the robot.
This is the list of all the components you will need for this project:
For this project, you will need the latest version of the Arduino IDE, along with the following libraries:
  • aREST
  • Adafruit_MotorShield

Hardware Configuration

Let’s now see how to assemble the robot. The Mini Robot Rover Chassis comes as a kit, so for the basic assembly I will refer you to this excellent guide to assemble the main parts of the robot:
https://learn.adafruit.com/bluefruit-feather-robot/wiring-and-assembly
You can basically follow this guide till you obtain a result like on the following picture:
hw1
So far, you should have the motors and the wheels assembled on the robot, as well as the 3.7V LiPo battery & the FeatherWing doubler mounted on the robot. We are going to use the battery to power the ESP8266 WiFi chip and the Motor FeatherWing, and we’ll use the FeatherWing Doubler to mount all the feather boards on the robot without using a lot of vertical space.
Now, we are going to take care about the motors of the robot. These will be powered by a larger power supply, that can drive the motors faster. First place four batteries (1.2V to 1.5V Alkaline or NimHA AA) into the 4 x AA battery holder, and then connect the battery holder to the motor FeatherWing component just as on the picture:
hw2
You can now place this FeatherWing on the FeatherWing doubler, as well as the ESP8266 Feather HUZZAH board. Also connect the two stepper motors to the motor FeatherWing. This should be the result at this stage:
hw3
Finally, mount the second stage of the robot using the metallic spacers, and also mount the battery holder on top of the robot:
hw4
Note that on the last picture, I already connected the 3.7V LiPo battery to the ESP8266 feather board. However, you can wait until the robot is fully configured to connect the battery.
Congratulations, you just assembled your mobile robot based on the ESP8266 WiFi chip! In the next section, we are going to learn how to configure it so it can receive commands via WiFi.

Configuring the Robot

We now need to configure the ESP8266 WiFi chip on our robot so it can receive commands via WiFi. For that, we are going to use the aREST framework, which is a very convenient way to make the ESP8266 be completely controllable via WiFi.
Let’s now have a look at the code for this project. It stars by including the required libraries:
  1. #include "ESP8266WiFi.h"
  2. #include <aREST.h>
  3. #include <Wire.h>
  4. #include <Adafruit_MotorShield.h>
#include "ESP8266WiFi.h"
#include <aREST.h>
#include <Wire.h>
#include <Adafruit_MotorShield.h>
After that, we create an instance of the Adafruit_MotorShield, and also create instances for the two motors:
  1. Adafruit_MotorShield AFMS = Adafruit_MotorShield();
  2. Adafruit_DCMotor *L_MOTOR = AFMS.getMotor(4);
  3. Adafruit_DCMotor *R_MOTOR = AFMS.getMotor(3);
Adafruit_MotorShield AFMS = Adafruit_MotorShield(); 
Adafruit_DCMotor *L_MOTOR = AFMS.getMotor(4);
Adafruit_DCMotor *R_MOTOR = AFMS.getMotor(3);
We also create an instance of the aREST library:
  1. aREST rest = aREST();
aREST rest = aREST();
You will need to enter your WiFi network name & password inside the sketch:
  1. const char* ssid = "your-wifi-password";
  2. const char* password = "your-wifi-name";
const char* ssid = "your-wifi-password";
const char* password = "your-wifi-name";
We also declare a set of functions to control the robots:
  1. int stop(String message);
  2. int forward(String message);
  3. int right(String message);
  4. int left(String message);
  5. int backward(String message);
int stop(String message);
int forward(String message);
int right(String message);
int left(String message);
int backward(String message);
We also expose all the control functions to the aREST API, so we can call them via WiFi:
  1. rest.function("stop", stop);
  2. rest.function("forward", forward);
  3. rest.function("left", left);
  4. rest.function("right", right);
  5. rest.function("backward", backward);
rest.function("stop", stop);
rest.function("forward", forward);
rest.function("left", left);
rest.function("right", right);
rest.function("backward", backward);
Inside the loop() function of the sketch, we process incoming connections with aREST:
  1. WiFiClient client = server.available();
  2. if (!client) {
  3. return;
  4. }
  5. while(!client.available()){
  6. delay(1);
  7. }
  8. rest.handle(client);
WiFiClient client = server.available();
if (!client) {
  return;
}
while(!client.available()){
  delay(1);
}
rest.handle(client);
Let’s now have a look at the implementation of the functions used to control the robot. For example, this is the function used to make the robot move forward:
  1. int forward(String command) {
  2. // Stop
  3. L_MOTOR->setSpeed(200);
  4. L_MOTOR->run( FORWARD );
  5. R_MOTOR->setSpeed(200);
  6. R_MOTOR->run( FORWARD );
  7. }
int forward(String command) {
  
  // Stop
  L_MOTOR->setSpeed(200);
  L_MOTOR->run( FORWARD );
 
  R_MOTOR->setSpeed(200);
  R_MOTOR->run( FORWARD );
  
}
Note that you can find the complete code inside the GitHub repository of the project:
https://github.com/openhomeautomation/esp8266-robot
It’s now finally time to configure the robot! First, grab all the code from the GitHub repository of the project, and modify it with your own WiFi name and password. Then, upload the code to the ESP8266 feather board. Once that’s done, open the Serial monitor, you should see the IP address of the board. Make sure you copy and paste this IP somewhere, you’ll need it in the next section where we’ll configure the interface to control the robot.

Controlling the Robot via WiFi

We now have a robot that can accept commands via WiFi, but we definitely don’t want to have to type any of commands inside a web browser: it would be way to slow to control a robot! That’s why we are now going to create a nice graphical interface to control the robot.
This interface will be based on aREST.js, a JavaScript library which is very convenient to control aREST-based projects. It will be automatically imported by the interface we are going to create in a moment, so you don’t need to worry about it. If you want to learn more about aREST.js, you can visit the GitHub repository of the library:
https://github.com/marcoschwartz/aREST.js
Let’s first have a look at the HTML file of the interface. Inside thetag, we import all the required files for the interface:
  1. <script type="text/javascript" src="https://cdn.rawgit.com/marcoschwartz/aREST.js/master/aREST.js"></script>
  2. <script type="text/javascript" src="script.js"></script>
<script type="text/javascript" src="https://cdn.rawgit.com/marcoschwartz/aREST.js/master/aREST.js"></script>
<script type="text/javascript" src="script.js"></script>
Now, inside the same file, we define a button for each of the commands of the robot, for example to make the robot go forward:
  1. <div class='row'>
  2. <div class="col-md-5"></div>
  3. <div class="col-md-2">
  4. <button id='forward' class='btn btn-primary btn-block' type="button">Forward</button>
  5. </div>
  6. <div class="col-md-5"></div>
  7. </div>
<div class='row'>

  <div class="col-md-5"></div>
  <div class="col-md-2">
    <button id='forward' class='btn btn-primary btn-block' type="button">Forward</button>
  </div>
  <div class="col-md-5"></div>

</div>
We still need to link the buttons inside the interface to the actual commands of the robot. This will be done in a file called script.js, which will make the link between the graphical interface & the robot.
The file starts by defining the IP address of the robot, and by creating an instance of an aREST device:
  1. var address = "192.168.0.103";
  2. var device = new Device(address);
var address = "192.168.0.103";
var device = new Device(address);
Then, for each of the buttons of the interface, we call the corresponding function on the robot. Also, as we want the buttons to behave like push buttons (meaning whenever the button is released, the robot stops), we also need to call the stop function when the button is released:
  1. $('#forward').mousedown(function() {
  2. device.callFunction("forward");
  3. });
  4. $('#forward').mouseup(function() {
  5. device.callFunction("stop");
  6. });
$('#forward').mousedown(function() {
  device.callFunction("forward");
 });
 $('#forward').mouseup(function() {
   device.callFunction("stop");
 });
It’s now time to finally test our interface and make our robot move around! For that, make sure to edit the script.js file inside the interface folder, and put the actual IP address of your ESP8266 WiFi chip. If that’s not done yet, also disconnect the ESP8266 feather board from USB, and power the ESP8266 using the 3.7V LiPo battery.
Then, open the interface with your favorite web browser. This is what you should see:
Screen Shot 2016-06-16 at 14.04.09
As you can see, there is a button for each function of the robot. You can now try it: whenever you press a button (and keep it pressed), your robot should move immediately!
This is an example of my own mobile robot moving around while I was using the interface:
giv_prev
Congratulations, you built your own mobile robot based on the ESP8266 and controlled it via WiFi! Note that you also control the robot using a mobile device, like a smartphone or tablet, using the exact same interface.

How to Go Further

In this article, we learned how to build a mobile robot based on the ESP8266 WiFi chip, and on the Adafruit Mini Robot Rover Chassis Kit. We first assembled the robot, and configured it so it accepts commands via WiFi. We then controlled the robot using a graphical interface running in your web browser.
There are of course many ways to now improve the project, based on what you learned in this article. You could for example add a distance sensor in front of the robot, and have the measured distance displayed inside the same interface. You could also couple a gyroscope to the robot, and have more complex functions like making the robot turn from a given angle. The possibilities offered by this excellent chassis & the ESP8266 WiFi chip are endless, so don’t hesitate to experiment and have fun!

No comments:

Post a Comment