This library enables an Android smartphone / tablet to act as a graphical display for your Arduino or ESP32.
Available as Arduino library "BlueDisplay".
🌎 Google Translate
With the BlueDisplay library you create the GUI for your application, e.g. Graphics, Text, Buttons and Sliders on the Arduino itself.
No Android programming required!
The Arduino is connected via USB-cable or Bluetooth with your smartphone / tablet, where the BlueDisplay app renders the GUI.
GUI callback, touch and sensor events are sent back to the Arduino, where they can be handled.
The Bluetooth connection can be achieved by using an ESP32 or connecting a HC-05 to the RX/TX pins of your Arduino.
Connecting the Arduino with an USB cable to your smartphone requires an USB-OTG adapter.
- Graphic + text output as well as printf implementation.
- Draw chart from byte or short values. Enables clearing of last drawn chart.
- Play system tones.
- Touch button + slider objects with tone feedback.
- Button and slider callback as well as touch and sensor events are sent back to Arduino.
- Automatic and manually scaling of display region.
- Easy mapping of UTF-8 characters like Ohm, Celsius etc..
- Up to 115200 Baud using HC-05 modules.
- USB OTG connection can be used instead of Bluetooth.
- Local display of received and sent commands for debugging purposes.
- Hex and ASCII output of received Bluetooth data at log level verbose.
- Debug messages as toasts.
- Thick line with Bresenham.
- Touch button + slider implementations for HX8347D and SSD1289 controller.
- Local event support for ADS7846 resistive touch controller.
- Local and remote displays can be used simultaneously and are synchonized when possible.
On Android, you need to install the BlueDisplay app.
//#define BLUETOOTH_BAUD_RATE BAUD_115200 // Activate this, if you have reprogrammed the HC05 module for 115200, otherwise 9600 is used as baud rate
#include "BlueDisplay.hpp"
// Declare callback handler for (re)connect and resize
void initDisplay(void);
void drawGui(void);
void setup() {
Serial.begin(BLUETOOTH_BAUD_RATE);
BlueDisplay1.initCommunication(&initDisplay, &drawGui);
}
void loop() {
...
checkAndHandleEvents();
}
void initDisplay(void) {
// Initialize display size and flags
BlueDisplay1.setFlagsAndSize(BD_FLAG_FIRST_RESET_ALL | BD_FLAG_USE_MAX_SIZE | BD_FLAG_TOUCH_BASIC_DISABLE, 320, 240);
// Initialize all GUI elements here
...
}
void drawGui(void) {
BlueDisplay1.clearDisplay(COLOR16_WHITE);
// Draw all GUI elements here
...
}
For boards which have more than one serial interface, the library tries to use Serial1 for the BT connection to leave Serial, which is mostly connected to the USB, for other purposes as logging etc..
If you require direct USB connection to the smartphone / tablet by cable for this board, you must activate the macro USE_USB_SERIAL
.
Another, but more more complicated, way is to modify the central serial interface function of the library.
You only have to change the first 2 lines of the function sendUSARTBufferNoSizeCheck()
in BlueSerial.hpp according to your requirements.
Android axis are defined for natural screen orientation, which is portrait for my devices:
- When the device lies flat on a table and its left side is down and right side is up or pushed on its left side toward the right, the X acceleration value is positive.
- When the device lies flat on a table and its bottom side is down and top side is up or pushed on its bottom side toward the top, the Y acceleration value is positive.
- When the device lies flat on a table, the acceleration value along Z is +9.81 (m/s^2).
The BlueDisplay application converts the axis, so that this definition holds for each screen orientation. For detailed information to sensors see ShowSensorValues example
In order to support compile options more easily,
the line #include <BlueDisplay.h>
must be changed to #include <BlueDisplay.hpp>
in your main program (aka *.ino file with setup() and loop()).
In all other files you must use #include <BlueDisplay.h>
, to prevent multiple definitions
linker errors:
To customize the library to different requirements, there are some compile options / macros available.
These macros must be defined in your program before the line #include <BlueDisplay.hpp>
to take effect.
Modify them by enabling / disabling them, or change the values if applicable.
Name | Default value | Description |
---|---|---|
BLUETOOTH_BAUD_RATE |
9600 | Change this, if you have reprogrammed the HC05 module for another baud rate e.g.115200. |
DO_NOT_NEED_BASIC_TOUCH_EVENTS |
disabled | Disables basic touch events like down, move and up. Saves up to 620 bytes program memory and 36 bytes RAM. |
USE_SIMPLE_SERIAL |
disabled | Only for AVR! Do not use the Serial object. Saves up to 1250 bytes program memory and 185 bytes RAM, if Serial is not used otherwise. |
USE_USB_SERIAL |
disabled | Activate it, if you want to force using Serial instead of Serial1 for direct USB cable connection to your smartphone / tablet. This is only required on platforms, which have Serial1 available. |
SUPPORT_LOCAL_DISPLAY |
disabled | Supports simultaneously drawing on the locally attached display. Not (yet) implemented for all commands! |
DISABLE_REMOTE_DISPLAY |
disabled | Suppress drawing to Bluetooth connected display. Allow only drawing on the locally attached display. Not (yet) implemented for all commands! |
LOCAL_GUI_FEEDBACK_TONE_PIN |
disabled | If defined, local GUI library calls tone(LOCAL_GUI_FEEDBACK_TONE_PIN, 3000, 50) on flags like FLAG_BUTTON_DO_BEEP_ON_TOUCH. |
SUPPORT_ONLY_TEXT_SIZE_11_AND_22 |
disabled | If defined, saves program memory especially for local GUI. |
LOCAL_DISPLAY_HEIGHT |
240 | The height of the local diplay used by the LocalGUI library. |
LOCAL_DISPLAY_WIDTH |
320 | The width of the local diplay used by the LocalGUI library. |
if we want to use special characters to display, we face the problem, that we can only send ASCII codes to be displayed. But fortunately the ASCII code table has at least 128 "unused" entries between 0x80 and 0xFF, normally used for the local codepage.
But with setCharacterMapping(<ASCII_value>, <UTF16_value>)
you can modify this codepage, i.e display the character <UTF16_value> if you send <ASCII_value>, which has to be between 0x80 and 0xFF.
Since the 2. parameter for setCharacterMapping is 16 bit, you cannot use characters whose Unicode code is higher than 0xFFFF like the electric light bulb (U+1F4A1 from https://www.fileformat.info/info/unicode/char/1f4a1/index.htm).
BlueDisplay1.setCharacterMapping(0x87, 0x2227); // mapping for unicode AND used as Forward symbol
BlueDisplay1.setCharacterMapping(0x88, 0x2228); // mapping for unicode OR used as Backwards symbol
By default, the local codepage of the Android system is used for display special characters above 0x7F.
But if you have a codepage which better fits your needs and you want to use as your default code page, you can change it with setCodePage(<ISO_8859_Number>)
. Internally it is done on Android with Charset.forName("ISO_8859_" + <ISO_8859_Number>)
.
Before using the examples, take care that the Bluetooth-module (e.g. the the HC-05 module) or ESP32 program is connected to your Android device and is visible in the Bluetooth Settings.
All examples initially use the baud rate of 9600. Especially the SimpleTouchScreenDSO example will run smoother with a baud rate of 115200.
For this, change the example baud rate by deactivating the line #define BLUETOOTH_BAUD_RATE BAUD_9600
and activating #define BLUETOOTH_BAUD_RATE BAUD_115200
.
AND change the Bluetooth-module baud rate e.g. by using the BTModuleProgrammer.ino example.
For ESP32 no baud rate must be specified :-).
Simple example to check your installation.
Breadboard | With debug output after pressing the "Stop" button |
---|---|
More elaborated example to show more features of the BlueDisplay library.
Screenshot | Graphics test page with additional thick red lines |
---|---|
Fritzing schematic for BlueDisplay example | BlueDisplay example breadboard picture |
Shows the accelerometer and gyroscope values received from the smartphone both graphical and numerical.
Simple helper program to configure your HC-05 or JDY-31 modules name and default baud rate with a serial monitor.
It can also be used to enter AT commands directly to the BT module for extended manual programming.
Sample outputs can be found here.
Example of controlling a RC-car by smartphone accelerometer sensor.
RC car control display | Hacked RC car |
---|---|
The accelerometer sensor of the android display is used to control two servos in a frame which holds a laser.
This is an example for using a fullscreen GUI.
If no BD connection available, the servo first marks the border and then moves randomly in this area (Cat Mover).
- Zero -> the actual sensor position is taken as the servos 90/90 degree position.
- Bias (reverse of Zero) -> take actual servos position as position for horizontal sensors position.
- Auto move -> moves randomly in the programmed border. Currently horizontal 45 to 135 and vertical 0 to 45.
Screenshot | Bias setting |
---|---|
300 kSamples DSO without external hardware (except the HC-05 module). For AC input, only a capacitor and 4 resistors are needed.
More information at Arduino-Simple-DSO.
Not for STM32.
DSO start screen | DSO chart screen with long info |
---|---|
Shows the distances measured by a HC-SR04 ultrasonic sensor. Can be used as a parking assistance.
Depending on the device you use, you can observe some random "delays" up to 500 ms in the timing of the display refresh.
The delays does not occur if you use a USB connection instead of the Bluetooth one.
The reason is, that the Android Bluetooth driver does not return its received bytes for a longer time.
If you send to much data during this delay the driver may hang, as you can observe for the SimpleDSO Application, which runs smooth with a USB connection.
Hanging may be avoided if using flow control, but the HC05 firmware and HC05 breakout boards do not support it.
On the ESP32, the BluetoothSerial library supports flow control and there you can observe that the client program also delays, when the smartphone driver takes its break.
This Bluetooth driver is usually delivered by the hardware vendor, so it may depend on the chips used in your smartphone.
It seems, that some Bluetooth SPP (Serial Port Profile) drivers are not really specified/tested/optimized for real time behavior.
Known devices with these "delays" are:
Lenovo K3 Note 6.0, Nexus7 with AW-NH665 BT-Chip running 6.0.1, Nexus 6P with ?8.x?, Kindle Fire HD 8 with Broadcom BCM2076 running 6.3.1.5.
Known devices without these "delays" are:
Samsung Note 3 running 5.0, Lifetab P9702 running 7.1.2, Lifetab E10310 running 4.2.2, XORO PAD 721 running 4.2.2, Samsung Galaxy S3 GT-I9300 running Lineage 7.1.2, LUX10 running 5.0, iRULU X11 running 5.1.1, Time2 TC1050G running 5.1, Pixel 4 XL running 10.
The extras folder (in the Arduino IDE use "Sketch > Show Sketch Folder" (or Ctrl+K) and then in the libraries/BlueDisplay/extras directory) contains more schematics, breadboard layouts and pictures which may help you building the example projects.
If you need debugging, you must use the debug()
functions since using Serial.print()
etc. gives errors (we have only one serial port on the Arduino).
BlueDisplay1.debug("DoBlink=", doBlink);
The debug content will then show up as toast on your Android device and is stored in the log. Change the log level in the app to see more or less information of the BlueDisplay communication.
To enable programming of the Arduino while the HC-05 module is connected, use a diode (e.g. a BAT 42) to connect Arduino rx and HC-05 tx. On Arduino MEGA 2560, TX1 is used, so no diode is needed.
|\ |
Arduino-rx ___| \|___ HC-05-tx
| /|
|/ |
- Minor changes and updated 3. party libs.
- Major refactoring, many bug fixes and seamless support of local display.
- All
*Rel*()
functions now have signed delta parameters. - Fixed bugs in
drawLineRelWithThickness()
and button list for local display. - Added
debug(const __FlashStringHelper *aStringPtr)
. - Added
bool delay(AndCheckForEvent()
.
- Added function setPosition() for sliders.
- Fixed bug in macros
BLUE
andCOLOR32_GET_BLUE
.
- ADCUtils now external sources.
- Improved BTModuleProgrammer program.
- Renamed *.cpp to *.hpp.
- Changed default serial for AVR from
USE_SIMPLE_SERIAL
to standard Arduino Serial. - Added ShowSensorValues example.
- Renamed mReferenceDisplaySize to mRequestedDisplaySize and renamed related function to getRequestedDisplaySize().
- New function
setBarThresholdDefaultColor
. Requires BlueDisplay app version 4.3. - New function
setPositiveNegativeSliders(..., aValue, aSliderDeadBand)
. - Renamed
setPrintf*
functions tosetWriteString*
. - Switched last 2 parameters in
initCommunication()
and the 3. parameter is now optional. - Compatible with MegaCore supported CPU's.
- New function
setCaptionFromStringArrayPGM()
. - Added flag
sBDEventJustReceived
.
- Arduino Due support added.
- New command
FUNCTION_CLEAR_DISPLAY_OPTIONAL
to enable resynchronizations of slow displays. Used by SimpleTouchScreenDSO.
- ESP32 and ESP8266 support added. External BT module required for ESP8266.
- Added
sMillisOfLastReceivedBDEvent
for user timeout detection. - Fixed bug in
debug(const char *aMessage, float aFloat)
. - Added
*LOCK_SENSOR_LANDSCAPE
and*LOCK_SENSOR_LANDSCAPE
in functionsetScreenOrientationLock()
. Requires BlueDisplay app version 4.2. - Removed unused
mCurrentDisplayHeight
andmCurrentDisplayWidth
member variables. - Fixed bug in draw function from
drawByte
todrawLong
. - Added short
drawText
functions. Requires BlueDisplay app version 4.2.
- Use type
Print *
instead ofStream *
. - New function
initSerial()
- Changed parameter
aTextSize
touint16_t
also for AVR specific functions.
- Porting to STM32.
- Changed default baud rate for all examples to
9600
. - Renamed
USART_send()
tosendUSART()
. - DSO example Version 3.1.
Initial Arduino library version
- Handling of no input for getNumber.
- Slider setScaleFactor() does not scale the actual value, mostly delivered as initial value at init().
- connect, reconnect and autoconnect improved/added. Improved debug() command. Simplified Red/Green button handling.
- Slider scaling changed and unit value added.
- Timeout for data messages. Get number initial value fixed.
- Bug autorepeat button in conjunction with UseUpEventForButtons fixed.
- Fixed silent tone bug for Android Lollipop and other bugs. Multiline text /r /n handling.
- Android time accessible on Arduino. Debug messages as toasts. Changed create button.
- Slider values scalable. GUI multi touch.Hex and ASCII output of received Bluetooth data at log level verbose.
- Improved tone and fullscreen handling. Internal refactoring. Bugfixes and minor improvements.
- Local display of received and sent commands for debug purposes.
- Android sensor accessible by Arduino.
The library examples are tested with GitHub Actions for the following boards:
- arduino:avr:uno
- arduino:avr:leonardo
- arduino:avr:mega
- esp8266:esp8266:huzzah:eesz=4M3M,xtal=80
- esp32:esp32:featheresp32:FlashFreq=80
- STMicroelectronics:stm32:GenF1:pnum=BLUEPILL_F103C8
Please write me a PM including your motivation/problem if you need a modification or an extension.