add time and elevation to gpx parsing
This commit is contained in:
parent
6b3c456c41
commit
a54f903326
3
elm.json
3
elm.json
@ -9,7 +9,9 @@
|
|||||||
"elm/browser": "1.0.2",
|
"elm/browser": "1.0.2",
|
||||||
"elm/core": "1.0.5",
|
"elm/core": "1.0.5",
|
||||||
"elm/html": "1.0.0",
|
"elm/html": "1.0.0",
|
||||||
|
"elm/time": "1.0.0",
|
||||||
"elm-explorations/test": "2.2.0",
|
"elm-explorations/test": "2.2.0",
|
||||||
|
"rtfeldman/elm-iso8601-date-strings": "1.1.4",
|
||||||
"ymtszw/elm-xml-decode": "3.2.2"
|
"ymtszw/elm-xml-decode": "3.2.2"
|
||||||
},
|
},
|
||||||
"indirect": {
|
"indirect": {
|
||||||
@ -17,7 +19,6 @@
|
|||||||
"elm/json": "1.1.3",
|
"elm/json": "1.1.3",
|
||||||
"elm/parser": "1.1.0",
|
"elm/parser": "1.1.0",
|
||||||
"elm/random": "1.0.0",
|
"elm/random": "1.0.0",
|
||||||
"elm/time": "1.0.0",
|
|
||||||
"elm/url": "1.0.0",
|
"elm/url": "1.0.0",
|
||||||
"elm/virtual-dom": "1.0.3",
|
"elm/virtual-dom": "1.0.3",
|
||||||
"miniBill/elm-xml-parser": "1.0.1",
|
"miniBill/elm-xml-parser": "1.0.1",
|
||||||
|
@ -1,18 +1,33 @@
|
|||||||
module Track exposing (Track, Point, parse)
|
module Track exposing (Track, Point, parse)
|
||||||
|
|
||||||
import Result
|
import Result
|
||||||
import Xml.Decode as XD exposing (path, list, floatAttr)
|
import Xml.Decode as XD exposing (path, list, single, floatAttr, stringAttr)
|
||||||
|
import Time -- exposing (utc, toHour, toMinute, toSecond)
|
||||||
|
import Iso8601
|
||||||
|
|
||||||
type alias Point =
|
type alias Point =
|
||||||
{ lat : Float
|
{ lat : Float
|
||||||
, lon : Float
|
, lon : Float
|
||||||
|
, ele : Float
|
||||||
|
, time : Time.Posix
|
||||||
}
|
}
|
||||||
|
|
||||||
type alias Track = List Point
|
type alias Track = List Point
|
||||||
|
|
||||||
pointDecoder = XD.map2 Point
|
timeDecoder : XD.Decoder Time.Posix
|
||||||
|
timeDecoder = XD.andThen (\ts ->
|
||||||
|
case Iso8601.toTime ts of
|
||||||
|
Result.Ok time -> XD.succeed time
|
||||||
|
Result.Err f -> XD.fail "err"
|
||||||
|
)
|
||||||
|
XD.string
|
||||||
|
|
||||||
|
pointDecoder = XD.map4 Point
|
||||||
(floatAttr "lat")
|
(floatAttr "lat")
|
||||||
(floatAttr "lon")
|
(floatAttr "lon")
|
||||||
|
(path ["ele"] (single XD.float))
|
||||||
|
(path ["time"] (single timeDecoder))
|
||||||
|
|
||||||
|
|
||||||
gpxDecoder =
|
gpxDecoder =
|
||||||
(path [ "trk", "trkseg", "trkpt" ] (list pointDecoder))
|
(path [ "trk", "trkseg", "trkpt" ] (list pointDecoder))
|
||||||
|
@ -4,6 +4,7 @@ import Fixtures
|
|||||||
import Track exposing (Track, Point)
|
import Track exposing (Track, Point)
|
||||||
import Test exposing (..)
|
import Test exposing (..)
|
||||||
import Expect exposing (Expectation)
|
import Expect exposing (Expectation)
|
||||||
|
import Time
|
||||||
|
|
||||||
specs: Test
|
specs: Test
|
||||||
specs =
|
specs =
|
||||||
@ -13,9 +14,9 @@ specs =
|
|||||||
let
|
let
|
||||||
r = Track.parse Fixtures.threepoints
|
r = Track.parse Fixtures.threepoints
|
||||||
expected =
|
expected =
|
||||||
[ (Point 51.600643 -0.01856)
|
[ (Point 51.600643 -0.01856 64.8 (Time.millisToPosix 1729669252256))
|
||||||
, (Point 51.600679 -0.018179)
|
, (Point 51.600679 -0.018179 65.5 (Time.millisToPosix 1729669255259))
|
||||||
, (Point 51.600697 -0.018064)
|
, (Point 51.600697 -0.018064 66.2 (Time.millisToPosix 1729669256231))
|
||||||
]
|
]
|
||||||
|
|
||||||
in
|
in
|
||||||
|
Loading…
Reference in New Issue
Block a user