You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

103 lines
2.5 KiB

2 years ago
import { ColorInput, ToggleInput, SliderInput, LabelElement } from '../../libs/flow.module.js';
import { BaseNode } from '../core/BaseNode.js';
import { PointsNodeMaterial } from 'three/nodes';
import * as THREE from 'three';
export class PointsMaterialEditor extends BaseNode {
constructor() {
const material = new PointsNodeMaterial();
super( 'Points Material', 1, material );
this.setWidth( 300 );
const color = new LabelElement( 'color' ).setInput( 3 );
const opacity = new LabelElement( 'opacity' ).setInput( 1 );
const size = new LabelElement( 'size' ).setInput( 1 );
const position = new LabelElement( 'position' ).setInput( 3 );
const sizeAttenuation = new LabelElement( 'Size Attenuation' );
color.add( new ColorInput( material.color.getHex() ).onChange( ( input ) => {
material.color.setHex( input.getValue() );
} ) );
opacity.add( new SliderInput( material.opacity, 0, 1 ).onChange( ( input ) => {
material.opacity = input.getValue();
this.updateTransparent();
} ) );
sizeAttenuation.add( new ToggleInput( material.sizeAttenuation ).onClick( ( input ) => {
material.sizeAttenuation = input.getValue();
material.dispose();
} ) );
color.onConnect( () => this.update(), true );
opacity.onConnect( () => this.update(), true );
size.onConnect( () => this.update(), true );
position.onConnect( () => this.update(), true );
this.add( color )
.add( opacity )
.add( size )
.add( position )
.add( sizeAttenuation );
this.color = color;
this.opacity = opacity;
this.size = size;
this.position = position;
this.sizeAttenuation = sizeAttenuation;
this.material = material;
this.update();
}
update() {
const { material, color, opacity, size, position } = this;
color.setEnabledInputs( ! color.getLinkedObject() );
opacity.setEnabledInputs( ! opacity.getLinkedObject() );
material.colorNode = color.getLinkedObject();
material.opacityNode = opacity.getLinkedObject() || null;
material.sizeNode = size.getLinkedObject() || null;
material.positionNode = position.getLinkedObject() || null;
material.dispose();
this.updateTransparent();
// TODO: Fix on NodeMaterial System
material.customProgramCacheKey = () => {
return THREE.MathUtils.generateUUID();
};
}
updateTransparent() {
const { material, opacity } = this;
material.transparent = opacity.getLinkedObject() || material.opacity < 1 ? true : false;
opacity.setIcon( material.transparent ? 'ti ti-layers-intersect' : 'ti ti-layers-subtract' );
}
}