0.1.2 • Published 7 years ago

leaflet-base64-legend v0.1.2

Weekly downloads
2
License
ISC
Repository
github
Last release
7 years ago

Leaflet.Base64Legend

A simple Leaflet plugin for showing legends with base64 elements.

Under active development!

See the example.

Tested with Leaflet 1.1.0

Install

From NPM:

npm install leaflet-base64-legend

Usage

Include the CSS:

<link rel="stylesheet" href="L.Control.Base64Legend.css" />

Include the JavaScript:

<script src="L.Control.Base64Legend-min.js"></script>

Options:

{
    position: 'topright',
    legends: [],   // array of legend entries - see README for format
    collapseSimple: false,  // if true, legend entries that are from a simple renderer will use compact presentation
    detectStretched: false  // if true, will test to see if legend entries look stretched.  These are usually in sets of 3 with the middle element having no label.
}

Inputs are an array of legends. Each legend has:

  • name
  • array of elements
  • type (optional). Options: 'stretched', null or absent

Each element has:

  • imageData: base64 encoded image data URI
  • label (optional)

Simple example:

var legends = [{
    "name": "A simple element",
    "elements": [{"imageData": ""}]
}];

var legend = L.control.base64legend({
    position: 'topright',
    legends: legends,
    collapseSimple: true
});

map.addControl(legend);

Categorical example:

var legends = [{
    "name": "A longer legend",
    "elements": [{
        "imageData": "",
        "label": "Alabama"
    }, {
        "imageData": "",
        "label": "Alaska"
    },
    ...
}];

Stretched example. Stretched legends use a compact display:

var legends = [{
    "name": "stretched legend",
    "type": "stretched",
    "elements": [
        {"label": "High : 4", "imageData": ""},
        {"label": "", "imageData": ""},
        {"label": "Low : 0", "imageData": ""}
    ]
}];

You can also have the plugin auto-detect stretched legends. Typically, these are identified by legends 3 elements long, where the label for the middle element is blank.

var legend = L.control.base64legend({
    ...
    detectStretched: true
});

Contributors:

0.1.2

7 years ago

0.1.1

7 years ago