-
Notifications
You must be signed in to change notification settings - Fork 122
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
[Feat] Support for Polygon and Polyline #435
Comments
I would argue that we do provide support for the geometry primitives, via the examples. All the components you find in the examples are intended to be copied into your project. I think this approach allows us to provide a far greater coverage of use-cases with the amount of time we have available to work on this library. The more components we have in the core library, the more time it will take to maintain it, so growing the library itself can only happen if the community maintaining it grows along with it. If I may ask, which benefits do you see bundling the components with the library instead of having them available to copy and adjust in the examples? |
Hey @usefulthink, I do agree that copying the files definitely is a valid approach, especially because, in this case, they are not very complex. I also understand that you want to use your limited capacity as efficiently as possible and find that very reasonable. In general, I think providing common use cases on a maintained basis (rather than providing a file to copy) is useful because I can benefit from updates you make to such examples. If, for example, you found a memory leak in your example and fixed it, I would not immediately benefit from that fix. I would need to keep an eye on the example and check for changes on a regular basis (and think about how to apply your fix to my own code and hope that the changes you made don't conflict with adaptations that I made to the file). In short: only one party would need to spend maintenance effort rather than everyone who uses the feature. Just to be clear: the above is my general opinion about providing common functionalities. Because of the low complexity of the specific examples of polygon and polyline, it's quite trivial to copy the code and adjust it (and maintain it on my own). This is currently no blocker for us, I just think it might be nice to have that feature out of the box in the future. |
I do agree with @BoveFabio please make this available so we can use it like how AdvancedMarker components can easily be imported and used. |
I do agree with @BoveFabio and @sosukofa can easily be imported and used. |
@usefulthink |
Have a look at the To use the The component isn't completed yet, which is why you can't just import it from our package, but there are people already using it this way. Also, it isn't too complicated, so you will be able to improve it or adjust for problems you see. Please report back if anything doesn't work for you! Here's how the react-google-maps/examples/geometry/src/app.tsx Lines 39 to 43 in f17bb37
The react-google-maps/examples/geometry/src/components/polyline.tsx Lines 71 to 76 in f17bb37
and replace it with a version that directly calls |
Heyy Martin
Thanks for helping me with the polyline, i need your help again concerning
add vehicle image as a marker and rotating the vehicle based on the course
from the data i'm getting
See my current implementation and help me the rotation does not affect the
vehicle marker please i need your help
…On Tue, Oct 15, 2024 at 12:04 AM Martin Schuhfuss ***@***.***> wrote:
Have a look at the app.jsx
<https://github.com/visgl/react-google-maps/blob/main/examples/geometry/src/app.tsx>
file of our 'Geometry' Example
<https://visgl.github.io/react-google-maps/examples/geometry>.
To use the Polyline component, you have to copy the code from
./src/components/polyline.tsx
<https://github.com/visgl/react-google-maps/blob/main/examples/geometry/src/components/polyline.tsx>
somewhere into your project and import it from there.
The component isn't completed yet, which is why you can't just import it
from our package, but there are people already using it this way. Also, it
isn't too complicated, so you will be able to improve it or adjust for
problems you see. Please report back if anything doesn't work for you!
Here's how the Polyline is created within the map-component:
https://github.com/visgl/react-google-maps/blob/f17bb37dbf588216e904103069c9323629b10f76/examples/geometry/src/app.tsx#L39-L43
The encodedPath uses a special format for the coordinates. If you have
dynamic data, you can create them from an array of coordinates with the
@googlemaps/polyline-codec
<https://github.com/googlemaps/js-polyline-codec>, or you can essentially
remove this part here:
https://github.com/visgl/react-google-maps/blob/f17bb37dbf588216e904103069c9323629b10f76/examples/geometry/src/components/polyline.tsx#L71-L76
and replace it with a version that directly calls polyline.setPath()
<https://developers.google.com/maps/documentation/javascript/reference/polygon#Polyline.setPath>
.
—
Reply to this email directly, view it on GitHub
<#435 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/A3326P7P4QM23TQ7REWFHGTZ3REXPAVCNFSM6AAAAABJ7KEHBKVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDIMJSGQ4DIOJRGU>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
Target Use Case
While I can already easily use many components like (advanced) markers, there is currently no polygon or polyline support. Obviously, it is possibly to write some code myself or even take the code from your geometry example in this repo. But it would be nice if polygon and polyline became officially supported.
Proposal
The basis is already there in the geometry example in this repo. It would probably only take a bit of refinement and could then be offered as a component the same way as markers, for example.
The text was updated successfully, but these errors were encountered: