Stateful map controller for Flutter Map. Manage markers, lines and polygons.
Api for the StatefulMapController
class
zoom
: get the current zoom value
zoomIn()
: increase the zoom level by 1
zoomOut()
: decrease the zoom level by 1
zoomTo
(Double
value): zoom to the provided value
center
: get the current center LatLng
value
centerOnPoint
(LatLng
point): center on the LatLng
value
addMarker
(String
name, Marker
marker): add a named marker on the map
addMarkers
(Map<String, Marker>
markers): add several named markers on the map
removeMarker
(String
name, Marker
marker): remove a named marker from the map
removeMarkers
(Map<String, Marker>
markers): remove several named markers from the map
markers
: get the markers that are on the map
namedMarkers
: get the markers with their names that are on the map
addLine
(String
name,
List<LatLng>
points,
double
width = 1.0,
Color
color = Colors.green,
bool
isDotted = false): add a line on the map
lines
: get the lines that are on the map
addPolygon
(String
name,
List<LatLng>
points,
double
width = 1.0,
Color
color = const Color(0xFF00FF00),
double
borderWidth = 0.0,
Color
borderColor = const Color(0xFFFFFF00)): add a polygon on the map
polygons
: get the polygons that are on the map
Execute some code right after the map is ready:
@override
void initState() {
statefulMapController.onReady.then((_) {
setState((_) =>_ready = true);
});
super.initState();
}
A changefeed is available: it's a stream with all state changes from the map controller. Use it to update the map when a change occurs:
statefulMapController.onReady.then((_) {
statefulMapController.changeFeed.listen((change) => setState(() {}));
});
}
The map controller can draw on the map from geojson data:
void loadData() async {
print("Loading geojson data");
final data = await rootBundle.loadString('assets/airports.geojson');
await statefulMapController.fromGeoJson(data,
markerIcon: Icon(Icons.local_airport), verbose: true);
}
@override
void initState() {
mapController = MapController();
statefulMapController = StatefulMapController(mapController: mapController);
statefulMapController.onReady.then((_) => loadData());
sub = statefulMapController.changeFeed.listen((change) => setState(() {}));
super.initState();
}
Some predefined tile layers are available.
FlutterMap(
mapController: mapController,
options: MapOptions(
center: LatLng(48.853831, 2.348722), zoom: 11.0),
layers: [
// Use the map controller's tile layer
statefulMapController.tileLayer,
MarkerLayerOptions(markers: statefulMapController.markers),
// ...
],
)
To switch tile layers at runtime use:
statefulMapController.switchTileLayer(TileLayerType.monochrome);
Available layers:
TileLayerType.normal
TileLayerType.topography
TileLayerType.monochrome
TileLayerType.hike
A tile layers bar is available:
Stack(children: <Widget>[
FlutterMap(
mapController: mapController,
options: MapOptions(center: LatLng(48.853831, 2.348722), zoom: 11.0),
layers: [
statefulMapController.tileLayer,
MarkerLayerOptions(markers: statefulMapController.markers),
],
),
Positioned(
top: 15.0,
right: 15.0,
child: TileLayersBar(controller: statefulMapController))
])