-
-
Notifications
You must be signed in to change notification settings - Fork 35.5k
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
Utils: Deprecate Exporters (Blender, 3DS Max and Maya) #12903
Comments
+1 for this - the existence of poorly maintained and out of date exporters in the repo is a unnecessary point of confusion for newcomers, especially since as @Mugen87 points out there are now much better options. |
Note: official GLTF Blender exporter (https://github.com/KhronosGroup/glTF-Blender-Exporter) doesn't currently allow proper animation export (only 1 animation per object is supported currently). |
@Usnul how does that compare to the Blender JSON exporter in this repo? |
@looeee |
OK, I don't use Blender so I won't comment further on that. However I can say from experience that trying to use the 3DS Max exporter, which hasn't been updated in several years, is an endless headache and I would strongly support removing it from the repo in favour of the FBX format. Similarly with the Maya FBX exporter, although the FBXLoader still needs to be updated to properly support pivots points there. |
When i remember correctly, Blender does not export animations when you select |
I think we should remove the Revit exporter README too - it just links to a separate repo which looks like it's barely been touched in last couple years. There are probably hundreds of three.js tools we could link to like this, but unless we are willing to make sure that they are actively maintained and working correctly, I don't think we need to include links to them here. Googling for "three.js revit exporter ' finds the repo just fine anyway. |
👍 |
I just want to highlight this statement because i think it's very important for |
As an innocent user, may I dare to give a comment ... Concerning Blender: No installation effort on Blender side, There were tremendious efforts to write the JSON exporter in python, |
@wolfgangvonludwigsburg |
@wolfgangvonludwigsburg if you were to look into building a .blend file loader, this would probably be a good place to start: https://raginggazebo.com/parsing-blender-3d-files-blend-1-of-3/ |
Many THX for your comments! But why is the Blender JSON exporter such error prone ... A very lot of tasks, that all can (and really do!) fail, mainly on Blender version changes. |
That's no good approach. Loading |
Unfortunately there are deeper problems with using |
To the original question, I'm going to skip adding a yes/no vote as I don't have much familiarity 3D authoring workflows. But as a maintainer and primarily a JS dev, being able to focus on loading and support for formats like FBX and glTF — which have actively maintained third-party authoring tools — does feel more likely to give reliable results. Aside, if there are any problems with current glTF ecosystem that prevent it from being a good enough workflow to solve this type of need, that's helpful feedback as well. 🙂 |
I did'nt argue to use the Blender .blend format as a general exchange format, I cannot estimate the efforts, maintaining a Python exporter + GUI under the Blender framework, @donmccurdy |
Yeah I think OBJ isn't mentioned here because the format doesn't support some popular features like animation, but certainly three.js will keep supporting OBJ for a very long time — it's a classic and reliable format. 3DS Max's |
One last throw in ... We already do have one modeling tool independant ex/importer: Collada, Preferably I did have this implementation kind in mind: https://developers.google.com/protocol-buffers/ It's a
Since the 2D/3D vector data we have to deal with are not so overly complex in nature, developing one Blender data file schema should be simply feasable ... |
There is actually a blend file parser in javascript 😁 |
uhh, I get support ... - thank you mrdoob ;-)) |
THE biggest (in terms of Terrabyte) 3D Model Application (Google Maps 3D) uses this efficient kind (protobufs) of implementation ... |
Going down the path of loading .blend may not be very sane. But is not really that different from loading .dae and .fbx... |
Anyway, I agree with the idea of deprecating the exporters. |
I agree with removing those exporters as well. You could even move them to some other repo where they can RIP :) |
Waiting seems reasonable to me. In particular for glTF it would be good to have a few things in place first:
Revisiting the question in Summer 2018 sounds about right. |
For the Blender exporter, I tend to agree. However I recommend removing at least the 3DS Max exporter immediately since there is already a mature and much better alternative in FBX. |
Sounds good to me 👌 |
Chiming in as a user of the Blender exporter here: one advantage of having the JSON is that it is extremely simple to modify after the export. Blender is only a part of our automated toolchain, and we do a lot of processing on the exported JSON, before it is ready to go to our web viewer. Having a transfer format that is so close to the internal threejs format, is a major bonus for us. Also, we've done some tests with other export formats, and have found that the JSON format is not so bad in terms of transfer size, once decently compressed, much better than Collada or FBX, for example. We did a quick protobuffers-based trial, and could go a bit smaller that way, but nothing that was worth the hassle to us. For large scenes and slow clients, the speed of parsing and converting to the internal ThreeJS model also becomes important. Since JSON parsing is heavily optimized in the browsers, and since the model structure is so similar, we've assumed that the JSON format would do quite well in this regard. Haven't actually tested this. |
Soft8Soft just released glTF-based exporter for 3ds Max. So it might be a good alternative to the removed JSON exporter. |
Thanks @alexkowel, great to see that (and congrats!). If you could add a link on this thread we'll list it with other glTF resources. 🙂 @dherben good points, thanks — About speed of parsing, I expect you'll find glTF to be even faster. The difference essentially is that metadata is still "just JSON" whereas the big parts of the payload (vertex positions, animation data) are in an ArrayBuffer chunk that can used to create a typed array for But for modifications to the data as part of a pipeline, I agree that plain JSON is easier to work with, as you said. There are libraries in various languages for working with glTF, but the tooling is not yet very mature. |
Current status of this issue: Exporters:
Converters:
|
@donmccurdy Just wanted to get back after experimenting more with glTF Blender exporter and Three.js loader. Turns out it is actually working quite well as scene format for our use case so far. What I'm now doing is to load the exported glTF file to a Three.js scene and then manipulate the Three.js scene hierarchy (swapping out placeholders with dynamic loaded stuff) before doing first render. There are probably still some features I'd like to see in glTF exporter, will try to comment or do PRs there :) |
Awesome, please do! 🙂 |
So is anyone going to be working on the current Blender exporter bugs? I expect the answer is no. In that case, we should say so. |
If no one else does before me... I would like to, at least, try to solve the rotation issues. #13130 |
I did not read the whole discussion, but my two cents. Last week I was asked to help a company that has a solution which uses Three.js in content delivery within permanent exhibition. Signages with 3D models that users can explore and interact with. The original devs that are long gone have used Three.js JSON Format. To prepare and get new models in (with a condition that changing runtime code is nogo) is a real nightmare. IMHO Three.js should focus on supporting established and as well as fast growing formats such as FBX and glTF. Priority on those formats that can hold multiple UV data bins (thus beloved OBJ should NOT be encouraged). Then animation. I know that Blender export addon supposedly supports both, but so does FBX. Imagine workflow where Blender'ed stuff goes out to
Instead of having to use many different exporters for different outputs the goal would be to use 1, max 2 formats. When writing OGL in the first 3 cases... the same model format should be used, that's it. For the last two points FBX is the king (different implementations for COLLADA across packages make it difficult to work with) and there actually the model is not "exposed". |
@kroko definitely agree 👍 I think the formats landscape is starting to become more clear. The three.js json format was done because there was no json format at the time. Defining a file format was the last thing I wanted to do when I was already doing a rendering engine and a API 😩 |
As a newbie, Three.js JSON exporter was very educational because it allowed me to see the raw data and underlying structure of the output geometries. Other exporters, as efficient as they are, don't let you see the data because they're mostly in a binary format. I agree that removing it from this repo would be the best option today, but as @hccampos said, maybe it could be placed in its own repo to remain for educational purposes. |
There will always be the option of exporting as JSON from http://threejs.org/editor/ |
Closed in #14117. |
I suggest we close now all open issues which are related to the Blender exporter. Agreed? |
I think someone may write some "official" documentation / pipeline for 3D models export/import (for basic and special features), common troubleshoot, and prune out or update all the outdated documents and examples. EG the knight example is very confusing, given that you don't have a blender json exporter anymore. Maybe JSONLoader for 3d models should be just kept for retrocompatibility, but we have to read that, etc. |
@stmaccarelli there is some new documentation here: https://threejs.org/docs/#manual/introduction/Loading-3D-models, but yes please let us know what else would be helpful! |
@donmccurdy I think that paper is poor. The master Animation System doc would be ok if the refs of the single objects would be correct. .CreateClipsFromMorphTargetSequences ( name : String, morphTargetSequence : Array, fps : Number, noLoop : Boolean ) : Array problem is that if I import a glTF file, there's no morphTargetSequence array... there are some morphTargetSomething objects stored here and there, but I don't know what and how to use. I think we should have some docs describing 3D Models management / workflows with very simple examples. We should also check that all the examples that feature 3D model loading, respect the same pattern. We should update examples, and while not possible we should write clearly that some parts are deprecated and what (like in the knight example... ) EG- if we decide that the JSON file format for 3D model should be deprecated, in favour of - say - glTF, it makes no sense that the only animation example that features both skeletal animation and morphtargets is the old knight one, that uses a JSON model from 10 versions ago, that stores a data structure that is not used anymore. |
@stmaccarelli There is no single recommended end-to-end workflow; I think we'd be hard pressed to provide that given different skill levels, preferences for free vs paid modeling tools, and particular needs. I don't think you'd commonly need that
In this case it doesn't matter whether the clips are TRS, skinned, or morph targets — you can play the animations all alike. I've written one possible workflow using Mixamo and Blender. Here is another using Maya.
This is a fair point, and we have some room to improve here.
Strictly speaking the JSON format and data structure are not deprecated, and it's still a totally reasonable way to [de]serialize a scene, but point taken. @mrdoob what do you think about our replacing some of the animation examples? Such as:
|
+1 for this. I vote for replacing at least the soldier from We could blend between idle / walk / run, and it would probably be possible to convert the model to glTF if that is preferred. Model size would be around 9mb, while the current model along with all the associated files is 71mb!! For It's about the same size as the current knight model, but since morph targets are more commonly used for facial expressions I'd say this one makes more sense. Again, it's currently in FBX format but could be converted to glTF if that is preferred. |
Here are a few examples to consider:
They're all animated, work correctly in three.js, and could probably be compressed or optimized a bit more than the Sketchfab download version. I don't have a rigged character with nice run/walk cycles, but the Mixamo->glTF workflow isn't too bad. |
I'd like to suggest the deprecation (removal) of the Blender, 3DS Max and Maya JSON exporters for two reasons:
FBXLoader
andGLTFLoader
) were greatly improved over time. In other words, it is much more likely to loadFBX
orglTF
files with proper results. Besides, these loaders are actively maintained by project collaborators.So instead of exporting to the JSON format, users should focus on other formats like
FBX
orglTF
. And in context of asset delivery, especiallyglTF
is a much better format than (uncompressed) JSON.The text was updated successfully, but these errors were encountered: