This is a project in which we built a mobile application to control a custom self-balancing robot through a Bluetooth HC-08 interface. The project allows sending commands to the Arduino micro controller to perform tasks such as:
- Movement in the 4 directions: Forward, Backward, Right and Left through a joystick interface.
- Getting all the measurements from the robot sensors to represent the robot status in tables and graphs.
- Change the PID controllers constants, and the maximum robots speeds.
- Draw the map of the robot in a canvas given the measurements.
The framework selected was Ionic Framework, this is a very nice an powerful tool for build android and ios mobile apps using JavaScript, HTML, and CSS. But for this particular I selected Reactjs as a JavaScript library with typescript template. For the state management the Redux with the plugging for react was selected.
////////////////////////// INTERFACES ////////////////////////
export interface IRobotState {
linearVelocity: number;
angularVelocity: number;
incliAngle: number;
posX: number;
posY: number;
robotOrien: number;
battery?: number;
startSampling?: boolean;
sampleTime?: number;
persistData?: boolean;
records?: Array<{
linearVelocity: number;
angularVelocity: number;
incliAngle: number;
posX: number;
posY: number;
robotOrien: number;
battery: number;
}>;
}
/////////////////////////////////////////////////////////////////
////////////////////////TYPES////////////////////////////////
export const SET_ROBOT_DYNAMIC_STATE = 'SET_ROBOT_DYNAMIC_STATE';
export const RESET_ROBOT_DYNAMIC_STATE = 'RESET_ROBOT_DYNAMIC_STATE';
export const PERSIST_ROBOT_DYNAMIC_STATE = 'PERSIST_ROBOT_DYNAMIC_STATE';
///////////////////////////////////////////////////////////
const initialState: IRobotState = {
linearVelocity: 0.0,
angularVelocity: 0.0,
incliAngle: 0.0,
posX: 0,
posY: 0,
robotOrien: 0.0,
battery: 50,
startSampling: false,
sampleTime: 150,
persistData: false,
records: [],
};
The app is composed by tabs and several components for rendering the different UIs.
- Driver
- Automatic
- Adjust Controllers
- Metrics
To collaborate or simply use this project you must have the android environment ready.
[https://developer.android.com/studio]
If you are linux user you simply execute this or add it to the appropriate shell-specific config file. Example: bash_profile, bashrc etc.
export ANDROID_SDK_ROOT=$HOME/Library/Android/sdk
export PATH=$PATH:$ANDROID_SDK_ROOT/emulator
export PATH=$PATH:$ANDROID_SDK_ROOT/platform-tools
[https://ionicframework.com/docs/intro/cli]
Once the repo has been downloaded, run the following commands
npm install
ionic serve
This runs the project in your web browser but the native pluggins will not work.
ionic cap add android
for generate the ios project
ionic cap add ios
Open the android studio in the folder android and run the app in the simulator.
For live functions and to work directly on the application mounted on the simulator run this.
npm run dev
[https://github.com/josealejandro2928/Self-Balancing-Arduino-Robot-Controller]
In the root of the project you have a demo of the app ".apk"
SB_Controller.apk