private void trackLaunch() { MissionLaunch launch = new MissionLaunch { Time = (float)Planetarium.GetUniversalTime(), Body = vessel.mainBody.name, VesselName = vessel.name, Funds = RmmUtil.CalculateVesselPrice(vessel), Crew = RmmUtil.AstronautCrewCount(vessel), Parts = MissionPart.GetMissionPartList(vessel), }; _mission.TrackLaunch(launch); trackingActive = true; trackingPrimary = true; trackingStatus = "Underway"; //----------------------- trackPartCount = RmmUtil.CountVesselParts(vessel); trackCrew = RmmUtil.AstronautCrewCount(vessel); trackCrewCapacity = RmmUtil.CrewCapacityCount(vessel); ScreenMessages.PostScreenMessage("mission tracking-LAUNCH", 4, ScreenMessageStyle.UPPER_CENTER); setOtherModules(); updateTrackingVars(vessel); updateNextLogicTime(vessel); }
private void updatePartCount() { int currentCount = RmmUtil.CountVesselParts(vessel); if (currentCount < trackPartCount) { trackPartCount = currentCount; } }
private void trackDeparture() { Part dockedPart = null; foreach (Part p in vessel.parts) { if (p.flightID == trackPort) { dockedPart = p; break; } } MissionDeparture departure = new MissionDeparture { Time = (float)Planetarium.GetUniversalTime(), Body = vessel.mainBody.name, Orbit = MissionOrbit.GetMissionOrbit(vessel.orbit), flightIDDockPart = trackPort, VesselName = vessel.name, Crew = RmmUtil.AstronautCrewCount(vessel), Parts = MissionPart.GetMissionPartList(vessel), Resources = MissionResource.GetMissionResourceList(vessel), Proppellants = RmmUtil.DetermineProppellantArray(vessel), Structure = Structure.GetDockedStructure(vessel, dockedPart) }; _mission.TrackDeparture(departure); trackingActive = true; trackingPrimary = true; trackingStatus = "Underway"; //----------------------- trackPartCount = RmmUtil.CountVesselParts(vessel); trackCrew = RmmUtil.AstronautCrewCount(vessel); trackCrewCapacity = RmmUtil.CrewCapacityCount(vessel); ScreenMessages.PostScreenMessage("mission tracking-DEPARTURE", 4, ScreenMessageStyle.UPPER_CENTER); setOtherModules(); updateTrackingVars(vessel); updateNextLogicTime(vessel); }
public void handleTrackingPrimary() { switch (trackingStatus) { case "Launch": if (vessel.situation == Vessel.Situations.FLYING || vessel.situation == Vessel.Situations.SUB_ORBITAL || vessel.situation == Vessel.Situations.ORBITING) { trackLaunch(); } break; case "Departure": foreach (Part p in vessel.parts) { if (p.flightID == trackPort && !RmmUtil.IsDocked(vessel, p)) { trackDeparture(); } } break; case "Underway": updatePartCount(); updateCrewCount(); updateMaxCrewCount(); // check for arrival if (_mission.Info.Type == 10) { if (vessel.situation == Vessel.Situations.ORBITING && RmmUtil.AllowedBody(vessel.mainBody.name)) { foreach (Part p in vessel.parts) { ModuleDockingNode dockingModule = p.Modules.OfType <ModuleDockingNode>().FirstOrDefault(); if (dockingModule != null) { Part dockedPart = RmmUtil.GetDockedPart(vessel, p); if (dockedPart != null && !Mission.PartIsMissionPart(dockedPart, _mission.Launch.Parts)) { trackArrival(p); return; } } } } } // make snapshot of vessel if (_mission.Info.Type == 10) { if (vessel.situation == Vessel.Situations.ORBITING && RmmUtil.AllowedBody(vessel.mainBody.name)) { // don't make snapshot when the vessel is in the process of docking. It leaves the docking port in the wrong state. bool isAnyPartDocking = false; foreach (Part p in vessel.parts) { ModuleDockingNode dockingModule = p.Modules.OfType <ModuleDockingNode>().FirstOrDefault(); if (dockingModule != null && RmmUtil.IsDocking(p)) { isAnyPartDocking = true; } } if (!isAnyPartDocking) { TakeVesselSnapShot(); } } } // check for landing if (_mission.Info.Type == 10 || _mission.Info.Type == 20) { if ((vessel.situation == Vessel.Situations.LANDED || vessel.situation == Vessel.Situations.SPLASHED) && RmmUtil.HomeBody(vessel.mainBody.name)) { if (landedTime == 0.0) { landedTime = Planetarium.GetUniversalTime(); landedLatitude = vessel.latitude; landedLongitude = vessel.longitude; landedTimeMessage = 0; } } if (landedTime > 0.0) { // Check still landed if (!(vessel.situation == Vessel.Situations.LANDED || vessel.situation == Vessel.Situations.SPLASHED) || !RmmUtil.HomeBody(vessel.mainBody.name)) { landedTime = 0.0; landedLatitude = 0.0; landedLongitude = 0.0; landedTimeMessage = 0; } // Check not moved else if (RmmUtil.GetDistanceBetweenPoints(landedLatitude, landedLongitude, vessel.latitude, vessel.longitude, vessel.mainBody.Radius) > 2) { landedTime = 0.0; landedLatitude = 0.0; landedLongitude = 0.0; landedTimeMessage = 0; } // Countdown else if (Planetarium.GetUniversalTime() - landedTime > 0.0 && Planetarium.GetUniversalTime() - landedTime < 10) { if (Planetarium.GetUniversalTime() - landedTime > landedTimeMessage + 1.0) { landedTimeMessage = landedTimeMessage + 1; ScreenMessages.PostScreenMessage("landing confirmation " + (10 - landedTimeMessage).ToString() + " seconds", 1, ScreenMessageStyle.UPPER_CENTER); } } // Landed else if (Planetarium.GetUniversalTime() - landedTime > 10) { TrackLanding(); return; } } } if (RmmUtil.CountVesselParts(vessel) > trackPartCount) { trackAbort("vessel has joined with non mission vessel"); } if (RmmUtil.AstronautCrewCount(vessel) > trackCrew) { trackAbort("crew has been added to vessel"); } updateTrackingVars(vessel); break; } }