Create A Bluetooth Joypad With App Inventor 2

BluetoothJoyPad_draftLayout_01_800Here we create a basic Classic Bluetooth joypad for use on an Android device to control a microprocessor (Arduino) connected to a Bluetooth module. The app is fairly simply. There are 2 screens; the first is the main control panel and the second is a connection page.

When the CONNECT button on the main screen is clicked the second screen is opened to allow the user to connect to a Bluetooth device. The direction buttons, when clicked, transmit codes to the Arduino.

 

App Inventor 2

The app is created in App Inventor 2 using Bluetooth Classic.

App inventor 2 is an easy way to get started with creating Android apps. It is designed primarily for teaching but you can build some surprisingly advanced and complex apps with it. App inventor is blocks based. This means programs are created using visual elements that are dragged and dropped rather than text that is typed. It is cloud based meaning you use a web browser.

I don’t go in to all the details of app inventor and I assume you have some basic experience with using it. At least you should have a google account and know where the app inventor website is.

 

Design

The Bluetooth Joypad has a simple interface and is used in landscape mode.

  • 4 direction buttons,
  • 3 regular buttons,
  • a connection indicator, and
  • a connect button.

BluetoothJoyPad_draftLayout_01_800

When the CONNECT button is pressed a second screen will open. The second screen handles the Bluetooth connection and the update speed.
BluetoothJoyPad_draftLayout_03b_800
The second screen has;

  • a button to initiate the Bluetooth connection process,
  • a slider to control the app update speed,
  • a BACK button to go back to the main screen.

As with many things in app inventor there are different ways to get the same layout. To make the layout as simple to create as possible I have a row across the top that holds the connection indicator and the menu button. Next there are 4 columns that hold the control buttons. Everything is then contained in an outer vertical arrangement which makes it easy to show/hide all the controls in one go.
BluetoothJoyPad_draftLayout_02
The first 3 vertical arrangements are vertically centre aligned.
The final column is bottom aligned.
The labels are used as spacers and aid the positioning.

 

Control codes

I am using single character control codes, this keeps the communication fairly simple and helps with the speed. Rather than using a single button clicked event I am using the button pressed and button released events. This means each button requires 2 codes:

Direction Buttons

U – Up button pressed u – Up button released
D – Down button pressed d – Down button released
L = Left button pressed l – Left button released
R – Right button pressed r – Right button release

Control Buttons

R – red button pressed r – red button released
G – green button pressed g – green button released
B – blue button pressed b – blue button released

The CONNECT button triggers internal events inside the app and does not need any code.

On the Arduino side, when it receives the character “U” it knows the up button has been pressed and when it gets the “u” character it knows the up button has been released. If it gets a “U” but no “u” it knows the up button is being held down. This is handy, for example, when using to control a remote car. “U” can mean go forward and keep going until the “u” is received. “R” can mean turn right, and keep turning right until the “r” is received.

Using single character codes also allows the Arduino code to be a lot simpler.

 

App Inventor 2 and Bluetooth

App inventor allows for apps with multiple screens but there is a caveat when using Bluetooth. Each screen has to have its own Bluetooth connection. This means if we use screen 2 to open a Bluetooth connection, after we go back to screen 1 we are no longer connected. To overcome this I will be using pseudo screens. The app will look like we are using 2 screens but in reality we are only using 1 and will be hiding and showing elements to make it look like we are swapping screens.
PAGE1_OUTER_VA acts as page 1 and PAGE2_OUTER_VA acts as page 2. When the app first starts only PAGE1_OUTER_VA is displayed. When the CONNECT button is clicked, PAGE1_OUTER_VA is hidden and PAGE2_OUTER_VA is displayed.

 

Screen Size

App inventor has some restrictions when it comes to screen size and how things are placed. It is good practice to use proportional sizing. This is where we specify the size as a percentage of the screen rather than by using resolution.

The direction buttons are about 18% of the screen width, the coloured buttons are 20%. You can change the sizes to suit your own design.

While developing the app I used a Samsung S7 but I also tried it on a Sony Compact Z3 and a Samsung 7” tablet. Although there are slight differences in the display on the 3 different devices the general layout is the same.

 

Creating the Layout

I do not go through every step of using App Inventor and expect that you have some experience with it. If not start by checking the online guides and examples. I do try to explain my choices and how best to handle things like Bluetooth.

Open a web browser and go to app inventor at http://ai2.appinventor.mit.edu/ and get started with a new project called Joypad_001. I append version numbers to the app name and as the app progresses I increase the value; Joypad_001, Joypad_002, etc.

The app screen is non-scrollable (I have found it better to leave the screen as scrollable and set it to non-scrollable in the code. Set the screen to Landscape and Responsive. Turn off the screen title by unchecking the TitleVisible check box.
Check Display hidden components in view

Then create the layout.
BluetoothJoyPad_draftLayout_02
Start with the outer elements, set the correct alingment, and then create the inner elements like the buttons and labels.
Or, if you wish, download the layout aia file. This is the first stage only. It is a working app but it doesn’t do much. The CONNET button takes you to the second screen and the BACK button takes to back to the first one.

Notes about the layout
The Screen1 is centre aligned and PAGE1_OUTER_VA is set to 95% width. This means there is a small margin either side.

BluetoothJoyPad_draftLayout_03_800

BluetoothJoyPad_draftLayout_07VerticalArrangement1,
VerticalArrangement2,
VerticalArrangement3

BluetoothJoyPad_draftLayout_08VerticalArrangement4

BluetoothJoyPad_draftLayout_04_800

BTN_CONNECT_PAGE size: height 12% , width 18%.

BluetoothJoyPad_draftLayout_05_800
Direction buttons: height 30%, Width 18%.

BluetoothJoyPad_draftLayout_06_800
Button size: height 15%, Width 20%.

BluetoothJoyPad_draftLayout_09

Now add the images (right Click Save as) or download all images.
BTN_UP BTN_RIGHT BTN_LEFT BTN_DOWN circle_blue_100x100 circle_red_100x100

 
Once the layout is completed add some basic blocks so that you can see how the app will work:
BluetoothJoyPad_001_Blocks

All these do is:
1. When the app starts (screen1.initialize)
– make the screen non-scrollable
– hide PAGE2_OUTER_VA

2. The next block handles the BTN_CONNECT_PAGE button. When the button is clicked page 2 is displayed;
– PAGE1_OUTER_VA is hidden (visible set to false)
– PAGE2_OUTER_VA is displayed (visible is set to true)

3. The third block handles the BTN_BACK. When this is clicked the app goes back to page 1 by hiding PAGE2_OUTER_VA and displaying PAGE1_OUTER_VA

Try what We have so far:
Download the BluetoothJoyPad_001 aia and give it a try.

 
 

Building The App

We will build the app in sections. In the first part we get the Bluetooth connecting and then we will add the button functions. Since the app will only have one way communication (app to Arduino) we do not need any code to handle receiving data, only sending. So all we need to do is make a connection, wait for a button press, and then send a code.

With Bluetooth Classic, the remote device has to be paired before we can make a connection. The pairing process is handled by the Android device via the devices settings. After a device is paired it remains in the Android devices paired device list. We will use this list in AI2 to allow the user to select the Bluetooth device to use. After the users selects a device the app will try to connect to it.

Since we are starting a new section, save the current project as “BluetoothJoyPad_002” and continue with the 002 version.

In the designer, add the Bluetooth Client to the project. In the Palette select BluetoothClient and drag it to the main window. This adds it to the project.

BluetoothJoyPad_Blocks_02BluetoothJoyPad_Blocks_03

Now add a ListPicker to the very bottom of the layout. For TEXT enter “Bluetooth device list” and uncheck the Visible box. We will use the CONNECT button to activate the ListPicker.
BluetoothJoyPad_Blocks_07BluetoothJoyPad_Blocks_08

Next add a Notifier:
BluetoothJoyPad_Blocks_09BluetoothJoyPad_Blocks_10

The Notifier will be used to display error messages, such as when Bluetooth is turn off or when a connection cannot be made.

 
In the Blocks editor, now that we have added the BluetoothClient we can access the Bluetooth blocks
BluetoothJoyPad_Blocks_05

I won’t go in to the details of every step but I will show the blocks and try to explain what they do.

Bluetooth Connection

blocks_004_BT_Connection

For the Bluetooth connection part we have 2 screen elements, the CONNECT button and the ListPicker. The ListPicker is set to invisible. There is also an empty list called PAIRED_BT_DEVICE_LIST. When the CONNECT button is clicked, the BTN_CONNECT_BT.Click function is called.

BluetoothJoyPad_Blocks_21b_BT_Connection

This first checks to see if Bluetooth is enabled. If not and error message is displayed. It then checks to see if there is already a connection, if there is, the user is asked if they would like to close it.

If Bluetooth is enabled and there isn’t a connection, all the paired devices are copied to the PAIRED_BT_DEVICE_LIST and if the length of the list > 0 we know we have at least 1 paired device and we can proceed. If the list is empty then another error message is displayed. If the list of paired devices is not empty, the list is then copied to the ListPicker and the ListPicker is activated. The paired device list comes from the system.

Using a list may seem like it is not required but it allows the app to check that there are paired devices. Without it there is the possibility that the app will display an empty list. Rather than showing the ListPicker on screen and allowing the user to click it, I use a button to activate it. This gives the app additional flexibility such as allowing the user to use the button to close the connection. This is a fairly robust way to initiate a connection in App Inventor 2.

After the user selects once of the paired devices from the ListPicker, the ListPicker1.AfterPicking block is called. It is here we try to make the connection.
BluetoothJoyPad_Blocks_22b_BT_Connection

If the connection is successful, the image used for IMG_BT_INDICAT is changed to “circle_blue_100x100.png” and the text on the BT button is changed to “CONNECTED”. If the connection fails an error message is displayed.

If there is an active connection when the user clicks the CONNECT button they are asked if they would like to close the connection. The Notifier1.AfterChoosing handles the user response. If they click the YES button the connection is closed and the image used for IMG_BT_INDICAT is changed to “circle_red_100x100.png” and the text on the BT button is changed to “NOT CONNECTED”.

BluetoothJoyPad_Blocks_23b_BT_Connection

If you want to try this, set up an HC-06 or an HC-05 (no need for an Arduino) and on an Android device, use the Settings => Bluetooth to pair with the Bluetooth module. After that, run the App Inventor app and try to connect.

 
Now we have the connection part done we need to add the blocks to handle the button clicks.

 

Button Clicks

First, save the current project as “BluetoothJoyPad_003”.

As mentioned earlier, the button clicks will have 2 states, pressed and released. We achieve this is App Inventor2 with the Button.TouchDown and the Button.TouchUp blocks.
BluetoothJoyPad_Blocks_24

We will need both blocks for each button and each button will send a different command. We could simply send the command within these blocks but since we are going to check the connection status before sending it is better to create a separate procedure called sendCommand.
BluetoothJoyPad_Blocks_25

sendCommand receives the command to send, checks the connection status and if connected, sends the command. It is always a good idea to check the connection status before trying to send anything. When you try to send data and there is no active connection you get a system error and these quickly become very annoying.

Use the sendCommand procedure by calling it while passing the command (or text) to send:
BluetoothJoyPad_Blocks_26

Now we can start to add the blocks to handle the button clicks. Remember that we are using capital letter for the TouchDown and lowercase for the TouchUp.

BluetoothJoyPad_Blocks_27

BluetoothJoyPad_Blocks_28

Save the project as “BluetoothJoyPad_004″.
Download BluetoothJoyPad_004.aia

 
 

Arduino

Most of the app is done so we can start work on the Arduino side.

Since this article is about the joypad and not the Arduino I am using a very simple circuit and sketch to test the app. The circuit consists of an Arduino, a HC-06 Bluetooth module and a voltage divider. The app displays the received data in the serial monitor.

 

The Circuit

BluetoothJoyPad_Blocks_30_Circuit_580

BluetoothJoyPad_Breadboard_1200

Arduino D9 (AltSoftSerial TX) to BT RX
Arduino D8 (AltSoftSerial RX)to BT TX
The BT module is getting power from the Arduinos 5V out pin
GND to GND.

The HC-06 RX pin is 3.3v and the Arduino D9 pin is 5V. This means we need to reduve the voltage. This is done with the voltage divider. The voltage divider uses a 1K ohm resistor and a 2k ohm resistor. This reduces 5v to 3.3v. The Arduino sees 3.3v as HIGH so we do not need to do anything on the BT TX pin. We can connect is directly to Arduino pin D8.

I am using a pre-made voltage divider.

The sketch is very simple. It uses AltSoftSerial to talk to the BT module and copies what ever it receives over AltSoftSerial to the serial monitor.

I am using a HC-06 and a HC-05 in slave mode can also be used. The HC-06 has the default settings:
Baud rate = 9600
Name = HC-06_ZG

// basicSerial_AltSoftSerial_01
//
//  Uses hardware serial to talk to the host computer and AltSoftSerial for communication with the bluetooth module
//  When data is received through AltSoftSerial it is copied to the serial monitor
//
//  Pins
//  Arduino D8 (ASS RX) - BT TX no need voltage divider 
//  Arduino D9 (ASS TX) - BT RX through a voltage divider
//  Arduino 5v out to BT vcc
//  GND to GND
 
#include <AltSoftSerial.h>
AltSoftSerial BTSerial; 
 
char c=' ';
 
void setup() 
{
    Serial.begin(9600);
    //Serial.print("Sketch:   ");   Serial.println(__FILE__);
    //Serial.print("Uploaded: ");   Serial.println(__DATE__);
    Serial.println(" ");
 
    BTSerial.begin(9600);  
    Serial.println("BTserial started at 9600");
 
}
 
void loop()
{
 
    // Read from the Bluetooth module and send to the Arduino Serial Monitor
    if (BTSerial.available())
    {
        c = BTSerial.read();
        Serial.println(c);
    }
 
 
}

Download the sketch

 

App In Action

Upload the code and run the app.

BluetoothJoyPad_41
when the app opens, click the CONNECT button. This op[ens the connection page
BluetoothJoyPad_42
Hit the NOT CONNECTED button.
BluetoothJoyPad_43
The list of paired devices is shown. Select the HC-06/HC-05 and the app tries to connect.
BluetoothJoyPad_44
If a connection is successful the button text changes to CONNECTED. Hit the BACK button to return to the main screen.
BluetoothJoyPad_45
The connection indicator is now blue.

With the serial monitor open, click the direction buttons.If the world is being good to you you should see the control codes.
BluetoothJoyPad_50

Now try the function buttons.
BluetoothJoyPad_51

 

Things To Try Next

Change the function buttons so that they have a single pressed event rather than a pressed and released event. Use the button.Click block.
Add a connect code to the app. When a connection is made get the app to send “CONNECTED” to the Arduino. You can then use this to know a connection has been established.

 

Downloads

Download BluetoothJoyPad_004.aia
Download the sketch

 
 

9 thoughts on “Create A Bluetooth Joypad With App Inventor 2”

  1. hallo my teacher i,m from indonesia, want to learn arduino.make the temperature and relay project which monitor from android, thanks teacher

    Reply
  2. Thankyou for this tutorial. This is very helpful to me. But i wand to send “z” when no any button is clicked. for example if up button is clicked send “A” if not clicked send “z”. How can i get this?

    Reply
  3. Hello Martyn, the download link for the .aia file is not working. I would really like to learn from this example and create one of my own for controlling the side mirrors of my car. I hope you see this comment as it seems it has been a while since you posted.

    Reply

Leave a Reply to attari Cancel reply