!7 p { pMain(It); } sclass It extends PApplet { //Artificial Horizon+Compass by Adrian Fernandez 4-19-2013 //Built with Processing 1.5.1 int W=1350; //My Laptop's screen width int H=690; //My Laptop's screen height float Pitch; float Bank; float Azimuth; float ArtificialHoizonMagnificationFactor=0.7f; float CompassMagnificationFactor=0.85f; float SpanAngle=120; int NumberOfScaleMajorDivisions; int NumberOfScaleMinorDivisions; PVector v1, v2; //For testing only void settings() { size(W, H); } void setup() { rectMode(CENTER); smooth(); //strokeCap(SQUARE);//Optional } void draw() { background(0); translate(W/4, H/2.1f); MakeAnglesDependentOnMouse(); Horizon(); rotate(-Bank); PitchScale(); Axis(); rotate(Bank); Borders(); Plane(); ShowAngles(); Compass(); ShowAzimuth(); } void MakeAnglesDependentOnMouse() //For testing only. { v2= new PVector(); v1= new PVector(W/2, H/2); v2.x=mouseX; v2.y=mouseY; Bank = PVector.angleBetween(v1, v2); Pitch=mouseY-H/2; Azimuth=(180/PI*10*Bank)%360; } void Horizon() { scale(ArtificialHoizonMagnificationFactor); noStroke(); fill(0, 180, 255); rect(0, -100, 900, 1000); fill(95, 55, 40); rotate(-Bank); rect(0, 400+Pitch, 900, 800); rotate(Bank); rotate(-PI-PI/6); SpanAngle=120; NumberOfScaleMajorDivisions=12; NumberOfScaleMinorDivisions=24; CircularScale(); rotate(PI+PI/6); rotate(-PI/6); CircularScale(); rotate(PI/6); } void ShowAzimuth() { fill(50); noStroke(); rect(20, 470, 440, 50); int Azimuth1=round(Azimuth); textAlign(CORNER); textSize(35); fill(255); text("Azimuth: "+Azimuth1+" Deg", 80, 477, 500, 60); } void Compass() { translate(2*W/3, 0); scale(CompassMagnificationFactor); noFill(); stroke(100); strokeWeight(80); ellipse(0, 0, 750, 750); strokeWeight(50); stroke(50); fill(0, 0, 40); ellipse(0, 0, 610, 610); for (int k=255;k>0;k=k-5) { noStroke(); fill(0, 0, 255-k); ellipse(0, 0, 2*k, 2*k); } strokeWeight(20); NumberOfScaleMajorDivisions=18; NumberOfScaleMinorDivisions=36; SpanAngle=180; CircularScale(); rotate(PI); SpanAngle=180; CircularScale(); rotate(-PI); fill(255); textSize(60); textAlign(CENTER); text("W", -375, 0, 100, 80); text("E", 370, 0, 100, 80); text("N", 0, -365, 100, 80); text("S", 0, 375, 100, 80); textSize(30); text("COMPASS-01", 0, -130, 500, 80); rotate(PI/4); textSize(40); text("NW", -370, 0, 100, 50); text("SE", 365, 0, 100, 50); text("NE", 0, -355, 100, 50); text("SW", 0, 365, 100, 50); rotate(-PI/4); CompassPointer(); } void CompassPointer() { rotate(PI+radians(Azimuth)); stroke(0); strokeWeight(4); fill(100, 255, 100); triangle(-20, -210, 20, -210, 0, 270); triangle(-15, 210, 15, 210, 0, 270); ellipse(0, 0, 45, 45); fill(0, 0, 50); noStroke(); ellipse(0, 0, 10, 10); triangle(-20, -213, 20, -213, 0, -190); triangle(-15, -215, 15, -215, 0, -200); rotate(-PI-radians(Azimuth)); } void Plane() { fill(0); strokeWeight(1); stroke(0, 255, 0); triangle(-20, 0, 20, 0, 0, 25); rect(110, 0, 140, 20); rect(-110, 0, 140, 20); } void CircularScale() { float GaugeWidth=800; textSize(GaugeWidth/30); float StrokeWidth=1; float an; float DivxPhasorCloser; float DivxPhasorDistal; float DivyPhasorCloser; float DivyPhasorDistal; strokeWeight(2*StrokeWidth); stroke(255); float DivCloserPhasorLenght=GaugeWidth/2-GaugeWidth/9-StrokeWidth; float DivDistalPhasorLenght=GaugeWidth/2-GaugeWidth/7.5f-StrokeWidth; for (int Division=0;Division