-
Notifications
You must be signed in to change notification settings - Fork 2.3k
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
Marker offset changes from 0.38 to 0.39 cause marker to jump on map drag #5131
Comments
@keyofj how are you performing these moves? |
@peterqliu We use Kendo UI draggable for our custom markers. We spent some time digging into this more today and it looks like it might be when the map is dragging and the custom 2d markers are having the transition property updated, it acts like it does not take into account the offset of the marker. Not conclusive yet. |
@keyofj I'm unsure how Kendo works, but if it's pure DOM manipulation, note that mapbox-gl does not track marker state (or any state, really) in the DOM. You will need to update marker position by calling .setLngLat() |
Yes sir we do that as mapbox does not have built in draggable features as Google.
The issue is not Kendo. There is a change made in mapbox from version 38 to 39 that is causing the issue. From the change list for 39 there was a change to the marker and how it centers. I surmise that it was done in relation to symbols and not the marker object?
Get Outlook for Android<https://aka.ms/ghei36>
…________________________________
From: Peter Liu <notifications@github.com>
Sent: Thursday, August 10, 2017 5:37:37 PM
To: mapbox/mapbox-gl-js
Cc: Michael Clark; Mention
Subject: Re: [mapbox/mapbox-gl-js] Marker offset changes from 0.38 to 0.39 cause marker to jump on map drag (#5131)
@keyofj<https://github.com/keyofj> I'm unsure how Kendo works, but if it's pure DOM manipulation, note that mapbox-gl does not track marker state (or any state, really) in the DOM. You will need to update marker position by calling .setLngLat()<https://www.mapbox.com/mapbox-gl-js/api/#popup#setlnglat>
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub<#5131 (comment)>, or mute the thread<https://github.com/notifications/unsubscribe-auth/AHoyQNjHJn2_JjdWZgMEdJFp0zYxscBrks5sW3ghgaJpZM4Oz0Qa>.
|
@keyofj can you please provide a minimal example on jsfiddle or jsbin that reproduces the behavior you're seeing? |
@mollymerp v0.38.0 - works Please note the marker placement in each example. v0.39.1 places the marker higher covering the street name where v0.38.0 is placed correctly on the LngLat. |
Thanks @keyofj, that JSFiddle helped -- I can see why it's behaving that way. When |
@jfirebaugh Thanks! I thought that with the Kendo draggable that the callbackSuccess was fired after the dragend but that was just an assumption on my part. I moved the show() method into the callback success and updated the offsets based on centering of marker and this appears to fix the problem for us. I will modify once the other update is completed. Thanks again! |
mapbox-gl-js version: 0.39.1
Steps to Trigger Behavior
Move the marker to an intersection as a reference point
data:image/s3,"s3://crabby-images/211bf/211bf23eccd8e92db2e6c4c28c86bd91958b33c4" alt="image"
Click on the map away from the marker, and SLIGHTLY drag the map.
data:image/s3,"s3://crabby-images/7a67e/7a67e5669231c6da7a19cee60fba77ac32bcb0ce" alt="image"
Expected Behavior
The marker remains at the position moved to.
Actual Behavior
The marker jumps and ignores the applied offsets.
Referencing the updates for 0.39 I saw that the marker was updated to position at its center. Taking that change into account I adjusted the marker offset with no effect. I can even take an offset off completely and it has the same behavior.
We also attached a mapbox popup to the marker and found that when the marker is originally placed on the map the popup opens centered on the marker (no offsets have been applied to the popup).
If I move the marker to another position and click to open the popup the popup is aligned to the top left of the marker.
When I again click on the map and slightly drag, the marker jumps to the popup.
data:image/s3,"s3://crabby-images/a721f/a721f0e6fa5fcc015f726f97da9be9f2446950de" alt="image"
If I revert back to version 0.38.0 none of the above happens and all is fine. The placement of these markers is critical to our application as the center point is used in reports to calculate distances. If the markers jump like this then those reports can be incorrect.
Any suggestions?
The text was updated successfully, but these errors were encountered: