time_aware_polyline 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/time_aware_polyline.rb +112 -0
  3. metadata +86 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: c5071a8a176e610fb30a11a2130c8e5170a8637544cb9cb225fb3760d3fec3f4
4
+ data.tar.gz: 6814832f43ec1e6f2af55a9f8661dc3f61a429df06131f67c6de13117708ecd4
5
+ SHA512:
6
+ metadata.gz: f3455e13c04da0a9a6cadff274a2d67efa9fe996a011de37063caf12d8df298c639cbe97adc72d3ab5cd175bee954d84a381bcfc81a173742918b40a646dc2b8
7
+ data.tar.gz: fe66761454fad0fb67e8aa31f15995b59123ff4aa83ec6c9c9a0342101532bd8e61091daf33ece31cad2c0db94e6624987aaa4f9d5aa2d459f408b293ff91642
@@ -0,0 +1,112 @@
1
+ module TimeAwarePolyline
2
+ require "time"
3
+ GPX_TIME_FORMAT = "%FT%T%:z".freeze # 2016-07-21T05:43:09+00:00
4
+
5
+ def self.encode_time_aware_polyline(gpx_logs)
6
+ _extend_time_aware_polyline(:gpx_logs => gpx_logs)
7
+ end
8
+
9
+ def self.decode_time_aware_polyline(polyline)
10
+ gpx_logs = []
11
+ index = 0
12
+ latitude = 0
13
+ longitude = 0
14
+ time_stamp = 0
15
+ while index < polyline.size
16
+ index, latitude_part, longitude_part, time_part = _decode_lat_lng_time_from_polyline(polyline, index)
17
+ latitude += latitude_part
18
+ longitude += longitude_part
19
+ time_stamp += time_part
20
+ gpx_log = _get_gpx_from_decoded(latitude, longitude, time_stamp)
21
+ gpx_logs.push(gpx_log)
22
+ end
23
+ gpx_logs
24
+ end
25
+
26
+ def self._get_time_for_polyline(iso_time)
27
+ Time.parse(iso_time).to_i
28
+ end
29
+
30
+ def self._get_time_from_polyline(int_representation)
31
+ Time.at(int_representation).utc.strftime(GPX_TIME_FORMAT)
32
+ end
33
+
34
+ def self._get_coordinate_for_polyline(coordinate)
35
+ (coordinate * 100_000.0).round(0).to_i
36
+ end
37
+
38
+ def self._get_coordinate_from_polyline(int_representation)
39
+ (int_representation * 1e-05).round(5)
40
+ end
41
+
42
+ def self._get_gpx_for_polyline(gpx)
43
+ [_get_coordinate_for_polyline(gpx[0]), _get_coordinate_for_polyline(gpx[1]), _get_time_for_polyline(gpx[2])]
44
+ end
45
+
46
+ def self._get_gpx_from_decoded(lat_rep, lon_rep, time_stamp_rep)
47
+ [_get_coordinate_from_polyline(lat_rep), _get_coordinate_from_polyline(lon_rep), _get_time_from_polyline(time_stamp_rep)]
48
+ end
49
+
50
+ def self._extend_time_aware_polyline(polyline: "", gpx_logs: nil, last_gpx_log: nil)
51
+ if last_gpx_log.nil?
52
+ last_latitude = 0
53
+ last_longitude = 0
54
+ last_time = 0
55
+ else
56
+ last_latitude, last_longitude, last_time = _get_gpx_for_polyline(last_gpx_log)
57
+ end
58
+ if polyline.nil?
59
+ polyline = ""
60
+ end
61
+ if gpx_logs.nil?
62
+ return polyline
63
+ end
64
+
65
+ gpx_logs.each do |gpx_log|
66
+ latitude, longitude, time_stamp = _get_gpx_for_polyline(gpx_log)
67
+ delta_latitude = latitude - last_latitude
68
+ delta_longitude = longitude - last_longitude
69
+ delta_time = time_stamp - last_time
70
+
71
+ _add_value_to_polyline(delta_latitude, polyline)
72
+ _add_value_to_polyline(delta_longitude, polyline)
73
+ _add_value_to_polyline(delta_time, polyline)
74
+
75
+ last_latitude = latitude
76
+ last_longitude = longitude
77
+ last_time = time_stamp
78
+ end
79
+ polyline
80
+ end
81
+
82
+ def self._add_value_to_polyline(value, polyline)
83
+ value = value.negative? ? ~(value << 1) : value << 1
84
+ while value >= 32
85
+ polyline << ((32 | (value & 31)) + 63).chr
86
+ value >>= 5
87
+ end
88
+ polyline << (value + 63).chr
89
+ polyline
90
+ end
91
+
92
+ def self._decode_lat_lng_time_from_polyline(polyline, index)
93
+ index, latitude_part = _get_decoded_dimension_from_polyline(polyline, index)
94
+ index, longitude_part = _get_decoded_dimension_from_polyline(polyline, index)
95
+ index, time_part = _get_decoded_dimension_from_polyline(polyline, index)
96
+ [index, latitude_part, longitude_part, time_part]
97
+ end
98
+
99
+ def self._get_decoded_dimension_from_polyline(polyline, index)
100
+ result = 1
101
+ shift = 0
102
+ b = nil
103
+ while b.nil? || b >= 31
104
+ b = (polyline[index].ord - 63) - 1
105
+ index += 1
106
+ result += b << shift
107
+ shift += 5
108
+ end
109
+ result = (result & 1).zero? ? result : ~result
110
+ [index, result >> 1]
111
+ end
112
+ end
metadata ADDED
@@ -0,0 +1,86 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: time_aware_polyline
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.2.1
5
+ platform: ruby
6
+ authors:
7
+ - Root
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2020-03-05 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rspec
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ description:
56
+ email:
57
+ - devs@joinroot.com
58
+ executables: []
59
+ extensions: []
60
+ extra_rdoc_files: []
61
+ files:
62
+ - lib/time_aware_polyline.rb
63
+ homepage: https://github.com/Root-App/time_aware_polyline
64
+ licenses:
65
+ - MIT
66
+ metadata: {}
67
+ post_install_message:
68
+ rdoc_options: []
69
+ require_paths:
70
+ - lib
71
+ required_ruby_version: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ required_rubygems_version: !ruby/object:Gem::Requirement
77
+ requirements:
78
+ - - ">="
79
+ - !ruby/object:Gem::Version
80
+ version: '0'
81
+ requirements: []
82
+ rubygems_version: 3.0.3
83
+ signing_key:
84
+ specification_version: 4
85
+ summary: Time aware ployline
86
+ test_files: []