Skip to content

AGKhalil/Cellphone_Robot_OpenCV

Repository files navigation

Cellphone_robot

Welcome to the Cellphone_Robot project! Through this project we are aiming to expand on Android based robotics. myRobot, the app within this repository, was created to control a small ROS controlled car-robot. The project showcases how an Android phone can significantly enhance a ROS-based robot through leveraging the many APIs out there. This project utlizes multiple libraries as well as APIs. In this user guide we will walk you through setting up the project for yourself and setting up the necessary access keys to use the app in tandem with a ROS project. That being said, all the libraries and APIs can be replaced or expanded upon so do not feel limited to our implementation of the repo.

This repo allow the robot to: access a Natural Language Processor, translate text, send SMS, send Slack messages, send GroupMe messages, post to Twitter, perform basic image processing, and communicate back and forth with a ROS network. In our hardware setup, we had the ROS network running on a Raspberry Pi 3 mounted on the RC robot itself. We used a portable rechargable battery to make this happen. The phone is also mounted on the robot using a cellphone holder. Have fun experimenting!

Demo Video

Demo Video

What does the app do?

The app is fundamentally acting as an extension to the robot, regardless of what the robot is or what it is capable of. The app acts as a higher level method of controlling the robot, while leveraging its access to the web and the many tools out there for Android phones. Once the robot is connected to the phone, the phone knows what the robot is capable of doing. The user can then communicate with the phone through texting or Instant Messaging over NLP to command the robot. This project is essentially a template for people to get creative with. If you have a ROS based robot and an Android phone, you can do all sorts of cool stuff.

Who is this project for?

This project was created as a starting point for the roboticits and Android developers out there to build upon. You do not to be an Android/ROS expert to use this project. That being said, you should be familiar with both environemnts to use this project to its full potential. Furthermore, the Setup guide assumes you have some familiarity with navigating Ubuntu systems.

ROS Setup

This user guide focuses mainly on setting up the Android app; however, to communicate with the ROS network a few steps need to be taken. This repo contains the ROS project we created to test the app with. To use the app you do not need to clone the whole project. There is only one script that your ROS project needs to have. That user guide will show you how to set up the script for your own uses, or you can just clone the whole project.

Connection

To connect the Android to ROS, you need to make sure the ROS_MASTER_URI is correctly referenced and that depends on whether the connection is over WIFI or USB.

WIFI

Ensure the ROS host machine, in our case the Rhaspberry PI, and the Android phone are connected to the same WIFI network.

On the ROS host, copy the Pi's wlan0 IP address. Then in terminal, go to your root directory, open .bashrc, and type the following at the bottom of the script.

export ROS_IP=DEVICE_IP_ADDRESS
export ROS_MASTER_URI=http://DEVICE_IP_ADDRESS:11311/

On the Android side, go to strings.xml located under /app/src/main/res/values and type in the ROS_MASTER_URI in the corresponding location.

 <string name="rosIP">http://DEVICE_IP_ADDRESS:11311/</string>

To update your ROS enviroments, run the following in a terminal:

source ~/.bashrc

Now you can launch roscore on the ROS host and the app will connect to it over WIFI.

USB

Connect the phone to the ROS host. Turn off WIFI connection on the ROS host device. On the Android, go to Settings > More > Tethering & portable hotspost and turn on USB tethering.

On the ROS host, copy the Pi's ethernet IP address. Then in terminal, go to your root directory, open .bashrc, and type the following at the bottom of the script.

export ROS_IP=DEVICE_IP_ADDRESS
export ROS_MASTER_URI=http://DEVICE_IP_ADDRESS:11311/

On the Android side, go to strings.xml located under /app/src/main/res/values and type in the ROS_MASTER_URI in the corresponding location.

 <string name="rosIP">http://DEVICE_IP_ADDRESS:11311/</string>

To update your ROS enviroments, run the following in a terminal:

source ~/.bashrc

Now you can launch roscore on the ROS host and the app will connect to it over USB.

ROS Package

The ROS package can be found here.

Android Setup

Libraries

OpenCV

OpenCV provides some tutorials and documentation through here. This library is processor dependent, so you need to find out your phone's ARM processor version and allocate the correct file to the jniLibs directory.

First, make sure you have the Android Debug Bridge (adb) installed.

After the installation is complete, run this: adb shell getprop ro.product.cpu.abilist. The output will tell you the phone's ARM processor version. For example, when I run the above command on a Huawei Honor 5x, the output is arm64-v8a,armeabi-v7a,armeabi.

I can pick any processor of the three to allocate to the OpenCV library. For the guide's purpose, let's choose arm64-v8a.

Next, go to processor_libs and copy the corresponding version directory. In this case, arm64-v8a. Afterwards, go to /app/src/main/jniLibs and paste arm64-v8a.

Now that you're done allocating the correct processor version file to OpenCV, delete processor_libs. You no longer need it and it is a relatively large folder.

Dialogflow

For setting up Dialogflow and trying sample app, please click here.

For detailed explanation of natual language process service, you can go here.

APIs

The app includes many APIs, all of which need access keys. Below are the respective links for obtaining them. All you need to do to have the APIs work is paste the keys in the corresponding string.xml allocation.

Twitter

This link will take you to registering your app for access keys. Once the registration process is done, go to strings.xml located under /app/src/main/res/values. Paste your respective access keys in the corresponding locations.

<string name="twitterSetOAuthConsumerKey">HERE</string>
<string name="twitterSetOAuthConsumerSecret">HERE</string>
<string name="twitterSetOAuthAccessToken">HERE</string>
<string name="twitterSetOAuthAccessTokenSecret">HERE</string>

Slack

This link will introduce how to register a bot and interact with it. Also, there are various Libraries, Plugins, and Sample Apps that you can use. In this project, we implement slack-api-android . Make sure you add the following line to your build.gradle.

allprojects {
    repositories {
        maven { url 'https://jitpack.io' }
    }
}

and:

dependencies {
    compile 'com.github.pschroen:slack-api-android:c66cc8d997'
}

Check here for usage.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published