Bueno sin más espero que le sirva por lo menos a alguien.
/**
* Setup Quadcopter Simulation
*
* this code is for a mini quadcopter simulation and stabilization with accelerometer and microcontroller
*/
/*
line(300, 160, 340,160); // top square mainframe quadcopter
line(300, 200, 340,200); // bottom square mainframe quadcopter
line(300, 160, 300,200); // this is the left side of mainframe
line(340, 160, 340,200); // this is the right side of mainframe
*/
// The statements in the setup() function
// execute once when the program begins
float angle = 0.0;
float angle1 = 0.0;
float angle2 = 0.0;
float angle3 = 0.0;
float VM1=10;
float VM2=10;
float VM3=10;
float VM4=10;
void setup() {
size(640, 320 ); // Size must be the first statement
stroke(255); // Set line drawing color to white
frameRate(30);
}
void M1(){
pushMatrix(); // Save the current position before the translate modifications.
angle=angle+VM1;
translate(270,130);
rotate(angle);
line(-35,0,35,0);
fill(125, 0, 0);
ellipse(-20,0,38,8);
ellipse( 20,0,38,8);
popMatrix(); // Restore the original positions after the translate modifications.
}
void M2(){
pushMatrix(); // Save the current position before the translate modifications.
angle1=angle1+VM2;
translate(370,130);
rotate(angle1);
line(-35,0,35,0);
fill(125,0,0);
ellipse(-20,0,38,8);
ellipse( 20,0,38,8);
popMatrix(); // Restore the original positions after the translate modifications.
}
void M3(){
pushMatrix(); // Save the current position before the translate modifications.
angle2=angle2+VM3;
translate(270,230);
rotate(angle2);
line(-35,0,35,0);
fill(0);
ellipse(-20,0,38,8);
ellipse( 20,0,38,8);
popMatrix(); // Restore the original positions after the translate modifications.
}
void M4(){
pushMatrix(); // Save the current position before the translate modifications.
angle3=angle3+VM4;
translate(370,230);
rotate(angle2);
line(-35,0,35,0);
fill(0);
ellipse(-20,0,38,8);
ellipse( 20,0,38,8);
popMatrix(); // Restore the original positions after the translate modifications.
}
void protector(){
noFill(); strokeWeight(4);
ellipse(270, 130, 100, 100); // M1 L1
ellipse(370, 130, 100, 100); // M2 R1
ellipse(270, 230, 100, 100); // M3 L2
ellipse(370, 230, 100, 100); strokeWeight(1); // M4 R2
fill(255);
ellipse(270, 130, 7, 7); // M1 L1
ellipse(370, 130, 7, 7); // M2 R1
ellipse(270, 230, 7, 7); // M3 L2
ellipse(370, 230, 7, 7);
}
// The statements in draw() are executed until the
// program is stopped. Each statement is executed in
// sequence and after the last line is read, the first
// line is executed again.
void draw() {
background(30); // Set the background to black
VM1= map(mouseX, 0, width, 0, height);
VM2= map(mouseX, 0, width, 0, height);
VM3=10;
VM4=10;
fill(0);
strokeWeight(4);
line(270,130,370,230); // L1 and R2 Arm motor
line(370,130,270,230); // L2 and R1 Arm motor
strokeWeight(1);
ellipse(320, 180, 40, 40); // for the ellipse ( this is center XY, this is diameter)
//line(320, 180, 320,180); // center of mainframe quadcopter
fill(50,0,40);
ellipse(270, 130, 20, 20); // M1 L1
ellipse(370, 130, 20, 20); // M2 R1
ellipse(270, 230, 20, 20); // M3 L2
ellipse(370, 230, 20, 20); // M4 R2
text("SIMULATION OF QUADCOPTER STABILIZER "+angle,10,40);
text("M1: "+VM1,10,60);
text("M2: "+VM2,10,70);
text("M3: "+VM3,10,80);
text("M4: "+VM4,10,90);
M1();
M2();
M3();
M4();
protector();
}