NormalMapEditor.js 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import { SelectInput, Element, LabelElement } from '../../libs/flow.module.js';
  2. import { BaseNode } from '../core/BaseNode.js';
  3. import { NormalMapNode, ConstNode } from 'three-nodes/Nodes.js';
  4. import { TangentSpaceNormalMap, ObjectSpaceNormalMap } from 'three';
  5. const nullValue = new ConstNode( 0 );
  6. export class NormalMapEditor extends BaseNode {
  7. constructor() {
  8. const node = new NormalMapNode( nullValue );
  9. super( 'Normal Map', 3, node, 175 );
  10. const source = new LabelElement( 'Source' ).setInput( 3 ).onConnect( () => {
  11. node.node = source.getLinkedObject() || nullValue;
  12. this.invalidate();
  13. } );
  14. const scale = new LabelElement( 'Scale' ).setInput( 3 ).onConnect( () => {
  15. node.scaleNode = scale.getLinkedObject();
  16. this.invalidate();
  17. } );
  18. const optionsField = new SelectInput( [
  19. { name: 'Tangent Space', value: TangentSpaceNormalMap },
  20. { name: 'Object Space', value: ObjectSpaceNormalMap }
  21. ], TangentSpaceNormalMap ).onChange( () => {
  22. node.normalMapType = Number( optionsField.getValue() );
  23. this.invalidate();
  24. } );
  25. this.add( new Element().add( optionsField ) )
  26. .add( source )
  27. .add( scale );
  28. }
  29. }