JoinEditor.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  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. };
  28. const xElement = setInputAestheticsFromType( new LabelElement( 'x | r' ), 'Number' ).onConnect( update );
  29. const yElement = setInputAestheticsFromType( new LabelElement( 'y | g' ), 'Number' ).onConnect( update );
  30. const zElement = setInputAestheticsFromType( new LabelElement( 'z | b' ), 'Number' ).onConnect( update );
  31. const wElement = setInputAestheticsFromType( new LabelElement( 'w | a' ), 'Number' ).onConnect( update );
  32. this.add( xElement )
  33. .add( yElement )
  34. .add( zElement )
  35. .add( wElement );
  36. update();
  37. }
  38. }
粤ICP备19079148号