/*
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.base;
import slash.common.type.CompactCalendar;
import static slash.navigation.common.NavigationConversion.*;
/**
* Represents a Mercator position in a route.
*
* @author Christian Pesch
*/
public class MercatorPosition extends BaseNavigationPosition {
protected Long x, y;
protected String description;
private Double elevation;
private Double speed;
private CompactCalendar time;
public MercatorPosition(Double longitude, Double latitude, Double elevation, Double speed, CompactCalendar time, String description) {
this(asX(longitude), asY(latitude), elevation, speed, time, description);
}
public MercatorPosition(Long x, Long y, Double elevation, Double speed, CompactCalendar time, String description) {
setElevation(elevation);
setSpeed(speed);
setTime(time);
this.x = x;
this.y = y;
setDescription(description);
}
public Double getLongitude() {
return x != null ? mercatorXToWgs84Longitude(x) : null;
}
public void setLongitude(Double longitude) {
this.x = asX(longitude);
}
public Double getLatitude() {
return y != null ? mercatorYToWgs84Latitude(y) : null;
}
public void setLatitude(Double latitude) {
this.y = asY(latitude);
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public Double getElevation() {
return elevation;
}
public void setElevation(Double elevation) {
this.elevation = elevation;
}
public Double getSpeed() {
return speed;
}
public void setSpeed(Double speed) {
this.speed = speed;
}
public CompactCalendar getTime() {
return time;
}
public void setTime(CompactCalendar time) {
this.time = time;
}
private static Long asX(Double longitude) {
return longitude != null ? wgs84LongitudeToMercatorX(longitude) : null;
}
private static Long asY(Double latitude) {
return latitude != null ? wgs84LatitudeToMercatorY(latitude) : null;
}
public Long getX() {
return x;
}
public Long getY() {
return y;
}
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
MercatorPosition that = (MercatorPosition) o;
return !(description != null ? !description.equals(that.description) : that.description != null) &&
!(getElevation() != null ? !getElevation().equals(that.getElevation()) : that.getElevation() != null) &&
!(x != null ? !x.equals(that.x) : that.x != null) &&
!(y != null ? !y.equals(that.y) : that.y != null) &&
!(hasTime() ? !getTime().equals(that.getTime()) : that.hasTime());
}
public int hashCode() {
int result;
result = (x != null ? x.hashCode() : 0);
result = 31 * result + (y != null ? y.hashCode() : 0);
result = 31 * result + (getElevation() != null ? getElevation().hashCode() : 0);
result = 31 * result + (description != null ? description.hashCode() : 0);
result = 31 * result + (hasTime() ? getTime().hashCode() : 0);
return result;
}
}