123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 |
- import * as React from "react";
- import { Observable } from "babylonjs/Misc/observable";
- import { IShadowLight } from "babylonjs/Lights/shadowLight";
- import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
- import { LineContainerComponent } from "../../../lineContainerComponent";
- import { CheckBoxLineComponent } from "../../../lines/checkBoxLineComponent";
- import { FloatLineComponent } from "../../../lines/floatLineComponent";
- import { LockObject } from "../lockObject";
- import { GlobalState } from '../../../../globalState';
- import { OptionsLineComponent } from '../../../lines/optionsLineComponent';
- import { ShadowGenerator } from 'babylonjs/Lights/Shadows/shadowGenerator';
- import { CascadedShadowGenerator } from 'babylonjs/Lights/Shadows/cascadedShadowGenerator';
- import { SliderLineComponent } from '../../../lines/sliderLineComponent';
- import { ButtonLineComponent } from '../../../lines/buttonLineComponent';
- import { DirectionalLight } from 'babylonjs/Lights/directionalLight';
- interface ICommonShadowLightPropertyGridComponentProps {
- globalState: GlobalState;
- light: IShadowLight;
- lockObject: LockObject;
- onPropertyChangedObservable?: Observable<PropertyChangedEvent>;
- }
- export class CommonShadowLightPropertyGridComponent extends React.Component<ICommonShadowLightPropertyGridComponentProps> {
- private _internals : { generatorType: number, mapSize: number };
- constructor(props: ICommonShadowLightPropertyGridComponentProps) {
- super(props);
- this._internals = {
- generatorType: 0,
- mapSize: 1024,
- };
- }
- createShadowGenerator() {
- const light = this.props.light;
- const scene = light.getScene();
- const internals = this._internals;
- let generator = internals.generatorType === 0 ? new ShadowGenerator(internals.mapSize, light) : new CascadedShadowGenerator(internals.mapSize, light as DirectionalLight);
- scene.meshes.forEach((m) => {
- generator.addShadowCaster(m);
- if (!m.isAnInstance) {
- m.receiveShadows = true;
- }
- });
- this.forceUpdate();
- }
- disposeShadowGenerator() {
- const light = this.props.light;
- light.getShadowGenerator()?.dispose();
- this.forceUpdate();
- }
- render() {
- const light = this.props.light;
- const internals = this._internals;
- const generator = light.getShadowGenerator() as (ShadowGenerator | CascadedShadowGenerator) || null;
- const csmGenerator = generator instanceof CascadedShadowGenerator;
- const camera = light.getScene().activeCamera;
- var typeGeneratorOptions = [
- { label: "Shadow Generator", value: 0 }
- ];
- if (light instanceof DirectionalLight) {
- typeGeneratorOptions.push({ label: "Cascaded Shadow Generator", value: 1 });
- }
- var mapSizeOptions = [
- { label: "2048x2048", value: 2048 },
- { label: "1024x1024", value: 1024 },
- { label: "512x512", value: 512 },
- { label: "256x256", value: 256 },
- ];
- var blurModeOptions;
- if (generator instanceof CascadedShadowGenerator) {
- blurModeOptions = [
- { label: "None", value: ShadowGenerator.FILTER_NONE },
- { label: "PCF", value: ShadowGenerator.FILTER_PCF },
- { label: "PCSS", value: ShadowGenerator.FILTER_PCSS },
- ];
- } else {
- blurModeOptions = [
- { label: "None", value: ShadowGenerator.FILTER_NONE },
- { label: "PCF", value: ShadowGenerator.FILTER_PCF },
- { label: "PCSS", value: ShadowGenerator.FILTER_PCSS },
- { label: "Poisson", value: ShadowGenerator.FILTER_POISSONSAMPLING },
- { label: "Exponential", value: ShadowGenerator.FILTER_EXPONENTIALSHADOWMAP },
- { label: "Blurred exponential", value: ShadowGenerator.FILTER_BLUREXPONENTIALSHADOWMAP },
- { label: "Close exponential", value: ShadowGenerator.FILTER_CLOSEEXPONENTIALSHADOWMAP },
- { label: "Blurred close exponential", value: ShadowGenerator.FILTER_BLURCLOSEEXPONENTIALSHADOWMAP },
- ];
- }
- var filteringQualityOptions = [
- { label: "Low", value: ShadowGenerator.QUALITY_LOW },
- { label: "Medium", value: ShadowGenerator.QUALITY_MEDIUM },
- { label: "High", value: ShadowGenerator.QUALITY_HIGH },
- ];
- var numCascadesOptions = [
- { label: "2", value: 2 },
- { label: "3", value: 3 },
- { label: "4", value: 4 },
- ];
- const near = camera ? camera.minZ : 0, far = camera ? camera.maxZ : 0;
- let filter = generator ? generator.filter : 0;
- return (
- <div>
- <LineContainerComponent globalState={this.props.globalState} title="SHADOWS">
- <CheckBoxLineComponent label="Shadows enabled" target={light} propertyName="shadowEnabled" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- { !csmGenerator && <>
- <FloatLineComponent lockObject={this.props.lockObject} label="Shadows near plane" target={light} propertyName="shadowMinZ" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <FloatLineComponent lockObject={this.props.lockObject} label="Shadows far plane" target={light} propertyName="shadowMaxZ" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </> }
- </LineContainerComponent>
- {
- generator == null &&
- <LineContainerComponent globalState={this.props.globalState} title="SHADOW GENERATOR">
- <OptionsLineComponent label="Type" options={typeGeneratorOptions} target={internals} propertyName="generatorType" />
- <OptionsLineComponent label="Map size" options={mapSizeOptions} target={internals} propertyName="mapSize" />
- <ButtonLineComponent label="Create generator" onClick={() => this.createShadowGenerator()} />
- </LineContainerComponent>
- }
- {
- generator !== null &&
- <LineContainerComponent globalState={this.props.globalState} title="SHADOW GENERATOR">
- <ButtonLineComponent label="Dispose generator" onClick={() => this.disposeShadowGenerator()} />
- { csmGenerator && <>
- <OptionsLineComponent label="Num cascades" options={numCascadesOptions} target={generator} propertyName="numCascades" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <CheckBoxLineComponent label="Debug mode" target={generator} propertyName="debug" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <CheckBoxLineComponent label="Stabilize cascades" target={generator} propertyName="stabilizeCascades" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Lambda" minimum={0} maximum={1.0} step={0.01} target={generator} propertyName="lambda" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Cascade blend" minimum={0} maximum={1.0} step={0.01} target={generator} propertyName="cascadeBlendPercentage" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <CheckBoxLineComponent label="Depth clamp" target={generator} propertyName="depthClamp" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <CheckBoxLineComponent label="Auto-Calc depth bounds" target={generator} propertyName="autoCalcDepthBounds" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Shadow MaxZ" minimum={near} maximum={far} step={0.5} target={generator} propertyName="shadowMaxZ" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- </> }
- <FloatLineComponent lockObject={this.props.lockObject} digits={4} step="0.0001" label="Bias" target={generator} propertyName="bias" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <FloatLineComponent lockObject={this.props.lockObject} label="Normal bias" target={generator} propertyName="normalBias" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <SliderLineComponent label="Darkness" target={generator} minimum={0} maximum={1} step={0.01} propertyName="darkness" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <CheckBoxLineComponent label="Allow transparent shadows" target={generator} propertyName="transparencyShadow" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- <OptionsLineComponent label="Filter" options={blurModeOptions}
- onSelect={() => {
- this.forceUpdate();
- }}
- target={generator} propertyName="filter" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- {
- (filter === ShadowGenerator.FILTER_PCF || filter === ShadowGenerator.FILTER_PCSS) &&
- <OptionsLineComponent label="Filtering quality" options={filteringQualityOptions}
- onSelect={() => {
- this.forceUpdate();
- }}
- target={generator} propertyName="filteringQuality" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- }
- {
- (filter === ShadowGenerator.FILTER_PCSS) &&
- <SliderLineComponent label="Penumbra ratio" minimum={0} maximum={0.5} step={0.001} target={generator} propertyName="contactHardeningLightSizeUVRatio" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- }
- {
- !csmGenerator && (filter === ShadowGenerator.FILTER_BLUREXPONENTIALSHADOWMAP || filter === ShadowGenerator.FILTER_BLURCLOSEEXPONENTIALSHADOWMAP) &&
- <CheckBoxLineComponent label="Use kernel blur" target={generator} propertyName="useKernelBlur"
- onValueChanged={() => this.forceUpdate()}
- onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- }
- {
- (generator instanceof ShadowGenerator) && (filter === ShadowGenerator.FILTER_BLUREXPONENTIALSHADOWMAP || filter === ShadowGenerator.FILTER_BLURCLOSEEXPONENTIALSHADOWMAP) &&
- !generator.useKernelBlur &&
- <SliderLineComponent label="Blur box offset" target={generator} propertyName="blurBoxOffset" minimum={1} maximum={64} step={1} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />}
- {
- (generator instanceof ShadowGenerator) && (filter === ShadowGenerator.FILTER_BLUREXPONENTIALSHADOWMAP || filter === ShadowGenerator.FILTER_BLURCLOSEEXPONENTIALSHADOWMAP) &&
- generator.useKernelBlur &&
- <SliderLineComponent label="Blur kernel" target={generator} propertyName="blurKernel" minimum={1} maximum={64} step={1} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- }
- {
- (generator instanceof ShadowGenerator) && (filter === ShadowGenerator.FILTER_BLUREXPONENTIALSHADOWMAP || filter === ShadowGenerator.FILTER_EXPONENTIALSHADOWMAP) &&
- <FloatLineComponent lockObject={this.props.lockObject} label="Depth scale" target={generator} propertyName="depthScale" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- }
- {
- (generator instanceof ShadowGenerator) && (filter === ShadowGenerator.FILTER_BLUREXPONENTIALSHADOWMAP || filter === ShadowGenerator.FILTER_EXPONENTIALSHADOWMAP) &&
- <SliderLineComponent label="Blur scale" target={generator} propertyName="blurScale" minimum={1} maximum={4} step={1} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- }
- {
- csmGenerator && (filter === ShadowGenerator.FILTER_PCSS) &&
- <SliderLineComponent label="Penumbra darkness" minimum={0} maximum={1.0} step={0.01} target={generator} propertyName="penumbraDarkness" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
- }
- </LineContainerComponent>
- }
- </div>
- );
- }
- }
|