-
Notifications
You must be signed in to change notification settings - Fork 178
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
Define shape for physics body #57
Comments
Hi @oleksiikiselov, So are you saying that you are able to render complex shapes using SVG - however, you also need to attach these complex shapes to a physics body so that you can perform physics simulations with MatterJS? Have your tried creating a composite body using multiple shapes and constraints? The
|
Hi @bberak, Thank you for the response. I think creating composite body might be too hard because the shape we need is too complex, but I will try to sort out the issues with SVG. The main issue is that according to |
Hi @oleksiikiselov, Are you able to process the SVGs ahead of time to get their vertices rather than parsing them in real-time? This would allow you to use JSDOM or other tools to get the vertices during development, save the vertices alongside the SVGs and then reference the vertices when required during runtime. This should hopefully prevent you from having to load and use heavy tools whilst the actual app is running.. |
Hi @bberak, Yes, I was thinking about that, have to make sure that I will be able to do animations with that approach in the future, but I plan to try that for sure. Thank you. |
No worries @oleksiikiselov - sounds like an interesting project. Let me know how it goes.. |
Probably it’s kind of necroposting, but @oleksiikiselov did you succeed in this issue? PS. Also previously I tried iOS native development using swift and this issue about low FPS with collision handling for complex shapes is even documented there in swift. |
Hey @gokadi, What happens to the performance of your game if you turn off / remove MatterJS collisions completely? Does the FPS improve? I suspect the low FPS is most likely due to the number of entities you are rendering at one time - but it might be useful to isolate the issue..
Interesting.. Could you point me to this documentation by any chance? Cheers, Boris |
Hi!
Yesterday I removed Matter from the project completely, and, well, fps slightly improved, but very slightly.
Well, it's not bluntly stated here, but still...
I think I faced several similar issue when I tried to do it, but unfortunately no links are saved from that time. Collision there was between very complex edge-based sprite and simple rectangular bullet. When collision started, fps dropped to almost 0. That's why I guess it's something related to this functionality on the "native" level. Too many computations are needed for very complex shaped, I guess. |
Thanks for the link @gokadi. Hopefully you can get away with very simple compound bodies for your bullet hell game. However, as I mentioned in the other thread, the bottleneck for you will probably be the large number of dynamic sprites and particles that will be moving on the screen (plus I'm sure the physics calculations for this on the JS thread will be relatively slow). |
Hello everyone!
I am using
react-native-game-engine
andmatter-js
for my application and I want to render a shape of my SVG element for example. On thereact-native
side it works great because I just show it inside my renderer component withreact-native-svg
. But the issue is that I also need amatter-js
physic body to have the same shape in order for physics to work correctly.I tried using
Matter.Bodies.fromVertices
method, but have a lot of issues during SVG conversion, so that was unsuccessful. I also found this guide https://www.codeandweb.com/physicseditor/tutorials/how-to-create-physics-shapes-for-phaser-3-and-matterjs, but it won't work because it is usingMatter.Render
and I am usingreact-native-game-engine
instead.So the question is how to render custom shapes and what is the preferable way to create them? Maybe
tree-js
will fit better for that?The text was updated successfully, but these errors were encountered: