cylinderEmitterGridComponent.tsx 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. import * as React from "react";
  2. import { Observable } from "babylonjs/Misc/observable";
  3. import { GlobalState } from '../../../../globalState';
  4. import { PropertyChangedEvent } from '../../../../propertyChangedEvent';
  5. import { SliderLineComponent } from '../../../lines/sliderLineComponent';
  6. import { CylinderParticleEmitter } from 'babylonjs/Particles/EmitterTypes/cylinderParticleEmitter';
  7. import { FloatLineComponent } from '../../../lines/floatLineComponent';
  8. import { LockObject } from '../lockObject';
  9. interface ICylinderEmitterGridComponentProps {
  10. globalState: GlobalState;
  11. emitter: CylinderParticleEmitter,
  12. lockObject: LockObject,
  13. replaySourceReplacement?: string,
  14. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  15. }
  16. export class CylinderEmitterGridComponent extends React.Component<ICylinderEmitterGridComponentProps> {
  17. constructor(props: ICylinderEmitterGridComponentProps) {
  18. super(props);
  19. }
  20. render() {
  21. let emitter = this.props.emitter;
  22. return (
  23. <>
  24. <FloatLineComponent replaySourceReplacement={this.props.replaySourceReplacement} lockObject={this.props.lockObject} label="Radius" target={emitter} propertyName="radius" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  25. <FloatLineComponent replaySourceReplacement={this.props.replaySourceReplacement} lockObject={this.props.lockObject} label="Height" target={emitter} propertyName="height" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  26. <SliderLineComponent replaySourceReplacement={this.props.replaySourceReplacement} label="Radius range" target={emitter} propertyName="radiusRange" minimum={0} maximum={1} step={0.01}
  27. onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  28. <SliderLineComponent replaySourceReplacement={this.props.replaySourceReplacement} label="Direction randomizer" target={emitter} propertyName="directionRandomizer" minimum={0} maximum={1} step={0.01}
  29. onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. </>
  31. );
  32. }
  33. }