defaultRenderingPipelinePropertyGridComponent.tsx 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. import * as React from "react";
  2. import { Observable } from "babylonjs/Misc/observable";
  3. import { DefaultRenderingPipeline } from "babylonjs/PostProcesses/RenderPipeline/Pipelines/defaultRenderingPipeline";
  4. import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
  5. import { LockObject } from "../lockObject";
  6. import { CommonRenderingPipelinePropertyGridComponent } from './commonRenderingPipelinePropertyGridComponent';
  7. import { SliderLineComponent } from '../../../lines/sliderLineComponent';
  8. import { LineContainerComponent } from '../../../lineContainerComponent';
  9. import { CheckBoxLineComponent } from '../../../lines/checkBoxLineComponent';
  10. import { Vector2LineComponent } from '../../../lines/vector2LineComponent';
  11. import { OptionsLineComponent } from '../../../lines/optionsLineComponent';
  12. import { ImageProcessingConfiguration } from 'babylonjs/Materials/imageProcessingConfiguration';
  13. import { Color3LineComponent } from '../../../lines/color3LineComponent';
  14. import { GlobalState } from '../../../../globalState';
  15. interface IDefaultRenderingPipelinePropertyGridComponentProps {
  16. globalState: GlobalState;
  17. renderPipeline: DefaultRenderingPipeline,
  18. lockObject: LockObject,
  19. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  20. }
  21. export class DefaultRenderingPipelinePropertyGridComponent extends React.Component<IDefaultRenderingPipelinePropertyGridComponentProps> {
  22. constructor(props: IDefaultRenderingPipelinePropertyGridComponentProps) {
  23. super(props);
  24. }
  25. render() {
  26. const renderPipeline = this.props.renderPipeline;
  27. const camera = renderPipeline.scene.activeCamera!;
  28. var toneMappingOptions = [
  29. { label: "Standard", value: ImageProcessingConfiguration.TONEMAPPING_STANDARD },
  30. { label: "ACES", value: ImageProcessingConfiguration.TONEMAPPING_ACES }
  31. ];
  32. var vignetteModeOptions = [
  33. { label: "Multiply", value: ImageProcessingConfiguration.VIGNETTEMODE_MULTIPLY },
  34. { label: "Opaque", value: ImageProcessingConfiguration.VIGNETTEMODE_OPAQUE }
  35. ];
  36. return (
  37. <div className="pane">
  38. <CommonRenderingPipelinePropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} renderPipeline={renderPipeline} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  39. <LineContainerComponent globalState={this.props.globalState} title="BLOOM">
  40. <CheckBoxLineComponent label="Enabled" target={renderPipeline}
  41. onValueChanged={() => this.forceUpdate()}
  42. propertyName="bloomEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  43. {
  44. renderPipeline.bloomEnabled &&
  45. <div>
  46. <SliderLineComponent label="Threshold" minimum={0} maximum={1} step={0.05} target={renderPipeline} propertyName="bloomThreshold" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  47. <SliderLineComponent label="Weight" minimum={0} maximum={1} step={0.05} target={renderPipeline} propertyName="bloomWeight" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  48. <SliderLineComponent label="Kernel" minimum={0} maximum={128} step={1} target={renderPipeline} propertyName="bloomKernel" onPropertyChangedObservable={this.props.onPropertyChangedObservable} decimalCount={0} />
  49. <SliderLineComponent label="Scale" minimum={0} maximum={1} step={0.25} target={renderPipeline} propertyName="bloomScale" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  50. </div>
  51. }
  52. </LineContainerComponent>
  53. <LineContainerComponent globalState={this.props.globalState} title="CHROMATIC ABERRATION">
  54. <CheckBoxLineComponent label="Enabled" target={renderPipeline}
  55. onValueChanged={() => this.forceUpdate()}
  56. propertyName="chromaticAberrationEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  57. {
  58. renderPipeline.chromaticAberrationEnabled &&
  59. <div>
  60. <SliderLineComponent label="aberrationAmount" minimum={0} maximum={128} step={0.1} target={renderPipeline.chromaticAberration} propertyName="aberrationAmount" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  61. <SliderLineComponent label="Radial intensity" minimum={0} maximum={1} step={0.01} target={renderPipeline.chromaticAberration} propertyName="radialIntensity" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  62. <Vector2LineComponent label="Center" target={renderPipeline.chromaticAberration} propertyName="centerPosition" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  63. <Vector2LineComponent label="Direction" target={renderPipeline.chromaticAberration} propertyName="direction" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  64. </div>
  65. }
  66. </LineContainerComponent>
  67. <LineContainerComponent globalState={this.props.globalState} title="DEPTH OF FIELD">
  68. <CheckBoxLineComponent label="Enabled" target={renderPipeline}
  69. onValueChanged={() => this.forceUpdate()}
  70. propertyName="depthOfFieldEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  71. {
  72. renderPipeline.depthOfFieldEnabled &&
  73. <div>
  74. <SliderLineComponent label="Focal length" minimum={0} maximum={camera.maxZ} step={0.1} target={renderPipeline.depthOfField} propertyName="focalLength" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  75. <SliderLineComponent label="fStop" minimum={0} maximum={32} step={0.1} target={renderPipeline.depthOfField} propertyName="fStop" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  76. <SliderLineComponent label="Distance" minimum={0} maximum={camera.maxZ} step={0.1} target={renderPipeline.depthOfField} propertyName="focusDistance" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  77. <SliderLineComponent label="Lens size" minimum={0} maximum={1000} step={1} target={renderPipeline.depthOfField} propertyName="lensSize" onPropertyChangedObservable={this.props.onPropertyChangedObservable} decimalCount={0} />
  78. </div>
  79. }
  80. </LineContainerComponent>
  81. <LineContainerComponent globalState={this.props.globalState} title="FXAA">
  82. <CheckBoxLineComponent label="Enabled" target={renderPipeline} propertyName="fxaaEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  83. </LineContainerComponent>
  84. <LineContainerComponent globalState={this.props.globalState} title="GLOW LAYER">
  85. <CheckBoxLineComponent label="Enabled" target={renderPipeline} propertyName="glowLayerEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  86. {
  87. renderPipeline.glowLayerEnabled &&
  88. <div>
  89. <SliderLineComponent label="Blur kernel size" minimum={1} maximum={128} step={1} decimalCount={0} target={renderPipeline.glowLayer} propertyName="blurKernelSize" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  90. <SliderLineComponent label="Intensity" minimum={0} maximum={10} step={0.1} target={renderPipeline.glowLayer} propertyName="intensity" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  91. </div>
  92. }
  93. </LineContainerComponent>
  94. <LineContainerComponent globalState={this.props.globalState} title="GRAIN">
  95. <CheckBoxLineComponent label="Enabled" target={renderPipeline}
  96. onValueChanged={() => this.forceUpdate()}
  97. propertyName="grainEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  98. {
  99. renderPipeline.grainEnabled &&
  100. <div>
  101. <CheckBoxLineComponent label="Animated" target={renderPipeline.grain} propertyName="animated" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  102. <SliderLineComponent label="Intensity" minimum={0} maximum={50} step={0.1} target={renderPipeline.grain} propertyName="intensity" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  103. </div>
  104. }
  105. </LineContainerComponent>
  106. <LineContainerComponent globalState={this.props.globalState} title="IMAGE PROCESSING">
  107. <CheckBoxLineComponent label="Enabled" target={renderPipeline}
  108. onValueChanged={() => this.forceUpdate()}
  109. propertyName="imageProcessingEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  110. {
  111. renderPipeline.imageProcessing &&
  112. <div>
  113. <SliderLineComponent minimum={0} maximum={4} step={0.1} label="Contrast" target={renderPipeline.imageProcessing} propertyName="contrast" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  114. <SliderLineComponent minimum={0} maximum={4} step={0.1} label="Exposure" target={renderPipeline.imageProcessing} propertyName="exposure" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  115. <CheckBoxLineComponent label="Tone mapping" target={renderPipeline.imageProcessing} propertyName="toneMappingEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  116. <OptionsLineComponent label="Tone mapping type" options={toneMappingOptions} target={renderPipeline.imageProcessing} propertyName="toneMappingType" onPropertyChangedObservable={this.props.onPropertyChangedObservable} onSelect={(value) => this.setState({ mode: value })} />
  117. <CheckBoxLineComponent label="Vignette" target={renderPipeline.imageProcessing} propertyName="vignetteEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  118. <SliderLineComponent minimum={0} maximum={4} step={0.1} label="Vignette weight" target={renderPipeline.imageProcessing} propertyName="vignetteWeight" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  119. <SliderLineComponent minimum={0} maximum={1} step={0.1} label="Vignette stretch" target={renderPipeline.imageProcessing} propertyName="vignetteStretch" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  120. <SliderLineComponent minimum={0} maximum={Math.PI} step={0.1} label="Vignette FOV" target={renderPipeline.imageProcessing} propertyName="vignetteCameraFov" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  121. <SliderLineComponent minimum={0} maximum={1} step={0.1} label="Vignette center X" target={renderPipeline.imageProcessing} propertyName="vignetteCentreX" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  122. <SliderLineComponent minimum={0} maximum={1} step={0.1} label="Vignette center Y" target={renderPipeline.imageProcessing} propertyName="vignetteCentreY" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  123. <Color3LineComponent label="Vignette color" target={renderPipeline.imageProcessing} propertyName="vignetteColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  124. <OptionsLineComponent label="Vignette blend mode" options={vignetteModeOptions} target={renderPipeline.imageProcessing} propertyName="vignetteBlendMode" onPropertyChangedObservable={this.props.onPropertyChangedObservable} onSelect={(value) => this.setState({ mode: value })} />
  125. </div>
  126. }
  127. </LineContainerComponent>
  128. <LineContainerComponent globalState={this.props.globalState} title="SHARPEN">
  129. <CheckBoxLineComponent label="Enabled" target={renderPipeline}
  130. onValueChanged={() => this.forceUpdate()}
  131. propertyName="sharpenEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  132. {
  133. renderPipeline.sharpenEnabled &&
  134. <div>
  135. <SliderLineComponent label="Color amount" minimum={0} maximum={1} step={0.05} target={renderPipeline.sharpen} propertyName="colorAmount" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  136. <SliderLineComponent label="Edge amount" minimum={0} maximum={5} step={0.05} target={renderPipeline.sharpen} propertyName="edgeAmount" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  137. </div>
  138. }
  139. </LineContainerComponent>
  140. </div>
  141. );
  142. }
  143. }