A TileStrata plugin for retrieving Mapbox Vector Tiles from a PostGIS database.
$ npm install tilestrata-postgismvt --save
Serve all map features.
var postgismvt = require('tilestrata-postgismvt');
server.layer('mylayer').route('tile.mvt')
.use(postgismvt({
lyr: {
table: 'schema.table',
geometry: 'geom',
type: 'circle',
srid: 4326,
minZoom: 3,
maxZoom: 19,
buffer: 10
fields: 'name gid',
resolution: 256,
},
pgConfig: {
host: 'localhost',
user: 'postgres',
password: 'mypassword',
database: 'postgres',
port: '5432'
}}))
);
Clustering can be used for point features sharing a coordinate in the tile coordinate space. Each feature contains an attribute count that can be used e. g. for a density map.
cluster: Attributes will be dropped.
server.layer('mylayer').route('tile.mvt')
.use(postgismvt({
lyr: {
...
mode: 'cluster'
},
pgConfig: {
...
}}))
);
cluster_fields: Attributes will be concatenated.
server.layer('mylayer').route('tile.mvt')
.use(postgismvt({
lyr: {
...
mode: 'cluster_fields'
},
pgConfig: {
...
}}))
);
resolution and mode both support a function as a parameter. The following configuration serves attributes in higher zoom levels only and increases the spatial accuracy.
server.layer('mylayer').route('tile.mvt')
.use(postgismvt({
lyr: {
resolution: function(server, req) {
if (req.z > 12) return 512;
return 256;
},
mode: function(server, req) {
if (req.z > 15) return null;
if (req.z > 13) return 'cluster_fields';
return 'cluster';
}
},
pgConfig: {
...
}}))
);
- PostGIS 2.4.0
- TileBBox.sql
Copyright © 2017 Stefan Zimmer
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at: http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.