VOID_Orbital:
[VOID.git] / VOID_Orbital.cs
blob:a/VOID_Orbital.cs -> blob:b/VOID_Orbital.cs
  // VOID
// //
// VOID_Orbital.cs // VOID_Orbital.cs
// //
// Author: // Copyright © 2014, toadicus
// toadicus <> // All rights reserved.
// //
// Copyright (c) 2013 toadicus // Redistribution and use in source and binary forms, with or without modification,
  // are permitted provided that the following conditions are met:
// //
// This program is free software: you can redistribute it and/or modify // 1. Redistributions of source code must retain the above copyright notice,
// it under the terms of the GNU General Public License as published by // this list of conditions and the following disclaimer.
// the Free Software Foundation, either version 3 of the License, or  
// (at your option) any later version.  
// //
// This program is distributed in the hope that it will be useful, // 2. Redistributions in binary form must reproduce the above copyright notice,
// but WITHOUT ANY WARRANTY; without even the implied warranty of // this list of conditions and the following disclaimer in the documentation and/or other
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // materials provided with the distribution.
// GNU General Public License for more details.  
// //
// You should have received a copy of the GNU General Public License // 3. Neither the name of the copyright holder nor the names of its contributors may be used
// along with this program. If not, see <http://www.gnu.org/licenses/>. // to endorse or promote products derived from this software without specific prior written permission.
  //
  // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
  // INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  // DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
   
using KSP; using KSP;
using System; using System;
  using ToadicusTools;
using UnityEngine; using UnityEngine;
   
namespace VOID namespace VOID
{ {
public class VOID_Orbital : VOID_WindowModule public class VOID_Orbital : VOID_WindowModule
{ {
[AVOID_SaveValue("toggleExtended")] [AVOID_SaveValue("toggleExtended")]
protected VOID_SaveValue<bool> toggleExtended = false; protected VOID_SaveValue<bool> toggleExtended = false;
   
[AVOID_SaveValue("precisionValues")] [AVOID_SaveValue("precisionValues")]
protected IntCollection precisionValues = new IntCollection(4, 230584300921369395); protected long _precisionValues = 230584300921369395;
  protected IntCollection precisionValues;
protected double orbitAltitude;  
protected double orbitVelocity;  
protected double orbitApoAlt;  
protected double oribtPeriAlt;  
protected string timeToApo;  
protected string timeToPeri;  
protected double orbitInclination;  
protected double gravityAccel;  
protected string orbitPeriod;  
protected double semiMajorAxis;  
protected double eccentricity;  
protected double meanAnomaly;  
protected double trueAnomaly;  
protected double eccAnomaly;  
protected double longitudeAscNode;  
protected double argumentPeriapsis;  
protected double localSiderealLongitude;  
   
public VOID_Orbital() public VOID_Orbital()
{ {
this._Name = "Orbital Information"; this._Name = "Orbital Information";
   
this.WindowPos.x = Screen.width - 520f; this.WindowPos.x = Screen.width - 520f;
this.WindowPos.y = 250f; this.WindowPos.y = 250f;
} }
   
public override void ModuleWindow(int _) public override void ModuleWindow(int _)
{ {
if (VOID_Core.Instance.updateTimer >= this.lastUpdate + VOID_Core.Instance.updatePeriod)  
{  
this.lastUpdate = VOID_Core.Instance.updateTimer;  
   
this.orbitAltitude = vessel.orbit.altitude;  
this.orbitVelocity = vessel.orbit.vel.magnitude;  
this.orbitApoAlt = vessel.orbit.ApA;  
this.oribtPeriAlt = vessel.orbit.PeA;  
this.timeToApo = Tools.ConvertInterval(vessel.orbit.timeToAp);  
this.timeToPeri = Tools.ConvertInterval(vessel.orbit.timeToPe);  
this.orbitInclination = vessel.orbit.inclination;  
   
double orbitRadius = vessel.mainBody.Radius + vessel.mainBody.GetAltitude(vessel.findWorldCenterOfMass());  
this.gravityAccel = (VOID_Core.Constant_G * vessel.mainBody.Mass) / Math.Pow(orbitRadius, 2);  
   
this.orbitPeriod = Tools.ConvertInterval(vessel.orbit.period);  
this.semiMajorAxis = vessel.orbit.semiMajorAxis;  
this.eccentricity = vessel.orbit.eccentricity;  
this.meanAnomaly = vessel.orbit.meanAnomaly * 180d / Math.PI;  
this.trueAnomaly = vessel.orbit.trueAnomaly;  
this.eccAnomaly = vessel.orbit.eccentricAnomaly * 180d / Math.PI;  
this.longitudeAscNode = vessel.orbit.LAN;  
this.argumentPeriapsis = vessel.orbit.argumentOfPeriapsis;  
this.localSiderealLongitude =  
Tools.FixDegreeDomain(vessel.longitude + vessel.orbit.referenceBody.rotationAngle);  
}  
   
int idx = 0; int idx = 0;
   
GUILayout.BeginVertical(); GUILayout.BeginVertical();
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.primaryName.DoGUIHorizontal ();
GUILayout.Label(VOIDLabels.void_primary + ":");  
GUILayout.FlexibleSpace();  
GUILayout.Label(vessel.mainBody.bodyName, GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); this.precisionValues [idx]= (ushort)VOID_Data.orbitAltitude.DoGUIHorizontal (this.precisionValues [idx]);
GUILayout.Label(VOIDLabels.void_altitude_asl + ":", GUILayout.ExpandWidth(true));  
GUILayout.FlexibleSpace();  
GUILayout.Label(  
Tools.MuMech_ToSI(this.orbitAltitude, this.precisionValues[idx]) + "m",  
GUILayout.ExpandWidth(false)  
);  
if (GUILayout.Button ("P")) {  
this.precisionValues [idx] = (ushort)((this.precisionValues[idx] + 3) % 15);  
}  
GUILayout.EndHorizontal();  
idx++; idx++;
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); this.precisionValues [idx]= (ushort)VOID_Data.orbitVelocity.DoGUIHorizontal (this.precisionValues [idx]);
GUILayout.Label(VOIDLabels.void_velocity + ":");  
GUILayout.FlexibleSpace();  
GUILayout.Label(Tools.MuMech_ToSI(this.orbitVelocity, this.precisionValues [idx]) + "m/s", GUILayout.ExpandWidth(false));  
   
if (GUILayout.Button ("P")) {  
this.precisionValues [idx] = (ushort)((this.precisionValues[idx] + 3) % 15);  
}  
GUILayout.EndHorizontal();  
idx++; idx++;
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); this.precisionValues [idx]= (ushort)VOID_Data.orbitApoAlt.DoGUIHorizontal (this.precisionValues [idx]);
GUILayout.Label(VOIDLabels.void_apoapsis + ":");  
GUILayout.FlexibleSpace();  
GUILayout.Label(Tools.MuMech_ToSI(this.orbitApoAlt, this.precisionValues [idx]) + "m", GUILayout.ExpandWidth(false));  
   
if (GUILayout.Button ("P")) {  
this.precisionValues [idx] = (ushort)((this.precisionValues[idx] + 3) % 15);  
}  
GUILayout.EndHorizontal();  
idx++; idx++;
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.timeToApo.DoGUIHorizontal();
GUILayout.Label("Time to Ap:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.timeToApo, GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); this.precisionValues [idx]= (ushort)VOID_Data.oribtPeriAlt.DoGUIHorizontal (this.precisionValues [idx]);
GUILayout.Label(VOIDLabels.void_periapsis + ":");  
GUILayout.FlexibleSpace();  
GUILayout.Label(  
Tools.MuMech_ToSI(this.oribtPeriAlt, this.precisionValues [idx]) + "m",  
GUILayout.ExpandWidth(false)  
);  
   
if (GUILayout.Button ("P")) {  
this.precisionValues [idx] = (ushort)((this.precisionValues[idx] + 3) % 15);  
}  
GUILayout.EndHorizontal();  
idx++; idx++;
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.timeToPeri.DoGUIHorizontal();
GUILayout.Label("Time to Pe:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.timeToPeri, GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.orbitInclination.DoGUIHorizontal("F3");
GUILayout.Label("Inclination:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.orbitInclination.ToString("F3") + "°", GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); this.precisionValues [idx]= (ushort)VOID_Data.gravityAccel.DoGUIHorizontal (this.precisionValues [idx]);
GUILayout.Label("Gravity:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(  
Tools.MuMech_ToSI(gravityAccel, this.precisionValues[idx]) + "m/s²",  
GUILayout.ExpandWidth(false)  
);  
   
if (GUILayout.Button ("P")) {  
this.precisionValues [idx] = (ushort)((this.precisionValues[idx] + 3) % 15);  
}  
GUILayout.EndHorizontal();  
idx++; idx++;
   
this.toggleExtended = GUILayout.Toggle(this.toggleExtended, "Extended info"); this.toggleExtended.value = GUILayout.Toggle(this.toggleExtended, "Extended info");
   
if (this.toggleExtended) if (this.toggleExtended)
{ {
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.orbitPeriod.DoGUIHorizontal();
GUILayout.Label("Period:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.orbitPeriod, GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); this.precisionValues [idx]= (ushort)VOID_Data.semiMajorAxis.DoGUIHorizontal (this.precisionValues [idx]);
GUILayout.Label("Semi-major axis:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(  
Tools.MuMech_ToSI(this.semiMajorAxis, this.precisionValues [idx]) + "m",  
GUILayout.ExpandWidth(false)  
);  
   
if (GUILayout.Button ("P")) {  
this.precisionValues [idx] = (ushort)((this.precisionValues[idx] + 3) % 15);  
}  
GUILayout.EndHorizontal();  
idx++; idx++;
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.eccentricity.DoGUIHorizontal("F4");
GUILayout.Label("Eccentricity:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.eccentricity.ToString("F4"), GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
// Toadicus edit: convert mean anomaly into degrees. VOID_Data.meanAnomaly.DoGUIHorizontal("F3");
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true));  
GUILayout.Label("Mean anomaly:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.meanAnomaly.ToString("F3") + "°", GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.trueAnomaly.DoGUIHorizontal("F3");
GUILayout.Label("True anomaly:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.trueAnomaly.ToString("F3") + "°", GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
// Toadicus edit: convert eccentric anomaly into degrees. VOID_Data.eccAnomaly.DoGUIHorizontal("F3");
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true));  
GUILayout.Label("Eccentric anomaly:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.eccAnomaly.ToString("F3") + "°", GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.longitudeAscNode.DoGUIHorizontal("F3");
GUILayout.Label("Long. ascending node:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.longitudeAscNode.ToString("F3") + "°", GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true)); VOID_Data.argumentPeriapsis.DoGUIHorizontal("F3");
GUILayout.Label("Arg. of periapsis:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.argumentPeriapsis.ToString("F3") + "°", GUILayout.ExpandWidth(false));  
GUILayout.EndHorizontal();  
   
// Toadicus edit: added local sidereal longitude. VOID_Data.localSiderealLongitude.DoGUIHorizontal("F3");
GUILayout.BeginHorizontal(GUILayout.ExpandWidth(true));  
GUILayout.Label("Local Sidereal Longitude:");  
GUILayout.FlexibleSpace();  
GUILayout.Label(this.localSiderealLongitude.ToString("F3") + "°", VOID_Core.Instance.LabelStyles["right"]);  
GUILayout.EndHorizontal();  
} }
   
GUILayout.EndVertical(); GUILayout.EndVertical();
GUI.DragWindow(); GUI.DragWindow();
} }
   
  public override void LoadConfig ()
  {
  base.LoadConfig ();
   
  this.precisionValues = new IntCollection (4, this._precisionValues);
  }
   
  public override void _SaveToConfig (KSP.IO.PluginConfiguration config)
  {
  this._precisionValues = this.precisionValues.collection;
   
  base._SaveToConfig (config);
  }
} }
} }