|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- import processing.serial.*;
- Serial myPort;
-
- float yaw = 0.0;
- float pitch = 0.0;
- float roll = 0.0;
-
- void setup()
- {
- size(600, 500, P3D);
-
- // if you have only ONE serial port active
- //myPort = new Serial(this, Serial.list()[0], 9600); // if you have only ONE serial port active
-
- // if you know the serial port name
- //myPort = new Serial(this, "COM5:", 9600); // Windows "COM#:"
- //myPort = new Serial(this, "\\\\.\\COM41", 9600); // Windows, COM10 or higher
- myPort = new Serial(this, "/dev/ttyACM0", 9600); // Linux "/dev/ttyACM#"
- //myPort = new Serial(this, "/dev/cu.usbmodem1217321", 9600); // Mac "/dev/cu.usbmodem######"
-
- textSize(16); // set text size
- textMode(SHAPE); // set text mode to shape
- }
-
- void draw()
- {
- serialEvent(); // read and parse incoming serial message
- background(255); // set background to white
- lights();
-
- translate(width/2, height/2); // set position to centre
-
- pushMatrix(); // begin object
-
- float c1 = cos(radians(roll));
- float s1 = sin(radians(roll));
- float c2 = cos(radians(-pitch));
- float s2 = sin(radians(-pitch));
- float c3 = cos(radians(yaw));
- float s3 = sin(radians(yaw));
- applyMatrix( c2*c3, s1*s3+c1*c3*s2, c3*s1*s2-c1*s3, 0,
- -s2, c1*c2, c2*s1, 0,
- c2*s3, c1*s2*s3-c3*s1, c1*c3+s1*s2*s3, 0,
- 0, 0, 0, 1);
-
- drawPropShield();
- //drawArduino();
-
- popMatrix(); // end of object
-
- // Print values to console
- print(roll);
- print("\t");
- print(-pitch);
- print("\t");
- print(yaw);
- println();
- }
-
- void serialEvent()
- {
- int newLine = 13; // new line character in ASCII
- String message;
- do {
- message = myPort.readStringUntil(newLine); // read from port until new line
- if (message != null) {
- String[] list = split(trim(message), " ");
- if (list.length >= 4 && list[0].equals("Orientation:")) {
- yaw = float(list[1]); // convert to float yaw
- pitch = float(list[2]); // convert to float pitch
- roll = float(list[3]); // convert to float roll
- }
- }
- } while (message != null);
- }
-
- void drawArduino()
- {
- /* function contains shape(s) that are rotated with the IMU */
- stroke(0, 90, 90); // set outline colour to darker teal
- fill(0, 130, 130); // set fill colour to lighter teal
- box(300, 10, 200); // draw Arduino board base shape
-
- stroke(0); // set outline colour to black
- fill(80); // set fill colour to dark grey
-
- translate(60, -10, 90); // set position to edge of Arduino box
- box(170, 20, 10); // draw pin header as box
-
- translate(-20, 0, -180); // set position to other edge of Arduino box
- box(210, 20, 10); // draw other pin header as box
- }
-
- void drawPropShield()
- {
- // 3D art by Benjamin Rheinland
- stroke(0); // black outline
- fill(0, 128, 0); // fill color PCB green
- box(190, 6, 70); // PCB base shape
-
- fill(255, 215, 0); // gold color
- noStroke();
-
- //draw 14 contacts on Y- side
- translate(65, 0, 30);
- for (int i=0; i<14; i++) {
- sphere(4.5); // draw gold contacts
- translate(-10, 0, 0); // set new position
- }
-
- //draw 14 contacts on Y+ side
- translate(10, 0, -60);
- for (int i=0; i<14; i++) {
- sphere(4.5); // draw gold contacts
- translate(10, 0, 0); // set position
- }
-
- //draw 5 contacts on X+ side (DAC, 3v3, gnd)
- translate(-10,0,10);
- for (int i=0; i<5; i++) {
- sphere(4.5);
- translate(0,0,10);
- }
-
- //draw 4 contacts on X+ side (G C D 5)
- translate(25,0,-15);
- for (int i=0; i<4; i++) {
- sphere(4.5);
- translate(0,0,-10);
- }
-
- //draw 4 contacts on X- side (5V - + GND)
- translate(-180,0,10);
- for (int i=0; i<4; i++) {
- sphere(4.5);
- translate(0,0,10);
- }
-
- //draw audio amp IC
- stroke(128);
- fill(24); //Epoxy color
- translate(30,-6,-25);
- box(13,6,13);
-
- //draw pressure sensor IC
- stroke(64);
- translate(32,0,0);
- fill(192);
- box(10,6,18);
-
- //draw gyroscope IC
- stroke(128);
- translate(27,0,0);
- fill(24);
- box(16,6,16);
-
- //draw flash memory IC
- translate(40,0,-15);
- box(20,6,20);
-
- //draw accelerometer/magnetometer IC
- translate(-5,0,25);
- box(12,6,12);
-
- //draw 5V level shifter ICs
- translate(42.5,2,0);
- box(6,4,8);
- translate(0,0,-20);
- box(6,4,8);
- }
|