[gnome-maps/wip/routing: 4/8] Add EPAF decoder
- From: Mattias Bengtsson <mattiasb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-maps/wip/routing: 4/8] Add EPAF decoder
- Date: Wed, 28 Aug 2013 01:13:01 +0000 (UTC)
commit af6b68a5546d8de2846c38dc48d7e23832ac2990
Author: Mattias Bengtsson <mattias jc bengtsson gmail com>
Date: Sat Aug 24 02:22:35 2013 +0200
Add EPAF decoder
Add a decoder for Encoded Polyline Algorithm Format (EPAF).
EPAF is a Google format for space efficient serialization of
coordinate series. Both OSRM and GraphHopper uses it for encoding
their routes.
src/Makefile-js.am | 1 +
src/polyline.js | 75 ++++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 76 insertions(+), 0 deletions(-)
---
diff --git a/src/Makefile-js.am b/src/Makefile-js.am
index 6eff717..d1ccdb6 100644
--- a/src/Makefile-js.am
+++ b/src/Makefile-js.am
@@ -6,6 +6,7 @@ dist_js_DATA = \
mapLocation.js \
mapView.js \
path.js \
+ polyline.js \
route.js \
routeService.js \
sidebar.js \
diff --git a/src/polyline.js b/src/polyline.js
new file mode 100644
index 0000000..01dceb3
--- /dev/null
+++ b/src/polyline.js
@@ -0,0 +1,75 @@
+/* -*- Mode: JS2; indent-tabs-mode: nil; js2-basic-offset: 4 -*- */
+/* vim: set et ts=4 sw=4: */
+/*
+ * Copyright (c) 2013 Mattias Bengtsson.
+ *
+ * GNOME Maps is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * GNOME Maps is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with GNOME Maps; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Author: Mattias Bengtsson <mattias jc bengtsson gmail com>
+ */
+
+// Google encoded polyline decoder
+// https://developers.google.com/maps/documentation/utilities/polylinealgorithm
+
+const Champlain = imports.gi.Champlain;
+
+const decode = (function() {
+
+ function _decodeValue(data, index) {
+ let b;
+ let shift = 0;
+ let value = 0;
+
+ do {
+ // 63 added to keep string printable
+ b = data.charCodeAt(index++) - 63;
+
+ // Get 5 bits at a time until hit the end of value
+ // (which is not OR'd with 0x20)
+ value |= (b & 0x1f) << shift;
+ shift += 5;
+ } while (b >= 0x20);
+
+ // negative values are encoded as two's complement
+ let ret_val = ((value & 1) ? ~(value >> 1) : (value >> 1));
+ return [ret_val, index];
+ }
+
+ function decode(data) {
+ let length = data.length;
+ let polyline = [];
+ let index = 0;
+ let lat = 0;
+ let lon = 0;
+
+ while (index < length) {
+ let latdelta, londelta;
+
+ [latdelta, index] = _decodeValue(data, index);
+ [londelta, index] = _decodeValue(data, index);
+
+ // first value is absolute, rest are relative to previous value
+ lat += latdelta;
+ lon += londelta;
+ polyline.push(new Champlain.Coordinate({
+ latitude: lat * 1e-5,
+ longitude: lon * 1e-5
+ }));
+ }
+ return polyline;
+ }
+
+ return decode;
+})();
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]