import { TemplateConfiguration } from './../templateManager'; export interface ViewerConfiguration { // configuration version version?: string; defaultViewer?: boolean; // indicates no configuration (except for initial configuration) should be changed. Will load the defaultCOnfiguration variable. configuration?: string | { url: string; mapper?: string; // json (default), html, yaml, xml, etc'. if not provided, file extension will be used. }; // native (!!!) javascript events. Mainly used in the JSON-format. // those events will be triggered by the container element (the tag); events?: { load: boolean | string; init: boolean | string; meshselected: boolean | string; pointerdown: boolean | string; pointerup: boolean | string; pointermove: boolean | string; // load: 'onViewerLoaded' // will trigger the event prefix-onViewerLoaded instead of prefix-onLoad (and ONLY this event). } | boolean; //events: true - fire all events eventPrefix?: string; canvasElement?: string; // if there is a need to override the standard implementation - ID of HTMLCanvasElement model?: { url?: string; loader?: string; // obj, gltf? position?: { x: number, y: number, z: number }; rotation?: { x: number, y: number, z: number, w: number }; scaling?: { x: number, y: number, z: number }; parentObjectIndex?: number; // the index of the parent object of the model in the loaded meshes array. [propName: string]: any; // further configuration, like title and creator } | string, description?: string | { title: string; subtitle?: string; thumbnail?: string; // URL or data-url }; scene?: { autoRotate?: boolean; rotationSpeed?: number; defaultCamera?: boolean; defaultLight?: boolean; clearColor?: { r: number, g: number, b: number, a: number }; imageProcessingConfiguration?: IImageProcessingConfiguration; }, // at the moment, support only a single camera. camera?: { position?: { x: number, y: number, z: number }; rotation?: { x: number, y: number, z: number, w: number }; fov?: number; fovMode?: number; minZ?: number; maxZ?: number; inertia?: number; behaviors?: Array; [propName: string]: any; }, skybox?: { cubeTexture: { noMipMap?: boolean; gammaSpace?: boolean; url: string | Array; }; pbr?: boolean; scale?: number; blur?: number; material?: { imageProcessingConfiguration?: IImageProcessingConfiguration; }; infiniteDIstance?: boolean; }; ground?: boolean | { size?: number; receiveShadows?: boolean; shadowOnly?: boolean; material?: { [propName: string]: any; } }; lights?: Array<{ type: number; name?: string; disabled?: boolean; position?: { x: number, y: number, z: number }; target?: { x: number, y: number, z: number }; direction?: { x: number, y: number, z: number }; diffuse?: { r: number, g: number, b: number }; specular?: { r: number, g: number, b: number }; intensity?: number; radius?: number; shadownEnabled?: boolean; // only on specific lights! shadowConfig?: { useBlurExponentialShadowMap?: boolean; useKernelBlur?: boolean; blurKernel?: number; blurScale?: number; [propName: string]: any; } [propName: string]: any; // no behaviors for light at the moment, but allowing configuration for future reference. behaviors?: Array }> // engine configuration. optional! engine?: { antialiasing?: boolean; }, template?: TemplateConfiguration // nodes? } export interface IImageProcessingConfiguration { colorGradingEnabled?: boolean; colorCurvesEnabled?: boolean; colorCurves?: { globalHue?: number; globalDensity?: number; globalSaturation?: number; globalExposure?: number; highlightsHue?: number; highlightsDensity?: number; highlightsSaturation?: number; highlightsExposure?: number; midtonesHue?: number; midtonesDensity?: number; midtonesSaturation?: number; midtonesExposure?: number; shadowsHue?: number; shadowsDensity?: number; shadowsSaturation?: number; shadowsExposure?: number; }; colorGradingWithGreenDepth?: boolean; colorGradingBGR?: boolean; exposure?: number; toneMappingEnabled?: boolean; contrast?: number; vignetteEnabled?: boolean; vignetteStretch?: number; vignetteCentreX?: number; vignetteCentreY?: number; vignetteWeight?: number; vignetteColor?: { r: number, g: number, b: number, a?: number }; vignetteCameraFov?: number; vignetteBlendMode?: number; vignetteM?: boolean; applyByPostProcess?: boolean; } export let defaultConfiguration: ViewerConfiguration = { version: "0.1", eventPrefix: 'babylonviewer-', events: true, defaultViewer: true, template: { html: require("../../assets/templates/default/defaultTemplate.html"), children: { loadingScreen: { html: require("../../assets/templates/default/loadingScreen.html"), config: { backgroundColor: "#000000", loadingImage: require('../../assets/img/loading.png')//"" } }, viewer: { html: require("../../assets/templates/default/defaultViewer.html"), children: { navBar: { html: require("../../assets/templates/default/navbar.html"), config: { buttons: [ { id: 'fullscreen-button', altText: "Fullscreen", image: require('../../assets/img/fullscreen.png') } ] }, events: { pointerdown: ['#fullscreen-button'] } } } } } }, camera: { behaviors: [ 0, { type: 2, zoomOnBoundingInfo: true, zoomStopsAnimation: false } ] }, lights: [ { type: 1, shadowEnabled: true, direction: { x: -0.2, y: -1, z: 0 }, position: { x: 0.017, y: 0.5, z: 0 }, intensity: 4.5, shadowConfig: { useBlurExponentialShadowMap: true, useKernelBlur: true, blurKernel: 64, blurScale: 4 } } ], skybox: { cubeTexture: { url: 'https://playground.babylonjs.com/textures/environment.dds', gammaSpace: false }, pbr: true, blur: 0.7, scale: 32, infiniteDIstance: false, material: { imageProcessingConfiguration: { colorCurves: { globalDensity: 89, globalHue: 58.88, globalSaturation: 94 }, colorCurvesEnabled: true, exposure: 1.5, contrast: 1.66, toneMappingEnabled: true, vignetteEnabled: true, vignetteWeight: 5, vignetteColor: { r: 0.8, g: 0.6, b: 0.4 }, vignetteM: true } } }, ground: true, engine: { antialiasing: true }, scene: { imageProcessingConfiguration: { exposure: 1.4, contrast: 1.66, toneMappingEnabled: true } //autoRotate: true, //rotationSpeed: 0.1 } }