[gnome-maps/wip/routing2: 3/9] Add EPAF decoder
- From: Mattias Bengtsson <mattiasb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-maps/wip/routing2: 3/9] Add EPAF decoder
- Date: Sun, 20 Apr 2014 03:38:23 +0000 (UTC)
commit a0ef9a7298083e5a23e0eb9f8486d70cb363d42a
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/epaf.js | 71 +++++++++++++++++++++++++++++++++++++++
src/gnome-maps.js.gresource.xml | 1 +
2 files changed, 72 insertions(+), 0 deletions(-)
---
diff --git a/src/epaf.js b/src/epaf.js
new file mode 100644
index 0000000..f96866d
--- /dev/null
+++ b/src/epaf.js
@@ -0,0 +1,71 @@
+/* -*- 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: Jussi Kukkonen <jku goto fi>
+ * Mattias Bengtsson <mattias jc bengtsson gmail com>
+ */
+
+// Google encoded polyline decoder
+// https://developers.google.com/maps/documentation/utilities/polylinealgorithm
+
+const Champlain = imports.gi.Champlain;
+
+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;
+}
diff --git a/src/gnome-maps.js.gresource.xml b/src/gnome-maps.js.gresource.xml
index 1770331..9173c9e 100644
--- a/src/gnome-maps.js.gresource.xml
+++ b/src/gnome-maps.js.gresource.xml
@@ -13,6 +13,7 @@
<file>notification.js</file>
<file>path.js</file>
<file>placeStore.js</file>
+ <file>epaf.js</file>
<file>route.js</file>
<file>routeService.js</file>
<file>searchPopup.js</file>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]