GarminGpsDataStructures.js
Summary
Garmin.DeviceControl A library of GPS track and waypoint data structures along with parsing tools.
Version: 1.0
Author: Michael Bina michael.bina.at.garmin.com
|
Class Summary
|
| Garmin.WayPoint |
WayPoint
WayPoint class reprsents a stored location
|
if (Garmin == undefined) var Garmin = {};
Garmin.WayPoint = function(lat, lng, elev, name){};
Garmin.WayPoint = Class.create();
Garmin.WayPoint.prototype = {
initialize: function(lat, lng, elev, name) {
this.lat = lat;
this.lng = lng;
this.name = name;
this.elev = elev;
this.date = null;
},
getName: function() {
return this.name;
},
getLat: function() {
return this.lat;
},
getLng: function() {
return this.lng;
},
getElev: function() {
return this.elev;
},
getDate: function() {
return this.date;
},
toString: function() {
return "WayPoint Point: (" + this.getLat() + ", " + this.getLng() + ")";
}
};
Garmin.TrackPoint = Class.create();
Garmin.TrackPoint.prototype = {
initialize: function() {
this.measurements = null;
this.date = null;
},
getMeasurement: function(context) {
var meas = this.measurements[context];
if(meas == undefined) {
meas = null;
}
return meas;
},
isValidLocation: function() {
return ( (this.getLat() != "null") && (this.getLat() != null) && (this.getLng() != "null") && (this.getLng() != null));
},
getLat: function() {
var meas = this.getMeasurement( "latitude" );
if(meas == null) {
return null;
} else {
return meas.value;
}
},
getLng: function() {
var meas = this.getMeasurement( "longitude" );
if(meas == null) {
return null;
} else {
return meas.value;
}
},
getElev: function() {
var meas = this.getMeasurement( "elevation" );
if(meas == null) {
return null;
} else {
return meas.value;
}
},
getDate: function() {
return this.date;
},
toString: function() {
return "TrackPoint Point: (" + this.getLat() + ", " + this.getLng() + ")";
}
};
Garmin.TrackSegment = Class.create();
Garmin.TrackSegment.prototype = {
initialize: function() {
this.points = new Array();
},
addTrackPoint: function(trackPointObject) {
this.points.push(trackPointObject);
},
findNearestValidLocationPoint: function(index, incDirection) {
if( this.getPoint( index ).isValidLocation() ) {
return this.getPoint( index );
} else if( index >= this.getLength() ) {
return this.findNearestValidLocationPoint(this.getLength()-1, -1);
} else {
return this.findNearestValidLocationPoint(index+incDirection, incDirection);
}
},
getPoint: function(index) {
index = Math.floor(index);
if(index >= this.getLength()) {
return this.getEnd();
}
if(index <= 0) {
return this.getStart();
}
return this.points[index];
},
getStart: function() {
return this.points[0];
},
getEnd: function() {
return this.points[this.getLength()-1];
},
getStartLat: function() {
return this.getStart().getLat();
},
getStartLng: function() {
return this.getStart().getLng();
},
getStartDate: function() {
return this.getStart().getDate();
},
getEndDate: function() {
return this.getEnd().getDate();
},
getDuration: function() {
return this.getStartDate().getDurationTo(this.getEndDate());
},
getLength: function() {
return this.points.length;
},
toString: function() {
return "Track Segment w/ " + this.getLength() + " points.";
}
};
Garmin.Track = Class.create();
Garmin.Track.prototype = {
initialize: function() {
this.segments = new Array();
},
addSegment: function(trackSegment) {
this.segments.push(trackSegment);
},
getSegment: function(index) {
index = Math.floor(index);
if(index >= this.getLastSegment()) {
return this.getEnd();
}
if(index <= 0) {
return this.getFirstSegment();
}
return this.segments[index];
},
getFirstSegment: function() {
return this.segments[0];
},
getLastSegment: function() {
return this.segments[this.getNumSegments()-1];
},
getNumSegments: function() {
return this.segments.length;
},
getStart: function() {
return this.getFirstSegment().getStart();
},
getStartLat: function() {
return this.getFirstSegment().getStartLat();
},
getStartLng: function() {
return this.getFirstSegment().getStartLng();
},
getStartDate: function() {
return this.getFirstSegment().getStartDate();
},
getEnd: function() {
return this.getLastSegment().getEnd();
},
getEndDate: function() {
return this.getLastSegment().getEndDate();
},
getDuration: function() {
return this.getStartDate().getDurationTo(this.getEndDate());
},
getLength: function() {
var length = 0;
for( var i=0; i < this.segments.length; i++ ) {
length += this.segments[i].getLength();
}
return length;
},
isDrawable: function() {
return (this.getStartDate() != null);
},
toString: function() {
return "Track w/ " + this.getNumSegments() + " segments.";
}
};
Garmin.GpsDataFactory = Class.create();
Garmin.GpsDataFactory.prototype = {
initialize: function() {
this.tracks = new Array();
this.waypoints = new Array();
},
getTracks: function() {
return this.tracks;
},
getWaypoints: function() {
return this.waypoints;
},
parseGpxString: function(gpxString) {
var gpxDocument = Garmin.XmlConverter.toDocument(gpxString);
this.parseGpxDocument(gpxDocument);
},
parseGpxDocument: function(gpxDocument) {
this.parseGpxTracks(gpxDocument);
this.parseGpxWaypoints(gpxDocument);
},
parseGpxTracks: function(gpxDocument) {
var tracks = new Array();
var trackNodes = gpxDocument.getElementsByTagName("trk");
for( var i=0; i < trackNodes.length; i++ ) {
var trk = new Garmin.Track();
var trackSegments = trackNodes[i].getElementsByTagName("trkseg");
for( var j=0; j < trackSegments.length; j++ ) {
var trkseg = new Garmin.TrackSegment();
var trackPoints = trackSegments[j].getElementsByTagName("trkpt");
for( var k=0; k < trackPoints.length; k++ ) {
var trkpt = new Garmin.TrackPoint();
var lat = trackPoints[k].getAttribute("lat");
var lng = trackPoints[k].getAttribute("lon");
var ele = trackPoints[k].getElementsByTagName("ele")[0].childNodes[0].nodeValue;
var timeNodes = trackPoints[k].getElementsByTagName("time");
if(timeNodes.length > 0) {
var time = timeNodes[0].childNodes[0].nodeValue;
trkpt.date = (new Garmin.DateTimeFormat()).parseXsdDateTime(time);
}
trkpt.measurements = {
latitude: {
value: lat,
context: "latitude"
},
longitude: {
value: lng,
context: "longitude"
},
elevation: {
value: ele,
context: "feet"
}
};
trkseg.addTrackPoint(trkpt);
}
trk.addSegment(trkseg);
}
tracks.push(trk);
}
this.tracks = tracks;
return tracks;
},
parseGpxWaypoints: function(gpxDocument) {
var waypoints = new Array();
var waypointNodes = gpxDocument.getElementsByTagName("wpt");
for( var i=0; i < waypointNodes.length; i++ ) {
var waypointNode = waypointNodes[i];
var lat = waypointNode.getAttribute("lat");
var lng = waypointNode.getAttribute("lon");
var name = waypointNode.getElementsByTagName("name")[0].childNodes[0].nodeValue;
var elevNode = waypointNode.getElementsByTagName("ele");
var ele = null;
if(elevNode.length > 0) {
ele = elevNode[0].childNodes[0].nodeValue;
}
var wpt = new Garmin.WayPoint(lat, lng, ele, name);
waypoints.push(wpt);
}
this.waypoints = waypoints;
return waypoints;
},
toString: function() {
return "GpsDataFactory.";
}
};
var GarminGpsDataStructures = {
require: function(libraryName) {
document.write('<script type="text/javascript" src="'+libraryName+'"></script>');
},
load: function() {
if((typeof Prototype=='undefined') ||
(typeof Element == 'undefined') ||
(typeof Element.Methods=='undefined') ||
parseFloat(Prototype.Version.split(".")[0] + "." +
Prototype.Version.split(".")[1]) < 1.5)
throw("GarminGpsDataStructures requires the Prototype JavaScript framework >= 1.5.0");
$A(document.getElementsByTagName("script")).findAll( function(s) {
return (s.src && s.src.match(/GarminGpsDataStructures\.js(\?.*)?$/))
}).each( function(s) {
var path = s.src.replace(/GarminGpsDataStructures\.js(\?.*)?$/,'');
var includes = s.src.match(/\?.*load=([a-z,]*)/);
(includes ? includes[1] : 'DateTimeFormat,XmlConverter').split(',').each(
function(include) { GarminGpsDataStructures.require(path+include+'.js') });
});
}
}
GarminGpsDataStructures.load();
Documentation generated by
JSDoc on Mon Apr 16 11:23:41 2007