the control's options
Removes a previously registered event listener.
The event type to remove listeners for.
The listener function to remove.
Adds a listener to a specified event type.
The event type to add a listen for.
The function to be called when the event is fired.
The listener function is called with the data object passed to fire
,
extended with target
and type
properties.
Register a control on the map and give it a chance to register event listeners and resources. This method is called by Map#addControl internally.
the Map this control will be added to
The control's container element. This should be created by the control and returned by onAdd without being attached to the DOM: the map will insert the control's element into the DOM as necessary.
Unregister a control on the map and give it a chance to detach event listeners and resources. This method is called by Map#removeControl internally.
Adds a listener that will be called only once to a specified event type.
The listener will be called first time the event fires after the listener is registered.
The event type to listen for.
Optional
listener: ListenerThe function to be called when the event is fired the first time.
this
or a promise if a listener is not provided
Bubble all events fired by this instance of Evented to this parent instance of Evented.
Optional
parent: EventedOptional
data: anyProgrammatically request and move the map to the user's location.
false
if called before control was added to a map, otherwise returns true
.
// Initialize the geolocate control.
let geolocate = new GeolocateControl({
positionOptions: {
enableHighAccuracy: true
},
trackUserLocation: true
});
// Add the control to the map.
map.addControl(geolocate);
map.on('load', () => {
geolocate.trigger();
});
A
GeolocateControl
control provides a button that uses the browser's geolocation API to locate the user on the map.Not all browsers support geolocation, and some users may disable the feature. Geolocation support for modern browsers including Chrome requires sites to be served over HTTPS. If geolocation support is not available, the
GeolocateControl
will show as disabled.The zoom level applied will depend on the accuracy of the geolocation provided by the device.
The
GeolocateControl
has two modes. IftrackUserLocation
isfalse
(default) the control acts as a button, which when pressed will set the map's camera to target the user location. If the user moves, the map won't update. This is most suited for the desktop. IftrackUserLocation
istrue
the control acts as a toggle button that when active the user's location is actively monitored for changes. In this mode theGeolocateControl
has three interaction states:GeolocateControl
button.These interaction states can't be controlled programmatically, rather they are set based on user interactions.
State Diagram
Example
See
Locate the user
Events
Event
trackuserlocationend
of type Event will be fired when theGeolocateControl
changes to the background state, which happens when a user changes the camera during an active position lock. This only applies whentrackUserLocation
istrue
. In the background state, the dot on the map will update with location updates but the camera will not.Event
trackuserlocationstart
of type Event will be fired when theGeolocateControl
changes to the active lock state, which happens either upon first obtaining a successful Geolocation API position for the user (ageolocate
event will follow), or the user clicks the geolocate button when in the background state which uses the last known position to recenter the map and enter active lock state (nogeolocate
event will follow unless the users's location changes).Event
userlocationlostfocus
of type Event will be fired when theGeolocateControl
changes to the background state, which happens when a user changes the camera during an active position lock. This only applies whentrackUserLocation
istrue
. In the background state, the dot on the map will update with location updates but the camera will not.Event
userlocationfocus
of type Event will be fired when theGeolocateControl
changes to the active lock state, which happens upon the user clicks the geolocate button when in the background state which uses the last known position to recenter the map and enter active lock state.Event
geolocate
of type Event will be fired on each Geolocation API position update which returned as success.data
- The returned Position object from the callback in Geolocation.getCurrentPosition() or Geolocation.watchPosition().Event
error
of type Event will be fired on each Geolocation API position update which returned as an error.data
- The returned PositionError object from the callback in Geolocation.getCurrentPosition() or Geolocation.watchPosition().Event
outofmaxbounds
of type Event will be fired on each Geolocation API position update which returned as success but user position is out of mapmaxBounds
.data
- The returned Position object from the callback in Geolocation.getCurrentPosition() or Geolocation.watchPosition().Example
Example
Example
Example
Example
Example
Example