2
0

JoinEditor.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import { LabelElement } from 'flow';
  2. import { BaseNodeEditor } from '../BaseNodeEditor.js';
  3. import { JoinNode, UniformNode, float } from 'three/nodes';
  4. import { setInputAestheticsFromType } from '../DataTypeLib.js';
  5. const NULL_VALUE = new UniformNode( 0 );
  6. export class JoinEditor extends BaseNodeEditor {
  7. constructor() {
  8. const node = new JoinNode();
  9. super( 'Join', node, 175 );
  10. const update = () => {
  11. const values = [
  12. xElement.getLinkedObject(),
  13. yElement.getLinkedObject(),
  14. zElement.getLinkedObject(),
  15. wElement.getLinkedObject()
  16. ];
  17. let length = 1;
  18. if ( values[ 3 ] !== null ) length = 4;
  19. else if ( values[ 2 ] !== null ) length = 3;
  20. else if ( values[ 1 ] !== null ) length = 2;
  21. const nodes = [];
  22. for ( let i = 0; i < length; i ++ ) {
  23. nodes.push( float( values[ i ] || NULL_VALUE ) );
  24. }
  25. node.nodes = nodes;
  26. this.invalidate();
  27. this.title.setOutput( length );
  28. };
  29. const xElement = setInputAestheticsFromType( new LabelElement( 'x | r' ), 'Number' ).onConnect( update );
  30. const yElement = setInputAestheticsFromType( new LabelElement( 'y | g' ), 'Number' ).onConnect( update );
  31. const zElement = setInputAestheticsFromType( new LabelElement( 'z | b' ), 'Number' ).onConnect( update );
  32. const wElement = setInputAestheticsFromType( new LabelElement( 'w | a' ), 'Number' ).onConnect( update );
  33. this.add( xElement )
  34. .add( yElement )
  35. .add( zElement )
  36. .add( wElement );
  37. update();
  38. }
  39. }