123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 |
- import * as React from "react";
- import { Observable } from "babylonjs/Misc/observable";
- import { DefaultRenderingPipeline } from "babylonjs/PostProcesses/RenderPipeline/Pipelines/defaultRenderingPipeline";
- import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
- import { LockObject } from "../lockObject";
- import { CommonRenderingPipelinePropertyGridComponent } from './commonRenderingPipelinePropertyGridComponent';
- import { SliderLineComponent } from '../../../lines/sliderLineComponent';
- import { LineContainerComponent } from '../../../lineContainerComponent';
- import { CheckBoxLineComponent } from '../../../../../sharedUiComponents/lines/checkBoxLineComponent';
- import { OptionsLineComponent } from '../../../../../sharedUiComponents/lines/optionsLineComponent';
- import { ImageProcessingConfiguration } from 'babylonjs/Materials/imageProcessingConfiguration';
- import { Color3LineComponent } from '../../../../../sharedUiComponents/lines/color3LineComponent';
- import { GlobalState } from '../../../../globalState';
- import { ButtonLineComponent } from '../../../../../sharedUiComponents/lines/buttonLineComponent';
- import { Vector2LineComponent } from "../../../../../sharedUiComponents/lines/vector2LineComponent";
- interface IDefaultRenderingPipelinePropertyGridComponentProps {
- globalState: GlobalState;
- renderPipeline: DefaultRenderingPipeline,
- lockObject: LockObject,
- onPropertyChangedObservable?: Observable<PropertyChangedEvent>
- }
- export class DefaultRenderingPipelinePropertyGridComponent extends React.Component<IDefaultRenderingPipelinePropertyGridComponentProps> {
- constructor(props: IDefaultRenderingPipelinePropertyGridComponentProps) {
- super(props);
- }
- render() {
- const renderPipeline = this.props.renderPipeline;
- const camera = renderPipeline.scene.activeCamera!;
- var toneMappingOptions = [
- { label: "Standard", value: ImageProcessingConfiguration.TONEMAPPING_STANDARD },
- { label: "ACES", value: ImageProcessingConfiguration.TONEMAPPING_ACES }
- ];
- var vignetteModeOptions = [
- { label: "Multiply", value: ImageProcessingConfiguration.VIGNETTEMODE_MULTIPLY },
- { label: "Opaque", value: ImageProcessingConfiguration.VIGNETTEMODE_OPAQUE }
- ];
- return (
- <div className="pane">
- <CommonRenderingPipelinePropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} renderPipeline={renderPipeline} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <LineContainerComponent globalState={this.props.globalState} title="BLOOM">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline}
- onValueChanged={() => this.forceUpdate()}
- propertyName="bloomEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- renderPipeline.bloomEnabled &&
- <div>
- <SliderLineComponent label="Threshold" minimum={0} maximum={1} step={0.05} target={renderPipeline} propertyName="bloomThreshold" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Weight" minimum={0} maximum={1} step={0.05} target={renderPipeline} propertyName="bloomWeight" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Kernel" minimum={0} maximum={128} step={1} target={renderPipeline} propertyName="bloomKernel" onPropertyChangedObservable={this.props.onPropertyChangedObservable} decimalCount={0} />
- <SliderLineComponent label="Scale" minimum={0} maximum={1} step={0.25} target={renderPipeline} propertyName="bloomScale" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </div>
- }
- </LineContainerComponent>
- <LineContainerComponent globalState={this.props.globalState} title="CHROMATIC ABERRATION">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline}
- onValueChanged={() => this.forceUpdate()}
- propertyName="chromaticAberrationEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- renderPipeline.chromaticAberrationEnabled &&
- <div>
- <SliderLineComponent label="aberrationAmount" minimum={0} maximum={128} step={0.1} target={renderPipeline.chromaticAberration} propertyName="aberrationAmount" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Radial intensity" minimum={0} maximum={1} step={0.01} target={renderPipeline.chromaticAberration} propertyName="radialIntensity" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <Vector2LineComponent label="Center" target={renderPipeline.chromaticAberration} propertyName="centerPosition" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <Vector2LineComponent label="Direction" target={renderPipeline.chromaticAberration} propertyName="direction" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </div>
- }
- </LineContainerComponent>
- <LineContainerComponent globalState={this.props.globalState} title="DEPTH OF FIELD">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline}
- onValueChanged={() => this.forceUpdate()}
- propertyName="depthOfFieldEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- renderPipeline.depthOfFieldEnabled &&
- <div>
- <SliderLineComponent label="Focal length" minimum={0} maximum={camera.maxZ} step={0.1} target={renderPipeline.depthOfField} propertyName="focalLength" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="fStop" minimum={0} maximum={32} step={0.1} target={renderPipeline.depthOfField} propertyName="fStop" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Distance" minimum={0} maximum={camera.maxZ} step={0.1} target={renderPipeline.depthOfField} propertyName="focusDistance" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Lens size" minimum={0} maximum={1000} step={1} target={renderPipeline.depthOfField} propertyName="lensSize" onPropertyChangedObservable={this.props.onPropertyChangedObservable} decimalCount={0} />
- </div>
- }
- </LineContainerComponent>
- <LineContainerComponent globalState={this.props.globalState} title="FXAA">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline} propertyName="fxaaEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </LineContainerComponent>
- <LineContainerComponent globalState={this.props.globalState} title="GLOW LAYER">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline} propertyName="glowLayerEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- renderPipeline.glowLayerEnabled &&
- <div>
- <SliderLineComponent label="Blur kernel size" minimum={1} maximum={128} step={1} decimalCount={0} target={renderPipeline.glowLayer} propertyName="blurKernelSize" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Intensity" minimum={0} maximum={10} step={0.1} target={renderPipeline.glowLayer} propertyName="intensity" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </div>
- }
- </LineContainerComponent>
- <LineContainerComponent globalState={this.props.globalState} title="GRAIN">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline}
- onValueChanged={() => this.forceUpdate()}
- propertyName="grainEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- renderPipeline.grainEnabled &&
- <div>
- <CheckBoxLineComponent label="Animated" target={renderPipeline.grain} propertyName="animated" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Intensity" minimum={0} maximum={50} step={0.1} target={renderPipeline.grain} propertyName="intensity" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </div>
- }
- </LineContainerComponent>
- <LineContainerComponent globalState={this.props.globalState} title="IMAGE PROCESSING">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline}
- onValueChanged={() => this.forceUpdate()}
- propertyName="imageProcessingEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- renderPipeline.imageProcessing &&
- <div>
- <ButtonLineComponent label="Convert clear color to linear" onClick={() => renderPipeline.scene.clearColor = renderPipeline.scene.clearColor.toLinearSpace()} />
- <ButtonLineComponent label="Convert clear color to gamma" onClick={() => renderPipeline.scene.clearColor = renderPipeline.scene.clearColor.toGammaSpace()} />
- <SliderLineComponent minimum={0} maximum={4} step={0.1} label="Contrast" target={renderPipeline.imageProcessing} propertyName="contrast" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent minimum={0} maximum={4} step={0.1} label="Exposure" target={renderPipeline.imageProcessing} propertyName="exposure" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <CheckBoxLineComponent label="Tone mapping" target={renderPipeline.imageProcessing} propertyName="toneMappingEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <OptionsLineComponent label="Tone mapping type" options={toneMappingOptions} target={renderPipeline.imageProcessing} propertyName="toneMappingType" onPropertyChangedObservable={this.props.onPropertyChangedObservable} onSelect={(value) => this.setState({ mode: value })} />
- <CheckBoxLineComponent label="Vignette" target={renderPipeline.imageProcessing} propertyName="vignetteEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent minimum={0} maximum={4} step={0.1} label="Vignette weight" target={renderPipeline.imageProcessing} propertyName="vignetteWeight" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent minimum={0} maximum={1} step={0.1} label="Vignette stretch" target={renderPipeline.imageProcessing} propertyName="vignetteStretch" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent minimum={0} maximum={Math.PI} step={0.1} label="Vignette FOV" target={renderPipeline.imageProcessing} propertyName="vignetteCameraFov" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent minimum={0} maximum={1} step={0.1} label="Vignette center X" target={renderPipeline.imageProcessing} propertyName="vignetteCentreX" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent minimum={0} maximum={1} step={0.1} label="Vignette center Y" target={renderPipeline.imageProcessing} propertyName="vignetteCentreY" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <Color3LineComponent label="Vignette color" target={renderPipeline.imageProcessing} propertyName="vignetteColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <OptionsLineComponent label="Vignette blend mode" options={vignetteModeOptions} target={renderPipeline.imageProcessing} propertyName="vignetteBlendMode" onPropertyChangedObservable={this.props.onPropertyChangedObservable} onSelect={(value) => this.setState({ mode: value })} />
- </div>
- }
- </LineContainerComponent>
- <LineContainerComponent globalState={this.props.globalState} title="SHARPEN">
- <CheckBoxLineComponent label="Enabled" target={renderPipeline}
- onValueChanged={() => this.forceUpdate()}
- propertyName="sharpenEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- renderPipeline.sharpenEnabled &&
- <div>
- <SliderLineComponent label="Color amount" minimum={0} maximum={1} step={0.05} target={renderPipeline.sharpen} propertyName="colorAmount" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Edge amount" minimum={0} maximum={5} step={0.05} target={renderPipeline.sharpen} propertyName="edgeAmount" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </div>
- }
- </LineContainerComponent>
- </div>
- );
- }
- }
|