mirror of
https://github.com/immich-app/immich.git
synced 2025-01-07 20:36:48 +01:00
99c6fdbc1c
* fix(mobile): upgrade maplibre_gl package to fix issue with crash in ios7.4 above simulator * chore: switch from deprecated widget and controller name to new name in latest sdk * remove todo --------- Co-authored-by: Alex <alex.tran1502@gmail.com>
82 lines
2.4 KiB
Dart
82 lines
2.4 KiB
Dart
import 'dart:async';
|
|
import 'dart:math';
|
|
|
|
import 'package:flutter/services.dart';
|
|
import 'package:immich_mobile/models/map/map_marker.model.dart';
|
|
import 'package:immich_mobile/utils/map_utils.dart';
|
|
import 'package:maplibre_gl/maplibre_gl.dart';
|
|
|
|
extension MapMarkers on MapLibreMapController {
|
|
static var _completer = Completer()..complete();
|
|
|
|
Future<void> addGeoJSONSourceForMarkers(List<MapMarker> markers) async {
|
|
return addSource(
|
|
MapUtils.defaultSourceId,
|
|
GeojsonSourceProperties(
|
|
data: MapUtils.generateGeoJsonForMarkers(markers.toList()),
|
|
),
|
|
);
|
|
}
|
|
|
|
Future<void> reloadAllLayersForMarkers(List<MapMarker> markers) async {
|
|
// Wait for previous reload to complete
|
|
if (!_completer.isCompleted) {
|
|
return _completer.future;
|
|
}
|
|
_completer = Completer();
|
|
|
|
// !! Make sure to remove layers before sources else the native
|
|
// maplibre library would crash when removing the source saying that
|
|
// the source is still in use
|
|
final existingLayers = await getLayerIds();
|
|
if (existingLayers.contains(MapUtils.defaultHeatMapLayerId)) {
|
|
await removeLayer(MapUtils.defaultHeatMapLayerId);
|
|
}
|
|
|
|
final existingSources = await getSourceIds();
|
|
if (existingSources.contains(MapUtils.defaultSourceId)) {
|
|
await removeSource(MapUtils.defaultSourceId);
|
|
}
|
|
|
|
await addGeoJSONSourceForMarkers(markers);
|
|
|
|
await addHeatmapLayer(
|
|
MapUtils.defaultSourceId,
|
|
MapUtils.defaultHeatMapLayerId,
|
|
MapUtils.defaultHeatMapLayerProperties,
|
|
);
|
|
|
|
_completer.complete();
|
|
}
|
|
|
|
Future<Symbol?> addMarkerAtLatLng(LatLng centre) async {
|
|
// no marker is displayed if asset-path is incorrect
|
|
try {
|
|
final ByteData bytes = await rootBundle.load("assets/location-pin.png");
|
|
await addImage("mapMarker", bytes.buffer.asUint8List());
|
|
return addSymbol(
|
|
SymbolOptions(
|
|
geometry: centre,
|
|
iconImage: "mapMarker",
|
|
iconSize: 0.15,
|
|
iconAnchor: "bottom",
|
|
),
|
|
);
|
|
} finally {
|
|
// no-op
|
|
}
|
|
}
|
|
|
|
Future<LatLngBounds> getBoundsFromPoint(
|
|
Point<double> point,
|
|
double distance,
|
|
) async {
|
|
final southWestPx = Point(point.x - distance, point.y + distance);
|
|
final northEastPx = Point(point.x + distance, point.y - distance);
|
|
|
|
final southWest = await toLatLng(southWestPx);
|
|
final northEast = await toLatLng(northEastPx);
|
|
|
|
return LatLngBounds(southwest: southWest, northeast: northEast);
|
|
}
|
|
}
|