Skip to content
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

NodeMaterial visual editor #14244

Closed
pailhead opened this issue Jun 8, 2018 · 32 comments
Closed

NodeMaterial visual editor #14244

pailhead opened this issue Jun 8, 2018 · 32 comments

Comments

@pailhead
Copy link
Contributor

pailhead commented Jun 8, 2018

The discussion in #7522 became convoluted, with several different topics overlapping.

One topic is:

NodeMaterial is verbose when coding, i can't make heads or tails with it, especially when compared to just writing GLSL.

To which the answer is mostly:

You're not intended to code, there will be a visual editor.

I actually didn't understand if @sunag's visual editor will be open sourced and will be part of three.js.

I'd like to discuss the visual editor component to NodeMaterial. When, how, why, etc. :)

For example:

I saw this editor https://shaderfrog.com/ mentioned in #7522, how does the three.js community decide which closed/open source tool it should depend on? What's the significance of SEA3D in this context and how does it relate to three.js?

@donmccurdy
Copy link
Collaborator

NodeMaterial is verbose when coding, i can't make heads or tails with it, especially when compared to just writing GLSL.

You're not intended to code, there will be a visual editor.

I would disagree with those assumptions, actually:

  1. If NodeMaterial went into src/, we should keep backward-compatible MeshFooMaterial classes that construct appropriate node materials for users. If users are doing things three.js already supports, they may as well keep using those.
  2. For a good subset of customizing existing three.js materials (e.g. per-vertex alpha, per-texture transforms, additional UV sets, texture swizzles, ...) writing NodeMaterial code is not hard. We should write docs, of course, but these features will be fairly easy to accomplish in code.
  3. For more custom shaders, or users who simply have a particular workflow preference, using a visual editor or writing a custom ShaderMaterial in a code editor are both viable options.

I think that the visual editor will help those who aren't comfortable writing shaders, and some artists and developers coming from other workflows may just prefer it. But I certainly do not think coding with NodeMaterial is by any means impractical.

About the particular visual editor — I think the examples given in #7522 are just examples. We'll want to build something specifically for three.js, based on existing work if possible...

@pailhead
Copy link
Contributor Author

pailhead commented Jun 8, 2018

Thanks for the input

  1. will this take away the ability for me to use onBeforeCompile as i was using it now? Ie. will my app that has onBeforeCompile break?
  2. no visual editor involved? Devs would write GLSL that would have to be wrapped with nodes?

What i've heard just now is that the visual node editor will come after NodeMaterial ie. there will be a state of the world where three.js users are (somewhat?) compelled to write code using various Node classes, without a visual editor?

If so, do you know of any framework that currently works like this (nodes, without a node flow visual editor)?

But I certainly do not think coding with NodeMaterial is by any means impractical.

To each their own :)

We'll want to build something specifically for three.js, based on existing work if possible...

I'd be curious to hear a guess on this time line? I could be cocky and ask 2020 :) but in all seriousness, it sounds like it will come after NodeMaterial becomes first class citizen?

@donmccurdy
Copy link
Collaborator

will this take away the ability for me to use onBeforeCompile as i was using it now?

No, or at least I don't think so.

no visual editor involved? Devs would write GLSL that would have to be wrapped with nodes?

you can continue to use ShaderMaterial without wrapping anything in nodes, if you prefer to write GLSL

What i've heard just now is that the visual node editor will come after NodeMaterial ... I'd be curious to hear a guess on this time line?

This is up for debate, I think.

@pailhead
Copy link
Contributor Author

pailhead commented Jun 8, 2018

Well, let's start the debate :)

The timeline on this stuff is very long. If NodeMaterial makes it in tomorrow, waiting another 2.5 years for the editor would be too much.

I think NodeMaterial is not as useful for coders, and useless for non GLSL users since they still have to understand how shading works.

Should NodeMaterial be coupled with a visual editor? Why, why not?

@makc
Copy link
Contributor

makc commented Jun 9, 2018

I saw this editor https://shaderfrog.com/ mentioned in #7522

emm, it does not seem to be node-based editor?

screen shot 2018-06-10 at 0 00 06

@pailhead
Copy link
Contributor Author

pailhead commented Jun 9, 2018

I realized that when i started playing with it, some nodes exist but they're for overlaying different materials it seems, so definitely not the tool that's needed?

@makc
Copy link
Contributor

makc commented Jun 17, 2018

Lemme bump this with http://victhorlopez.github.io/editor/

screen shot 2018-06-17 at 12 01 22

this is for litegl but I bet some code could be borrowed to bring this kind of function in 3js editor

@mrdoob
Copy link
Owner

mrdoob commented Jul 12, 2018

@sunag used to have his editor live at http://sea3d.poonya.com/flow/
Seems like the page is no longer working...

@pailhead

This comment has been minimized.

@quacrobat
Copy link

@makc that uses https://github.com/jagenjo/litegraph.js so maybe a good place to start for someone to implement a threejs version?

@mrdoob mrdoob added this to the rXX milestone Oct 15, 2018
@pailhead
Copy link
Contributor Author

That looks like an interesting resource I was trying to find a framework for making a generic graph editor.

@mrdoob
Copy link
Owner

mrdoob commented Oct 16, 2018

@pailhead why was this closed?

@pailhead pailhead reopened this Oct 16, 2018
@pailhead
Copy link
Contributor Author

I think i actually misclicked :)

@pailhead
Copy link
Contributor Author

@mrdoob any thoughts of how a tool built with a dependency like this would fit the big picture? I plan to dig into his some.

@makc
Copy link
Contributor

makc commented Oct 16, 2018

@pailhead there is already loads of files in editor/js/libs so why not add another one? in for a penny - in for a pound.

@pailhead
Copy link
Contributor Author

I had a brain fart. This wouldn’t have to be a dependency of three

@AndrewRayCode
Copy link
Contributor

emm, it does not seem to be node-based editor?

I should make the UI more obvious ;) https://shaderfrog.com/app/view/2826 click "edit" on this shader

screen shot 2018-12-29 at 12 56 11 am

I personally use ShaderFrog to make custom Three shaders, but frankly it's difficult / impossible for other people to do the same, the system does not support it well and I have to download and manually hack the output to suit my needs.

ShaderFrog's node system doesn't use Three's NodeMaterial stuff (nor do I understand the nodematerial stuff) - it's meant to be something more general to glsl.

@looeee
Copy link
Collaborator

looeee commented Jul 9, 2019

Here's an article from Babylon.js on the state development of their node material and visual editor. It's a bit light on details but you can read more details on their implementation and progress on GH and the babylon.js forum.

@pailhead
Copy link
Contributor Author

pailhead commented Feb 3, 2020

Dang, wish I could have seen some of these examples before starting this from scratch,

https://dusanbosnjak.com/test/nodes/

@wonglok
Copy link
Contributor

wonglok commented Feb 24, 2020

Hi Guys, omg i've been dreaming about the APIs of node based material >v< just found this page from google. OMG im so blessed. i've been working on the proof of concept of something that works like a node based system for a few years.

https://age.wonglok.com/
https://effectnode.com/
https://igraph.effectnode.com/

Thank you so much for all your hard work guys >v<!!!!

@wonglok
Copy link
Contributor

wonglok commented Feb 24, 2020

I will definitely try to make a GUI + JSON + SDK for ThreeJS Node APIs for my personal fun fun usage >v<!!! Thank you all!!!! OMG!!!!

@quacrobat
Copy link

I will definitely try to make a GUI + JSON + SDK for ThreeJS Node APIs for my personal fun fun usage >v<!!! Thank you all!!!! OMG!!!!

did you do it??

@wonglok
Copy link
Contributor

wonglok commented May 16, 2020

I will definitely try to make a GUI + JSON + SDK for ThreeJS Node APIs for my personal fun fun usage >v<!!! Thank you all!!!! OMG!!!!

did you do it??

i did it yayyyyyyyy
https://v2.effectnode.com/

@pailhead
Copy link
Contributor Author

Nice! Is this using NodeMaterial under the hood?

@wonglok
Copy link
Contributor

wonglok commented May 16, 2020

Yes :D

https://github.com/wonglok/effectnode2-gui

@quacrobat
Copy link

i did it yayyyyyyyy
https://v2.effectnode.com/

super cool!
but how do you use the result in code?

@makc
Copy link
Contributor

makc commented May 20, 2020

@quacrobat apparently you could press "copy" button and then do this but with the copied json.

@quacrobat
Copy link

@quacrobat apparently you could press "copy" button and then do this but with the copied json.

Thanks, I saw that, but still couldn't figure it out, mainly because I'm not familiar with the Vue.js syntax...
Also, I think this only copies a JSON text that describes the nodes GUI, and is not parsed code that Three.js could read directly. Am I wrong?

I wish that "copy" button just copied code that looks like:

var params = { ... }
var nodeMaterial = new TREE.StandardNodeMaterial(params)

:)

@makc
Copy link
Contributor

makc commented May 22, 2020

vue? no, that is makeMat function that you get from this 120 lines of code file and it should make a material useable in 3js directly

@quacrobat
Copy link

Aha! exactly what i was looking for. Thanks again @makc

@mrdoob
Copy link
Owner

mrdoob commented Jan 22, 2022

#23165

@mrdoob mrdoob closed this as completed Jan 22, 2022
@mrdoob mrdoob removed this from the r??? milestone Jan 22, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

11 participants