Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mapnik/node-mapnik
Bindings to mapnik for node.js
https://github.com/mapnik/node-mapnik
Last synced: 3 days ago
JSON representation
Bindings to mapnik for node.js
- Host: GitHub
- URL: https://github.com/mapnik/node-mapnik
- Owner: mapnik
- License: bsd-3-clause
- Created: 2010-11-16T04:00:45.000Z (about 14 years ago)
- Default Branch: master
- Last Pushed: 2024-12-29T12:20:46.000Z (13 days ago)
- Last Synced: 2025-01-02T02:06:30.046Z (10 days ago)
- Language: C++
- Homepage: http://mapnik.org/documentation/node-mapnik
- Size: 21.1 MB
- Stars: 535
- Watchers: 32
- Forks: 166
- Open Issues: 101
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-vector-tiles - node-mapnik - Node.js API for vector tiles which depends on `mapnik-vector-tile` (Parsers & Generators)
README
# node-mapnik
Bindings to [Mapnik](http://mapnik.org) for [node](http://nodejs.org).
## Usage
Render a map from a stylesheet:
```js
const fs = require('node:fs');
const mapnik = require('@mapnik/mapnik');// register fonts and datasource plugins
mapnik.register_default_fonts();
mapnik.register_default_input_plugins();var map = new mapnik.Map(256, 256);
map.load('./test/stylesheet.xml', function(err,map) {
if (err) throw err;
map.zoomAll();
var im = new mapnik.Image(256, 256);
map.render(im, function(err,im) {
if (err) throw err;
im.encode('png', function(err,buffer) {
if (err) throw err;
fs.writeFile('map.png',buffer, function(err) {
if (err) throw err;
console.log('saved map image to map.png');
});
});
});
});
```Convert a jpeg image to a png:
```js
var mapnik = require('@mapnik/mapnik');
new mapnik.Image.open('input.jpg').save('output.png');
```Convert a shapefile to GeoJSON:
```js
const fs = require('node:fs');
const path = require('node:path');
const mapnik = require('@mapnik/mapnik');mapnik.register_datasource(path.join(mapnik.settings.paths.input_plugins,'shape.input'));
var ds = new mapnik.Datasource({type:'shape',file:'test/data/world_merc.shp'});
var featureset = ds.featureset()
var geojson = {
"type": "FeatureCollection",
"features": [
]
}
var feat = featureset.next();
while (feat) {
geojson.features.push(JSON.parse(feat.toJSON()));
feat = featureset.next();
}
fs.writeFileSync("output.geojson",JSON.stringify(geojson,null,2));
```For more sample code see [the tests](./test) and [sample code](https://github.com/mapnik/node-mapnik-sample-code).
## Requirements
Starting from `v4.6.0`, `node-mapnik` module is published as "universal" binaries on [GitHub NPM registry](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-npm-registry) and [npmjs](https://www.npmjs.com) using [node-addon-api](https://github.com/nodejs/node-addon-api),
[node-gyp-build](https://github.com/prebuild/node-gyp-build) and [prebuildify](https://github.com/prebuild/prebuildify)Currently supported platforms are
* `linux-x64`
* `linux-arm64` (from v4.6.5)
* `darwin-x64`
* `darwin-arm64`Consult N-API documentation for more details: https://nodejs.org/dist/latest/docs/api/n-api.html#n_api_node_api_version_matrix
## Installing
### With npm
```bash
npm install @mapnik/mapnik
```
Note: If using GitHub NPM registry consult "[Installing a package](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-npm-registry#installing-a-package)
". You will need to authenticate to GitHub Packages, see "[Authenticating to GitHub Packages](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-npm-registry#authenticating-to-github-packages)."* Check for config file `[.npmrc](https://docs.npmjs.com/cli/v10/configuring-npm/npmrc)`, create a new .npmrc file if one doesn't exist.
* Edit the .npmrc file to include the following lines, replacing TOKEN with your personal access token.
```bash
@mapnik:registry=https://npm.pkg.github.com
//npm.pkg.github.com/:_authToken=XXXXXXXXXXXXXXXXXXXXXXXXX
```
Note: This will install the latest node-mapnik 4.6.x series, which is recommended.### Source Build [WIP]
On macOS and Linux:
* Ensure `mapnik-config` program is available and on your `${PATH}`.
* `npm install --build-from-source`
* To "prebuild" binaries `npm run prebuildify`
#### Note on SSE:
SSE support is enabled by default on `x86_64`.
## Using node-mapnik from your node app
To require node-mapnik as a dependency of another package put in your package.json:
"dependencies" : { "@mapnik/mapnik":"*" } // replace * with a given semver version string
## Tests
To run the tests do:
npm test
## License
BSD, see LICENSE.txt