/*
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.kml;
import slash.common.type.CompactCalendar;
import slash.navigation.base.BaseRoute;
import slash.navigation.base.RouteCharacteristics;
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.itn.TomTomPosition;
import slash.navigation.itn.TomTomRoute;
import slash.navigation.itn.TomTomRouteFormat;
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;
/**
* A Google Earth (.kml) route.
*
* @author Christian Pesch
*/
public class KmlRoute extends BaseRoute<KmlPosition, BaseKmlFormat> {
private String name;
private List<String> description;
private List<KmlPosition> positions;
public KmlRoute(BaseKmlFormat format, RouteCharacteristics characteristics,
String name, List<String> description, List<KmlPosition> positions) {
super(format, characteristics);
this.name = name;
this.description = description;
this.positions = positions;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List<String> getDescription() {
return description;
}
public List<KmlPosition> getPositions() {
return positions;
}
public int getPositionCount() {
return positions.size();
}
public void add(int index, KmlPosition position) {
positions.add(index, position);
}
public KmlPosition createPosition(Double longitude, Double latitude, Double elevation, Double speed, CompactCalendar time, String description) {
return new KmlPosition(longitude, latitude, elevation, speed, time, description);
}
protected BcrRoute asBcrFormat(BcrFormat format) {
List<BcrPosition> bcrPositions = new ArrayList<BcrPosition>();
for (KmlPosition kmlPosition : positions) {
bcrPositions.add(kmlPosition.asMTPPosition());
}
return new BcrRoute(format, getName(), getDescription(), bcrPositions);
}
protected GoPalRoute asGoPalRouteFormat(GoPalRouteFormat format) {
List<GoPalPosition> gopalPositions = new ArrayList<GoPalPosition>();
for (KmlPosition position : positions) {
gopalPositions.add(position.asGoPalRoutePosition());
}
return new GoPalRoute(format, getName(), gopalPositions);
}
protected GpxRoute asGpxFormat(GpxFormat format) {
List<GpxPosition> gpxPositions = new ArrayList<GpxPosition>();
for (KmlPosition kmlPosition : positions) {
gpxPositions.add(kmlPosition.asGpxPosition());
}
return new GpxRoute(format, getCharacteristics(), getName(), getDescription(), gpxPositions);
}
protected KmlRoute asKmlFormat(BaseKmlFormat format) {
List<KmlPosition> kmlPositions = new ArrayList<KmlPosition>(getPositions());
return new KmlRoute(format, getCharacteristics(), getName(), getDescription(), kmlPositions);
}
protected NmeaRoute asNmeaFormat(BaseNmeaFormat format) {
List<NmeaPosition> nmeaPositions = new ArrayList<NmeaPosition>();
for (KmlPosition position : positions) {
nmeaPositions.add(position.asNmeaPosition());
}
return new NmeaRoute(format, getCharacteristics(), nmeaPositions);
}
protected NmnRoute asNmnFormat(NmnFormat format) {
List<NmnPosition> nmnPositions = new ArrayList<NmnPosition>();
for (KmlPosition kmlPosition : positions) {
nmnPositions.add(kmlPosition.asNmnPosition());
}
return new NmnRoute(format, getCharacteristics(), getName(), nmnPositions);
}
protected SimpleRoute asSimpleFormat(SimpleFormat format) {
List<Wgs84Position> wgs84Positions = new ArrayList<Wgs84Position>();
for (KmlPosition kmlPosition : positions) {
wgs84Positions.add(kmlPosition.asWgs84Position());
}
return new Wgs84Route(format, getCharacteristics(), wgs84Positions);
}
protected TcxRoute asTcxFormat(TcxFormat format) {
List<Wgs84Position> wgs84Positions = new ArrayList<Wgs84Position>();
for (KmlPosition position : positions) {
wgs84Positions.add(position.asWgs84Position());
}
return new TcxRoute(format, getCharacteristics(), getName(), wgs84Positions);
}
protected TomTomRoute asTomTomRouteFormat(TomTomRouteFormat format) {
List<TomTomPosition> tomTomPositions = new ArrayList<TomTomPosition>();
for (KmlPosition 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;
final KmlRoute kmlRoute = (KmlRoute) o;
return !(description != null ? !description.equals(kmlRoute.description) : kmlRoute.description != null) &&
!(name != null ? !name.equals(kmlRoute.name) : kmlRoute.name != null) &&
getCharacteristics().equals(kmlRoute.getCharacteristics()) &&
positions.equals(kmlRoute.positions);
}
public int hashCode() {
int result;
result = (name != null ? name.hashCode() : 0);
result = 29 * result + (description != null ? description.hashCode() : 0);
result = 29 * result + getCharacteristics().hashCode();
result = 29 * result + positions.hashCode();
return result;
}
}