-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Create a specification for primitive physics shapes (boxes, spheres, etc) #1986
Comments
I have written a draft here of a spec that handles collision shapes: It covers the main features of Blender, Newton Dynamics, and Bullet Physics. Convex hulls are explicitly defined, and stored in binary. Polygon mesh shapes support a varying number of indices per face, or can use a constant number of indices (i.e. triangle or quad meshes). Multiple shapes can be defined per node. I have never seen a hierarchy of collision subobjects in a physics lib, we always just use a group of subobjects that are treated as one. The spec does not include physics properties or joints, as those can be implemented in a separate self-contained extension if desired. |
@Leadwerks There is an open PR that seems to have a similar (or maybe even the exact same) goal: #2087 (Disclaimer: I have not read into the details of your draft spec (beyond noticing a typo in EDIT: Sorry, that may not have been the perfect fit. The other PR seems to focus on using the glTF built-in structures to define the collision meshes, whereas your proposal might be seen as a combination of ~"allowing defining certain primitives (box, sphere...)" and "allowing to use something (namely a mesh or a one of these primitives) for collision detection". One overlap might be the "convex hull" definition, though... |
@javagl Indeed, these are related, but not the same. This proposal is about defining shapes, not meshes. While you can make a cube out of 8 vertices and 12 triangles, it's not nearly as efficient for physics engines to handle compated to just defining a box collider. Both collision shapes and collision meshes can be used for physics and more, so they are related in how they are used. |
@aaronfranke Yes, sorry, I'll have to read the PRs/proposals more closely (i.e. this one, the one that Leadwerks mentioned, and the one from MAXAR that I linked to). From quickly skimming over them, I can only make some vague, high level points (that may or may not be obvious):
Regarding 1.: The term 'primitive' is a bit loaded, due to
Modeling that cleanly could already be difficult. Keeping the use case of "collision detection" in mind: Collision detection with a sphere is trivial. Collision detection with an ellipsoid is pretty much non-trivial compared to that. Also, for pure rendering this should probably include "half-spheres", maybe "cylinder segments", and maybe even slightly more complex objects like a "chamfer box". Or, more abstractly, some of the questions are:
Regarding 2.: The main point here is: It would be great if it was possible to use geometry for collision detection transparently, regardless of whether it is a "primitive", or a glTF
But I'm pretty sure that some of these aspects are already covered in the existing proposals, to some extent. One thing that I found "surprising" from the first, quick glance at the Another thing is the aforementioned overlap between the concepts for a "convex hull". While it could be presented with a glTF
The reason for that is that for collision detection, it would be important to know that this mesh is guaranteed to be a convex hull. (Checking that manually for an arbitrary glTF |
I'm not in madly in love with any particular spec as long as it contains the most common features that Blender, Newton, Bullet, and PhysX will use. I'm happy to help work on the spec or plugin if we can agree on the design. Of all the people talking about this, who actually has experience working with the glTF exporter for Blender? That is probably the person who will be calling the shots on this. In my document, the offset matrix of the shape is meant to be multiplied by the node's matrix. This was designed around the collision offset matrix in Newton Dynamics, but encompasses the "axis" functionality in the Blender physics spec. |
Since this proposal was written, work on the OMI_collider and OMI_physics_body has progressed. Hoping to see reviews. |
|
I like the simple nature of this proposal! I'm not totally sure that the collision details ("has sensor", physics properties, etc) are necessarily the same as "I just want a box in a scene." I ended up with something close to this proposal when I wanted a spec for the "lowest common denominator" primitive-as-JSON exports, here's the JSONschema. Basically it's the minimum reproducible information (i.e. for a cylinder |
Since opening this proposal, These extensions support all of the use cases I mentioned in the OP, but in a cleaner way. Here is a test project with several simple test GLTF files: Godot_GLTF_OMI_physics.zip I'll give some specific responses to the comments in this thread: @Leadwerks Compared to your @erikdahlstrom @mikedh Compared to your spec, OMI physics does not specify any transforms, which is not necessary information since it's already present on the GLTF nodes that the colliders are attached to. OMI physics does not have WKT or extrusion shapes, and OMI physics makes the distinction between convex hull and concave mesh shapes. Also, OMI has @javagl You've made many good points in this thread, thank you! For OMI physics we're keeping things fairly simple, driven by what's commonly needed, so for example we do not have |
I'm not deeply enough involved here (on a technical level, and also in view of the engines/implementations that might use or support these extensions) to provide profound, technical feedback. I could look at a particular extension specification on a "high level" (e.g. whether the JSON schema is consistent and in line with other parts of the glTF, and maybe raise a few domain-specific questions). But beyond that, my thoughts have mainly been related to trying to carve out the "description of geometric objects" in a way that can be reused elsewhere (also see my latest comment at eoineoineoin/glTF_Physics#1 (comment) ). Whether or not that's feasible is hard to say without digging deeper into each proposal. |
@aaronfranke I'm leaving this for @bjornblissing to answer, as I'm no longer with Maxar. |
EDIT: Please note that the specific details in this proposal no longer reflect what I believe to be the best approach. The goals behind this proposal, specifying geometric shapes, are still valid.
I'm working on Godot Engine and I would like the ability to specify primitive geometric shapes in a GLTF file for the purpose of being read and used by a physics system and by other systems such as audio.
I have seen that #1135 exists, and it has received some negative feedback. It's a huge proposal which includes things like physics materials, joint constraints, gravity, and more. Really the full extent of that proposal is overkill for what I want, so I am opening this proposal to hopefully get something simpler added to the specification.
Godot has a GLTF exporter, so I will try to be as specific as possible as to what the output currently looks like in the
.gltf
file and what the desired output would be if this specification was added.Here is a screenshot of an example scene I am working with (
core.tscn
from the TPS demo):And here is that same screenshot but with the meshes hidden, so that only the primitive colliders are visible:
When exporting, the collision primitives easily visible in the second screenshot are not preserved. However, each of the collision shapes do get exported with a name, rotation, and translation, just with no shape defined. It looks like this in the
.gltf
:If allowed by the spec, the information about primitive shapes could look something like this:
Here is an overview of what the proposed API could look like. All numbers must be >= 0.
primitive_box
size
member of type Vector3 (three numbers), which specify the "diameter" of the box, sosize
of[1, 1, 1]
means a 1x1x1 cube.size
withextents
that defines the "radius" of the box, soextents
of[1, 1, 1]
means a 2x2x2 cube.primitive_sphere
radius
member which is one number that defines the distance from the center to the surface.primitive_capsule
radius
member which is one number that defines the distance from the center to the surface of both "cap" semi-spheres.height
member which is one number that defines the distance from the very bottom to the very top.primitive_cylinder
radius
member which is one number that defines the distance from the center to the edge of both circles.height
member which is one number that defines the distance between the centers of both circles.Arguments can be made for a few other primitive types, such as cones, cylinders with different end sizes, and rays. However, the above are the only ones I'm familiar with and I know to be broadly useful.
This information would be much more efficient than storing mesh triangles for each physics object, and would make it easier to move scenes between projects and even between different game engines. These shapes could be used by more than just collision, for two examples in Godot, Area nodes can be used to change the audio settings for some part(s) of the level, and can also be used to change the gravity for some part(s) of the level.
This is really two proposals in one, with the below dependent upon, but really separate from, the above. Without the below, software would just have to guess as to what the purpose of the shapes are, or let the user specify with import settings.
To make this proposal even more useful, it would be nice to be able to define the purpose of the shapes. Because physics bodies are very often composed out of multiple shapes, each object with a shape would be children of a parent physics body of some kind. In the case above, one of them looks like this in the
.gltf
file:Then, the parent body would have its purposed defined, something like this:
The exact API of this part is something I'm less sure about than the above shape API. We want to be able to specify many different types of physics bodies to provide as much information as possible to software, including rigid, kinematic, static, character, area detection, audio manipulation, and more. The specific details of these things (like defining mass or whatever) are simple and specific enough that we should consider letting each piece of software handle it on their own. It could be argued that these things (like mass etc) are worth defining in GLTF, but not in this proposal specifically. In this proposal the goal is to be able to define primitive geometric shapes, and likely also define the purpose of the shapes.
The text was updated successfully, but these errors were encountered: