Changeset 17715 in josm for trunk/src/org/openstreetmap


Ignore:
Timestamp:
2021-04-08T22:56:06+02:00 (4 years ago)
Author:
simon04
Message:

see #14176 - Migrate GPX to Instant

Location:
trunk/src/org/openstreetmap/josm
Files:
18 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/org/openstreetmap/josm/data/gpx/GpxData.java

    r17439 r17715  
    44import java.io.File;
    55import java.text.MessageFormat;
     6import java.time.Instant;
    67import java.util.ArrayList;
    78import java.util.Arrays;
     
    910import java.util.Collections;
    1011import java.util.Comparator;
    11 import java.util.Date;
    1212import java.util.HashMap;
    1313import java.util.HashSet;
     
    200200                boolean split = false;
    201201                WayPoint prevLastOwnWp = null;
    202                 Date prevWpTime = null;
     202                Instant prevWpTime = null;
    203203                for (WayPoint wp : wpsOld) {
    204                     Date wpTime = wp.getDate();
     204                    Instant wpTime = wp.getInstant();
    205205                    boolean overlap = false;
    206206                    if (wpTime != null) {
    207207                        for (GpxTrackSegmentSpan ownspan : getSegmentSpans()) {
    208                             if (wpTime.after(ownspan.firstTime) && wpTime.before(ownspan.lastTime)) {
     208                            if (wpTime.isAfter(ownspan.firstTime) && wpTime.isBefore(ownspan.lastTime)) {
    209209                                overlap = true;
    210210                                if (connect) {
     
    219219                                break;
    220220                            } else if (connect && prevWpTime != null
    221                                     && prevWpTime.before(ownspan.firstTime)
    222                                     && wpTime.after(ownspan.lastTime)) {
     221                                    && prevWpTime.isBefore(ownspan.firstTime)
     222                                    && wpTime.isAfter(ownspan.lastTime)) {
    223223                                // the overlapping high priority track is shorter than the distance
    224224                                // between two waypoints of the low priority track
     
    287287    static class GpxTrackSegmentSpan {
    288288
    289         final Date firstTime;
    290         final Date lastTime;
     289        final Instant firstTime;
     290        final Instant lastTime;
    291291        private final boolean inv;
    292292        private final WayPoint firstWp;
     
    294294
    295295        GpxTrackSegmentSpan(WayPoint a, WayPoint b) {
    296             Date at = a.getDate();
    297             Date bt = b.getDate();
    298             inv = bt.before(at);
     296            Instant at = a.getInstant();
     297            Instant bt = b.getInstant();
     298            inv = bt.isBefore(at);
    299299            if (inv) {
    300300                firstWp = b;
     
    333333
    334334        boolean overlapsWith(GpxTrackSegmentSpan other) {
    335             return (firstTime.before(other.lastTime) && other.firstTime.before(lastTime))
    336                 || (other.firstTime.before(lastTime) && firstTime.before(other.lastTime));
     335            return (firstTime.isBefore(other.lastTime) && other.firstTime.isBefore(lastTime))
     336                || (other.firstTime.isBefore(lastTime) && firstTime.isBefore(other.lastTime));
    337337        }
    338338
     
    720720     * @return  minimum and maximum dates in array of 2 elements
    721721     */
    722     public static Date[] getMinMaxTimeForTrack(IGpxTrack trk) {
     722    public static Instant[] getMinMaxTimeForTrack(IGpxTrack trk) {
    723723        final LongSummaryStatistics statistics = trk.getSegments().stream()
    724724                .flatMap(seg -> seg.getWayPoints().stream())
     
    727727        return statistics.getCount() == 0 || (statistics.getMin() == 0 && statistics.getMax() == 0)
    728728                ? null
    729                 : new Date[]{new Date(statistics.getMin()), new Date(statistics.getMax())};
     729                : new Instant[]{Instant.ofEpochMilli(statistics.getMin()), Instant.ofEpochMilli(statistics.getMax())};
    730730    }
    731731
     
    737737    * @since 7319
    738738    */
    739     public synchronized Date[] getMinMaxTimeForAllTracks() {
     739    public synchronized Instant[] getMinMaxTimeForAllTracks() {
    740740        long now = System.currentTimeMillis();
    741741        final LongSummaryStatistics statistics = tracks.stream()
     
    746746                .summaryStatistics();
    747747        return statistics.getCount() == 0
    748                 ? new Date[0]
    749                 : new Date[]{new Date(statistics.getMin()), new Date(statistics.getMax())};
     748                ? new Instant[0]
     749                : new Instant[]{Instant.ofEpochMilli(statistics.getMin()), Instant.ofEpochMilli(statistics.getMax())};
    750750    }
    751751
  • trunk/src/org/openstreetmap/josm/data/gpx/GpxImageCorrelation.java

    r17579 r17715  
    33
    44import java.util.ArrayList;
    5 import java.util.Date;
    65import java.util.List;
    76import java.util.concurrent.TimeUnit;
     
    226225                final GpxImageEntry curImg = images.get(i);
    227226                final GpxImageEntry curTmp = curImg.getTmp();
    228                 final long time = curImg.getExifTime().getTime();
     227                final long time = curImg.getExifInstant().toEpochMilli();
    229228                if ((!isLast && time > curWpTime) || time < prevWpTime) {
    230229                    break;
     
    239238                        curTmp.setPos(curWp.getCoor());
    240239                    }
    241                     curTmp.setGpsTime(new Date(curImg.getExifTime().getTime() - offset));
     240                    curTmp.setGpsTime(curImg.getExifInstant().minusMillis(offset));
    242241                    curTmp.flagNewGpsData();
    243242                    curImg.tmpUpdated();
     
    253252                GpxImageEntry curImg = images.get(i);
    254253                GpxImageEntry curTmp = curImg.getTmp();
    255                 final long imgTime = curImg.getExifTime().getTime();
     254                final long imgTime = curImg.getExifInstant().toEpochMilli();
    256255                if (imgTime < prevWpTime) {
    257256                    break;
     
    265264                        curTmp.setElevation(prevElevation + (curElevation - prevElevation) * timeDiff);
    266265                    }
    267                     curTmp.setGpsTime(new Date(curImg.getExifTime().getTime() - offset));
     266                    curTmp.setGpsTime(curImg.getExifInstant().minusMillis(offset));
    268267                    curTmp.flagNewGpsData();
    269268                    curImg.tmpUpdated();
     
    281280
    282281        // No photos or the first photo taken is later than the search period
    283         if (lstSize == 0 || searchedTime < images.get(0).getExifTime().getTime())
     282        if (lstSize == 0 || searchedTime < images.get(0).getExifInstant().toEpochMilli())
    284283            return -1;
    285284
    286285        // The search period is later than the last photo
    287         if (searchedTime > images.get(lstSize - 1).getExifTime().getTime())
     286        if (searchedTime > images.get(lstSize - 1).getExifInstant().toEpochMilli())
    288287            return lstSize-1;
    289288
     
    294293        while (endIndex - startIndex > 1) {
    295294            curIndex = (endIndex + startIndex) / 2;
    296             if (searchedTime > images.get(curIndex).getExifTime().getTime()) {
     295            if (searchedTime > images.get(curIndex).getExifInstant().toEpochMilli()) {
    297296                startIndex = curIndex;
    298297            } else {
     
    300299            }
    301300        }
    302         if (searchedTime < images.get(endIndex).getExifTime().getTime())
     301        if (searchedTime < images.get(endIndex).getExifInstant().toEpochMilli())
    303302            return startIndex;
    304303
    305304        // This final loop is to check if photos with the exact same EXIF time follows
    306         while ((endIndex < (lstSize - 1)) && (images.get(endIndex).getExifTime().getTime()
    307                 == images.get(endIndex + 1).getExifTime().getTime())) {
     305        while ((endIndex < (lstSize - 1)) && (images.get(endIndex).getExifInstant().toEpochMilli()
     306                == images.get(endIndex + 1).getExifInstant().toEpochMilli())) {
    308307            endIndex++;
    309308        }
  • trunk/src/org/openstreetmap/josm/data/gpx/GpxImageEntry.java

    r17579 r17715  
    66import java.io.File;
    77import java.io.IOException;
     8import java.time.Instant;
    89import java.util.Date;
    910import java.util.List;
     
    4344    private LatLon exifCoor;
    4445    private Double exifImgDir;
    45     private Date exifTime;
     46    private Instant exifTime;
    4647    /**
    4748     * Flag isNewGpsData indicates that the GPS data of the image is new or has changed.
     
    5152    private boolean isNewGpsData;
    5253    /** Temporary source of GPS time if not correlated with GPX track. */
    53     private Date exifGpsTime;
     54    private Instant exifGpsTime;
    5455
    5556    private String iptcCaption;
     
    6869    private Double elevation;
    6970    /** The time after correlation with a gpx track */
    70     private Date gpsTime;
     71    private Instant gpsTime;
    7172
    7273    private int width;
     
    173174     * is returned if that copy exists.
    174175     * @return the GPS time value
    175      */
     176     * @deprecated Use {@link #getGpsInstant}
     177     */
     178    @Deprecated
    176179    public Date getGpsTime() {
    177180        if (tmp != null)
     
    181184
    182185    /**
     186     * Returns the GPS time value. The GPS time value from the temporary copy
     187     * is returned if that copy exists.
     188     * @return the GPS time value
     189     */
     190    public Instant getGpsInstant() {
     191        return tmp != null ? tmp.gpsTime : gpsTime;
     192    }
     193
     194    /**
    183195     * Convenient way to determine if this entry has a GPS time, without the cost of building a defensive copy.
    184196     * @return {@code true} if this entry has a GPS time
     
    208220     * Returns EXIF time
    209221     * @return EXIF time
    210      */
     222     * @deprecated Use {@link #getExifInstant}
     223     */
     224    @Deprecated
    211225    public Date getExifTime() {
    212226        return getDefensiveDate(exifTime);
     227    }
     228
     229    /**
     230     * Returns EXIF time
     231     * @return EXIF time
     232     */
     233    public Instant getExifInstant() {
     234        return exifTime;
    213235    }
    214236
     
    226248     * @return the EXIF GPS time
    227249     * @since 6392
    228      */
     250     * @deprecated Use {@link #getExifGpsInstant}
     251     */
     252    @Deprecated
    229253    public Date getExifGpsTime() {
    230254        return getDefensiveDate(exifGpsTime);
     255    }
     256
     257    /**
     258     * Returns the EXIF GPS time.
     259     * @return the EXIF GPS time
     260     */
     261    public Instant getExifGpsInstant() {
     262        return exifGpsTime;
    231263    }
    232264
     
    240272    }
    241273
    242     private static Date getDefensiveDate(Date date) {
     274    private static Date getDefensiveDate(Instant date) {
    243275        if (date == null)
    244276            return null;
    245         return new Date(date.getTime());
     277        return Date.from(date);
    246278    }
    247279
     
    325357     * Sets EXIF time.
    326358     * @param exifTime EXIF time
    327      */
     359     * @deprecated Use {@link #setExifTime(Instant)}
     360     */
     361    @Deprecated
    328362    public void setExifTime(Date exifTime) {
    329         this.exifTime = getDefensiveDate(exifTime);
     363        this.exifTime = exifTime == null ? null : exifTime.toInstant();
    330364    }
    331365
     
    334368     * @param exifGpsTime the EXIF GPS time
    335369     * @since 6392
    336      */
     370     * @deprecated Use {@link #setExifGpsTime(Instant)}
     371     */
     372    @Deprecated
    337373    public void setExifGpsTime(Date exifGpsTime) {
    338         this.exifGpsTime = getDefensiveDate(exifGpsTime);
    339     }
    340 
     374        this.exifGpsTime = exifGpsTime == null ? null : exifGpsTime.toInstant();
     375    }
     376
     377    /**
     378     * Sets the GPS time.
     379     * @param gpsTime the GPS time
     380     * @deprecated Use {@link #setGpsTime(Instant)}
     381     */
     382    @Deprecated
    341383    public void setGpsTime(Date gpsTime) {
    342         this.gpsTime = getDefensiveDate(gpsTime);
     384        this.gpsTime = gpsTime == null ? null : gpsTime.toInstant();
     385    }
     386
     387    /**
     388     * Sets EXIF time.
     389     * @param exifTime EXIF time
     390     */
     391    public void setExifTime(Instant exifTime) {
     392        this.exifTime = exifTime;
     393    }
     394
     395    /**
     396     * Sets the EXIF GPS time.
     397     * @param exifGpsTime the EXIF GPS time
     398     */
     399    public void setExifGpsTime(Instant exifGpsTime) {
     400        this.exifGpsTime = exifGpsTime;
     401    }
     402
     403    /**
     404     * Sets the GPS time.
     405     * @param gpsTime the GPS time
     406     */
     407    public void setGpsTime(Instant gpsTime) {
     408        this.gpsTime = gpsTime;
    343409    }
    344410
     
    635701                        Logging.warn(topException);
    636702                        Logging.info(tr("Can''t parse metadata for file \"{0}\". Using last modified date as timestamp.", fn));
    637                         setExifTime(new Date(file.lastModified()));
     703                        setExifTime(Instant.ofEpochMilli(file.lastModified()));
    638704                        setExifCoor(null);
    639705                        setPos(null);
     
    646712        // Changed to silently cope with no time info in exif. One case
    647713        // of person having time that couldn't be parsed, but valid GPS info
    648         Date time = null;
     714        Instant time = null;
    649715        try {
    650             time = ExifReader.readTime(metadata);
     716            time = ExifReader.readInstant(metadata);
    651717        } catch (JosmRuntimeException | IllegalArgumentException | IllegalStateException ex) {
    652718            Logging.warn(ex);
     
    655721        if (time == null) {
    656722            Logging.info(tr("No EXIF time in file \"{0}\". Using last modified date as timestamp.", fn));
    657             time = new Date(file.lastModified()); //use lastModified time if no EXIF time present
     723            time = Instant.ofEpochMilli(file.lastModified()); //use lastModified time if no EXIF time present
    658724        }
    659725        setExifTime(time);
     
    705771        }
    706772
    707         ifNotNull(dirGps.getGpsDate(), this::setExifGpsTime);
     773        ifNotNull(dirGps.getGpsDate(), d -> setExifGpsTime(d.toInstant()));
    708774
    709775        IptcDirectory dirIptc = metadata.getFirstDirectoryOfType(IptcDirectory.class);
  • trunk/src/org/openstreetmap/josm/data/gpx/WayPoint.java

    r17132 r17715  
    33
    44import java.awt.Color;
     5import java.time.Instant;
    56import java.util.ArrayList;
    67import java.util.Date;
     
    1617import org.openstreetmap.josm.tools.Logging;
    1718import org.openstreetmap.josm.tools.Utils;
    18 import org.openstreetmap.josm.tools.date.DateUtils;
    1919import org.openstreetmap.josm.tools.template_engine.TemplateEngineDataProvider;
    2020
     
    6666        attr = new HashMap<>(0);
    6767        attr.putAll(p.attr);
    68         if (p.getDate() != null) {
    69             attr.put(PT_TIME, p.getDate());
    70         }
    7168        lat = p.lat;
    7269        lon = p.lon;
     
    139136     * @param time the time to set
    140137     * @since 9383
    141      */
     138     * @deprecated Use {@link #setInstant(Instant)}
     139     */
     140    @Deprecated
    142141    public void setTime(Date time) {
    143         setTimeInMillis(time.getTime());
     142        setInstant(time.toInstant());
    144143    }
    145144
     
    149148     * @param ts seconds from the epoch
    150149     * @since 13210
    151      */
     150     * @deprecated Use {@link #setInstant(Instant)}
     151     */
     152    @Deprecated
    152153    public void setTime(long ts) {
    153         setTimeInMillis(ts * 1000);
     154        setInstant(Instant.ofEpochSecond(ts));
    154155    }
    155156
     
    161162     */
    162163    public void setTimeInMillis(long ts) {
    163         attr.put(PT_TIME, new Date(ts));
     164        setInstant(Instant.ofEpochMilli(ts));
     165    }
     166
     167    /**
     168     * Sets the {@link #PT_TIME} attribute to the specified time.
     169     *
     170     * @param instant the time to set
     171     */
     172    public void setInstant(Instant instant) {
     173        attr.put(PT_TIME, instant);
    164174    }
    165175
     
    185195     */
    186196    public long getTimeInMillis() {
    187         Date d = getDateImpl();
    188         return d == null ? 0 : d.getTime();
     197        Instant d = getInstant();
     198        return d == null ? 0 : d.toEpochMilli();
    189199    }
    190200
     
    196206     */
    197207    public boolean hasDate() {
    198         return attr.get(PT_TIME) instanceof Date;
     208        return attr.get(PT_TIME) instanceof Instant;
    199209    }
    200210
     
    204214     * @return a copy of the Date object associated with this waypoint
    205215     * @since 14456
    206      */
     216     * @deprecated Use {@link #getInstant()}
     217     */
     218    @Deprecated
    207219    public Date getDate() {
    208         return DateUtils.cloneDate(getDateImpl());
    209     }
    210 
    211     /**
    212      * Returns the waypoint time Date object.
    213      *
    214      * @return the Date object associated with this waypoint
    215      */
    216     private Date getDateImpl() {
     220        Instant instant = getInstant();
     221        return instant == null ? null : Date.from(instant);
     222    }
     223
     224    /**
     225     * Returns the waypoint instant.
     226     *
     227     * @return the instant associated with this waypoint
     228     * @since 14456
     229     */
     230    public Instant getInstant() {
    217231        if (attr != null) {
    218232            final Object obj = attr.get(PT_TIME);
    219233
    220             if (obj instanceof Date) {
    221                 return (Date) obj;
     234            if (obj instanceof Instant) {
     235                return (Instant) obj;
    222236            } else if (obj == null) {
    223237                Logging.trace("Waypoint {0} value unset", PT_TIME);
  • trunk/src/org/openstreetmap/josm/gui/layer/GpxLayer.java

    r17439 r17715  
    1010import java.awt.event.ActionEvent;
    1111import java.io.File;
    12 import java.text.DateFormat;
     12import java.time.Instant;
     13import java.time.format.DateTimeFormatter;
     14import java.time.format.FormatStyle;
     15import java.time.temporal.ChronoUnit;
    1316import java.util.ArrayList;
    1417import java.util.Arrays;
     
    157160     */
    158161    public static String getTimespanForTrack(IGpxTrack trk) {
    159         Date[] bounds = GpxData.getMinMaxTimeForTrack(trk);
     162        Instant[] bounds = GpxData.getMinMaxTimeForTrack(trk);
    160163        return bounds != null ? formatTimespan(bounds) : "";
    161164    }
     
    166169     * @return The timespan as a string
    167170     */
    168     public static String formatTimespan(Date[] bounds) {
     171    public static String formatTimespan(Instant[] bounds) {
    169172        String ts = "";
    170         DateFormat df = DateUtils.getDateFormat(DateFormat.SHORT);
     173        DateTimeFormatter df = DateUtils.getDateFormatter(FormatStyle.SHORT);
    171174        String earliestDate = df.format(bounds[0]);
    172175        String latestDate = df.format(bounds[1]);
    173176
    174177        if (earliestDate.equals(latestDate)) {
    175             DateFormat tf = DateUtils.getTimeFormat(DateFormat.SHORT);
     178            DateTimeFormatter tf = DateUtils.getTimeFormatter(FormatStyle.SHORT);
    176179            ts += earliestDate + ' ';
    177180            ts += tf.format(bounds[0]) + " - " + tf.format(bounds[1]);
    178181        } else {
    179             DateFormat dtf = DateUtils.getDateTimeFormat(DateFormat.SHORT, DateFormat.MEDIUM);
     182            DateTimeFormatter dtf = DateUtils.getDateTimeFormatter(FormatStyle.SHORT, FormatStyle.MEDIUM);
    180183            ts += dtf.format(bounds[0]) + " - " + dtf.format(bounds[1]);
    181184        }
    182185
    183         int diff = (int) (bounds[1].getTime() - bounds[0].getTime()) / 1000;
     186        long diff = ChronoUnit.SECONDS.between(bounds[1], bounds[0]);
    184187        ts += String.format(" (%d:%02d)", diff / 3600, (diff % 3600) / 60);
    185188        return ts;
     
    355358        long to = toDate.getTime();
    356359        for (IGpxTrack trk : data.getTracks()) {
    357             Date[] t = GpxData.getMinMaxTimeForTrack(trk);
     360            Instant[] t = GpxData.getMinMaxTimeForTrack(trk);
    358361
    359362            if (t == null) continue;
    360             long tm = t[1].getTime();
     363            long tm = t[1].toEpochMilli();
    361364            trackVisibility[i] = (tm == 0 && showWithoutDate) || (from <= tm && tm <= to);
    362365            i++;
  • trunk/src/org/openstreetmap/josm/gui/layer/OsmDataLayer.java

    r17626 r17715  
    2424import java.io.IOException;
    2525import java.time.DateTimeException;
     26import java.time.Instant;
    2627import java.util.ArrayList;
    2728import java.util.Arrays;
     
    878879                wpt.setTimeInMillis(DateUtils.tsFromString(v));
    879880            } else if (!n.isTimestampEmpty()) {
    880                 wpt.setTime(Integer.toUnsignedLong(n.getRawTimestamp()));
     881                wpt.setInstant(Instant.ofEpochSecond(Integer.toUnsignedLong(n.getRawTimestamp())));
    881882            }
    882883        } catch (UncheckedParseException | DateTimeException e) {
  • trunk/src/org/openstreetmap/josm/gui/layer/geoimage/CorrelateGpxWithImages.java

    r17548 r17715  
    2828import java.text.ParseException;
    2929import java.text.SimpleDateFormat;
     30import java.time.Instant;
     31import java.time.ZoneOffset;
     32import java.time.format.DateTimeFormatter;
     33import java.time.format.FormatStyle;
    3034import java.util.ArrayList;
    3135import java.util.Arrays;
    3236import java.util.Collections;
    3337import java.util.Comparator;
    34 import java.util.Date;
    3538import java.util.Dictionary;
    3639import java.util.Hashtable;
     
    768771        void updateExifComponents(ImageEntry img) {
    769772            imgDisp.setImage(img);
    770             Date date = img.getExifTime();
     773            Instant date = img.getExifInstant();
    771774            if (date != null) {
    772                 DateFormat df = DateUtils.getDateTimeFormat(DateFormat.SHORT, DateFormat.MEDIUM);
    773                 df.setTimeZone(DateUtils.UTC); // EXIF data does not contain timezone information and is read as UTC
     775                DateTimeFormatter df = DateUtils.getDateTimeFormatter(FormatStyle.SHORT, FormatStyle.MEDIUM)
     776                        .withZone(ZoneOffset.UTC); // EXIF data does not contain timezone information and is read as UTC
    774777                lbExifTime.setText(df.format(date));
    775778                tfGpsTime.setText(df.format(date));
     
    12601263
    12611264        // Init variables
    1262         long firstExifDate = imgs.get(0).getExifTime().getTime();
     1265        long firstExifDate = imgs.get(0).getExifInstant().toEpochMilli();
    12631266
    12641267        // Finds first GPX point
     
    13341337                .filter(e -> e.getExifCoor() == null || exif)
    13351338                .filter(e -> tagged || !e.isTagged() || e.getExifCoor() != null)
    1336                 .sorted(Comparator.comparing(ImageEntry::getExifTime))
     1339                .sorted(Comparator.comparing(ImageEntry::getExifInstant))
    13371340                .collect(Collectors.toList());
    13381341    }
  • trunk/src/org/openstreetmap/josm/gui/layer/geoimage/ImageViewerDialog.java

    r17188 r17715  
    1313import java.awt.event.KeyEvent;
    1414import java.awt.event.WindowEvent;
    15 import java.text.DateFormat;
    16 import java.text.SimpleDateFormat;
     15import java.time.ZoneOffset;
     16import java.time.format.DateTimeFormatter;
     17import java.time.format.FormatStyle;
    1718import java.util.Collections;
    1819import java.util.List;
     
    472473            }
    473474
    474             DateFormat dtf = DateUtils.getDateTimeFormat(DateFormat.SHORT, DateFormat.MEDIUM);
    475             // Make sure date/time format includes milliseconds
    476             if (dtf instanceof SimpleDateFormat) {
    477                 String pattern = ((SimpleDateFormat) dtf).toPattern();
    478                 if (!pattern.contains(".SSS")) {
    479                     dtf = new SimpleDateFormat(pattern.replace(":ss", ":ss.SSS"));
    480                 }
    481             }
    482             // Set timezone to UTC since UTC is assumed when parsing the EXIF timestamp,
    483             // see see org.openstreetmap.josm.tools.ExifReader.readTime(com.drew.metadata.Metadata)
    484             dtf.setTimeZone(DateUtils.UTC);
     475            DateTimeFormatter dtf = DateUtils.getDateTimeFormatter(FormatStyle.SHORT, FormatStyle.MEDIUM)
     476                    // Set timezone to UTC since UTC is assumed when parsing the EXIF timestamp,
     477                    // see see org.openstreetmap.josm.tools.ExifReader.readTime(com.drew.metadata.Metadata)
     478                    .withZone(ZoneOffset.UTC);
    485479
    486480            if (entry.hasExifTime()) {
    487                 osd.append(tr("\nEXIF time: {0}", dtf.format(entry.getExifTime())));
     481                osd.append(tr("\nEXIF time: {0}", dtf.format(entry.getExifInstant())));
    488482            }
    489483            if (entry.hasGpsTime()) {
    490                 osd.append(tr("\nGPS time: {0}", dtf.format(entry.getGpsTime())));
     484                osd.append(tr("\nGPS time: {0}", dtf.format(entry.getGpsInstant())));
    491485            }
    492486            Optional.ofNullable(entry.getIptcCaption()).map(s -> tr("\nCaption: {0}", s)).ifPresent(osd::append);
  • trunk/src/org/openstreetmap/josm/gui/layer/gpx/ChooseTrackVisibilityAction.java

    r17321 r17715  
    1313import java.awt.event.MouseEvent;
    1414import java.awt.event.MouseListener;
     15import java.time.Instant;
    1516import java.util.Arrays;
    1617import java.util.Comparator;
     
    8889            String name = (String) Optional.ofNullable(attr.get(GpxConstants.GPX_NAME)).orElse("");
    8990            String desc = (String) Optional.ofNullable(attr.get(GpxConstants.GPX_DESC)).orElse("");
    90             Date[] time = GpxData.getMinMaxTimeForTrack(trk);
     91            Instant[] time = GpxData.getMinMaxTimeForTrack(trk);
    9192            String url = (String) Optional.ofNullable(attr.get("url")).orElse("");
    9293            tracks[i] = new Object[]{name, desc, time, trk.length(), url, trk};
     
    140141        t.setRowSorter(rowSorter);
    141142        rowSorter.setModel(model);
    142         rowSorter.setComparator(2, Comparator.comparing((Date[] d) -> d == null ? Long.MIN_VALUE : d[0].getTime()));
     143        rowSorter.setComparator(2, Comparator.comparing((Instant[] d) -> d == null ? Instant.MIN : d[0]));
    143144        rowSorter.setComparator(3, Comparator.comparingDouble(length -> (double) length));
    144145        // default column widths
     
    150151            public Component getTableCellRendererComponent(
    151152                    JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
    152                 if (value instanceof Date[]) {
    153                     value = GpxLayer.formatTimespan(((Date[]) value));
     153                if (value instanceof Instant[]) {
     154                    value = GpxLayer.formatTimespan(((Instant[]) value));
    154155                }
    155156                return super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
  • trunk/src/org/openstreetmap/josm/gui/layer/gpx/ConvertFromGpxLayerAction.java

    r17586 r17715  
    77import java.awt.event.ActionEvent;
    88import java.awt.event.ActionListener;
     9import java.time.Instant;
    910import java.util.ArrayList;
    1011import java.util.Date;
     
    3637import org.openstreetmap.josm.spi.preferences.Config;
    3738import org.openstreetmap.josm.tools.GBC;
    38 import org.openstreetmap.josm.tools.date.DateUtils;
    3939
    4040/**
     
    123123            String key = entry.getKey();
    124124            Object obj = entry.getValue();
    125             if (check && !keys.contains(key) && (obj instanceof String || obj instanceof Number || obj instanceof Date)) {
     125            if (check && !keys.contains(key) && (obj instanceof String || obj instanceof Number || obj instanceof Instant)) {
    126126                keys.add(key);
    127127            }
     
    129129                // only convert when required
    130130                p.put(GpxConstants.GPX_PREFIX + key, obj.toString());
    131             } else if (obj instanceof Date && GpxConstants.PT_TIME.equals(key)) {
     131            } else if (obj instanceof Instant && GpxConstants.PT_TIME.equals(key)) {
    132132                // timestamps should always be converted
    133                 Date date = (Date) obj;
     133                Instant date = (Instant) obj;
    134134                if (!none) { //... but the tag will only be set when required
    135                     p.put(GpxConstants.GPX_PREFIX + key, DateUtils.fromDate(date));
    136                 }
    137                 p.setTimestamp(date);
     135                    p.put(GpxConstants.GPX_PREFIX + key, String.valueOf(date));
     136                }
     137                p.setTimestamp(Date.from(date));
    138138            }
    139139        }
  • trunk/src/org/openstreetmap/josm/gui/layer/gpx/DateFilterPanel.java

    r16553 r17715  
    77import java.awt.GridBagLayout;
    88import java.awt.event.ActionListener;
     9import java.time.Instant;
    910import java.time.ZoneId;
    1011import java.time.ZonedDateTime;
     
    5253
    5354        final Date startTime, endTime;
    54         Date[] bounds = layer.data.getMinMaxTimeForAllTracks();
    55         startTime = (bounds.length == 0) ? Date.from(ZonedDateTime.of(2000, 1, 1, 0, 0, 0, 0, ZoneId.systemDefault()).toInstant()) : bounds[0];
    56         endTime = (bounds.length == 0) ? new Date() : bounds[1];
     55        Instant[] bounds = layer.data.getMinMaxTimeForAllTracks();
     56        if (bounds.length == 0) {
     57            startTime = Date.from(ZonedDateTime.of(2000, 1, 1, 0, 0, 0, 0, ZoneId.systemDefault()).toInstant());
     58            endTime = new Date();
     59        } else {
     60            startTime = Date.from(bounds[0]);
     61            endTime = Date.from(bounds[1]);
     62        }
    5763
    5864        dateFrom.setDate(startTime);
  • trunk/src/org/openstreetmap/josm/gui/layer/gpx/GpxDrawHelper.java

    r16913 r17715  
    2222import java.io.BufferedReader;
    2323import java.io.IOException;
     24import java.time.Instant;
    2425import java.util.ArrayList;
    2526import java.util.Arrays;
    2627import java.util.Collections;
    27 import java.util.Date;
    2828import java.util.LinkedList;
    2929import java.util.List;
     
    565565        double now = System.currentTimeMillis()/1000.0;
    566566        if (colored == ColorMode.TIME) {
    567             Date[] bounds = data.getMinMaxTimeForAllTracks();
     567            Instant[] bounds = data.getMinMaxTimeForAllTracks();
    568568            if (bounds.length >= 2) {
    569                 minval = bounds[0].getTime()/1000.0;
    570                 maxval = bounds[1].getTime()/1000.0;
     569                minval = bounds[0].getEpochSecond();
     570                maxval = bounds[1].getEpochSecond();
    571571            } else {
    572572                minval = 0;
  • trunk/src/org/openstreetmap/josm/io/nmea/NmeaReader.java

    r16643 r17715  
    366366                    // As this sentence has no complete time only use it
    367367                    // if there is no time so far
    368                     currentwp.setTime(d);
     368                    currentwp.setInstant(d.toInstant());
    369369                }
    370370                // elevation
     
    494494                }
    495495                // time: this sentence has complete time so always use it.
    496                 currentwp.setTime(d);
     496                currentwp.setInstant(d.toInstant());
    497497                // speed
    498498                accu = e[RMC.SPEED.position];
     
    544544            if (ps.pWp != currentwp) {
    545545                if (ps.pWp != null) {
    546                     ps.pWp.getDate();
     546                    ps.pWp.getInstant();
    547547                }
    548548                ps.pWp = currentwp;
  • trunk/src/org/openstreetmap/josm/io/rtklib/RtkLibPosReader.java

    r16643 r17715  
    9191                                    Double.parseDouble(fields[IDX_LON])));
    9292                            currentwp.put(GpxConstants.PT_ELE, fields[IDX_HEIGHT]);
    93                             currentwp.setTime(parseDate(fields[IDX_DATE]+" "+fields[IDX_TIME]));
     93                            currentwp.setInstant(parseDate(fields[IDX_DATE]+" "+fields[IDX_TIME]).toInstant());
    9494                            currentwp.put(GpxConstants.RTKLIB_Q, Integer.parseInt(fields[IDX_Q]));
    9595                            currentwp.put(GpxConstants.PT_SAT, fields[IDX_NS]);
  • trunk/src/org/openstreetmap/josm/io/session/GeoImageSessionExporter.java

    r14741 r17715  
    8787            }
    8888            if (entry.hasGpsTime()) {
    89                 addAttr("gps-time", Long.toString(entry.getGpsTime().getTime()), imgElem, support);
     89                addAttr("gps-time", Long.toString(entry.getGpsInstant().toEpochMilli()), imgElem, support);
    9090            }
    9191            if (entry.getExifOrientation() != null) {
     
    9393            }
    9494            if (entry.hasExifTime()) {
    95                 addAttr("exif-time", Long.toString(entry.getExifTime().getTime()), imgElem, support);
     95                addAttr("exif-time", Long.toString(entry.getExifInstant().toEpochMilli()), imgElem, support);
    9696            }
    9797            if (entry.hasExifGpsTime()) {
    98                 addAttr("exif-gps-time", Long.toString(entry.getExifGpsTime().getTime()), imgElem, support);
     98                addAttr("exif-gps-time", Long.toString(entry.getExifGpsInstant().toEpochMilli()), imgElem, support);
    9999            }
    100100            if (entry.getExifCoor() != null) {
  • trunk/src/org/openstreetmap/josm/io/session/GeoImageSessionImporter.java

    r14205 r17715  
    66import java.io.File;
    77import java.io.IOException;
     8import java.time.Instant;
    89import java.util.ArrayList;
    9 import java.util.Date;
    1010import java.util.List;
    1111
     
    9090                break;
    9191            case "gps-time":
    92                 entry.setGpsTime(new Date(Long.parseLong(attrElem.getTextContent())));
     92                entry.setGpsTime(Instant.ofEpochMilli(Long.parseLong(attrElem.getTextContent())));
    9393                break;
    9494            case "exif-orientation":
     
    9696                break;
    9797            case "exif-time":
    98                 entry.setExifTime(new Date(Long.parseLong(attrElem.getTextContent())));
     98                entry.setExifTime(Instant.ofEpochMilli(Long.parseLong(attrElem.getTextContent())));
    9999                break;
    100100            case "exif-gps-time":
    101                 entry.setExifGpsTime(new Date(Long.parseLong(attrElem.getTextContent())));
     101                entry.setExifGpsTime(Instant.ofEpochMilli(Long.parseLong(attrElem.getTextContent())));
    102102                break;
    103103            case "exif-coordinates":
  • trunk/src/org/openstreetmap/josm/tools/ExifReader.java

    r17548 r17715  
    66import java.io.IOException;
    77import java.time.DateTimeException;
     8import java.time.Instant;
    89import java.util.Date;
    910import java.util.List;
     
    4243     * @param filename The JPEG file to read
    4344     * @return The date/time read in the EXIF section, or {@code null} if not found
    44      */
     45     * @deprecated Use {@link #readInstant(File)}
     46     */
     47    @Deprecated
    4548    public static Date readTime(File filename) {
    46         try {
    47             final Metadata metadata = JpegMetadataReader.readMetadata(filename);
    48             return readTime(metadata);
     49        Instant instant = readInstant(filename);
     50        return instant == null ? null : Date.from(instant);
     51    }
     52
     53    /**
     54     * Returns the date/time from the given JPEG file.
     55     * @param filename The JPEG file to read
     56     * @return The date/time read in the EXIF section, or {@code null} if not found
     57     */
     58    public static Instant readInstant(File filename) {
     59        try {
     60            final Metadata metadata = JpegMetadataReader.readMetadata(filename);
     61            return readInstant(metadata);
    4962        } catch (JpegProcessingException | IOException e) {
    5063            Logging.error(e);
     
    5871     * @return The date/time read in the EXIF section, or {@code null} if not found
    5972     * @since 11745
    60      */
     73     * @deprecated Use {@link #readInstant(Metadata)}
     74     */
     75    @Deprecated
    6176    public static Date readTime(Metadata metadata) {
     77        Instant instant = readInstant(metadata);
     78        return instant == null ? null : Date.from(instant);
     79    }
     80
     81    /**
     82     * Returns the date/time from the given JPEG file.
     83     * @param metadata The EXIF metadata
     84     * @return The date/time read in the EXIF section, or {@code null} if not found
     85     */
     86    public static Instant readInstant(Metadata metadata) {
    6287        try {
    6388            String dateTimeOrig = null;
     
    109134            if (dateStr != null) {
    110135                dateStr = dateStr.replace('/', ':'); // workaround for HTC Sensation bug, see #7228
    111                 final Date date = DateUtils.fromString(dateStr);
     136                Instant date = DateUtils.parseInstant(dateStr);
    112137                if (subSeconds != null) {
    113138                    try {
    114                         date.setTime(date.getTime() + (long) (TimeUnit.SECONDS.toMillis(1) * Double.parseDouble("0." + subSeconds)));
     139                        date = date.plusMillis((long) (TimeUnit.SECONDS.toMillis(1) * Double.parseDouble("0." + subSeconds)));
    115140                    } catch (NumberFormatException e) {
    116141                        Logging.warn("Failed parsing sub seconds from [{0}]", subSeconds);
  • trunk/src/org/openstreetmap/josm/tools/date/DateUtils.java

    r17712 r17715  
    287287     * @return the date format used for GPX waypoints
    288288     * @since 14055
    289      */
     289     * @deprecated Use {@link Instant#toString()}
     290     */
     291    @Deprecated
    290292    public static DateFormat getGpxFormat() {
    291293        SimpleDateFormat result = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'");
Note: See TracChangeset for help on using the changeset viewer.