ssao2RenderingPipelinePropertyGridComponent.tsx 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import * as React from "react";
  2. import { Observable } from "babylonjs/Misc/observable";
  3. import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
  4. import { LockObject } from "../../../../../sharedUiComponents/tabs/propertyGrids/lockObject";
  5. import { CommonRenderingPipelinePropertyGridComponent } from './commonRenderingPipelinePropertyGridComponent';
  6. import { SliderLineComponent } from '../../../lines/sliderLineComponent';
  7. import { LineContainerComponent } from '../../../lineContainerComponent';
  8. import { SSAO2RenderingPipeline } from 'babylonjs/PostProcesses/RenderPipeline/Pipelines/ssao2RenderingPipeline';
  9. import { GlobalState } from '../../../../globalState';
  10. interface ISSAO2RenderingPipelinePropertyGridComponentProps {
  11. globalState: GlobalState;
  12. renderPipeline: SSAO2RenderingPipeline,
  13. lockObject: LockObject,
  14. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  15. }
  16. export class SSAO2RenderingPipelinePropertyGridComponent extends React.Component<ISSAO2RenderingPipelinePropertyGridComponentProps> {
  17. constructor(props: ISSAO2RenderingPipelinePropertyGridComponentProps) {
  18. super(props);
  19. }
  20. render() {
  21. const renderPipeline = this.props.renderPipeline;
  22. const camera = renderPipeline.scene.activeCamera!;
  23. return (
  24. <div className="pane">
  25. <CommonRenderingPipelinePropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} renderPipeline={renderPipeline} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  26. <LineContainerComponent globalState={this.props.globalState} title="SSAO">
  27. <SliderLineComponent label="Strength" minimum={0} maximum={2} step={0.05} target={renderPipeline} propertyName="totalStrength" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  28. <SliderLineComponent label="Base" minimum={0} maximum={1} step={0.05} target={renderPipeline} propertyName="base" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  29. <SliderLineComponent label="Max Z" minimum={0} maximum={camera.maxZ} step={1} target={renderPipeline} propertyName="maxZ" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. <SliderLineComponent label="Min Z aspect" minimum={0} maximum={0.5} step={0.01} target={renderPipeline} propertyName="minZAspect" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  31. <SliderLineComponent label="Radius" minimum={0} maximum={10} step={0.05} target={renderPipeline} propertyName="radius" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  32. </LineContainerComponent>
  33. </div>
  34. );
  35. }
  36. }