The v4.3.0 release includes features and fixes from 92 pull requests.
When you want to get all features at a given pixel, use the new map.getFeaturesAtPixel()
method.
Before:
var features = [];
map.forEachFeatureAtPixel(pixel, function(feature) {
features.push(feature);
});
After:
var features = map.getFeaturesAtPixel(pixel);
The new ol.Sphere.getArea()
and ol.Sphere.getLength()
methods can be used to calculate spherical measures on geometries. This is the recommended over using the geometry.getArea()
or geometry.getLength()
methods.
Bad:
geometry.getArea();
Good:
ol.Sphere.getArea(geometry);
It is now possible to configure the drag and drop interaction with a vector source:
var dragAndDrop = new ol.interaction.DragAndDrop({source: source});
Any dropped features will replace all existing features on the source.
It is now possible to configure the modify interaction with a vector source (in addition to a feature collection):
var modify = new ol.interaction.Modify({source: source});
With this configuration, all features on the source are eligible for modification while the interaction is active.
To delete features with the modify interaction, press the alt
key while clicking on an existing vertex. If you want to configure the modify interaction with a different delete condition, use the deleteCondition
option. For example, to allow deletion on a single click with no modifier keys, configure the interaction like this:
var interaction = new ol.interaction.Modify({
source: source,
deleteCondition: function(event) {
return ol.events.condition.noModifierKeys(event) && ol.events.condition.singleClick(event);
}
});
The motivation for this change is to make the modify, draw, and snap interactions all work well together. Previously, the use of these interactions with the default configuration would make it so you couldn't reliably add new vertices (click with no modifier) and delete existing vertices (click with no modifier).
By default, the ol.source.VectorTile
constructor creates an XYZ tile grid (in Web Mercator) for 512 pixel tiles and assumes a max zoom level of 22. If you were creating a vector tile source with an explicit tileGrid
option, you can now remove this.
Before:
var source = new ol.source.VectorTile({
tileGrid: ol.tilegrid.createXYZ({tileSize: 512, maxZoom: 22}),
url: url
});
After:
var source = new ol.source.VectorTile({
url: url
});
If you need to change the max zoom level, you can pass the source a maxZoom
option. If you need to change the tile size, you can pass the source a tileSize
option. If you need a completely custom tile grid, you can still pass the source a tileGrid
option.
The tilePixelRatio
option was only used for tiles in projections with tile-pixels
as units. For tiles read with ol.format.MVT
and the default tile loader, or tiles with the default pixel size of 4096 pixels, no changes are necessary. For the very rare cases that do not fall under these categories, a custom tileLoadFunction
now needs to be configured on the ol.source.VectorTile
. In addition to calling tile.setFeatures()
and tile.setProjection()
, it also needs to contain code like the following:
var extent = tile.getFormat() instanceof ol.format.MVT ?
tile.getLastExtent() :
[0, 0, tilePixelRatio * tileSize, tilePixelRatio * tileSize];
tile.setExtent(extent);
Usually rotation animations should animate along the shortest arc. There are rare occasions where a spinning animation effect is desired. So if you previously had something like
map.getView().animate({
rotation: 2 * Math.PI,
duration: 2000
});
we recommend to split the animation into two parts and use different easing functions. The code below results in the same effect as the snippet above did with previous versions:
map.getView().animate({
rotation: Math.PI,
easing: ol.easing.easeIn
}, {
rotation: 2 * Math.PI,
easing: ol.easing.easeOut
});
- #7117 - Sensible default tilegrid for vector tiles (@tschaub)
- #7116 - fix(package): update rollup to version 0.47.2 (@openlayers)
- #7111 - Remove broken wrapX handling from ol.Graticule (@ahocevar)
- #7107 - Update rollup to the latest version π (@openlayers)
- #7106 - Update proj4 to the latest version π (@openlayers)
- #7105 - Functions for spherical calculations (@tschaub)
- #7104 - Update sinon to the latest version π (@openlayers)
- #6807 - Initialize hasZ in the constructor of GML3 (@Jenselme)
- #7102 - Allow drag and drop interaction to be configured with a source (@tschaub)
- #6825 - Read/write Tessellate tag in KML format (@oterral)
- #7098 - Use fractional coordinates for CSS positioning (@ahocevar)
- #7064 - Do not use Array.prototype.forEach when dealing with potentially large arrays (@ahocevar)
- #7093 - Allow modify interaction to be configured with a source (@tschaub)
- #7096 - Add new Map#getFeaturesAtPixel method (@ahocevar)
- #7094 - Add missing zIndex options (@icholy)
- #7087 - Fix scale line for EPSG:4326 maps (@ahocevar)
- #7088 - Update sinon to the latest version π (@openlayers)
- #7085 - Update eslint to the latest version π (@openlayers)
- #7084 - Fix a typo in the street-labels example (@ahocevar)
- #7082 - Update eslint to the latest version π (@openlayers)
- #7079 - Optimize custom renderer code, examples and API (@ahocevar)
- #7080 - Update jsdoc to the latest version π (@openlayers)
- #7078 - Fix return type annotation of ol.layer.VectorTile.getSource (@geosense)
- #7073 - Make ol.layer.Group change handling consistent (@gberaudo)
- #7075 - Update sinon to the latest version π (@openlayers)
- #7072 - Improve API docs for ol.VectorTile (@ahocevar)
- #7070 - Get tilePixelRatio from MVT tiles (@ahocevar)
- #7069 - Update mocha to the latest version π (@openlayers)
- #7068 - Update fs-extra to the latest version π (@openlayers)
- #7066 - Fix ol.interaction.Extent event type and documentation (@ahocevar)
- #7032 - Fix KML Export Icon Anchor (@raiyni)
- #7065 - Only use API functions in example (@ahocevar)
- #7022 - Allow styles to configure a custom renderer (@ahocevar)
- #7061 - Update docs and issue and pull request instructions (@ahocevar)
- #7059 - Allow to configure Extent interaction with an extent (@ahocevar)
- #7060 - Removing invalid urn (@wnordmann)
- #7051 - Changing the EPSG3857.PROJECTION array assignment and adding urn:ogc:β¦ (@wnordmann)
- #7045 - Respect pixelRatio when scaling images (@ahocevar)
- #7023 - Update tile size and resolutions of vector tile examples (@ahocevar)
- #7005 - Add spatial reference inside geometry in EsriFormat (@Sol1du2)
- #7034 - Move non-build dependencies to devDependencies (@probins)
- #7050 - Update sinon to the latest version π (@openlayers)
- #6976 - Example - Earthquake Clusters - Change evt.type of interaction (@ehanoj)
- #7048 - Update sinon to the latest version π (@openlayers)
- #7041 - Update eslint to the latest version π (@openlayers)
- #7042 - Line dash offset (@gkresic)
- #6980 - Added tileClass to TileWMS (@ZachTRice)
- #7028 - Fix Graticule use of incorrect min/maxLon values (@greggian)
- #7021 - Update fs-extra to the latest version π (@openlayers)
- #7018 - Update jsdoc to the latest version π (@openlayers)
- #7015 - Update sinon to the latest version π (@openlayers)
- #7014 - Update jsdoc to the latest version π (@openlayers)
- #7013 - Remove ol.sphere.WGS84 and ol.sphere.NORMAL (@tschaub)
- #6981 - Render transparent vector layers to an intermediate canvas (@gberaudo)
- #6899 - Use number literal for sphere radius (@probins)
- #7011 - Update jsdoc to the latest version π (@openlayers)
- #7008 - Update sinon to the latest version π (@openlayers)
- #7007 - fix(package): update rollup to version 0.45.0 (@openlayers)
- #6996 - 6987: Memory leak with WMS time source with reprojection (@ch08532)
- #7003 - Update jsdoc to the latest version π (@openlayers)
- #7004 - Use https for bing and stamen attributions (@fredj)
- #6998 - Update eslint to the latest version π (@openlayers)
- #6999 - Make VectorTile source work with multiple layers (@ahocevar)
- #6988 - Add missing type annotations (@ahocevar)
- #6984 - Update closure-util to the latest version π (@openlayers)
- #6970 - Fix Bug when adding/removing layer with no cache (@cmortazavi)
- #6972 - Handle error tiles properly (@ahocevar)
- #6973 - Update clean-css-cli to the latest version π (@openlayers)
- #6971 - Update sinon to the latest version π (@openlayers)
- #6968 - Shortest arc rotation animation improvements and upgrade notes (@ahocevar)
- #6966 - Add getResolutionForZoom method for ol.View (@ahocevar)
- #6965 - Use shortest rotation delta for animation (@ahocevar)
- #6967 - Add RoadOnDemand imagery set to Bing example (@ahocevar)
- #6964 - Fix KML ExtendedData reading (@fredj)
- #6958 - Remove error tiles after loading is finished (@ahocevar)
- #6793 - Webgl text (@GaborFarkas)
- #6960 - Queue tiles before loading (@tschaub)
- #6957 - Greenkeeper/eslint 4.1.1 (@openlayers)
- #6955 - Update async to the latest version π (@openlayers)
- #6916 - Upgrade eslint to v4.0.0 (@marcjansen)
- #6943 - Update sinon to the latest version π (@openlayers)
- #6939 - Abort loading when tile is disposed (@ahocevar)
- #6930 - Handle setActive(false) on an interaction without map (@openlayers)
- #6936 - Do not stop the render loop when all wanted tiles are aborted (@ahocevar)
- #6920 - Fix minor type strength inconsistency (@klokantech)
- #6935 - Use transparent image from canvas context (@ahocevar)
- #6933 - Improve proj.get() logic (@probins)
- #6931 - Make sure we use the default featurePrefix (@bartvde)
- #6928 - Only adjust resolution when center within projection extent (@ahocevar)
- #6923 - Load tasks/build-ext.js in strict mode (@fredj)
- #6918 - Remove unnecessary pixelRatio check (@ahocevar)
- #6917 - Correct typo in graticule docs (@probins)