hemisphericLightPropertyGridComponent.tsx 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. import * as React from "react";
  2. import { Observable } from "babylonjs/Misc/observable";
  3. import { HemisphericLight } from "babylonjs/Lights/hemisphericLight";
  4. import { PropertyChangedEvent } from "../../../../propertyChangedEvent";
  5. import { CommonLightPropertyGridComponent } from "./commonLightPropertyGridComponent";
  6. import { LineContainerComponent } from "../../../lineContainerComponent";
  7. import { Color3LineComponent } from "../../../../../sharedUiComponents/lines/color3LineComponent";
  8. import { Vector3LineComponent } from "../../../lines/vector3LineComponent";
  9. import { LockObject } from "../lockObject";
  10. import { GlobalState } from '../../../../globalState';
  11. interface IHemisphericLightPropertyGridComponentProps {
  12. globalState: GlobalState,
  13. light: HemisphericLight,
  14. lockObject: LockObject,
  15. onPropertyChangedObservable?: Observable<PropertyChangedEvent>
  16. }
  17. export class HemisphericLightPropertyGridComponent extends React.Component<IHemisphericLightPropertyGridComponentProps> {
  18. constructor(props: IHemisphericLightPropertyGridComponentProps) {
  19. super(props);
  20. }
  21. render() {
  22. const light = this.props.light;
  23. return (
  24. <div className="pane">
  25. <CommonLightPropertyGridComponent globalState={this.props.globalState} lockObject={this.props.lockObject} light={light} onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  26. <LineContainerComponent globalState={this.props.globalState} title="SETUP">
  27. <Color3LineComponent label="Diffuse" target={light} propertyName="diffuse" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  28. <Color3LineComponent label="Ground" target={light} propertyName="groundColor" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  29. <Vector3LineComponent label="Direction" target={light} propertyName="direction" onPropertyChangedObservable={this.props.onPropertyChangedObservable} />
  30. </LineContainerComponent>
  31. </div>
  32. );
  33. }
  34. }