emcconville/google-map-polyline-encoding-tool

A simple class to handle polyline-encoding for Google Maps

Installs: 7 039

Dependents: 0

Stars: 36

Watchers: 4

Forks: 16

Open Issues: 3

Language: PHP

v1.2.4 2015-01-04 02:49 UTC

README

Build Status Coverage Status

A simple PHP class for translating polyline into an encoded strings for Google Maps.

Install

Use composer.

$ curl -sS https://getcomposer.org/installer | php
$ cat > composer.json <<EOF
{
   "require": {
      "emcconville/google-map-polyline-encoding-tool" : ">=1.2.1"
   }
}
EOF
$ php composer.phar install

Old fashion way.

$ git clone git://github.com/emcconville/google-map-polyline-encoding-tool.git
$ make
$ cp dist/Polyline.php /path/to/your/application/includes/Polyline.php

Usage

Encoding

// Points to encode
$points = array(
        array(41.89084,-87.62386),
        array(41.89086,-87.62279),
        array(41.89028,-87.62277),
        array(41.89028,-87.62385),
        array(41.89084,-87.62386)
    );

$encoded = Polyline::Encode($points);
//=> wxt~Fd`yuOCuErBC?vEoB@

Tribune

Decoding

// String to decode
$encoded = "kiw~FpoavObBA?fAzEC";

$points = Polyline::Decode($encoded);
//=> array(
//     41.90374,-87.66729,41.90324,-87.66728,
//     41.90324,-87.66764,41.90214,-87.66762
//   );

// Or list of tuples
$points = Polyline::Pair($points);
//=> array(
//     array(41.90374,-87.66729),
//     array(41.90324,-87.66728),
//     array(41.90324,-87.66764),
//     array(41.90214,-87.66762)
//   );

Records

Examples

See examples directory for creative ideas, and please contribute new use-cases / hacks.

Specify precision

Precision defaults to 1e-5 (0.00001) which is expected by Google Map API. Other API's like OSRM expect a precision of 1e-6. You can adjust the precision you want by sub-classing Polyline, and overwrite the $precision static property.

class PolylineOSRM extends Polyline
{
    protected static $precision = 6;
}
$points = PolylineOSRM::Decode($line);
$line = PolylineOSRM::Encode($points);

Caution

  • Adjusting the precision level will not guarantee improved accuracy. Existing issues with PHP's internal float point arithmetic can contribute accuracy issues.
  • Third party libraries will not automatically know what level of precision was used during encoding.

Namespace

By default, no namespace is defined. If a user wishes to have this library under a namespace, simply run the following.

$ make namespace

This will copy a namespace-enabled version to dist/emcconville/Polyline.php. Behavior & usage are preserved.

use emcconville\Polyline as GooPly;
$gooString = GooPly::decode($points);

Family

This library exists as a PHP reference point for Google's Encoded Polyline Algorithm Format. There is also a C implementation, and a namespace/trait library under active development.

Requires google-map-polyline-encoding-tool polyline-encoder php_polyline PHP 5.3 5.4 C-API Supports google-map-polyline-encoding-tool polyline-encoder php_polyline Google ✔ ✔ ✔ Bing ✔ Precision ✔ ✔ ✔ Tuple ✔ ✔ Traits ✔ Abstraction ✔ Hosted google-map-polyline-encoding-tool polyline-encoder php_polyline Github ✔ ✔ Bitbucket ✔ ✔