English / 日本語
Renders a simple circle on a MapLibre GL JS map.
This library is intended to work with MapLibre GL JS v5.x. (The latest version was developed with v5.6.2.)
Please run the following command:
npm install https://github.com/codemonger-io/maplibre-geo-circle-layer.git#v0.1.0Whenever commits are pushed to the main branch, a developer package is published to the npm registry managed by GitHub Packages.
A developer package bears the next release version but followed by a dash (-) plus the short commit hash; e.g., 0.1.0-abc1234 where abc1234 is the short commit hash of the commit used to build the package (snapshot).
You can find developer packages here.
To install a developer package, you need to configure a classic GitHub personal access token (PAT) with at least the read:packages scope.
Below briefly explains how to configure a PAT.
Please refer to the GitHub documentation for more details.
Once you have a PAT, please create a .npmrc file in your home directory with the following contents (please replace $YOUR_GITHUB_PAT with your PAT):
//npm.pkg.github.com/:_authToken=$YOUR_GITHUB_PAT
In the root directory of your project, create another .npmrc file with the following contents:
@codemonger-io:registry=https://npm.pkg.github.com
Then you can install a developer package with the following command:
npm install @codemonger-io/[email protected]Please replace abc1234 with the short commit hash of the snapshot you want to install.
The following snippet adds a custom layer (id="example-circle") that renders a transparent blue circle with the radius of 100 meters around Tokyo Station:
import { GeoCircleLayer } from '@codemonger-io/maplibre-geo-circle-layer';
// suppose map: maplibre-gl.Map
map.addLayer(new GeoCircleLayer('example-circle', {
    radiusInMeters: 100,
    center: { lng: 139.7671, lat: 35.6812 },
    fill: { red: 0.5, green: 0.5, blue: 1, alpha: 0.5 },
}));You will see something like the following,

There is an example project in the example folder.
You can change the following properties of a GeoCircleLayer after creating it.
- radiusInMeters: radius in meters of the circle
- center: center of the circle
- fill: fill color of the circle
- numTriangles: number of triangles to approximate a circle
If you change any of the above properties, GeoCircleLayer triggers repaint of the map.
Please refer to the api-docs/markdown folder.
Node.js version 14 or higher is required to build this library.
pnpm install --frozen-lockfilepnpm buildpnpm build:docThis also runs pnpm build.
You can run a type checker without building the library.
pnpm type-checkpnpm testGitHub Actions that builds and verifies the target will start when a pull-request or push is initiated to the main branch.
MapLibre GL JS has a built-in circle layer. It can render multiple circles on a layer, but you have to specify radiuses in pixels (screen units). So it is not suitable for rendering a shape that circles a geographical area.
maplibre-gl-draw-circle offers more features than maplibre-geo-circle-layer does.
For instance, maplibre-gl-circle has an optional feature that enables interactive editing of circles.
You might prefer maplibre-geo-circle-layer for simplicity.