3 import java.text.ParseException;
5 import java.util.TreeMap;
7 import org.w3c.dom.DOMException;
9 @SuppressWarnings("serial")
10 public class ElementMapTRKPT extends TreeMap<Date, TagTrkpt> {
11 public static final long DIFF_MAE_TIME = 3000L; // before 3 secound
13 public ElementMapTRKPT() {
14 super(new TimeComparator());
18 * 拡張put value:ElementをputするとElement内のtimeを読み取ってkeyとしてthis.put(key,value)する。
19 * <trkpt lat="36.4260153752" lon="138.0117778201">
21 * <time>2017-05-21T23:02:16Z</time>
25 * @return keyとして登録したtime:Date
26 * @throws ParseException
27 * @throws DOMException
29 public Date put(TagTrkpt tag) throws DOMException, ParseException {
30 this.put(tag.time, tag);
35 * 指定時刻(jptime)のTRKPTエレメントを取り出す。
37 * @param jptime 指定する日時
38 * @return エレメントTRKPT。指定時刻に対応するノードがないときはnullを返す。
39 * @throws ParseException
41 public TagTrkpt getValue(Date jptime) throws ParseException {
42 TagTrkpt imaE = getTrkpt(jptime);
44 TagTrkpt maeE = getMaeTrkpt(imaE.time);
46 Complementation comp = new Complementation(imaE, maeE);
49 // 直前の位置と、現在地から進行方向を求める
50 // 経度(longitude)と経度から進行方向を求める
51 if (Complementation.param_GpxOverwriteMagvar) {
52 comp.complementationMagvar();
55 // 緯度・経度と時間差から速度(km/h)を求める
56 if (Complementation.param_GpxOutputSpeed) {
57 comp.complementationSpeed();
59 //return (TagTrkpt)(comp.imaTag.trkpt.cloneNode(true));
60 return (TagTrkpt)(comp.imaTag);
68 * [map]から指定した時刻の<trkpt>エレメントを取り出す。
69 * 取り出すエレメントは、指定した時刻と同一時刻、もしくは、直近・直前の時刻のエレメントとする。
70 * 指定した時刻以前のエレメントが存在しない場合は null を返す。
71 * 指定した時刻と直近・直前のエレメントの時刻との乖離が プロパティ[OVER_TIME_LIMIT=3000(ミリ秒)]より大きい場合には null を返す。
74 * @return <trkpt>エレメント。対象のエレメントが存在しなかった場合には null。
75 * @throws ParseException
77 private TagTrkpt getTrkpt(Date jptime) throws ParseException {
79 for (Date key : this.keySet()) {
80 int flag = jptime.compareTo(key);
82 if (keyTime != null) {
83 return this.get(keyTime);
91 keyTime = new Date(key.getTime());
94 if (keyTime != null) {
95 if (Math.abs(keyTime.getTime() - jptime.getTime()) <= OVER_TIME_LIMIT) {
96 return this.get(keyTime);
103 * ロガーの最終取得時刻を超えた場合、どこまでを有効とするかを設定する。
104 * この設定がないと、最終取得時刻を超えたものは全て有効になってしまう。
105 * OVER_TIME_LIMITは、GPSロガーの位置取得間隔()よりも長くする必要がある。長すぎても良くない。
107 public static long OVER_TIME_LIMIT = 3000; // ミリ秒(msec)
109 private TagTrkpt getMaeTrkpt(Date time) throws ParseException {
111 for (Date key : this.keySet()) {
112 int flag = time.compareTo(key);
114 maeTime = new Date(key.getTime());
116 else if (flag == 0) {
117 if (maeTime == null) {
120 return this.get(maeTime);
124 if (maeTime == null) {
127 if (Math.abs(maeTime.getTime() - time.getTime()) > OVER_TIME_LIMIT) {
130 return this.get(maeTime);
136 public void printinfo() {
137 Date firstTime = null;
138 Date lastTime = null;
139 for (Date key : this.keySet()) {
140 if (firstTime == null) {
141 firstTime = new Date(key.getTime());
143 lastTime = new Date(key.getTime());
145 System.out.println(String.format("| <trkseg/> |%20s|%20s|", ImportPicture.toUTCString(firstTime), ImportPicture.toUTCString(lastTime)));