30e49f01d277ae457ef74d21563170254f05f3c9
[utils] /
1 /*
2  * Copyright 2006 the original author or authors.
3  * 
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  * 
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  * 
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */ 
16
17 package org.wamblee.gps.track;
18
19 import java.io.Serializable;
20 import java.util.ArrayList;
21 import java.util.List;
22
23 import org.wamblee.gps.geometry.Point;
24
25 /**
26  * Represents a GPS track. 
27  */
28 public class Track implements Serializable {
29     
30     private List<TrackPoint> _points; 
31     
32     /**
33      * Constructs an empty track. 
34      *
35      */
36     public Track() { 
37         _points = new ArrayList<TrackPoint>();
38     }
39     
40     /**
41      * Adds a point to a track. 
42      * @param aPoint Point. 
43      */
44     public void addPoint(TrackPoint aPoint) { 
45         _points.add(aPoint);
46     }
47     
48     /**
49      * @return Number of points in the track. 
50      */
51     public int size()  { 
52         return _points.size(); 
53     }
54     
55     public double getMinCoordinate(int i) {
56         if ( size() == 0 ) { 
57             throw new IllegalArgumentException("empty track");
58         }
59         double min = getPoint(0).getCoordinates().getX(i);
60         for (int j = 1; j < size(); j++) { 
61             min = Math.min(min, getPoint(j).getCoordinates().getX(i));
62         }
63         return min;
64     }
65     
66     public double getMaxCoordinate(int i) {
67         if ( size() == 0 ) { 
68             throw new IllegalArgumentException("empty track");
69         }
70         double max = getPoint(0).getCoordinates().getX(i);
71         for (int j = 1; j < size(); j++) { 
72             max = Math.max(max, getPoint(j).getCoordinates().getX(i));
73         }
74         return max;
75     }
76     
77     /**
78      * Gets the point at the given inded. 
79      * @param aIndex 0 &lt;= aIndex &lt; size()
80      * @return Point.
81      */
82     public Point getPoint(int aIndex) { 
83         return _points.get(aIndex);
84     }
85 }