-
Notifications
You must be signed in to change notification settings - Fork 130
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[FEATURE] Improvement suggestion for map annotations. #436
Comments
Thanks for creating this feature request @smallTrogdor.
Sounds interesting. Although does that mean that we need to check the Annotation type in all these functions or would there be no separation between different annotations in the controller?
What is the functionality of the annotator? Is it similar to what the AnnotationManager currently is?
I think it's currently not covered in #431 (now #433) but probably should be. 👍 I think this discussion is kind of similar to the discussion in #366 (comment) about how wide the API provided by maplibre_gl should be. |
There is no differentiation between annotations for the user, however the annotation manager needs to differ those annotations using sealed classes and pattern matching to add the annotations to separate layers, but only uses a single GeoJSON source. I track the layers created separately, but the annotations in one LinkedHashMap.
Yes, very similar, however it is exposed to the user with a callback.
Yes, the annotation manager should be able to react to style changes to re-add annotations in my opinion (maybe with a switch to disable this functionality). Before #433, I went an extra length and abstracted the style setting with a MapStyler, that I could listen to. Then I would expose only that styler to the user (which would just pass in the new style to the underlying map, as discussed in #431 as well). Here is some excerpt from my code (maybe it helps): @override
Future<void> addAnnotations(Iterable<MapAnnotation> annotations) async {
final newAnnotations = annotations.where(_isNotKnown);
if (newAnnotations.isEmpty) return;
if (!_isGeoJsonSourceAdded) await _addGeoJsonSource();
return _addAnnotationsToLayer(newAnnotations);
}
// ...
Future<void> _addAnnotationsToLayer(
Iterable<MapAnnotation> annotations,
) async {
await _addLayersIfNecessary(annotations);
return _updateAll(annotations);
}
Future<void> _addLayersIfNecessary(
Iterable<MapAnnotation> annotations,
) async {
for (final a in annotations) {
final layerId = _getAnnotationIdentifier(a);
if (_addedLayers.keys.contains(layerId)) continue;
final layerProperties = _getLayerProperties(a);
await _applyLayerToStyle(layerId, layerProperties);
}
}
Future<void> _applyLayerToStyle(
String layerId,
LayerProperties layerProperties,
) {
return _controller
.addLayer(_kSourceId, layerId, layerProperties)
.catchError(_throwAnnotatorException(
'Adding layer $layerId failed with exception: '))
.then((_) => _addedLayers[layerId] = layerProperties);
}
_getAnnotationIdentifier(MapAnnotation annotation) => switch (annotation) { // the pattern matching
MapSymbol() => _kSymbolIdentifier,
MapCircle() => _kCircleIdentifier,
// would need to be extended for all annotation types (line, fill)
};
LayerProperties _getLayerProperties(MapAnnotation annotation) =>
switch (annotation) {
MapSymbol() => MapSymbolLayer().makeLayerExpressions(), // the maplibre_gl layer expressions
MapCircle() => MapCircleLayer().makeLayerExpressions(),
}; This is the method being called when the style changes:
|
I forgot to mention: I filter the annotations in the layers with a custom property I set when adding ... to not confuse them from the same source ... A first proposal could also be to deprecate the addCircle, addLine, etc methods in the controller and simply generalize them to a single addAnnotation(AnnotationType annotation) method ... would be a lot smaller of a change ... What do you think @josxha ? |
Sorry for my late reply @smallTrogdor. |
@josxha Thanks for the update! I have two questions:
Thanks @kuhnroyal for a feedback :) Note: I will be afk until mid july and can implement it once back (will only take an evening or two in my estimation now) |
I have not used annotations so far, so I don't currently have an opinion. |
The current implementation in maplibre_gl is about the same as in mapbox_gl. This feature would move us more apart from the mapbox_gl API, question is how much this matters to us. The development of mapbox_gl has mostly stopped in favor of the 1st party mapbox_maps_flutter package. |
Still might make sense to check how this is implemented there. |
Hi @kuhnroyal and @josxha, any update on that ? - I am back to the keyboard now and could start working on the PR soon. I also saw, that #444 is kind of dead / not being worked on anymore... In general the effort in this plugin from this spring has toned down a bit again, is there anything I can do help? It is really highly appreciated! |
Hi @smallTrogdor, I haven't heared back from @kuhnroyal but I think your proposed changes are a good idea to clean up the controllers' API. |
Alright, I will get to it at the end of this month 👍 |
Feature Description
I have recently started building a thin wrapper package for my company in a private repo on top of this library and I am really grateful for this plugin - thank you for all the work and the maintenance - good work!
Working a lot with this plugin, I came across the way annotations are managed as of today. After careful consideration, I decided to implement my own way (just using add / set geoJson source) instead of relying on the controller's addCircle, addFill, addX , removeCircle, removeX methods for the following reasons:
Therefore I propose and wanted to discuss with you about:
What do you think about that ? - I would be willing to invest my time into within the next couple weeks.
Describe alternatives you've considered
Using annotations the same way as today (which is in the end ok and has some bugs that one could also prioritize).
Additional context
No response
The text was updated successfully, but these errors were encountered: