/* This file is part of RouteConverter. RouteConverter is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. RouteConverter is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with RouteConverter; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA Copyright (C) 2007 Christian Pesch. All Rights Reserved. */ package slash.navigation.fpl; import slash.common.type.CompactCalendar; import slash.navigation.base.BaseRoute; import slash.navigation.base.SimpleFormat; import slash.navigation.base.SimpleRoute; import slash.navigation.base.Wgs84Position; import slash.navigation.base.Wgs84Route; import slash.navigation.bcr.BcrFormat; import slash.navigation.bcr.BcrPosition; import slash.navigation.bcr.BcrRoute; import slash.navigation.gopal.GoPalPosition; import slash.navigation.gopal.GoPalRoute; import slash.navigation.gopal.GoPalRouteFormat; import slash.navigation.gpx.GpxFormat; import slash.navigation.gpx.GpxPosition; import slash.navigation.gpx.GpxRoute; import slash.navigation.photo.PhotoFormat; import slash.navigation.itn.TomTomPosition; import slash.navigation.itn.TomTomRoute; import slash.navigation.itn.TomTomRouteFormat; import slash.navigation.kml.BaseKmlFormat; import slash.navigation.kml.KmlPosition; import slash.navigation.kml.KmlRoute; import slash.navigation.nmea.BaseNmeaFormat; import slash.navigation.nmea.NmeaPosition; import slash.navigation.nmea.NmeaRoute; import slash.navigation.nmn.NmnFormat; import slash.navigation.nmn.NmnPosition; import slash.navigation.nmn.NmnRoute; import slash.navigation.tcx.TcxFormat; import slash.navigation.tcx.TcxRoute; import java.util.ArrayList; import java.util.List; import static slash.navigation.base.RouteCharacteristics.Track; import static slash.navigation.base.RouteComments.createRouteName; /** * A Garmin Flight Plan (.fpl) route. * * @author Christian Pesch */ public class GarminFlightPlanRoute extends BaseRoute<GarminFlightPlanPosition, GarminFlightPlanFormat> { private String name; private List<String> description; private List<GarminFlightPlanPosition> positions; public GarminFlightPlanRoute(String name, List<String> description, List<GarminFlightPlanPosition> positions) { super(new GarminFlightPlanFormat(), Track); this.name = name; this.description = description; this.positions = positions; } public String getName() { return name != null ? name : createRouteName(positions); } public void setName(String name) { this.name = name; } public List<String> getDescription() { return description; } public List<GarminFlightPlanPosition> getPositions() { return positions; } public int getPositionCount() { return positions.size(); } public void add(int index, GarminFlightPlanPosition position) { positions.add(index, position); } public GarminFlightPlanPosition createPosition(Double longitude, Double latitude, Double elevation, Double speed, CompactCalendar time, String description) { return new GarminFlightPlanPosition(longitude, latitude, elevation, description); } protected BcrRoute asBcrFormat(BcrFormat format) { List<BcrPosition> bcrPositions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { bcrPositions.add(position.asMTPPosition()); } return new BcrRoute(format, getName(), getDescription(), bcrPositions); } protected GoPalRoute asGoPalRouteFormat(GoPalRouteFormat format) { List<GoPalPosition> gopalPositions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { gopalPositions.add(position.asGoPalRoutePosition()); } return new GoPalRoute(format, getName(), gopalPositions); } protected GpxRoute asGpxFormat(GpxFormat format) { List<GpxPosition> gpxPositions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { gpxPositions.add(position.asGpxPosition()); } return new GpxRoute(format, getCharacteristics(), getName(), getDescription(), gpxPositions); } protected SimpleRoute asPhotoFormat(PhotoFormat format) { List<Wgs84Position> wgs84Positions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { wgs84Positions.add(position.asWgs84Position()); } return new Wgs84Route(format, getCharacteristics(), wgs84Positions); } protected KmlRoute asKmlFormat(BaseKmlFormat format) { List<KmlPosition> kmlPositions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { kmlPositions.add(position.asKmlPosition()); } return new KmlRoute(format, getCharacteristics(), getName(), getDescription(), kmlPositions); } protected NmeaRoute asNmeaFormat(BaseNmeaFormat format) { List<NmeaPosition> nmeaPositions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { nmeaPositions.add(position.asNmeaPosition()); } return new NmeaRoute(format, getCharacteristics(), nmeaPositions); } protected NmnRoute asNmnFormat(NmnFormat format) { List<NmnPosition> nmnPositions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { nmnPositions.add(position.asNmnPosition()); } return new NmnRoute(format, getCharacteristics(), getName(), nmnPositions); } protected SimpleRoute asSimpleFormat(SimpleFormat format) { List<Wgs84Position> wgs84Positions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { wgs84Positions.add(position.asWgs84Position()); } return new Wgs84Route(format, getCharacteristics(), wgs84Positions); } protected TcxRoute asTcxFormat(TcxFormat format) { List<Wgs84Position> wgs84Positions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { wgs84Positions.add(position.asWgs84Position()); } return new TcxRoute(format, getCharacteristics(), getName(), wgs84Positions); } protected TomTomRoute asTomTomRouteFormat(TomTomRouteFormat format) { List<TomTomPosition> tomTomPositions = new ArrayList<>(); for (GarminFlightPlanPosition position : positions) { tomTomPositions.add(position.asTomTomRoutePosition()); } return new TomTomRoute(format, getCharacteristics(), getName(), tomTomPositions); } public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; GarminFlightPlanRoute that = (GarminFlightPlanRoute) o; return !(name != null ? !name.equals(that.name) : that.name != null) && !(positions != null ? !positions.equals(that.positions) : that.positions != null); } public int hashCode() { int result = name != null ? name.hashCode() : 0; result = 31 * result + (positions != null ? positions.hashCode() : 0); return result; } }