I really love using the ThreeJS editor; it feels clean, simple and there’s something uniquely “zen” about creating projects with it.
The only problem I have is importing modules, such as OrbitControls.js, Canon/Ammo.js etc to add extra functionality. I’ve found it nearly impossible to do so, and after some cursory Googling have found other people are struggling with the same.
Does anyone know of an easy way of importing external scripts into the editor?
It would be great to be able to declare/import the modules directly with a dependencies section, and really broaden its usefulness.
IMO, the recommended way for doing this is to fork the project and add the dependencies in the module files.
I’ve mentioned this already at GitHub but for the record I do it here again: three.js is moving to a ES6 module only codebase and thus global script imports will disappear over time. Hence, it’s not a proper solution to include scripts via the script tag. Add adding a solution that automatically imports/install npm package seems to be overkill for the current editor.
Thanks for your quick response. I suppose one of the things that stands out about the editor is it’s incredibly accessible.
As someone who’s slightly more geared towards the visual arts side of development this is really helpful in terms of overcoming technical barriers. It’s a pleasure to use, and explore.
A way to add things like physics and post-processing from within the editor would be really appealing, and almost make it a fully-fledged development suite. Having to fork and edit the source might be a little intense, and puts that technical barrier back up again (for me at least).
I found recently a solution: with a browser recently updated and supporting dynamic ES modules imports you can write a script into the editor (by example onto the scene object) :
This method use browser’s cache so several launches with [Play] button will load the source only once.
eval is here because the code editor (esprima) forbit to use import() directly as it’s a reserved word.
And I created a THREEx global object because the newly ES modules structure of the main three.js lib creates a THREE object that is sealed (not extendable) so you can’t add properties to it…
Don’t forget to add the x in code samples you get from documentation and examples: