Merge branch 'master' of https://eng-git.canterbury.ac.nz/seng302-2017/team-7 into story28
commit
b1e55f8c7d
@ -0,0 +1,50 @@
|
|||||||
|
package seng302.Model;
|
||||||
|
|
||||||
|
import seng302.GPSCoordinate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by cbt24 on 7/04/17.
|
||||||
|
*/
|
||||||
|
public class TrackPoint {
|
||||||
|
private GPSCoordinate coordinate;
|
||||||
|
private long timeAdded;
|
||||||
|
private long expiry;
|
||||||
|
private double minAlpha;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new track point with fixed GPS coordinates and time, to reach minimum opacity on expiry.
|
||||||
|
* @param coordinate position of point on physical race map
|
||||||
|
* @param timeAdded system clock at time of addition
|
||||||
|
* @param expiry time to minimum opacity after added
|
||||||
|
*/
|
||||||
|
public TrackPoint(GPSCoordinate coordinate, long timeAdded, long expiry) {
|
||||||
|
this.coordinate = coordinate;
|
||||||
|
this.timeAdded = timeAdded;
|
||||||
|
this.expiry = expiry;
|
||||||
|
this.minAlpha = 0.1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the position of the point on physical race map.
|
||||||
|
* @return GPS coordinate of point
|
||||||
|
*/
|
||||||
|
public GPSCoordinate getCoordinate() {
|
||||||
|
return coordinate;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets opacity of point scaled by age in proportion to expiry, between 1 and minimum opacity inclusive.
|
||||||
|
* @return greater of minimum opacity and scaled opacity
|
||||||
|
*/
|
||||||
|
public double getAlpha() {
|
||||||
|
return Double.max(minAlpha,1.0 - (double)(System.currentTimeMillis() - timeAdded) / expiry);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets time point was added to track.
|
||||||
|
* @return system clock at time of addition
|
||||||
|
*/
|
||||||
|
public long getTimeAdded() {
|
||||||
|
return timeAdded;
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in new issue