15. Interface and application programming¶
Working in group¶
The tools that have been investigated and can be applied in this work block are: P5.js and Teachable Machine.
data:image/s3,"s3://crabby-images/4de65/4de65d0977fee1664bfd15d1d020d2e1222b585f" alt=""
- p5.js is a JavaScript library for creative programming.
- It's a reinterpretation of Processing, but now as a web language, unlike Processing, which runs on your computer.
- It is a free and open source tool; accessible to all.
- It presents a fairly friendly interface, which even allows us to edit the examples that it makes available to us.
data:image/s3,"s3://crabby-images/e9dc0/e9dc0076be2dd30146fdb444ac8cbecf61a5905a" alt=""
The following is an example that can be applied to an interface.
data:image/s3,"s3://crabby-images/5a5c3/5a5c31cf323a006c93179f4cf96840842dedeca0" alt=""
These are downloadable that can easily be worked on in Processing
It is a web-based AI tool developed by Google that makes building machine learning models fast, easy, and accessible to everyone.
data:image/s3,"s3://crabby-images/c36c3/c36c350bbd5a66e078bb16258da4604dd4d78067" alt=""
Basically it allows you to create video and audio type applications.
data:image/s3,"s3://crabby-images/43b8f/43b8fcf1685a502431236a9984c5201766a1963d" alt=""
An application can be created that, based on image recognition, has a specific behavior. It could be similar to the behavior of a sensor for example.
data:image/s3,"s3://crabby-images/f8d30/f8d30d304c103963633735e859950b52e51554ad" alt=""
Individual assignment¶
App
An application will be developed that allows controlling the activation and deactivation of the led on the pcb, via bluetooth, through a cell phone.
The physical implementation will be similar to the one in the following image:
data:image/s3,"s3://crabby-images/ba330/ba330d1802f1e108ecc8919eb9d3bc4d623fc2bd" alt=""
The interface layout in MIT App Inventor will be similar to the following:
data:image/s3,"s3://crabby-images/3d27f/3d27f79d3ee513e8189600401b5d738341358387" alt=""
The instructions of what the program will do will be:
/*Application: Interface
Author: Guadalupe Nieves Choque Choque*/
#include <SoftwareSerial.h>
#define pin_tx 7
#define pin_rx 8
SoftwareSerial SerialPort(pin_rx, pin_tx);
#define pinLed 2
void setup() {
SerialPort.begin(9600);
pinMode(pinLed, OUTPUT);
digitalWrite(pinLed, LOW);
}
void loop() {
if (SerialPort.available()){
switch(SerialPort.read()){
case '1':
digitalWrite(pinLed, HIGH);
break;
case '0':
digitalWrite(pinLed, LOW);
break;
}
}
}
On the Arduino:
data:image/s3,"s3://crabby-images/5011b/5011b7d7f700c1e7476ac36f57d74aa3c3b41158" alt=""
Running the application physically
data:image/s3,"s3://crabby-images/e7c25/e7c2554b504cb43b9b4f450722e162538f3c2021" alt=""
data:image/s3,"s3://crabby-images/57d34/57d34ce5ae29fdab3b4a0bfe60351faaef0fa11d" alt=""
In the video:
Natives files¶
Ord | Description | Files |
---|---|---|
1 | App Inferface | Interface.ino |