Skip to content
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] Replace the polylabel dependency with an own implementation #1746

Open
josxha opened this issue Dec 2, 2023 · 8 comments
Open
Labels
feature This issue requests a new feature P: 3 (low) (Default priority for feature requests) S: core Scoped to the core flutter_map functionality

Comments

@josxha
Copy link
Contributor

josxha commented Dec 2, 2023

What do you want implemented?

The current integration of polylabel is not very well performance optimized. By implementing our own port of polylabel, we can:

  • have better performance
  • decrease our dependance on 3rd party packages

What other alternatives are available?

No response

Can you provide any other information?

Current usage of the polylabel package:

LatLng _computePolylabel(List<LatLng> points) {
  final labelPosition = polylabel(
    [
      List<math.Point>.generate(points.length,
          (i) => math.Point(points[i].longitude, points[i].latitude)),
    ],
    // "precision" is a bit of a misnomer. It's a threshold for when to stop
    // dividing-and-conquering the polygon in the hopes of finding a better
    // point with more distance to the polygon's outline. It's given in
    // point-units, i.e. degrees here. A bigger number means less precision,
    // i.e. cheaper at the expense off less optimal label placement.
    precision: 0.000001,
  );
  return LatLng(
    labelPosition.point.y.toDouble(),
    labelPosition.point.x.toDouble(),
  );
}

Severity

Minimum: Not required for my use

@josxha josxha added feature This issue requests a new feature P: 3 (low) (Default priority for feature requests) labels Dec 2, 2023
@josxha josxha self-assigned this Dec 2, 2023
@josxha josxha changed the title [FEATURE] Replace the polylabel dependency with our own port of mapbox polylabel [FEATURE] Replace the polylabel dependency with an own port of mapbox polylabel Dec 2, 2023
@josxha josxha added this to the v7.0 milestone Dec 2, 2023
@mootw
Copy link
Contributor

mootw commented Dec 2, 2023

i noticed this while working on #1750 and added a comment //TODO does this really need to be changed to a math.Point type?

@JaffaKetchup JaffaKetchup added the S: core Scoped to the core flutter_map functionality label Dec 10, 2023
@JosefWN
Copy link
Contributor

JosefWN commented Jan 10, 2024

Maybe better to be inspired rather than straight-up porting, perhaps a bit touchy since it's a commercial company, and porting counts as redistribution from a legal point of view. In their licensing terms:

The software and files in this repository (collectively, "Software") are
licensed under the Mapbox TOS for use only with the relevant Mapbox product(s)
listed at [www.mapbox.com/pricing](http://www.mapbox.com/pricing).
...
* Redistributions of source code must retain the above copyright notice,
  this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
  this list of conditions and the following disclaimer in the documentation
  and/or other materials provided with the distribution.
...

https://github.com/mapbox/mapbox-gl-js?tab=License-1-ov-file#readme

Other than Your Content, all content displayed on the site or accessible
through the Services, including text, images, maps, software or source code,
are the property of Mapbox and/or third parties and are protected by
United States and international intellectual property laws.

https://www.mapbox.com/legal/tos/

Porting would be a violation of the TOS, and even if it weren't, only dependencies are managed automatically by flutter (bundling the licenses with the binary), so it could be a bit cumbersome 😅

I think it's quite a bit different to port things from Mapbox than it is from, say, Leaflet.

@JaffaKetchup
Copy link
Member

(It is possible to use LicenseBinding to add licenses to the Flutter app: https://api.flutter.dev/flutter/foundation/LicenseRegistry/addLicense.html)

@JosefWN
Copy link
Contributor

JosefWN commented Jan 10, 2024

Ah, thanks, didn't know! If we could automate that it would certainly simplify things for the users of flutter_map, I'm still doubtful that porting is allowed within the scope of the TOS though?

@josxha
Copy link
Contributor Author

josxha commented Jan 12, 2024

I'm still doubtful that porting is allowed within the scope of the TOS though

Good point, in that case we should see that as an encouragement to remove the dependency to the polylabel package anyways.

@josxha josxha changed the title [FEATURE] Replace the polylabel dependency with an own port of mapbox polylabel [FEATURE] Replace the polylabel dependency with an own implementation Jan 12, 2024
@josxha josxha removed their assignment Jan 19, 2024
@josxha josxha moved this to To do in Development Jan 21, 2024
@navispatial
Copy link

Maybe a late comment on TOS problems mentioned above but MapBox has published their polylabel implementation as JavaScript code in a separate repository: https://github.com/mapbox/polylabel

The license https://github.com/mapbox/polylabel/blob/master/LICENSE should allow any kind of ports (however this is not a legally verified comment...) as long as license text is provided in all copies.

This is the JavaScript file that covers the whole polylabel algorithm: https://github.com/mapbox/polylabel/blob/master/polylabel.js

It has a dependency to a very simple TinyQueue implementation (with a very permissive license too):
https://github.com/mourner/tinyqueue/blob/main/index.js

Instead of that it's possible to use PriorityQueue class from the Dart package:collection package (as flutter_map seems to already have a dependency on it).

There's also an another port of polylabel to Dart in the geobase package, but maybe that's not an answer either to this issue (as transformation between polyline data structures would be needed also when using it):

@josxha
Copy link
Contributor Author

josxha commented Dec 5, 2024

Hello @navispatial, thanks for your message!
I'd be interested in what your ongoing plans with geobase are? I've seen that geobase is not limited to any projection but supports simple geometries as well, just like flutter_map intends to be. With recent versions, you've added a lot of more complex algorithms like polylabel, point-in-polygon, vincentry and so on. It's great work and you have great documentation as well!
I'd like to ask if you have plans to some day have most or all functionality geospartial analysis tools like turfjs provides? Another more general question, is geobase RFC 7946 compliant, and will it be in the future?

@josxha josxha removed this from the v7.0 milestone Dec 5, 2024
@navispatial
Copy link

Hello @josxha! Thanks for comments and questions on the geobase package .

I just updated an issue Roadmap 2025: The current state and candidate issues for the geobase package #254 on the geospatial repository. Maybe that could give hints what are plans on geobase. Next release geobase 1.5.0 is not scheduled yet but maybe February or March 2025 might be a good guess.

About your questions:

RFC 7946 compliance:

  • simple geometry and geospatial feature classes should be able to represent all data structures decoded from a RFC 7946 compliant GeoJSON data
  • also encoding / decoding support for GeoJSON is based on the RFC 7946
  • there are internal tests on this
  • however no official compliance tests on RFC 7946 are applied

Geospatial analysis tools like those provided by turfjs

  • few new 2D cartesian algorithms and UTM / MGRS based functions on ellipsoidal geodesy is planned on the roadmap of geobase
  • however turfjs is quite extensive library based on WGS84 geographic coordinates
  • currently (at least for 2025) there are no plans on geobase to support such extensive set of geospatial analysis functions (even if a small set of similar functionality already supported by geobase)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature This issue requests a new feature P: 3 (low) (Default priority for feature requests) S: core Scoped to the core flutter_map functionality
Projects
Status: To do
Development

No branches or pull requests

5 participants