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

default marker offset #6012

Merged
merged 2 commits into from
Jan 25, 2018
Merged

default marker offset #6012

merged 2 commits into from
Jan 25, 2018

Conversation

andrewharvey
Copy link
Collaborator

@andrewharvey andrewharvey commented Jan 18, 2018

Launch Checklist

  • briefly describe the changes in this PR
    Provide default element for Marker class per #3557 #5661 implemented a default Marker element, this PR applies an offset for that default Marker, so the tip of the marker image is located at the marker lng/lat.

  • write tests for all new functionality

  • document any changes to public APIs
    I don't think it needs any special documentation as I'd consider it to be expected behaviour so I consider this to be a bug fix rather than a breaking change.

  • post benchmark scores

  • manually test the debug page

Copy link
Contributor

@mollymerp mollymerp left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change makes sense to me and looks good when testing locally – I just had one comment about the offset amount.

src/ui/marker.js Outdated
@@ -127,8 +125,22 @@ class Marker {
svg.appendChild(page1);

element.appendChild(svg);

// if no element and no offset option given apply an offset for the default marker
const defaultMarkerOffset = [0, -14];
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

did you determine the -14 through trial and error or some other way? seeing that the SVG is 41px tall makes this number non-obvious to me, although it looks great when I tested the branch. it would be nice to avoid hardcoding this constant and get the offset from some of the SVG properties.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I actually opened the SVG in Inkscape and measured the distance from the image center to where the tip is, but you could calculate it based on the center of the shadow ellipse, from the SVG, but it would add a fair bit more code and not sure how useful that would be. I've added some comments on where the -14 magic number came from.

What do you think, should be leave it as is with the comment or go ahead and calculate it on the fly from the SVG?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

gotcha – I think we can leave it hardcoded for now with the comment.

@andrewharvey andrewharvey force-pushed the marker-default-element-offset branch from 8c75c46 to e49ca66 Compare January 24, 2018 01:55
Copy link
Contributor

@mollymerp mollymerp left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @andrewharvey – this works for me. One thing I thought of was maybe adding a comment to the element param of Marker constructor to indicate that, if an element is provided, the marker will be placed such that the center of the element is on the LngLat they set so users will know they need to offset if they want different behavior.

@andrewharvey
Copy link
Collaborator Author

andrewharvey commented Jan 25, 2018

Thanks @andrewharvey – this works for me. One thing I thought of was maybe adding a comment to the element param of Marker constructor to indicate that, if an element is provided, the marker will be placed such that the center of the element is on the LngLat they set so users will know they need to offset if they want different behavior.

Thanks for reviewing @mollymerp .

@jay-manday is working on Marker anchor at #6031 which also brings in Flow and better JSDoc for Marker. I think once the anchor option is introduced it makes it a bit clearer that by default they are anchored to the middle, so I'm tempted to leave the comment out and have it addressed in #6031, which also helps reduce the conflicts which have arisen between both PRs.

Does that work?

@anandthakker
Copy link
Contributor

Thanks @andrewharvey !

@anandthakker anandthakker merged commit d11cf30 into master Jan 25, 2018
@anandthakker anandthakker deleted the marker-default-element-offset branch January 25, 2018 02:08
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants