12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- import { ButtonInput, SliderInput, NumberInput, LabelElement, Element } from '../../libs/flow.module.js';
- import { BaseNode } from '../core/BaseNode.js';
- import { UniformNode } from 'three/nodes';
- export class SliderEditor extends BaseNode {
- constructor() {
- const node = new UniformNode( 0 );
- super( 'Slider', 1, node );
- this.collapse = true;
- const field = new SliderInput( 0, 0, 1 ).onChange( () => {
- node.value = field.getValue();
- } );
- const updateRange = () => {
- const min = minInput.getValue();
- const max = maxInput.getValue();
- if ( min <= max ) {
- field.setRange( min, max );
- } else {
- maxInput.setValue( min );
- }
- };
- const minInput = new NumberInput().onChange( updateRange );
- const maxInput = new NumberInput( 1 ).onChange( updateRange );
- const minElement = new LabelElement( 'Min.' ).add( minInput ).setVisible( false );
- const maxElement = new LabelElement( 'Max.' ).add( maxInput ).setVisible( false );
- const moreElement = new Element().add( new ButtonInput( 'More' ).onClick( () => {
- minElement.setVisible( true );
- maxElement.setVisible( true );
- moreElement.setVisible( false );
- } ) ).setSerializable( false );
- this.add( new Element().add( field ) )
- .add( minElement )
- .add( maxElement )
- .add( moreElement );
- this.onBlur( () => {
- minElement.setVisible( false );
- maxElement.setVisible( false );
- moreElement.setVisible( true );
- } );
- }
- }
|