123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- import { UIColor, UINumber, UIRow, UIText } from './libs/ui.js';
- import { SetMaterialColorCommand } from './commands/SetMaterialColorCommand.js';
- import { SetMaterialValueCommand } from './commands/SetMaterialValueCommand.js';
- function SidebarMaterialColorProperty( editor, property, name ) {
- const signals = editor.signals;
- const container = new UIRow();
- container.add( new UIText( name ).setWidth( '90px' ) );
- const color = new UIColor().onInput( onChange );
- container.add( color );
- let intensity;
- if ( property === 'emissive' ) {
- intensity = new UINumber( 1 ).setWidth( '30px' ).setRange( 0, Infinity ).onChange( onChange );
- container.add( intensity );
- }
- let object = null;
- let material = null;
- function onChange() {
- if ( material[ property ].getHex() !== color.getHexValue() ) {
- editor.execute( new SetMaterialColorCommand( editor, object, property, color.getHexValue(), 0 /* TODO: currentMaterialSlot */ ) );
- }
- if ( intensity !== undefined ) {
- if ( material[ `${ property }Intensity` ] !== intensity.getValue() ) {
- editor.execute( new SetMaterialValueCommand( editor, object, `${ property }Intensity`, intensity.getValue(), /* TODO: currentMaterialSlot*/ 0 ) );
- }
- }
- }
- function update() {
- if ( object === null ) return;
- if ( object.material === undefined ) return;
- material = object.material;
- if ( property in material ) {
- color.setHexValue( material[ property ].getHexString() );
- if ( intensity !== undefined ) {
- intensity.setValue( material[ `${ property }Intensity` ] );
- }
- container.setDisplay( '' );
- } else {
- container.setDisplay( 'none' );
- }
- }
- //
- signals.objectSelected.add( function ( selected ) {
- object = selected;
- update();
- } );
- signals.materialChanged.add( update );
- return container;
- }
- export { SidebarMaterialColorProperty };
|