- More precise angle computation for line labels
- Add support for
"text-keep-upright": false
- Fix
text-field
value issues - Update examples and add references to MapLibre
- Fix issue with missing
expandUrl
from OpenLayers
- Adjust
MapboxVectorLayer
type generics for OpenLayers v10
- Remove polyfill.io from examples, no code changes
- Type updates for OpenLayers 9.2.x
- Make minZoom inclusive by zoom instead of resolution internally
- Improved docs and examples
- Avoid
document.createElement()
for more web worker friendliness
- Use point resolution for hillshade calculation
- Fix layer minzoom
- Add webfonts option to override ol:webfonts
- Properly handle fractional layer minzoom and maxzoom
- Generous peer dependency range for ol
- Fall back to default icon-color when drawing SDF
- Fix zIndex of background layer when applying style to an existing map
- Use correct
line-color
andbackground-color
defaults - Add support for
circle-translate
- Do not throw when style contains an unsupported layer type
- Fix rendering for zero text halo
- Fix scaling of
icon-offset
- Allow computed values for
text-tranform
- Add support for
text-ignore-placement
andtext-allow-overlap
- Consider the
icon-size
layout property also for icons not provided by the stylesheet - Handle fractional layer
minzoom
andmaxzoom
properly when fetching source data
- New 'updateMapboxSource()' utility function.
- Accept
Promise
as return type fortransformRequest()
- Do not overwrite existing search param with access token
- The
transformRequest
hook is now called for every singleTiles
request with the final url, instead of just once with the url template. - Generated OpenLayers Tile and VectorTile sources previously used the template urls obtained by
source.getUrl()
orsource.getUrls()
. Now they use atileLoadFunction
configured by ol-mapbox-style instead. - Generated OpenLayers Vector sources are now always configured with a
loader
by ol-mapbox-style. ThegetUrl()
method will return the url without thetransformRequest
transform. When the url is templated ({bbox-...}
),getUrl()
will returnundefined
.
- The
transformRequest
hook now also accepts a url string as return value. When aRequest
is returned, it will be fully respected - not just the request'surl
.
- More ol versions included in peer dependency version range
- Make
ol
a peer dependency
- Use ol >= 7.x || v8.0.0-dev to allow deduping
- The ol-mapbox-style package now contains untranspiled modern JavaScript code. When targeting older browsers, make sure to configure your build tools to transpile the code accordingly.
- New
MapboxVectorLayer
export, which replacesol/layer/MapboxVector
from OpenLayers.
- Small fixes for add/update/removeMapboxLayer
- Support for SDF sprites
- Improved documentation for
applyStyle
addMapboxLayer()
can now also add a layer as first layer in the layer stack.addMapboxLayer()
is no longer restricted go layers with the same source.
- Add terrarium hillshade example
- Add getStyleForLayer() function for more efficient legend creation without
recordStyleLayer(true)
ol-mapbox-style no longer defaults to loading Google fonts when a required font is not available. Instead, it respects the new metadata.ol:webfonts
field in the Mapbox Style document. Example:
{
"version": 8,
"metadata": {
"ol:webfonts": "https://mytileservergl.com/fonts/{font-family}/{fontweight}{-fontstyle}.css"
}
// ...
}
The supported template placeholders are
- {font-family}: CSS font family converted to lowercase, blanks replaced with
-
, e.g.noto-sans
- {Font+Family}: CSS font family in original case, blanks replaced with
+
, e.g.Noto+Sans
- {fontweight}: CSS font weight (numeric), e.g.
400
,700
- {fontstyle}: CSS font style, e.g.
normal
,italic
- {-fontstyle}: CSS font style other than normal, e.g.
-italic
or empty string for normal
In addition to providing fonts along with the style, this can be used to retrieve fonts from a CDN (e.g. @fontsource
) or Google fonts. If this metadata field is not set to the style, the following default template will be used:
https://cdn.jsdelivr.net/npm/@fontsource/{font-family}/{fontweight}{-fontstyle}.css
To retain the current behavior (i.e. use Google Fonts), the template URL will have to be
https://fonts.googleapis.com/css?family={Font+Family}:{fontweight}{fontstyle}
- Fix a potential tile cache issue
- Fix problem caused by
getUid
function missing in the full build - Make
updateMapboxStyle()
work with objects that are not a reference to the original one - Add support for the
tms
tile scheme forraster
andvector
layers - Add support for the
terrarium
encoding forraster-dem
sources - Fix an issue where the
icon-offset
layout property modifies the underlying Mapbox Style object - Set the correct input projection for
geojson
sources when theprojection
option is used
- Fix addMapboxLayer - updateMapboxLayer - removeMapboxLayer sequence
- Fix
updateMapboxLayer()
and function/filter cache handling
- Export
removeMapboxLayer
- Fix initial visibility of
vector
andgeojson
source layers
- Add support for
symbol-placement: "line-center"
- Add support for the
"id"
expression
- New
removeMapboxLayer()
function - Substantial fixes to the
addMapboxLayer()
function - Manage OpenLayers layer visibility based on the visibility of its Mapbox layers
Previously, the {bbox-epsg-3857}
and {bbox-epsg-[custom projection srs code]}
template replacement included the projection's SRS identifier, e.g. 1234,4567,4321,7654,EPSG:9876
. Now, the template replacement just includes the bounding box. This means that e.g. WFS source URLs need to be changed in the Mapbox style.
If you previously had a source definition like
{
"type": "geojson",
"data": "https://ahocevar.com/geoserver/wfs?service=WFS&version=1.1.0&request=GetFeature&typename=osm:water_areas&outputFormat=application/json&srsname=EPSG:4326&bbox={bbox-epsg-3857}"
}
you have to change it to
{
"type": "geojson",
"data": "https://ahocevar.com/geoserver/wfs?service=WFS&version=1.1.0&request=GetFeature&typename=osm:water_areas&outputFormat=application/json&srsname=EPSG:4326&bbox={bbox-epsg-3857},EPSG:3857"
}
The reason for this breaking change is compatibility with OCG API Features and other services that do not accept the SRS identifier as additional BBOX parameter.
- Improved icon halo - now looks the same as text halo
- New API for working with layer style objects and updating the rendered style
- Improved access token handling for the Mapbox example
- New
updateSource
option onapplyStyle()
for keeping pre-configured OpenLayers sources - Fix
mapbox-layers
array forraster
orraster-dem
layers that share the same source - Support for
paint
propertiesicon-halo-color
andicon-halo-width
- Support for projections, using the new
projection
option
- Add support for labels with
symbol-spacing
- Fix background bleeding issue when re-applying style
- Add support for
hillshade-highlight-color
andhillshade-shadow-color
- Fix geojson layers with
bbox
in combination withtransformRequest
- Fix tilejson loading when using same source in different styles at the same time
- Update documentation for
getLayer()
andgetSource()
forLayerGroup
support - Update
getLayers()
to work withLayerGroup
s - Make
transformRequest
option work for raster sources with inlint TileJSON definition
- Fix a regression that prevented mapbox:// tiles from getting loaded
- Avoid excessive data downloads for geojson layers below minzoom
- Allow setting OpenLayers layer opacity when no
raster-opacity
is set - Use high resolution tiles for mapbox.satellite when browser supports it
- Support bounding box requests for
geojson
sources - Fix 3-argument signature for
applyStyle()
- Add support for raster-dem sources with hillshade layers
- New hook for supplying images without project sprite spritesheet
- Fix issue with new background handling, which is now done in a postrender function rather than prerender
- Simplified 3-argument signature of
applyStyle()
. The longer signatures continue to work, but are deprecated.
apply()
can now also apply to anol/layer/Group
.- Backgrounds are no longer applied using OpenLayers's
setBackground()
, but with a prerender function for the first layer
- ol-mapbox-style now requires OpenLayers 7
icon-offset
has been fixed. If you previously worked around the x-value moving left instead of right with increasing offset, you have to remove this workaround now.
- Added support for
text-justify
- Updated dependencies
- CI changes
- More secure regular expression for property templates; simplified template handling
- Avoid unnecessary TileJSON fetches
- New
SpriteImage
type for thetransformRequest
option
- Add require field to package.json's exports to avoid ESLint complaints
- Add main field to package.json to avoid ESLint complaints (was meant to go into 8.1.0 already)
- Add support for
icon-ignore-placement
andicon-allow-overlap
- Add main field to package.json to avoid ESLint complaints
- Fix relative source url handling for GeoJSON sources
- Fix website examples
- Use rollup instead of webpack for creating bundles
- Remove
webfont-matcher
dependency. Instead, load Google fonts only when they are not available already. - Normalize Arial font name to make sure it can be detected.
- Use
sans-serif
as fallback font.
- Do not advertise the
dist/olms.js
cjs bundle inpackage.json
, because its imports fromol
are not cjs compliant. This should resolve problems with old bundlers that pick the cjs bundle instead of the ejs bundle.
- Add
Accept: application/json
header to requests for jsons. This avoids e.g. problems with Esri servers returning HTML instead of JSON - Reduce build size by stripping more fields from the style spec json.
- Fix
applyStyle()
regression that broke the function when nosourceOrLayer
was provided
- Fix display of optional arguments in API docs
- Fix layer stack regression when layers from one source are spread across multiple OpenLayers layers
- Display API docs correctly on npmjs.com
- The package now provides two separate bundles for umd and ejs.
dist/olms.js
is the umd bundle,dist/index.js
the ejs bundle. No other JavaScript files are provided in thedist/
folder any more. - Imports from the
dist/
folder are no longer supported. They need to be replaced with imports from the package, e.g.import {stylefunction} from "ol-mapbox-style"
instead ofimport stylefunction from "ol-mapbox-style/dist/stylefunction"
. - The
apply()
function has been replaced with an alias of the default export. This means thatapply()
now returns aPromise<Map>
instead of aMap
. - The auto-generated types are now stricter, because they reference OpenLayers types correctly, instead of using
any
.
apply()
,applyStyle()
andapplyBackground()
now take anoptions
argument, which can contain atransformRequest
option. With that function, urls and requests for styles, sprites, tiles and data can be modified. This can be useful e.g. to fix relative urls or to add credentials.- Another available option is
accessToken
. In combination with the new support formapbox://
urls, it has become much easier to use maps and styles from Mapbox. - Finally, a set of resolutions can be configured in the
options
. This makes it much easier to work with layers or maps in projections other than Web Mercator. - The
applyStyle()
function has become more powerful and can now create and populate the source of the provided layer. feature-state
is now supported. The new functionssetFeatureState()
andgetFeatureState()
can be used to set and get the feature state.- The build size is now at least 80 kB smaller because of pre-processing of the style specification from the
@mapbox/mapbox-gl-style-spec
package. The umd bundle no longer contains the OpenLayers code that has been there by accident for a few releases, which had unnecessarily increased the build size by almost 400 kB. - The API docs are now generated with typedoc instead of documentation.js
- Do not use overflow for line labels
- Declutter also vector layers
- Allow text to overflow polygons
ol-mapbox-style now requires OpenLayers >= 6.13.
- Add support for rich text labels (with OpenLayers v6.13+)
- Require ol >= 6.13
- Add support for the
icon-offset
layout property - Fix
circle
layers with default radius
- Fix handling of fonts with two-word weights (e.g. "Semi Bold")
- Fix rendering of fill-outline when fill is fully transparent
- Use OpenLayers's fixed
ol/View#getProperties()
method, if available - Avoid applying background if layout is none
- Fix color calculation for zero opacity when
renderTransparent(true)
is set.
- New
renderTransparent()
configuration option for more flexible hit detection - Add
stylefunction
module functions to legacy build - Better default view detection to avoid overwriting of view configurations
applyBackground()
now also accepts an OpenLayers >= 6.10VectorTile
layer as first argument.
- Publish declaration source maps
- Fix TileJSON handling of relative urls
- Cache functions and filters per
stylefunction
invocation
- Fix handling of
icon-color
- Publish auto-generated
.d.ts
files for TypeScript
- Remove
ol
peer dependency frompackage.json
for easier of use dev versions ofol
- Export
setupVectorSource()
for use in OpenLayers
- Fix import of
@mapbox/mapbox-gl-style-spec
- Fix
webfont-matcher
import
- Change package to
"type": "module"
- Updates to work seamlessly with ol > 6.5
- Support relative urls for TileJSON tiles (#320)
- Do not render icons when
icon-color
has zero opacity (#317)
- New
stylefunction.recordStyleLayer()
function to know which rendered layer a feature belongs to (#309)
- Improved support for relative urls in style documents (#307)
- Improved support for relative urls in style documents (#304)
- Allow empty spritesheets (#306)
- Added support for
fill-extrusion
, using a 2D fallback (#303)
- Fix OpenLayers version mismatch with legacy builds (was missing in 6.1.3) #291
- Added
Object.assign
polyfill for compatibility with old browsers #281 - Fix line wrapping of text labels #283 #284
- Fix OpenLayers version mismatch with legacy builds #291
- No more polyfills for
Object.assign
andString#startsWith
needed #276 - Fixed issue with disappearing labels #273
- MultiLineString labeling improvements #272
- Improved developer experience with proper TypeScript configuration #270
- Fix version issue with @mapbox/mapbox-gl-style-spec
- Improvements and bug fixes for multi-line text and wrapping
- Support for running
stylefunction
in web workers
ol-mapbox-style now ships with transpiled modules in the dist/
folder, and sources in the src/
folder. Previously, all modules were provided in the root directory.
When upgrading, the import paths need to be checked. For example,
import stylefunction from 'ol-mapbox-style/stylefunction';
needs to be changed to
import stylefunction from 'ol-mapbox-style/dist/stylefunction';
- Allow mapbox:// urls for all layer types, not just vector
- Update dependencies
- Use ol@6.0.1
- Do not fail when icons come from an expression
- Only set the maxResolution on a new view, instead of the whole resolutions array
- Fix an issue with `icon-color´ handling
- Fix an issue with parsing Google font names
- Add support for the
icon-anchor
property - More efficient handling or tilejson and shared vector tile sources
- More efficient midpoint rendering
- Only include style spec once
- Trim the label-field string
- Round text size to integer pixels
- Requires ol@6
- Uses new OpenLayers z-index ordering for decluttered content
- Support for the
text-rotation-alignment
property - Better
max-angle
handling in combination withtext-letter-spacing
- Load Google fonts with the correct weight and style
- Support for the
text-max-angle
layout property - More efficient color handling without cache
- Improve text wrapping for to avoid short lines
- Apply default resolutions (Mapbox zoom levels) to the view
- Do not create layers for unsupported layer types
- Support for the
text-translate
paint property - Improve performance for circle styles
- Smarter text wrapping. We now try to distribute text more evenly across lines
- Take letter spacing into account for calculating line breaks
- Add support for the
text-line-height
layout property - Respect text halo for text anchor
- Fix how we interpret the
text-halo-width
paint property - Respect
tileSize
for TileJSON when specified in the style doc
v4.1.0 brings a few performance improvements and bug fixes:
- More efficient font caching
- Always stroke polygons to be in line with the style spec
- Stroke polygons without drawing the outline a 2nd time
- Do not cache transparent colors, making hiding features more efficient
- Fix background opacity
- Respect minzoom from TileJSON sources, avoiding underzooming which can lead to loading thousands of tiles
The way how we handle zoom
, minzoom
and maxzoom
throughout the library has been reworked:
- When ol-mapbox-style creates an
ol/View
instance, it will be configured with the zoom level range that mapbox-gl uses. When updating from previous versions, you will notice that the zoom levels of the OpenLayers view will now match those in the Mapbox Style object. Previously OpenLayers zoom levels were higher by 1. - When a Mapbox Style object is configured with a
zoom
, the zoom level will now be interpreted like in mapbox-gl, i.e. you will be zoomed in one level deeper than before the update. minzoom
andmaxzoom
on a Mapbox Style layer were previously determined by the tile size of the underlying source. For raster sources with a tile size of 256, this means thatminzoom
andmaxzoom
are zoomed in one level deeper than before the update. For sources with a tile size of 512, nothing changes.minzoom
andmaxzoom
on a Mapbox Style source now influence theol/tilegrid/TileGrid
that ol-mapbox-style creates for a source in a different way. The resolutions will always match mapbox-gl default zoom levels.minzoom
andmaxzoom
on Mapbox Style layers no longer influences whether theol/layer/Layer
instance is setvisible
at a certain resolution. Instead, the layer'smaxResolution
andminResolution
are set.
- Add support for
text-letter-spacing
- Reduce garbage by reusing padding array
- Fix
getSource()
,getLayer()
andgetLayers()
utility functions - Add support for
text-padding
- Add
getLayers()
utility function
- Use karma for tests
- Fix handling of relative paths
- Use CircleCI for continuous integration
- Do not limit raster layers to a
maxzoom
of 24 - Fix visibility handling
- Fix raster layer
minzoom
andmaxzoom
- Support
minzoom
andmaxzoom
for raster layers
- Use TileJSON relative urls only when a TileJSON
url
was used
- Fix
icon-rotation
- Fix standalone build
- Use TileJSON for all raster and vector sources
- Add support for TileJSON bounds
- Transfer copyright to the contributors
- Fix source/layer extent handling
- Add support for
raster-opacity
- Do not set
zIndex
on layers - Add support for
icon-rotation-alignment
:'map'
- Set layer properties only once and use first index as
zIndex
- Improve docs, error handling and tests
- Stop using empty layer ids for
finalizeLayer()
- Add default export that returns a
Promise
instead of anol/Map
instance - Make layer ids for background unique
- Handle errors for unavailable TileJSON sources
- Factor out functions from
processStyle
's monster loop - Remove tile load transition for raster layers entirely
- Update dev dependencies
- Cleaned up
applyStyle()
and added tests - Add support for
circle-stroke-opacity
- Use block scope variables
- Use transpiled imports for mapbox-gl-style-spec
- Fix local font detection
- Add
mapbox-style
property to theol/Map
instance - Add
getSource()
andgetLayer()
helper functions - Move examples to ES6
- Allow users to specify custom resolutions
- Add support for
fill-pattern
- Add support for filter expressions
- Smarter font stack handling
- Opacity transition only for the bottom layer
- README updates
- Fix imports
- Use webpack and babel instead of browserify
- Add continuous integration, coverage reports and use sonarqube for language quality
- Use jest for testing
- Add attribution to sources created by
apply
- Depend on ol@5
- Move mapbox-to-ol-style package into this library
- Clear caches when
applyStyle
is called again - Provide a standalone build
- Do not use isomorphic-fetch
- Fix typos in API docs
- Respect existing map view when setting
center
andzoom
- Run eslint on the code
- Set
maxResolution
on the layer, respectingminzoom
of the source
- Update mapbox-to-ol-style and openlayers versions
- Fix background
- Do not fail when
setTarget(null)
is called on the map - Set center and zoom when no view was created
- Fix background color
- Revert to older
mapbox-gl-style-spec
version
- Fix numeric interpolation
- Simplify web font handling
- Fix sprite urls
- Properly initialize path parts
- Only set extent when it has not been set before
- Update examples
- Fallback to low-res sprites when
@2x
spritesheet is not available - Use native OpenLayers decluttering
- Make ESRI relative paths work with
apply()
- Make examples mobile and cross-browser ready
- Cleanup and documentation improvements
- Performance improvements
- Decluttering of labels and symbols
- Added support for horizontal
text-anchor
- Fixed a bug with function properties
- Respect
visibility
from all layers'slayout
- Add support for raster and tilejson sources
- Fix a minor point styling issue
- Fix polygon outline leaks when using line styles on polygons
- Add optional
path
argument toapplyStyle()
- Fix build on Windows
- Performance improvmeents from the
mapbox-to-ol-style
package
- Add support for
has
and!has
filters
- Added new `apply() function, which drastically simplifies the API.
With version 2.x, ol-mapbox-style switched to the ol
npm package for the OpenLayers dependency. Users of dist/olms.js
will not notice this change. Applications that have been using the openlayers
npm package should be migrated to the ol
package too.
If switching to ol
is not yet desired, it is still possible to use ol-mapbox-style with the openlayers
package, with the help of standalonify
. You have to require OpenLayers as global.ol = require('openlayers');
. To build the bundle, use a command like the following:
$ node_modules/.bin/browserify -g [ babelify --plugins [ transform-es2015-modules-commonjs ] ] -p [ standalonify --name null --deps [ null --ol/style/style ol.style.Style --ol/style/fill ol.style.Fill --ol/style/stroke ol.style.Stroke --ol/style/circle ol.style.Circle --ol/style/icon ol.style.Icon --ol/style/text ol.style.Text ] ] example/index.js > example/bundle.js
For applications that do not need sprites and web fonts for their styles, a separate mapbox-to-ol-style
package with focus on small build size and minimal dependencies has been created. ol-mapbox-style depends on that package.
If you have previously been using the getStyleFunction
function, you now have to import it from mapbox-to-ol-style
. If you have not used anything else from ol-mapbox-style, you can uninstall it.
ol-mapbox-style now automatically loads web fonts from Google. So in most cases, it is no longer necessary to scan the Mapbox Style for fonts and include them manually in the html of the application.