|
@@ -4,19 +4,20 @@ namespace Model
|
|
|
{
|
|
|
public class FXJHGenerate
|
|
|
{
|
|
|
- public static TurningPoint[]
|
|
|
- FromStartToMission(FlightPlanEditor editor, TurningPoint[] turningPoints) //生成从基地到任务段起点的航路点
|
|
|
+ public static void FromStartToMission(FlightPlanEditor editor,ref List<TurningPoint> turningPoints) //生成从基地到任务段起点的航路点
|
|
|
{
|
|
|
- turningPoints[0].TurningPointName = "爬升";
|
|
|
- turningPoints[0].TurningPointLongitude = editor.originbase.BaseLongitude; //基地位置
|
|
|
- turningPoints[0].TurningPointLatitude = editor.originbase.BaseLatitude;
|
|
|
- turningPoints[0].TurningPointHeight = editor.originbase.BaseHeight;
|
|
|
- turningPoints[0].TurningPointType = "普通";
|
|
|
- //turningPoints[0].TurningPointVelocity = editor.climbsegment.ClimbVelocity;
|
|
|
- turningPoints[0].SegmentFlightFuelConsumption = 1;
|
|
|
- turningPoints[0].SegmentFlightTime = 0;
|
|
|
- turningPoints[0].RemainingFuel = 0;
|
|
|
-
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "爬升",
|
|
|
+ TurningPointLongitude = editor.originbase.BaseLongitude, //基地位置
|
|
|
+ TurningPointLatitude = editor.originbase.BaseLatitude,
|
|
|
+ TurningPointHeight = editor.originbase.BaseHeight,
|
|
|
+ TurningPointType = "普通",
|
|
|
+ //TurningPointVelocity = editor.climbsegment.ClimbVelocity;
|
|
|
+ SegmentFlightFuelConsumption = 1,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
|
|
|
double k;
|
|
|
double lat1, lon1; //直升机起飞后爬升到的航路点的经纬度,记为经纬度1
|
|
@@ -33,16 +34,17 @@ namespace Model
|
|
|
lon1 = editor.originbase.BaseLongitude - 0.08544 / (Math.Sqrt(k * k + 1));
|
|
|
}
|
|
|
|
|
|
- turningPoints[1].TurningPointName = "巡航";
|
|
|
- turningPoints[1].TurningPointLongitude = lon1;
|
|
|
- turningPoints[1].TurningPointLatitude = lat1;
|
|
|
- turningPoints[1].TurningPointHeight = 2000;
|
|
|
- turningPoints[1].TurningPointType = "普通";
|
|
|
- turningPoints[1].SegmentFlightFuelConsumption = 2;
|
|
|
- turningPoints[1].SegmentFlightTime = 0;
|
|
|
- turningPoints[1].RemainingFuel = 0;
|
|
|
-
|
|
|
- return turningPoints;
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "巡航",
|
|
|
+ TurningPointLongitude = lon1,
|
|
|
+ TurningPointLatitude = lat1,
|
|
|
+ TurningPointHeight = 2000,
|
|
|
+ TurningPointType = "普通",
|
|
|
+ SegmentFlightFuelConsumption = 2,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
//获取油耗率
|
|
@@ -156,83 +158,86 @@ namespace Model
|
|
|
return GetCruisingVelocity(editor, height) / 2;
|
|
|
}
|
|
|
|
|
|
- public static TurningPoint[]
|
|
|
- ZhenCha(List<double[]> SC01, FlightPlanEditor editor, TurningPoint[] turningPoints) //侦查模型航路点生成
|
|
|
+ public static void ZhenCha(List<double[]> SC01, FlightPlanEditor editor, ref List<TurningPoint> turningPoints) //侦查模型航路点生成
|
|
|
{
|
|
|
int i;
|
|
|
for (i = 0; i < SC01.Count - 1; i++)
|
|
|
{
|
|
|
- turningPoints[i + 2].TurningPointName = "巡航";
|
|
|
- turningPoints[i + 2].TurningPointLongitude = SC01[i][0];
|
|
|
- turningPoints[i + 2].TurningPointLatitude = SC01[i][1];
|
|
|
- turningPoints[i + 2].TurningPointHeight = SC01[i][2];
|
|
|
- turningPoints[i + 2].TurningPointType = "侦查";
|
|
|
- turningPoints[i + 2].SegmentFlightFuelConsumption = 3;
|
|
|
- turningPoints[i + 2].SegmentFlightTime = 0;
|
|
|
- turningPoints[i + 2].RemainingFuel = 0;
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "巡航",
|
|
|
+ TurningPointLongitude = SC01[i][0],
|
|
|
+ TurningPointLatitude = SC01[i][1],
|
|
|
+ TurningPointHeight = SC01[i][2],
|
|
|
+ TurningPointType = "侦查",
|
|
|
+ SegmentFlightFuelConsumption = 3,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
}
|
|
|
-
|
|
|
- return turningPoints;
|
|
|
}
|
|
|
|
|
|
- public static TurningPoint[] SuoHuaJiang(double resulttime, FlightPlanEditor editor,
|
|
|
- TurningPoint[] turningPoints) //索滑降模型航路点生成
|
|
|
+ public static void SuoHuaJiang(double resulttime, FlightPlanEditor editor,
|
|
|
+ ref List<TurningPoint> turningPoints) //索滑降模型航路点生成
|
|
|
{
|
|
|
- turningPoints[2].TurningPointName = "索滑降";
|
|
|
- turningPoints[2].TurningPointLongitude = editor.missionpoint.MissionPointLongitude;
|
|
|
- turningPoints[2].TurningPointLatitude = editor.missionpoint.MissionPointLatitude;
|
|
|
- turningPoints[2].TurningPointHeight = editor.missionpoint.MissionPointHeight;
|
|
|
- turningPoints[2].TurningPointType = "索滑降";
|
|
|
- turningPoints[2].SegmentFlightFuelConsumption = 5;
|
|
|
- turningPoints[2].SegmentFlightTime = resulttime;
|
|
|
- turningPoints[2].RemainingFuel = 0;
|
|
|
-
|
|
|
-
|
|
|
- return turningPoints;
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "索滑降",
|
|
|
+ TurningPointLongitude = editor.missionpoint.MissionPointLongitude,
|
|
|
+ TurningPointLatitude = editor.missionpoint.MissionPointLatitude,
|
|
|
+ TurningPointHeight = editor.missionpoint.MissionPointHeight,
|
|
|
+ TurningPointType = "索滑降",
|
|
|
+ SegmentFlightFuelConsumption = 5,
|
|
|
+ SegmentFlightTime = resulttime,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
- public static TurningPoint[] XunHu(FlightPlanEditor editor, TurningPoint[] turningPoints)
|
|
|
+ public static void XunHu(FlightPlanEditor editor,ref List<TurningPoint> turningPoints)
|
|
|
{
|
|
|
int i;
|
|
|
for (i = 0; i < editor.airroute.Length; i++)
|
|
|
{
|
|
|
- turningPoints[2 + i].TurningPointName = "巡航";
|
|
|
- turningPoints[2 + i].TurningPointLongitude = editor.airroute[i].AirRouteLongitude;
|
|
|
- turningPoints[2 + i].TurningPointLatitude = editor.airroute[i].AirRouteLatitude;
|
|
|
- turningPoints[2 + i].TurningPointHeight = editor.airroute[i].AirRouteHeight;
|
|
|
- turningPoints[2 + i].TurningPointType = "普通";
|
|
|
- turningPoints[2 + i].SegmentFlightFuelConsumption = 3;
|
|
|
- turningPoints[2 + i].SegmentFlightTime = 0;
|
|
|
- turningPoints[2 + i].RemainingFuel = 0;
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "巡航",
|
|
|
+ TurningPointLongitude = editor.airroute[i].AirRouteLongitude,
|
|
|
+ TurningPointLatitude = editor.airroute[i].AirRouteLatitude,
|
|
|
+ TurningPointHeight = editor.airroute[i].AirRouteHeight,
|
|
|
+ TurningPointType = "普通",
|
|
|
+ SegmentFlightFuelConsumption = 3,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
}
|
|
|
-
|
|
|
- return turningPoints;
|
|
|
+
|
|
|
}
|
|
|
|
|
|
- public static TurningPoint[]
|
|
|
- MieHuo1(FlightPlanEditor editor, TurningPoint[] turningPoints, int PointNumberIcon) //灭火任务从取水点到火场部分的航路点生成
|
|
|
+ public static void MieHuo1(FlightPlanEditor editor,ref List<TurningPoint> turningPoints) //灭火任务从取水点到火场部分的航路点生成
|
|
|
{
|
|
|
- turningPoints[2 + PointNumberIcon].TurningPointName = "取水"; //PointNumberIcon:洒水的次数
|
|
|
- turningPoints[2 + PointNumberIcon].TurningPointLongitude = editor.missionpoint.MissionPointLongitude;
|
|
|
- turningPoints[2 + PointNumberIcon].TurningPointLatitude = editor.missionpoint.MissionPointLatitude;
|
|
|
- turningPoints[2 + PointNumberIcon].TurningPointHeight = editor.missionpoint.MissionPointHeight;
|
|
|
- turningPoints[2 + PointNumberIcon].TurningPointType = "取水";
|
|
|
- turningPoints[2 + PointNumberIcon].SegmentFlightFuelConsumption = 3;
|
|
|
- turningPoints[2 + PointNumberIcon].SegmentFlightTime = 120;
|
|
|
- turningPoints[2 + PointNumberIcon].RemainingFuel = 0;
|
|
|
-
|
|
|
-
|
|
|
- //从火点飞到灭火模型返回的精确地洒水点
|
|
|
- turningPoints[3 + PointNumberIcon].TurningPointName = "洒水";
|
|
|
- turningPoints[3 + PointNumberIcon].TurningPointLongitude = editor.firepoint[0].FirePointLongitude;
|
|
|
- turningPoints[3 + PointNumberIcon].TurningPointLatitude = editor.firepoint[0].FirePointLatitude;
|
|
|
- turningPoints[3 + PointNumberIcon].TurningPointHeight = editor.firepoint[0].FirePointHeight;
|
|
|
- turningPoints[3 + PointNumberIcon].TurningPointType = "巡航";
|
|
|
- turningPoints[3 + PointNumberIcon].SegmentFlightFuelConsumption = 3;
|
|
|
- turningPoints[3 + PointNumberIcon].SegmentFlightTime = 0;
|
|
|
- turningPoints[3 + PointNumberIcon].RemainingFuel = 0;
|
|
|
-
|
|
|
- return turningPoints;
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "取水",
|
|
|
+ TurningPointLongitude = editor.missionpoint.MissionPointLongitude,
|
|
|
+ TurningPointLatitude = editor.missionpoint.MissionPointLatitude,
|
|
|
+ TurningPointHeight = editor.missionpoint.MissionPointHeight,
|
|
|
+ TurningPointType = "取水",
|
|
|
+ SegmentFlightFuelConsumption = 3,
|
|
|
+ SegmentFlightTime = 120,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
+
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "洒水",
|
|
|
+ TurningPointLongitude = editor.firepoint[0].FirePointLongitude,
|
|
|
+ TurningPointLatitude = editor.firepoint[0].FirePointLatitude,
|
|
|
+ TurningPointHeight = editor.firepoint[0].FirePointHeight,
|
|
|
+ TurningPointType = "巡航",
|
|
|
+ SegmentFlightFuelConsumption = 3,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
public static MissionEndPoint ZhenChaMissionEndPoint(List<double[]> SC01) //侦查模型任务终点生成
|
|
@@ -256,50 +261,54 @@ namespace Model
|
|
|
return missionEndPoint;
|
|
|
}
|
|
|
|
|
|
- public static TurningPoint[] JijiangMiehuo(FlightPlanEditor editor, TurningPoint[] turningPoints,
|
|
|
- int TransportNumber)
|
|
|
+ public static void JijiangMiehuo(FlightPlanEditor editor,ref List<TurningPoint> turningPoint)
|
|
|
{
|
|
|
- turningPoints[2 + TransportNumber].TurningPointName = "地面灭火"; //
|
|
|
- turningPoints[2 + TransportNumber].TurningPointLongitude = editor.originbase.BaseLongitude;
|
|
|
- turningPoints[2 + TransportNumber].TurningPointLatitude = editor.originbase.BaseLatitude;
|
|
|
- turningPoints[2 + TransportNumber].TurningPointHeight = editor.originbase.BaseHeight;
|
|
|
- turningPoints[2 + TransportNumber].TurningPointType = "转运";
|
|
|
- turningPoints[2 + TransportNumber].SegmentFlightFuelConsumption = 2;
|
|
|
- turningPoints[2 + TransportNumber].SegmentFlightTime = 0;
|
|
|
- turningPoints[2 + TransportNumber].RemainingFuel = 0;
|
|
|
-
|
|
|
-
|
|
|
- turningPoints[3 + TransportNumber].TurningPointName = "地面灭火";
|
|
|
- turningPoints[3 + TransportNumber].TurningPointLongitude = editor.missionpoint.MissionPointLongitude;
|
|
|
- turningPoints[3 + TransportNumber].TurningPointLatitude = editor.missionpoint.MissionPointLatitude;
|
|
|
- turningPoints[3 + TransportNumber].TurningPointHeight = editor.missionpoint.MissionPointHeight;
|
|
|
- turningPoints[3 + TransportNumber].TurningPointType = "转运";
|
|
|
- turningPoints[3 + TransportNumber].SegmentFlightFuelConsumption = 2;
|
|
|
- turningPoints[3 + TransportNumber].SegmentFlightTime = 0;
|
|
|
- turningPoints[3 + TransportNumber].RemainingFuel = 0;
|
|
|
-
|
|
|
-
|
|
|
- return turningPoints;
|
|
|
+ turningPoint.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "地面灭火",
|
|
|
+ TurningPointLongitude = editor.originbase.BaseLongitude,
|
|
|
+ TurningPointLatitude = editor.originbase.BaseLatitude,
|
|
|
+ TurningPointHeight = editor.originbase.BaseHeight,
|
|
|
+ TurningPointType = "转运",
|
|
|
+ SegmentFlightFuelConsumption = 2,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
+
|
|
|
+ turningPoint.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "地面灭火",
|
|
|
+ TurningPointLongitude = editor.missionpoint.MissionPointLongitude,
|
|
|
+ TurningPointLatitude = editor.missionpoint.MissionPointLongitude,
|
|
|
+ TurningPointHeight = editor.missionpoint.MissionPointHeight,
|
|
|
+ TurningPointType = "转运",
|
|
|
+ SegmentFlightFuelConsumption = 2,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
|
|
|
- public static TurningPoint[] FromMissionToEnd(FlightPlanEditor editor, MissionEndPoint missionEndPoint,
|
|
|
- TurningPoint[] turningPoints, int Length) //生成从任务段终点到基地的航路点
|
|
|
+ public static void FromMissionToEnd(FlightPlanEditor editor, MissionEndPoint missionEndPoint, ref List<TurningPoint> turningPoints) //生成从任务段终点到基地的航路点
|
|
|
{
|
|
|
- turningPoints[Length].TurningPointName = "巡航";
|
|
|
- turningPoints[Length].TurningPointLongitude = missionEndPoint.MissionEndPointLongitude;
|
|
|
- turningPoints[Length].TurningPointLatitude = missionEndPoint.MissionEndPointLatitude;
|
|
|
- turningPoints[Length].TurningPointHeight = missionEndPoint.MissionEndPointHeight;
|
|
|
- turningPoints[Length].TurningPointType = "普通";
|
|
|
- turningPoints[Length].SegmentFlightFuelConsumption = 3;
|
|
|
- turningPoints[Length].SegmentFlightTime = 0;
|
|
|
- turningPoints[Length].RemainingFuel = 0;
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "巡航",
|
|
|
+ TurningPointLongitude = missionEndPoint.MissionEndPointLongitude,
|
|
|
+ TurningPointLatitude = missionEndPoint.MissionEndPointLatitude,
|
|
|
+ TurningPointHeight = missionEndPoint.MissionEndPointHeight,
|
|
|
+ TurningPointType = "普通",
|
|
|
+ SegmentFlightFuelConsumption = 3,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
+
|
|
|
|
|
|
double k;
|
|
|
double lat2, lon2;
|
|
|
- k = (turningPoints[Length].TurningPointLatitude - editor.originbase.BaseLatitude) /
|
|
|
- (turningPoints[Length].TurningPointLongitude - editor.originbase.BaseLongitude);
|
|
|
- if (turningPoints[Length].TurningPointLongitude > editor.originbase.BaseLongitude)
|
|
|
+ k = (turningPoints[^1].TurningPointLatitude - editor.originbase.BaseLatitude) /
|
|
|
+ (turningPoints[^1].TurningPointLongitude - editor.originbase.BaseLongitude);
|
|
|
+ if (turningPoints[^1].TurningPointLongitude > editor.originbase.BaseLongitude)
|
|
|
{
|
|
|
lat2 = 0.08544 * k / (Math.Sqrt(k * k + 1)) + editor.originbase.BaseLatitude;
|
|
|
lon2 = 0.08544 / (Math.Sqrt(k * k + 1)) + editor.originbase.BaseLongitude;
|
|
@@ -310,22 +319,22 @@ namespace Model
|
|
|
lon2 = editor.originbase.BaseLongitude - 0.08544 / (Math.Sqrt(k * k + 1));
|
|
|
}
|
|
|
|
|
|
- turningPoints[Length + 1].TurningPointName = "降高";
|
|
|
- turningPoints[Length + 1].TurningPointLongitude = lon2;
|
|
|
- turningPoints[Length + 1].TurningPointLatitude = lat2;
|
|
|
- turningPoints[Length + 1].TurningPointHeight = 2000;
|
|
|
- turningPoints[Length + 1].TurningPointType = "普通";
|
|
|
- turningPoints[Length + 1].SegmentFlightFuelConsumption = 4;
|
|
|
- turningPoints[Length + 1].SegmentFlightTime = 0;
|
|
|
- turningPoints[Length + 1].RemainingFuel = 0;
|
|
|
-
|
|
|
-
|
|
|
- return turningPoints;
|
|
|
+ turningPoints.Add(new TurningPoint
|
|
|
+ {
|
|
|
+ TurningPointName = "降高",
|
|
|
+ TurningPointLongitude = lon2,
|
|
|
+ TurningPointLatitude = lat2,
|
|
|
+ TurningPointHeight = 2000,
|
|
|
+ TurningPointType = "普通",
|
|
|
+ SegmentFlightFuelConsumption = 4,
|
|
|
+ SegmentFlightTime = 0,
|
|
|
+ RemainingFuel = 0,
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
- public static void InitializeVelocities(FlightPlanEditor editor, TurningPoint[] turningPoints, ref double[] velocitys)
|
|
|
+ public static void InitializeVelocities(FlightPlanEditor editor,List<TurningPoint> turningPoints, ref double[] velocitys)
|
|
|
{
|
|
|
velocitys[0] = GetClimbVelocity(editor, turningPoints[0].TurningPointHeight);
|
|
|
velocitys[1] = GetCruisingVelocity(editor, turningPoints[1].TurningPointHeight);
|
|
@@ -334,7 +343,7 @@ namespace Model
|
|
|
}
|
|
|
|
|
|
|
|
|
- public static void InitializeFuelConsumptions(FlightPlanEditor editor, TurningPoint[] turningPoints, ref double[] fuelConsumptions)
|
|
|
+ public static void InitializeFuelConsumptions(FlightPlanEditor editor, List<TurningPoint> turningPoints, ref double[] fuelConsumptions)
|
|
|
{
|
|
|
fuelConsumptions[0] = GetClimbFuelConsumptionRate(editor, turningPoints[0].TurningPointHeight);
|
|
|
fuelConsumptions[1] = GetCruisingFuelConsumptionRate(editor, turningPoints[1].TurningPointHeight);
|
|
@@ -342,21 +351,20 @@ namespace Model
|
|
|
fuelConsumptions[3] = GetDescentFuelConsumptionRate(editor, turningPoints[0].TurningPointHeight);
|
|
|
fuelConsumptions[4] = GetHoverFuelConsumptionRate(editor, turningPoints[2].TurningPointHeight);
|
|
|
}
|
|
|
- public static TurningPoint[] FXJHTPDiedai(FlightPlanEditor editor, TurningPoint[] turningPoints,
|
|
|
- int FXJHTPLength, double[] velocitys, double[] fuelConsumptions) //各航段飞行时间、油耗计算和航路点油耗迭代
|
|
|
+ public static void FXJHTPDiedai(FlightPlanEditor editor,ref List<TurningPoint> turningPoints,double[] velocitys, double[] fuelConsumptions) //各航段飞行时间、油耗计算和航路点油耗迭代
|
|
|
{
|
|
|
- TurningPoint[] FXJHTP = turningPoints;
|
|
|
+
|
|
|
int i;
|
|
|
double DEG_TO_RAD_LOCAL = 3.1415926535897932 / 180;
|
|
|
- double[] x = new double[FXJHTPLength];
|
|
|
- double[] y = new double[FXJHTPLength];
|
|
|
- double[] z = new double[FXJHTPLength];
|
|
|
+ double[] x = new double[turningPoints.Count];
|
|
|
+ double[] y = new double[turningPoints.Count];
|
|
|
+ double[] z = new double[turningPoints.Count];
|
|
|
|
|
|
- for (i = 0; i < FXJHTPLength; i++) //LLA坐标转换为ECEF坐标
|
|
|
+ for (i = 0; i < turningPoints.Count; i++) //LLA坐标转换为ECEF坐标
|
|
|
{
|
|
|
- double lon = FXJHTP[i].TurningPointLongitude * DEG_TO_RAD_LOCAL;
|
|
|
- double lat = FXJHTP[i].TurningPointLatitude * DEG_TO_RAD_LOCAL;
|
|
|
- double hei = FXJHTP[i].TurningPointHeight;
|
|
|
+ double lon = turningPoints[i].TurningPointLongitude * DEG_TO_RAD_LOCAL;
|
|
|
+ double lat = turningPoints[i].TurningPointLatitude * DEG_TO_RAD_LOCAL;
|
|
|
+ double hei = turningPoints[i].TurningPointHeight;
|
|
|
|
|
|
double a = 6378137.0;
|
|
|
double b = 6356752.31424518;
|
|
@@ -367,12 +375,12 @@ namespace Model
|
|
|
z[i] = ((b * b * N) / (a * a) + hei) * Math.Sin(lat);
|
|
|
}
|
|
|
|
|
|
- for (i = 0; i < FXJHTPLength; i++)
|
|
|
+ for (i = 0; i < turningPoints.Count; i++)
|
|
|
{
|
|
|
- if (FXJHTP[i].SegmentFlightTime == 0)
|
|
|
+ if (turningPoints[i].SegmentFlightTime == 0)
|
|
|
{
|
|
|
double distanceab;
|
|
|
- if (i != FXJHTPLength - 1)
|
|
|
+ if (i != turningPoints.Count - 1)
|
|
|
{
|
|
|
distanceab = Math.Sqrt(Math.Pow(x[i] - x[i + 1], 2) + Math.Pow(y[i] - y[i + 1], 2) +
|
|
|
Math.Pow(z[i] - z[i + 1], 2));
|
|
@@ -387,7 +395,7 @@ namespace Model
|
|
|
|
|
|
|
|
|
// 根据飞行段类型选择不同的燃油消耗率计算函数
|
|
|
- switch (FXJHTP[i].SegmentFlightFuelConsumption)
|
|
|
+ switch (turningPoints[i].SegmentFlightFuelConsumption)
|
|
|
{
|
|
|
case 1:
|
|
|
velocity = velocitys[0];
|
|
@@ -410,7 +418,7 @@ namespace Model
|
|
|
}
|
|
|
|
|
|
// 使用计算得到的速度计算飞行时间
|
|
|
- FXJHTP[i].SegmentFlightTime = CalculateSegmentFlightTime(distanceab, velocity);
|
|
|
+ turningPoints[i].SegmentFlightTime = CalculateSegmentFlightTime(distanceab, velocity);
|
|
|
|
|
|
double CalculateSegmentFlightTime(double distance, double velocity)
|
|
|
{
|
|
@@ -419,12 +427,12 @@ namespace Model
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
- FXJHTP[i].SegmentFlightTime = FXJHTP[i].SegmentFlightTime;
|
|
|
+ turningPoints[i].SegmentFlightTime = turningPoints[i].SegmentFlightTime;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
- for (i = 0; i < FXJHTPLength; i++)
|
|
|
+ for (i = 0; i < turningPoints.Count; i++)
|
|
|
{
|
|
|
double remainingFuel;
|
|
|
if (i == 0)
|
|
@@ -433,12 +441,12 @@ namespace Model
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
- remainingFuel = FXJHTP[i - 1].RemainingFuel;
|
|
|
+ remainingFuel = turningPoints[i - 1].RemainingFuel;
|
|
|
}
|
|
|
|
|
|
double fuelConsumption = 0;
|
|
|
// 根据飞行段类型选择不同的燃油消耗率计算函数,1代表爬升,2代表平飞远航,3代表平飞久航,4代表下降,5代表悬停
|
|
|
- switch (FXJHTP[i].SegmentFlightFuelConsumption)
|
|
|
+ switch (turningPoints[i].SegmentFlightFuelConsumption)
|
|
|
{
|
|
|
case 1:
|
|
|
fuelConsumption = fuelConsumptions[0];
|
|
@@ -458,7 +466,7 @@ namespace Model
|
|
|
}
|
|
|
|
|
|
|
|
|
- remainingFuel -= fuelConsumption * FXJHTP[i].SegmentFlightTime / 3600; // 更新剩余燃油
|
|
|
+ remainingFuel -= fuelConsumption * turningPoints[i].SegmentFlightTime / 3600; // 更新剩余燃油
|
|
|
|
|
|
if (remainingFuel < 0)
|
|
|
{
|
|
@@ -466,27 +474,12 @@ namespace Model
|
|
|
break;
|
|
|
}
|
|
|
|
|
|
- FXJHTP[i].RemainingFuel = remainingFuel;
|
|
|
+ turningPoints[i].RemainingFuel = remainingFuel;
|
|
|
}
|
|
|
|
|
|
- return FXJHTP;
|
|
|
}
|
|
|
|
|
|
- public static void FXJHTPPrint(TurningPoint[] FXJHTP, int FXJHTPLength) //航路点打印
|
|
|
- {
|
|
|
- int i;
|
|
|
- for (i = 0; i < FXJHTPLength; i++)
|
|
|
- {
|
|
|
- Console.WriteLine("航路点序号: {0}", i + 1); // {0}是占位符,在字符串中插入变量的值
|
|
|
- Console.WriteLine("航路点名称: {0}", FXJHTP[i].TurningPointName);
|
|
|
- Console.WriteLine("航路点类型: {0}", FXJHTP[i].TurningPointType);
|
|
|
- Console.WriteLine("航路点时间: {0}", FXJHTP[i].SegmentFlightTime);
|
|
|
- Console.WriteLine("航路点油耗: {0}", FXJHTP[i].SegmentFlightFuelConsumption);
|
|
|
- Console.WriteLine("航路点经度: {0}", FXJHTP[i].TurningPointLongitude);
|
|
|
- Console.WriteLine("航路点纬度: {0}", FXJHTP[i].TurningPointLatitude);
|
|
|
- Console.WriteLine("航路点海拔: {0}", FXJHTP[i].TurningPointHeight);
|
|
|
- }
|
|
|
- }
|
|
|
+
|
|
|
|
|
|
/// <summary>
|
|
|
/// 巡护用
|
|
@@ -495,7 +488,7 @@ namespace Model
|
|
|
/// <param name="editor"></param>
|
|
|
/// <param name="nowtime"></param>
|
|
|
/// <returns></returns>
|
|
|
- public static CurrentLocation GetCurrentLocation(TurningPoint[] turningPoints, FlightPlanEditor editor,
|
|
|
+ public static CurrentLocation GetCurrentLocation(List<TurningPoint> turningPoints, FlightPlanEditor editor,
|
|
|
double nowtime)
|
|
|
{
|
|
|
CurrentLocation currentLocation = new CurrentLocation();
|
|
@@ -552,20 +545,19 @@ namespace Model
|
|
|
/// <param name="FXJHTPLength"></param>
|
|
|
/// <param name="nowtime"></param>
|
|
|
/// <returns></returns>
|
|
|
- public static CurrentLocation
|
|
|
- GetAllCurrentLocation(TurningPoint[] FXJHTP, int FXJHTPLength, double nowtime) //飞机实时位置打印
|
|
|
+ public static CurrentLocation GetAllCurrentLocation(List<TurningPoint> turningPoints, double nowtime) //飞机实时位置打印
|
|
|
{
|
|
|
CurrentLocation currentLocation = new CurrentLocation();
|
|
|
- double[] timetable = new double[FXJHTPLength + 1];
|
|
|
+ double[] timetable = new double[turningPoints.Count + 1];
|
|
|
timetable[0] = 0;
|
|
|
int segmentnumber = -1;
|
|
|
int i;
|
|
|
- for (i = 0; i < FXJHTPLength; i++)
|
|
|
+ for (i = 0; i < turningPoints.Count; i++)
|
|
|
{
|
|
|
- timetable[i + 1] = timetable[i] + FXJHTP[i].SegmentFlightTime;
|
|
|
+ timetable[i + 1] = timetable[i] + turningPoints[i].SegmentFlightTime;
|
|
|
}
|
|
|
|
|
|
- for (i = 0; i < FXJHTPLength + 1; i++)
|
|
|
+ for (i = 0; i < turningPoints.Count + 1; i++)
|
|
|
{
|
|
|
if ((nowtime - timetable[i]) >= 0)
|
|
|
{
|
|
@@ -577,57 +569,57 @@ namespace Model
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- if (segmentnumber < FXJHTPLength - 1)
|
|
|
+ if (segmentnumber < turningPoints.Count - 1)
|
|
|
{
|
|
|
- currentLocation.CurrentLon = FXJHTP[segmentnumber].TurningPointLongitude +
|
|
|
- ((FXJHTP[segmentnumber + 1].TurningPointLongitude -
|
|
|
- FXJHTP[segmentnumber].TurningPointLongitude) /
|
|
|
- FXJHTP[segmentnumber].SegmentFlightTime) *
|
|
|
+ currentLocation.CurrentLon = turningPoints[segmentnumber].TurningPointLongitude +
|
|
|
+ ((turningPoints[segmentnumber + 1].TurningPointLongitude -
|
|
|
+ turningPoints[segmentnumber].TurningPointLongitude) /
|
|
|
+ turningPoints[segmentnumber].SegmentFlightTime) *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
- currentLocation.CurrentLat = FXJHTP[segmentnumber].TurningPointLatitude +
|
|
|
- ((FXJHTP[segmentnumber + 1].TurningPointLatitude -
|
|
|
- FXJHTP[segmentnumber].TurningPointLatitude) /
|
|
|
- FXJHTP[segmentnumber].SegmentFlightTime) *
|
|
|
+ currentLocation.CurrentLat = turningPoints[segmentnumber].TurningPointLatitude +
|
|
|
+ ((turningPoints[segmentnumber + 1].TurningPointLatitude -
|
|
|
+ turningPoints[segmentnumber].TurningPointLatitude) /
|
|
|
+ turningPoints[segmentnumber].SegmentFlightTime) *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
- currentLocation.CurrentHei = FXJHTP[segmentnumber].TurningPointHeight +
|
|
|
- ((FXJHTP[segmentnumber + 1].TurningPointHeight -
|
|
|
- FXJHTP[segmentnumber].TurningPointHeight) /
|
|
|
- FXJHTP[segmentnumber].SegmentFlightTime) *
|
|
|
+ currentLocation.CurrentHei = turningPoints[segmentnumber].TurningPointHeight +
|
|
|
+ ((turningPoints[segmentnumber + 1].TurningPointHeight -
|
|
|
+ turningPoints[segmentnumber].TurningPointHeight) /
|
|
|
+ turningPoints[segmentnumber].SegmentFlightTime) *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
- currentLocation.CurrentFuel = FXJHTP[segmentnumber].RemainingFuel -
|
|
|
- FXJHTP[segmentnumber].SegmentFlightFuelConsumption *
|
|
|
+ currentLocation.CurrentFuel = turningPoints[segmentnumber].RemainingFuel -
|
|
|
+ turningPoints[segmentnumber].SegmentFlightFuelConsumption *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
}
|
|
|
- else if (segmentnumber == FXJHTPLength - 1)
|
|
|
+ else if (segmentnumber == turningPoints.Count - 1)
|
|
|
{
|
|
|
- currentLocation.CurrentLon = FXJHTP[segmentnumber].TurningPointLongitude +
|
|
|
- ((FXJHTP[0].TurningPointLongitude -
|
|
|
- FXJHTP[segmentnumber].TurningPointLongitude) /
|
|
|
- FXJHTP[segmentnumber].SegmentFlightTime) *
|
|
|
+ currentLocation.CurrentLon = turningPoints[segmentnumber].TurningPointLongitude +
|
|
|
+ ((turningPoints[0].TurningPointLongitude -
|
|
|
+ turningPoints[segmentnumber].TurningPointLongitude) /
|
|
|
+ turningPoints[segmentnumber].SegmentFlightTime) *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
- currentLocation.CurrentLat = FXJHTP[segmentnumber].TurningPointLatitude +
|
|
|
- ((FXJHTP[0].TurningPointLatitude -
|
|
|
- FXJHTP[segmentnumber].TurningPointLatitude) /
|
|
|
- FXJHTP[segmentnumber].SegmentFlightTime) *
|
|
|
+ currentLocation.CurrentLat = turningPoints[segmentnumber].TurningPointLatitude +
|
|
|
+ ((turningPoints[0].TurningPointLatitude -
|
|
|
+ turningPoints[segmentnumber].TurningPointLatitude) /
|
|
|
+ turningPoints[segmentnumber].SegmentFlightTime) *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
- currentLocation.CurrentHei = FXJHTP[segmentnumber].TurningPointHeight +
|
|
|
- ((FXJHTP[0].TurningPointHeight -
|
|
|
- FXJHTP[segmentnumber].TurningPointHeight) /
|
|
|
- FXJHTP[segmentnumber].SegmentFlightTime) *
|
|
|
+ currentLocation.CurrentHei = turningPoints[segmentnumber].TurningPointHeight +
|
|
|
+ ((turningPoints[0].TurningPointHeight -
|
|
|
+ turningPoints[segmentnumber].TurningPointHeight) /
|
|
|
+ turningPoints[segmentnumber].SegmentFlightTime) *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
- currentLocation.CurrentFuel = FXJHTP[segmentnumber].RemainingFuel -
|
|
|
- FXJHTP[segmentnumber].SegmentFlightFuelConsumption *
|
|
|
+ currentLocation.CurrentFuel = turningPoints[segmentnumber].RemainingFuel -
|
|
|
+ turningPoints[segmentnumber].SegmentFlightFuelConsumption *
|
|
|
(nowtime - timetable[segmentnumber]);
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
- currentLocation.CurrentLon = FXJHTP[0].TurningPointLongitude;
|
|
|
- currentLocation.CurrentLat = FXJHTP[0].TurningPointLatitude;
|
|
|
- currentLocation.CurrentHei = FXJHTP[0].TurningPointHeight;
|
|
|
+ currentLocation.CurrentLon = turningPoints[0].TurningPointLongitude;
|
|
|
+ currentLocation.CurrentLat = turningPoints[0].TurningPointLatitude;
|
|
|
+ currentLocation.CurrentHei = turningPoints[0].TurningPointHeight;
|
|
|
currentLocation.Currentvelo = 0;
|
|
|
- currentLocation.CurrentFuel = FXJHTP[segmentnumber - 1].RemainingFuel -
|
|
|
- FXJHTP[segmentnumber - 1].SegmentFlightFuelConsumption *
|
|
|
- FXJHTP[segmentnumber - 1].SegmentFlightTime;
|
|
|
+ currentLocation.CurrentFuel = turningPoints[segmentnumber - 1].RemainingFuel -
|
|
|
+ turningPoints[segmentnumber - 1].SegmentFlightFuelConsumption *
|
|
|
+ turningPoints[segmentnumber - 1].SegmentFlightTime;
|
|
|
}
|
|
|
|
|
|
return currentLocation;
|