-
-
Notifications
You must be signed in to change notification settings - Fork 743
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
Collision boxes drift toward angled geometry despite text-offset
#2171
Comments
Isn't this basically the same as #2170? |
I figured it’s a different issue that happens to affect the same property. If you disable |
I see, thanks for the clarification. |
* Add render tests for text-offset with curved lines. * Improvements to text-offset for symbol-placement: line. Instead of offsetting glyphs directly from line (which causes gaps or overlap at line vertices), create an offset line to place glyphs along. * Updated render tests with new behavior for text-offset with line labels. * Add CHANGELOG entry. * Add ProjectionCache typing * Add line intersection unit test. * Add render test for collision issue #2171 * Add more line intersection tests. * Move findLineIntersection into util * Factor out projectVertexToViewport and findOffsetIntersectionPoint Add comments Rename variables with preference for avoiding abbreviation * Factor out normal calculation into a function. * Unit tests for line offset calculation. * Add jsdoc style type comments. * Reduce indentation.
Fixed by #2260 |
maplibre-gl-js version: 3.0.0-pre.4 (but this issue has been reported since at least 2017)
browser: Firefox 109 on macOS
Steps to Trigger Behavior
text-field
andsymbol-placement
set toline
.text-offset
to a different value to spread the layers apart.Link to Demonstration
In this test case, there are two labels that say “Lorem ipsum dolor sit amet”. Each is rendered by a symbol layer that is identical except for a different
text-offset
.text-ignore-placement
remains disabled:https://jsbin.com/zuxuyap/edit?js,output
showCollisionBoxes
is enabled: the blue circles are the collision boxes of the label that GL JS decided to show, while the red circles are the collision boxes of the label that GL JS decided to hide.Expected Behavior
Both labels should be visible. The collision boxes should approximately align with the rendered glyphs.
Actual Behavior
The second layer’s label collides out the first layer’s label, even though there’s plenty of room to show both. Both labels’ collision boxes drift toward the angle in the geometry instead of staying consistently offset:
Impact
Typically, you’d style an international border by labeling a different country on either side of the border. This requires
text-offset
. However, this issue means that, on a sufficiently curved border, only one of the two labels will ever appear. For a practical example in a real, deployed style, see https://github.com/ZeLonewolf/openstreetmap-americana/pull/753#issuecomment-1413315442.Depending on the style, it may be possible to partially work around this issue by setting
text-ignore-placement
totrue
, disabling collision detection. However, the issue still reproduces, just less frequently. Moreover, in some styles, this may cause other layers’ labels to overlap, making them unreadable.This issue was previously reported and confirmed in mapbox/mapbox-gl-js#4798 (comment).
The text was updated successfully, but these errors were encountered: