-
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
GLTF for standalone material files #1420
Comments
Hello Josh, I'm also new to glTF, and I've been looking it over for a couple weeks now. You could probably do this with extensions. You could dump "materials" and everything below it (textures,samplers,images) into its own material file. Then, add a uri reference to this material file using your own extension. If the importing app didn't support your extension, then it would just ignore it, and use whatever default material is provided in the scene. But, to make it useful, other apps would have to support it, like Substance Desiger. Or you would have to write your own exporters.
Just an idea off the top of my head. Don't know if it'll work or not for you. |
No need for an extension — the spec allows this already:
For example, a glTF file might contain only a {
"asset": {...},
"materials": [...]
} However, I'm not aware of exporters that currently create files this way. In three.js we're working on loading arbitrary pieces of a glTF file: mrdoob/three.js#14492 |
It's good that this is at least accounted for. Is there any official file extension for GLTF materials, like "GLMF" or something? |
+1 for Don's comments, but I'll toss in a caveat here. Sometimes in Substance Painter I'll have a clean surface that's been splattered by mud a certain way, or a metallic surface with rust spots, etc. My point is that "materials" in the physical, non-GPU sense of the word, can be considered as per-texel in glTF 2. You often can have a metallic texel next to a rust texel, with the rust pattern highly specific to the current model geometry. The things that glTF labels as "materials" are more akin to render states or texture sets for a whole region of a model comprised of multiple physical materials. In core 2.0 without extensions, each one is a copy of the core PBR material with some blend/cull options toggled and a specific stack of textures. Generally I don't expect this type of glTF material to be reusable across models, certainly not the way SP material presets are easily reusable. |
Just a question, assuming a glTF scene has been split up into parts, how does an importing app recognize multiple asset files? Should it scan the entire local directory for assets? And how does it know those asset files belong to each other, if the main file doesn't contain any uri references to them? Or are you using a file naming scheme, like myscene0.gltf, myscene1.gtlf, myscene2.gltf, etc... |
The .gltf file will contain references to all textures and .bin files it uses, and the importing app can load them as needed. |
In Leadwerks Game Engine, a material consists of the following:
So that's where I'm coming from. My dream is to be able to select a GLMF file in Windows Explorer and have stock Windows display a sphere with the material on it in the preview pane. |
In core glTF 2.0, the material definition is similar. It consists of:
The Damaged Helmet model has an example of what I'm talking about. This model has metal, glass, lighted elements, and rubber hoses, among other details. How many glTF materials are being used to convey all of these different substances? This model was originally textured in Substance Painter, and several different SP material presets were clearly used in its construction. But the final result was exported to a single base color, a single metal/rough, a single occlusion, a single normal map, and a single emissive map, that collectively form a single glTF 2.0 core material. I do like the idea of using the glTF container to share libraries of things, but in the case of materials, I think there are some practical considerations that may complicate the process. |
98% of materials are going to use the default PBR shader paradigm, so I am fine with that. Custom shaders are an exception and should not dictate the capabilities of the entire system. One of the strengths of GLTF is that Khronos is actually making firm decisions this time around. You could make a good case for a Blinn-Phong mode, but anything in addition to that is going to depend on the individual engine the material is meant to be used in. |
Yes. I can imagine a glTF with a bunch of |
Okay, I tried isolating a material from the damaged helment GLTF file and this is what I came up with: What do you think?
|
If we modify the damaged_helment GLTF file to use external material files, then it looks like this:
|
I think this arguably fits into #1518, i.e. rather than designing a mechanism specifically for materials to be referenced in an external file, perhaps (or perhaps not) there should be a more general mechanism for referencing a resource that handles external references? On the other hand, more feedback would probably also help to prioritize this; I'm not sure how common it is for the material JSON to be large enough to benefit from using external files, or if this is more of an asset management convenience. |
I've been working with GLTF for a while now and have a better understanding of the format. It seems like we can use this for material files, adding some extensions where needed. I am interested to if Khronos gives some more direction on this sort of usage. The main reason I am doing this is because our editor has CSG level design features so the developer is using a lot of standalone material files not embedded in a model. |
I think, if you're not dissuaded by my comments above, the next step would be to put together a sample of what a stand-alone material file would look like in glTF. At a minimum it would have the |
Okay, below is an example of a valid standalone GLTF material.
Because the spec says a GLTF file can contain "libraries" (plural) of assets it makes sense to indicate which material is considered the "main" asset, so I added a "material" parameter similar to the "scene" parameter, indicating which material to load. This also makes implementation easier because if this value is present you know it is a GLTF material file. After thinking about it a while, I think it's probably best to continue using the gltf / glb file extension for all asset types, and not getting tricky with new extensions.
Loading this material from another GLTF file is a no-brainer:
So this only needs two small changes to work:
|
Rather than adding That said, I'm most curious about the contents of So I question the practicality of this, but, from a technical perspective, getting it through the glTF Validator (possibly with the help of an extension) seems easy enough. |
Sounds good, that's a good use for it. |
I'm just starting to look into the GLTF spec, and so far I approve of most of the design decisions. One thing I am not seeing is whether the format supports / is meant to support standalone material files. There are many situations when a material should be shared by multiple model files or just kept as a standalone asset the user can load programmatically. Considering how bad the state of cross-application materials is in the game industry, this seems like a golden opportunity. I was disappointed to see that Substance Designer does not export materials in GLTF format. It seems that the spec designers think of a material as being a bunch of settings attached to a model.
If it's conceivable, I would like to replace our model and material files entirely with GLTF.
What can you tell me about this?
The text was updated successfully, but these errors were encountered: