pbrMetallicRoughnessMaterialPropertyGridComponent.tsx 5.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import * as React from "react";
  2. import { Observable } from "babylonjs/Misc/observable";
  3. import { PBRMetallicRoughnessMaterial } from "babylonjs/Materials/PBR/pbrMetallicRoughnessMaterial";
  4. import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
  5. import { LineContainerComponent } from "../../../lineContainerComponent";
  6. import { Color3LineComponent } from "../../../../../sharedUiComponents/lines/color3LineComponent";
  7. import { SliderLineComponent } from "../../../lines/sliderLineComponent";
  8. import { CommonMaterialPropertyGridComponent } from "./commonMaterialPropertyGridComponent";
  9. import { TextureLinkLineComponent } from "../../../lines/textureLinkLineComponent";
  10. import { LockObject } from "../../../../../sharedUiComponents/tabs/propertyGrids/lockObject";
  11. import { GlobalState } from '../../../../globalState';
  12. import { CheckBoxLineComponent } from '../../../../../sharedUiComponents/lines/checkBoxLineComponent';
  13. interface IPBRMetallicRoughnessMaterialPropertyGridComponentProps {
  14. globalState: GlobalState,
  15. material: PBRMetallicRoughnessMaterial,
  16. lockObject: LockObject,
  17. onSelectionChangedObservable?: Observable<any>,
  18. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  19. }
  20. export class PBRMetallicRoughnessMaterialPropertyGridComponent extends React.Component<IPBRMetallicRoughnessMaterialPropertyGridComponentProps> {
  21. private _onDebugSelectionChangeObservable = new Observable<TextureLinkLineComponent>();
  22. constructor(props: IPBRMetallicRoughnessMaterialPropertyGridComponentProps) {
  23. super(props);
  24. }
  25. renderTextures() {
  26. const material = this.props.material;
  27. const onDebugSelectionChangeObservable = this._onDebugSelectionChangeObservable;
  28. return (
  29. <LineContainerComponent globalState={this.props.globalState} title="TEXTURES">
  30. <TextureLinkLineComponent label="Base" texture={material.baseTexture} propertyName="baseTexture" material={material} onSelectionChangedObservable={this.props.onSelectionChangedObservable} onDebugSelectionChangeObservable={onDebugSelectionChangeObservable} />
  31. <TextureLinkLineComponent label="Metallic roughness" texture={material.metallicRoughnessTexture} propertyName="metallicRoughnessTexture" material={material} onSelectionChangedObservable={this.props.onSelectionChangedObservable} onDebugSelectionChangeObservable={onDebugSelectionChangeObservable} />
  32. <TextureLinkLineComponent label="Normal" texture={material.normalTexture} propertyName="normalTexture" material={material} onSelectionChangedObservable={this.props.onSelectionChangedObservable} onDebugSelectionChangeObservable={onDebugSelectionChangeObservable} />
  33. <TextureLinkLineComponent label="Environment" texture={material.environmentTexture} propertyName="environmentTexture" material={material} onSelectionChangedObservable={this.props.onSelectionChangedObservable} onDebugSelectionChangeObservable={onDebugSelectionChangeObservable} />
  34. <TextureLinkLineComponent label="Emissive" texture={material.emissiveTexture} propertyName="emissiveTexture" material={material} onSelectionChangedObservable={this.props.onSelectionChangedObservable} onDebugSelectionChangeObservable={onDebugSelectionChangeObservable} />
  35. <TextureLinkLineComponent label="Lightmap" texture={material.lightmapTexture} propertyName="lightmapTexture" material={material} onSelectionChangedObservable={this.props.onSelectionChangedObservable} onDebugSelectionChangeObservable={onDebugSelectionChangeObservable} />
  36. </LineContainerComponent>
  37. )
  38. }
  39. render() {
  40. const material = this.props.material;
  41. return (
  42. <div className="pane">
  43. <CommonMaterialPropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} material={material} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  44. {this.renderTextures()}
  45. <LineContainerComponent globalState={this.props.globalState} title="LIGHTING & COLORS">
  46. <Color3LineComponent label="Base" target={material} propertyName="baseColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} isLinear={true} />
  47. <Color3LineComponent label="Emissive" target={material} propertyName="emissiveColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} isLinear={true} />
  48. </LineContainerComponent>
  49. <LineContainerComponent globalState={this.props.globalState} title="LEVELS" closed={true}>
  50. <SliderLineComponent label="Metallic" target={material} propertyName="metallic" minimum={0} maximum={1} step={0.01} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  51. <SliderLineComponent label="Roughness" target={material} propertyName="roughness" minimum={0} maximum={1} step={0.01} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  52. </LineContainerComponent>
  53. <LineContainerComponent globalState={this.props.globalState} title="NORMAL MAP" closed={true}>
  54. <CheckBoxLineComponent label="Invert X axis" target={material} propertyName="invertNormalMapX" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  55. <CheckBoxLineComponent label="Invert Y axis" target={material} propertyName="invertNormalMapY" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  56. </LineContainerComponent>
  57. </div>
  58. );
  59. }
  60. }