Rand Stats

Map::Leaflet

zef:bduggan

Actions Status Actions Status

NAME

Map::Leaflet - Generate maps using leaflet.js

SYNOPSIS

use Map::Leaflet;

my $map = Map::Leaflet.new;
$map.add-marker({ :lat(40.7128), :lon(-74.0060) }, "New York City");
$map.add-marker({ :lat(40.7589), :lon(-73.9851) }, "Empire State Building");
$map.add-marker({ :lat(40.7267), :lon(-73.9815) }, "Tompkins Square Park");

$map.add-geojson(q:to/GEOJSON/);
{
  "type": "Feature",
  "geometry": {
    "type": "LineString",
    "coordinates": [
      [-74.0060, 40.7128],
      [-73.9851, 40.7589],
      [-73.9815, 40.7267],
      [-74.0060, 40.7128]
    ]
  }
}
GEOJSON

spurt "map.html", $map.generate-page;

output

DESCRIPTION

Generate HTML that renders a map, using the excellent leaflet.js library.

The Map::Leaflet class represents a map which can be rendered as HTML. Use a map object to create objects which are analagous to their javascript counterparts, and then render the entire page to generate the javascript.

There are default values for many of the leaflet objects, in an attempt to make common cases work more easily out of the box.

METHODS

new

my $map = Map::Leaflet.new;
my $map = Map::Leaflet.new(
    center => { :lat(40.7128), :lon(-74.0060) },
    zoom => 13
);

Constructor. If no center is specified, then bounds are computed, and the starting view will have a zoom level and extents that fit all of the layers that have been added.

Other options to the constructor are:

title

The title of the HTML page. Defaults to 'Map'.

center

A hash with lat and lon keys.

zoom

The zoom level (integer).

width, height

The height and width of the map. Defaults to 95vw and 95vh, respectively.

extra-css

Extra CSS to include in the HTML. The default adds a border, centers the map, and provides a class for div-icons.

tile-provider

The tile provider to use. Defaults to 'CartoDB.Positron'. For a complete list of providers, see https://leaflet-extras.github.io/leaflet-providers/preview/.

Here are a few of the providers listed: CartoDB.Positron, OpenStreetMap.Mapnik, Esri.WorldstreetMap

leaflet-version, leaflet-providers-version

The version of leaflet.js and leaflet-providers.js to use. Defaults to 1.9.4 and 1.13.0, respectively.

add-marker

$map.add-marker({ :lat(40.7128), :lon(-74.0060) }, "New York City");

Add a marker. The first argument is a hash with lat and lon keys, and the second argument is an optional popup text. See create-marker below for a more flexible way to create markers.

create-div-icon

my $div-icon = $map.create-div-icon(html => '<b>New York City</b>');
my $div-icon = $map.create-div-icon: html => '<b>Paris</b>', iconSize => 'auto', className => 'mlraku-div-icon';

Create a divIcon. Accepts all of the leaflet.js options. See https://leafletjs.com/reference.html#divicon. Defaults to auto-sizing, a yellow background, and a black border, and a class of 'mlraku-div-icon'.

Also accepts a name option, which is used to name the icon in the javascript (defaults to an auto-generated name).

Returns a Map::Leaflet::DivIcon object.

create-icon

my $icon = $map.create-icon(iconUrl => 'https://leafletjs.com/examples/custom-icons/leaf-green.png');
my $icon = $map.create-icon: iconUrl => 'https://leafletjs.com/examples/custom-icons/leaf-green.png', iconSize => '[38, 95]';

Create an icon. Accepts all of the leaflet.js options. See https://leafletjs.com/reference.html#icon. Note that the iconSize, iconAnchor, popupAnchor, and tooltipAnchor are all PointStr objects, which can be either a string of the form "[x, y]" or the string "auto".

create-marker

$map.create-marker(latlng => [ $lat, $lon ], options => %( icon => $icon ));
$map.create-marker: latlng => [ $lat, $lon ], options => %( title => 'New York City', popup-text => 'The Big Apple' );

Create a marker. Accepts all of the leaflet.js options. See https://leafletjs.com/reference.html#marker. Also accepts popup-text as an option to generate a popup that is bound to the marker.

Defaults to False values for autoPan and autoPanFocus.

add-geojson

$map.add-geojson($geojson, $style);
$map.add-geojson(q:to/GEOJSON/);
{
  "type": "Feature",
  "geometry": {
    "type": "LineString",
    "coordinates": [
      [-74.0060, 40.7128],
      [-73.9851, 40.7589],
      [-73.9815, 40.7267],
      [-74.0060, 40.7128]
    ]
  }
}
GEOJSON
$map.add-geojson(
  %( :type<Feature>, :geometry(
    %( :type<LineString>, :coordinates(
      [
        [-74.0060, 40.7128],
        [-73.9851, 40.7589],
        [-73.9815, 40.7267],
        [-74.0060, 40.7128]
      ]
    ))
  )),
  style => { :color<red> }
);

Add a GeoJSON layer. $geojson can be a string or a hash. $style is optional and can also be a string or a hash.

generate-page

spurt "map.html", $map.generate-page;

Generate a complete HTML page for the map (including html, head, body, etc.). Returns a string.

SEE ALSO

https://leafletjs.com/

AUTHOR

Brian Duggan