https://kamilfurtak.github.io/ng-openlayers/
Hiere is a link to the blog post with the tutorial on how to create interactive maps with Angular 17 and latest OpenLayers using this library:
https://blog.furtak.dev/create-interactive-maps-with-angular-17-and-latest-openlayers-7ae9b7fdb7ec
To install this library, run:
npm install ng-openlayers --save
Import AngularOpenlayersModule ex. to your AppComponent in standalone mode.
Now add OpenLayers CSS styles to your project. Open angular.json and add "node_modules/ol/ol.css" next to existing css styles.
"styles": [
"src/styles.css",
"node_modules/ol/ol.css"
],
Here is a "minimal" map example with default interactions and controls:
<div style="height: 500px">
<aol-map>
<aol-view [zoom]="2">
<aol-coordinate [x]="5.795122" [y]="45.210225" [srid]="'EPSG:4326'"></aol-coordinate>
</aol-view>
<aol-layer-tile>
<aol-source-osm></aol-source-osm>
</aol-layer-tile>
<aol-interaction-default></aol-interaction-default>
<aol-control-scaleline></aol-control-scaleline>
<aol-control-zoomslider></aol-control-zoomslider>
<aol-control-zoom></aol-control-zoom>
</aol-map>
</div>
https://stackblitz.com/edit/stackblitz-starters-amwibo?file=src%2Fmain.ts
Most of the following documentation is an adaptation of OpenLayers' own documentation: https://openlayers.org/en/latest/apidoc/. While trying to cover most important aspects in here, this documentation is by no means exhaustive, please refer to https://openlayers.org/en/latest/apidoc/ if in doubt. Contributions welcome!
For each supported OpenLayers class, there is a corresponding Angular component. The components instantiate their underlying
OpenLayers counterpart as part of their initialization and carry the reference in their instance
property which is public.
Each property of the underlying OpenLayers object is also an @Input()
property of the Angular component.
Each component has a directive selector of the form aol-
and a structure of components that corresponds to the hierarchy of
OpenLayers objects is built in a declarative Angular fashion.
The MapComponent
(aol-map
) is the root component of ng-openlayers maps.
Available parameters are:
width
(string|undefined
): width of the enclosing<div>
. Defaults to100%
.height
(string|undefined
): height of the enclosing<div>
. Defaults to100%
.pixelRatio
(number|undefined
): physical pixels to device-independent pixels (dips) ratio. Defaults towindow.devicePixelRatio
.keyboardEventTarget
(Element|string|undefined
): element to listen to keyboard events on. Defaults to enclosing<div>
.loadTilesWhileAnimating
(boolean|undefined
): tiles loading policy while animating. Defaults tofalse
.loadTilesWhileInteracting
(boolean|undefined
): tiles loading policy while interacting. Defaults tofalse
.logo
(string|boolean|undefined
): map logo. Providetrue
to display the Openlayers logo or a string URL. Defaults toundefined
.renderer
('canvas'|'webgl'|undefined
): map renderer. Defaults to canvas.
Exposed events are:
olClick
(ol.MapBrowserEvent
) - A click with no dragging. A double click will fire two of this.dblClick
(ol.MapBrowserEvent
) - A true double click, with no dragging.moveStart
(ol.MapEvent
) - Triggered when the map start been moved.moveEnd
(ol.MapEvent
) - Triggered after the map is moved.pointerdrag
(ol.MapBrowserEvent
) experimental - Triggered when a pointer is dragged.pointermove
(ol.MapBrowserEvent
) - Triggered when a pointer is moved. Note that on touch devices this is triggered when the map is panned, so is not the same as mousemove.postcompose
(ol.render.Event
) experimentalpostrender
(ol.MapEvent
) experimental - Triggered after a map frame is rendered.precompose
(ol.render.Event
) experimentalpropertychange
(ol.Object.Event
) - Triggered when a property is changed.singleclick
(ol.MapBrowserEvent
) - A true single click with no dragging and no double click. Note that this event is delayed by 250 ms to ensure that it is not a double click.
A map component without a view won't fetch tiles, i.e. it stays blank, provide an <aol-view>
component to display
the map.
Here is a simple example, based on OpenStreetMap tiles source:
<aol-map [width]="'500px'" [height]="'300px'">
<aol-view [zoom]="2">
<aol-coordinate [x]="5.795122" [y]="45.210225" [srid]="'EPSG:4326'"></aol-coordinate>
</aol-view>
<aol-layer-tile>
<aol-source-osm></aol-source-osm>
</aol-layer-tile>
</aol-map>
The ViewComponent
(<aol-view>
) describes which content to display. In most cases, the view specifies the center of the map,
i.e. coordinates on which the map is centered, and a zoom level or extent.
Available parameters are:
constrainRotation
(boolean|number|undefined
) Rotation constraint. false means no constraint. true means no constraint, but snap to zero near zero. A number constrains the rotation to that number of values. For example, 4 will constrain the rotation to 0, 90, 180, and 270 degrees. Defaults totrue
.enableRotation
(boolean|undefined
) Enable rotation. If false a rotation constraint that always sets the rotation to zero is used. The constrainRotation option has no effect if enableRotation is false. Defaults totrue
.extent
(ol.Extent|undefined
) extent that constrains the center, in other words, center cannot be set outside this extent. Defaults toundefined
.maxResolution
(number|undefined
) The maximum resolution used to determine the resolution constraint. It is used together withminResolution
(ormaxZoom
) andzoomFactor
. If unspecified it is calculated in such a way that the projection's validity extent fits in a 256x256 px tile. If the projection is Spherical Mercator (the default) thenmaxResolution
defaults to40075016.68557849 / 256 = 156543.03392804097
.minResolution
(number|undefined
) The minimum resolution used to determine the resolution constraint. It is used together withmaxResolution
(orminZoom
) andzoomFactor
. If unspecified it is calculated assuming 29 zoom levels (with a factor of 2). If the projection is Spherical Mercator (the default) thenminResolution
defaults to40075016.68557849 / 256 / Math.pow(2, 28) = 0.0005831682455839253
.maxZoom
(number|undefined
) The maximum zoom level used to determine the resolution constraint. It is used together withminZoom
(ormaxResolution
) andzoomFactor
. Default is 28. Note that ifminResolution
is also provided, it is given precedence overmaxZoom
.minZoom
(number|undefined
) The minimum zoom level used to determine the resolution constraint. It is used together withmaxZoom
(orminResolution
) andzoomFactor
. Default is 0. Note that ifmaxResolution
is also provided, it is given precedence overminZoom
.resolution
(number|undefined
) The initial resolution for the view. The units are projection units per pixel (e.g. meters per pixel). An alternative to setting this is to setzoom
. Default isundefined
, and layer sources will not be fetched if neither this norzoom
are defined.resolutions
(number[]|undefined
) Resolutions to determine the resolution constraint. If set themaxResolution
,minResolution
,minZoom
,maxZoom
, andzoomFactor
options are ignored.rotation
(number|undefined
) The initial rotation for the view in radians (positive rotation clockwise). Defaults to 0.zoom
(number|undefined
) Only used if resolution is not defined. Zoom level used to calculate the initial resolution for the view. The initial resolution is determined using theol.View#constrainResolution
method.zoomFactor
(number|undefined
) The zoom factor used to determine the resolution constraint. Defaults to 2.
<aol-view [zoom]="15">
<aol-coordinate [x]="5" [y]="45" [srid]="'EPSG:4326'"></aol-coordinate>
</aol-view>
LayerComponents
(<aol-layer-*>
) provide ways to displaying contents on the map.
Available parameters are:
opacity
(number|undefined
): layer's opacity, defaults to1
(opaque).visible
(boolean|undefined
): layers visibility, defaults totrue
.extent
(ol.Extent|undefined
): bounding extent for layer rendering. The layer will not be rendered outside of this extent.zIndex
(number|undefined
) experimental: layers are ordered, first by Z-index and then by position. The default Z-index is 0.minResolution
(number|undefined
: minimum resolution (inclusive) at which the layer is visible.maxResolution
(number|undefined
: maximum resolution (exclusive) at which the layer is visible.
The SourceComponent
s (aol-source-*
) represent a map source and belong to a layer.
Source attributions can either be passed via the attributions
input property or defined in a declarative way. If multiple sources share the
same attribution, the attribution should be defined in the code portion as an ol.AttributionLike
and passed via the attributions
input
property of the source as they would otherwise appear multiple times.
<aol-layer-vectortile
[renderMode]="'vector'"
[maxResolution]="312"
[style]="myStyle"
[zIndex]="20"
>
<aol-source-vectortile
[tilePixelRatio]="16"
[tileUrlFunction]="tileUrlFn"
>
<aol-attributions>
<aol-attribution>© by me</aol-attribution>
</aol-attributions>
<aol-format-mvt></aol-format-mvt>
<aol-tilegrid
[minZoom]="5"
[extent]="tileGridExtent"
>
</aol-tilegrid>
</aol-source-vectortile>
</aol-layer-vectortile>
The FeatureComponent
(aol-feature
) is a vector object with a geometry and other attribute properties, similar to the features in
vector file formats like GeoJSON. Used in conjunction with a geometry (<aol-geometry-*>
) and a style (<aol-style>
),
it allows displaying vector shapes on the map.
<aol-feature>
<aol-geometry-point>
<aol-coordinate [x]="5" [y]="45" [srid]="'EPSG:4326'"></aol-coordinate>
</aol-geometry-point>
<aol-style>
<aol-style-circle [radius]="10">
<aol-style-stroke [color]="'black'" [width]="2"></aol-style-stroke>
<aol-style-fill [color]="'green'"></aol-style-fill>
</aol-style-circle>
</aol-style>
</aol-feature>
The GeometryComponents
(aol-geometry-*
) allow defining geometrical shapes that, used in conjunction with a geometry
(<aol-geometry-*>
) and a style (<aol-style>
), display said geometrical shape to the map.
The GeometryLinestringComponent
(aol-geometry-linestring
) defines a collection of connected segments.
<aol-feature>
<aol-geometry-linestring>
<aol-collection-coordinates
[coordinates]="[[5.0, 45.01],[5.01, 45.03]]"
[srid]="'EPSG:4326'">
</aol-collection-coordinates>
</aol-geometry-linestring>
<aol-style>
<aol-style-stroke [color]="'red'"></aol-style-stroke>
</aol-style>
</aol-feature>
The GeometryPointComponent
(aol-geometry-point
) defines a single point.
<aol-feature>
<aol-geometry-point>
<aol-coordinate [x]="5" [y]="45" [srid]="'EPSG:4326'"></aol-coordinate>
</aol-geometry-point>
<aol-style>
<aol-style-circle [radius]="10">
<aol-style-stroke [color]="'black'" [width]="width"></aol-style-stroke>
<aol-style-fill [color]="'green'"></aol-style-fill>
</aol-style-circle>
</aol-style>
</aol-feature>
The GeometryPolygonComponent
(aol-geometry-polygon
) defines a polygon.
<aol-feature>
<aol-geometry-polygon>
<aol-collection-coordinates
[coordinates]="[[[5, 45],[5.05, 45.05],[5.05, 44.95],[4.95, 44.95]]]"
[srid]="'EPSG:4326'"
>
</aol-collection-coordinates>
</aol-geometry-polygon>
<aol-style>
<aol-style-stroke [color]="'red'"></aol-style-stroke>
<aol-style-fill [color]="[255,0,0,0.5]"></aol-style-fill>
</aol-style>
</aol-feature>
The GeometryMultiPointComponent
(aol-geometry-multipoint
) defines a collection of points.
<aol-feature>
<aol-geometry-multipoint>
<aol-collection-coordinates
[coordinates]="[[5, 45],[5.05, 45.05],[5.05, 44.95],[4.95, 44.95]]"
[srid]="'EPSG:4326'"
>
</aol-collection-coordinates>
</aol-geometry-multipoint>
<aol-style>
<aol-style-circle [radius]="10">
<aol-style-stroke [color]="'black'" [width]="width"></aol-style-stroke>
<aol-style-fill [color]="'green'"></aol-style-fill>
</aol-style-circle>
</aol-style>
</aol-feature>
The GeometryMultiLinestringComponent
(aol-geometry-multilinestring
) defines a collection of multilines.
<aol-feature>
<aol-geometry-multilinestring>
<aol-collection-coordinates
[coordinates]="[[[5.0, 45.01],[5.01, 45.03]],[[6.0, 45.01],[6.01, 45.03]]]"
[srid]="'EPSG:4326'">
</aol-collection-coordinates>
</aol-geometry-multilinestring>
<aol-style>
<aol-style-stroke [color]="'red'"></aol-style-stroke>
</aol-style>
</aol-feature>
The GeometryMultiPolygonComponent
(aol-geometry-multipolygon
) defines a collection polygons.
<aol-feature>
<aol-geometry-multipolygon>
<aol-collection-coordinates
[coordinates]="[[[5, 45],[5.05, 45.05],[5.05, 44.95],[4.95, 44.95]],[[6, 45],[6.05, 45.05],[6.05, 44.95],[5.95, 44.95]]]"
[srid]="'EPSG:4326'"
>
</aol-collection-coordinates>
</aol-geometry-multipolygon>
<aol-style>
<aol-style-stroke [color]="'red'"></aol-style-stroke>
<aol-style-fill [color]="[255,0,0,0.5]"></aol-style-fill>
</aol-style>
</aol-feature>
StyleComponents
(<aol-style-*>
) provide ways to altering the look of vector features.
WARNING : as of now, changes on style directives are not displayed. This issue lies in OpenLayers: openlayers/openlayers#5775 (related).
<aol-style-*>
must be encapsulated in a <aol-style>
component. As of now, only StyleCircleComponent
(<aol-style-circle>
), StyleFillComponent
(<aol-style-fill>
),
StyleIconComponent
(<aol-style-icon
) and StyleFillComponent
(<aol-style-stroke>
) are implemented.
StyleCircleComponent
(<aol-style-circle>
) displays a circle.
Note that it can be further style using <aol-style-fill>
and <aol-style-stroke>
.
Available parameters are:
radius
(number|undefined
): circle's radius, defaults to10px
.snapToPixel
(boolean|undefined
): whether or not use sub-pixels, defaults totrue
.
StyleFillComponent
(<aol-style-fill>
) fills the host with a color, or gradient of colors.
Available parameters are:
color
(Color|ColorLike|undefined
): color, gradient or pattern. Seeol.color
andol.colorlike
for possible formats. Defaults to black.
The StyleIconComponent
(<aol-style-icon
) displays an icon.
Available parameters are:
anchor
([number, number]
): image anchor. Defaults to[0.5, 0.5]
: icon center.anchorXUnits
(style.IconAnchorUnits
): X anchor unit: 'fraction' indicates a fraction of the icon, 'pixels' indicates a value in pixels. Defaults to 'fraction'.anchorYUnits
(style.IconAnchorUnits
): Y anchor unit: 'fraction' indicates a fraction of the icon, 'pixels' indicates a value in pixels. Defaults to 'fraction'.anchorOrigin
(style.IconOrigin
): origin of the anchor:bottom-left
,bottom-right
,top-left
ortop-right
. Defaults totop-left
.color
([number, number, number, number]
): tint of the icon. If not specified, the icon will be left as is.crossOrigin
(style.IconOrigin
):crossOrigin
attribute for loaded images.img
(string
): image object for the icon.offset
([number, number]
): offset, which, together with the size and the offset origin, define the sub-rectangle to use from the original icon image. Defaults to[0, 0]
.offsetOrigin
(style.IconOrigin
): origin of the offset:bottom-left
,bottom-right
,top-left
ortop-right
. Defaults totop-left
.opacity
(number
): opacity of the icon. Default is 1.scale
(number
): scalesnapToPixel
(boolean
): whether or not use sub-pixels, defaults totrue
.rotateWithView
(boolean
): whether to rotate the icon with the view. Defaults tofalse
.rotation
(number
): rotation in radians (positive rotation clockwise). Defaults to 0.size
([number, number]
): icon size in pixel. Can be used together with offset to define the sub-rectangle to use from the origin (sprite) icon image.imgSize
([number, number]
): image size in pixels. Only required if img is set and src is not, and for SVG images in Internet Explorer 11. The providedimgSize
needs to match the actual size of the image.src
(string
): image source URI. Required.
StyleStrokeComponent
(<aol-style-stroke>
) adds a stroke around the host.
Available parameters are:
color
: (Color|ColorLike|undefined
): color, gradient or pattern. Seeol.color
andol.colorlike
for possible formats. Defaults to black.lineCap
: (string|undefined
): line cap style:butt
,round
, orsquare
. Default toround
.lineDash
: (number[]|undefined
): line dash pattern. Defaults toundefined
(no dash). No support in Internet Explorer 10 and lower.lineJoin
: (string|undefined
): line join style:bevel
,round
, ormiter
. Defaults toround
.miterLimit
: (number|undefined
): miter limit. Defaults to 10.width
: (number|undefined
): line width.
StyleTextComponent
(<aol-style-text>
) adds a text ons the host.
Available parameters are:
font
: (string|undefined
): Font style as CSS 'font' value. Default is '10px sans-serif'offsetX
: (number|undefined
): Horizontal text offset in pixels. A positive will shift the text right. Default is 0.offsetY
: (number|undefined
): Vertical text offset in pixels. A positive will shift the text down. Default is 0.scale
: (number|undefined
): Scale.rotateWithView
: (boolean|undefined
): Whether to rotate the text with the view. Default is false.rotation
: (number|undefined
): Rotation in radians (positive rotation clockwise). Default is 0.text
: (string|undefined
): Text content.textAlign
: (string|undefined
): Text alignment. Possible values: 'left', 'right', 'center', 'end' or 'start'. Default is 'start'.textBaseLine
: (string|undefined
): Text base line. Possible values: 'bottom', 'top', 'middle', 'alphabetic', 'hanging', 'ideographic'. Default is 'alphabetic'.
For each ol.control
class, there is a corresponding component. Apart from the specialized pre-defined controls, you can define your own
custom controls using a simple declarative syntax. Use the map component's CSS to style and position the control on the map view.
<aol-control>
<aol-content>
<div id="controlnameforcssstyling" class="ol-unselectable ol-control">
<span (click)="doSomething()">{{ someContent() }}</span>
</div>
</aol-content>
</aol-control>
Similar to controls, custom overlays can be defined using HTML markup. Overlays have a position on the map as opposed to controls which are positioned on the map view. You can style overlay components like a regular component element.
<aol-overlay>
<aol-coordinate
[x]="longitude"
[y]="latitude"
[srid]="'EPSG:4326'"
>
</aol-coordinate>
<aol-content>
<div class="my-overlay-class">
<h1>This is an overlay</h1>
</div>
</aol-content>
</aol-overlay>
You could add default interactions to the map (drag, zoom, etc) just adding the aol-interaction-default
component.
<aol-map>
<aol-interaction-default></aol-interaction-default>
</aol-map>
Interaction for drawing feature geometries. See https://openlayers.org/en/master/apidoc/ol.interaction.Draw.html
Draw point
<aol-map>
<df-interaction-draw type="Point"></df-interaction-draw>
</aol-map>
Available parameters
clickTolerance
(number
|undefined
) The maximum distance in pixels between "down" and "up" for a "up" event to be considered a "click" event and actually add a point/vertex to the geometry being drawn. Default is 6 pixels. That value was chosen for the draw interaction to behave correctly on mouse as well as on touch devices.features
(ol.Collection.<ol.Feature>
|undefined
) Destination collection for the drawn features.source
(ol.source.Vector
|undefined
) Destination source for the drawn features.snapTolerance
(number
|undefined
) Pixel distance for snapping to the drawing finish. Default is 12.type
(ol.geom.GeometryType
) Drawing type ('Point', 'LineString', 'Polygon', 'MultiPoint', 'MultiLineString', 'MultiPolygon' or 'Circle'). Required.maxPoints
(number
|undefined
) The number of points that can be drawn before a polygon ring or line string is finished. The default is no restriction.minPoints
(number
|undefined
) The number of points that must be drawn before a polygon ring or line string can be finished. Default is 3 for polygon rings and 2 for line strings.finishCondition
(ol.EventsConditionType
|undefined
) A function that takes anol.MapBrowserEvent
and returns a boolean to indicate whether the drawing can be finished.style
(ol.style.Style
|Array.<ol.style.Style>
|ol.StyleFunction
|undefined
) Style for sketch features.geometryFunction
(ol.DrawGeometryFunctionType
|undefined
) Function that is called when a geometry's coordinates are updated.geometryName
(string
|undefined
) Geometry name to use for features created by the draw interaction.condition
(ol.EventsConditionType
|undefined
) A function that takes anol.MapBrowserEvent
and returns a boolean to indicate whether that event should be handled. By defaultol.events.condition.noModifierKeys
, i.e. a click, adds a vertex or deactivates freehand drawing.freehand
(boolean
|undefined
) Operate in freehand mode for lines, polygons, and circles. This makes the interaction always operate in freehand mode and takes precedence over any freehandCondition option.freehandCondition
(ol.EventsConditionType
|undefined
) Condition that activates freehand drawing for lines and polygons. This function takes anol.MapBrowserEvent
and returns a boolean to indicate whether that event should be handled. The default isol.events.condition.shiftKeyOnly
, meaning that theShift
key activates freehand drawing.wrapX
(boolean
|undefined
) Wrap the world horizontally on the sketch overlay. Default is false.
Exposed events are:
onChange
(ol.events.Event
) - Generic change event. Triggered when the revision counter is increased.onChangeActive
(ol.Object.Event
)onDrawEnd
(ol.interaction.Draw.Event
) - Triggered upon feature draw endonDrawStart
(ol.interaction.Draw.Event
) - Triggered upon feature draw startonPropertyChange
(ol.Object.Event
) - Triggered when a property is changed.
To generate all *.js
, *.js.map
and *.d.ts
files:
npm run ngc
To lint all *.ts
files:
npm run lint
Live example (reload on code changes):
npm install -g @angular/cli
cd example
npm install
ng serve
Live example will be viewable at locahost:4200
MPL-2.0 - Kamil Furtak [email protected] Copyright 2024 FComp