configuration.ts 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. import { TemplateConfiguration } from './../templateManager';
  2. export interface ViewerConfiguration {
  3. // configuration version
  4. version?: string;
  5. defaultViewer?: boolean; // indicates no configuration (except for initial configuration) should be changed. Will load the defaultCOnfiguration variable.
  6. configuration?: string | {
  7. url: string;
  8. mapper?: string; // json (default), html, yaml, xml, etc'. if not provided, file extension will be used.
  9. };
  10. // native (!!!) javascript events. Mainly used in the JSON-format.
  11. // those events will be triggered by the container element (the <babylon> tag);
  12. events?: {
  13. load: boolean | string;
  14. init: boolean | string;
  15. meshselected: boolean | string;
  16. pointerdown: boolean | string;
  17. pointerup: boolean | string;
  18. pointermove: boolean | string;
  19. // load: 'onViewerLoaded' // will trigger the event prefix-onViewerLoaded instead of prefix-onLoad (and ONLY this event).
  20. } | boolean; //events: true - fire all events
  21. eventPrefix?: string;
  22. canvasElement?: string; // if there is a need to override the standard implementation - ID of HTMLCanvasElement
  23. model?: {
  24. url?: string;
  25. loader?: string; // obj, gltf?
  26. position?: { x: number, y: number, z: number };
  27. rotation?: { x: number, y: number, z: number, w: number };
  28. scaling?: { x: number, y: number, z: number };
  29. parentObjectIndex?: number; // the index of the parent object of the model in the loaded meshes array.
  30. } | string,
  31. description?: string | {
  32. title: string;
  33. subtitle?: string;
  34. thumbnail?: string; // URL or data-url
  35. };
  36. scene?: {
  37. autoRotate?: boolean;
  38. rotationSpeed?: number;
  39. defaultCamera?: boolean;
  40. defaultLight?: boolean;
  41. clearColor?: { r: number, g: number, b: number, a: number };
  42. imageProcessingConfiguration?: IImageProcessingConfiguration;
  43. },
  44. // at the moment, support only a single camera.
  45. camera?: {
  46. position?: { x: number, y: number, z: number };
  47. rotation?: { x: number, y: number, z: number, w: number };
  48. fov?: number;
  49. fovMode?: number;
  50. minZ?: number;
  51. maxZ?: number;
  52. inertia?: number;
  53. behaviors?: Array<number | {
  54. type: number;
  55. [propName: string]: any;
  56. }>;
  57. [propName: string]: any;
  58. },
  59. skybox?: {
  60. cubeTexture: {
  61. noMipMap?: boolean;
  62. gammaSpace?: boolean;
  63. url: string | Array<string>;
  64. };
  65. pbr?: boolean;
  66. scale?: number;
  67. blur?: number;
  68. material?: {
  69. imageProcessingConfiguration?: IImageProcessingConfiguration;
  70. };
  71. infiniteDIstance?: boolean;
  72. };
  73. ground?: boolean | {
  74. size?: number;
  75. receiveShadows?: boolean;
  76. shadowOnly?: boolean;
  77. material?: {
  78. [propName: string]: any;
  79. }
  80. };
  81. lights?: Array<{
  82. type: number;
  83. name?: string;
  84. disabled?: boolean;
  85. position?: { x: number, y: number, z: number };
  86. target?: { x: number, y: number, z: number };
  87. direction?: { x: number, y: number, z: number };
  88. diffuse?: { r: number, g: number, b: number };
  89. specular?: { r: number, g: number, b: number };
  90. intensity?: number;
  91. radius?: number;
  92. shadownEnabled?: boolean; // only on specific lights!
  93. shadowConfig?: {
  94. useBlurExponentialShadowMap?: boolean;
  95. useKernelBlur?: boolean;
  96. blurKernel?: number;
  97. blurScale?: number;
  98. [propName: string]: any;
  99. }
  100. [propName: string]: any;
  101. // no behaviors for light at the moment, but allowing configuration for future reference.
  102. behaviors?: Array<number | {
  103. type: number;
  104. [propName: string]: any;
  105. }>
  106. }>
  107. // engine configuration. optional!
  108. engine?: {
  109. antialiasing?: boolean;
  110. },
  111. template?: TemplateConfiguration
  112. // nodes?
  113. }
  114. export interface IImageProcessingConfiguration {
  115. colorGradingEnabled?: boolean;
  116. colorCurvesEnabled?: boolean;
  117. colorCurves?: {
  118. globalHue?: number;
  119. globalDensity?: number;
  120. globalSaturation?: number;
  121. globalExposure?: number;
  122. highlightsHue?: number;
  123. highlightsDensity?: number;
  124. highlightsSaturation?: number;
  125. highlightsExposure?: number;
  126. midtonesHue?: number;
  127. midtonesDensity?: number;
  128. midtonesSaturation?: number;
  129. midtonesExposure?: number;
  130. shadowsHue?: number;
  131. shadowsDensity?: number;
  132. shadowsSaturation?: number;
  133. shadowsExposure?: number;
  134. };
  135. colorGradingWithGreenDepth?: boolean;
  136. colorGradingBGR?: boolean;
  137. exposure?: number;
  138. toneMappingEnabled?: boolean;
  139. contrast?: number;
  140. vignetteEnabled?: boolean;
  141. vignetteStretch?: number;
  142. vignetteCentreX?: number;
  143. vignetteCentreY?: number;
  144. vignetteWeight?: number;
  145. vignetteColor?: { r: number, g: number, b: number, a?: number };
  146. vignetteCameraFov?: number;
  147. vignetteBlendMode?: number;
  148. vignetteM?: boolean;
  149. applyByPostProcess?: boolean;
  150. }
  151. export let defaultConfiguration: ViewerConfiguration = {
  152. version: "0.1",
  153. eventPrefix: 'babylonviewer-',
  154. events: true,
  155. defaultViewer: true,
  156. template: {
  157. html: require("../../assets/templates/default/defaultTemplate.html"),
  158. children: {
  159. loadingScreen: {
  160. html: require("../../assets/templates/default/loadingScreen.html"),
  161. config: {
  162. backgroundColor: "#000000",
  163. loadingImage: require('../../assets/img/loading.png')//""
  164. }
  165. },
  166. viewer: {
  167. html: require("../../assets/templates/default/defaultViewer.html"),
  168. children: {
  169. navBar: {
  170. html: require("../../assets/templates/default/navbar.html")
  171. }
  172. }
  173. }
  174. }
  175. },
  176. camera: {
  177. behaviors: [
  178. 0,
  179. {
  180. type: 2,
  181. zoomOnBoundingInfo: true,
  182. zoomStopsAnimation: false
  183. }
  184. ]
  185. },
  186. lights: [
  187. {
  188. type: 1,
  189. shadowEnabled: true,
  190. direction: { x: -0.2, y: -1, z: 0 },
  191. position: { x: 0.017, y: 0.5, z: 0 },
  192. intensity: 4.5,
  193. shadowConfig: {
  194. useBlurExponentialShadowMap: true,
  195. useKernelBlur: true,
  196. blurKernel: 64,
  197. blurScale: 4
  198. }
  199. }
  200. ],
  201. skybox: {
  202. cubeTexture: {
  203. url: 'http://localhost:9000/environment.dds',
  204. gammaSpace: false
  205. },
  206. pbr: true,
  207. blur: 0.7,
  208. scale: 32,
  209. infiniteDIstance: false,
  210. material: {
  211. imageProcessingConfiguration: {
  212. colorCurves: {
  213. globalDensity: 89,
  214. globalHue: 58.88,
  215. globalSaturation: 94
  216. },
  217. colorCurvesEnabled: true,
  218. exposure: 1.5,
  219. contrast: 1.66,
  220. toneMappingEnabled: true,
  221. vignetteEnabled: true,
  222. vignetteWeight: 5,
  223. vignetteColor: { r: 0.8, g: 0.6, b: 0.4 },
  224. vignetteM: true
  225. }
  226. }
  227. },
  228. ground: true,
  229. engine: {
  230. antialiasing: true
  231. },
  232. scene: {
  233. imageProcessingConfiguration: {
  234. exposure: 1.4,
  235. contrast: 1.66,
  236. toneMappingEnabled: true
  237. }
  238. //autoRotate: true,
  239. //rotationSpeed: 0.1
  240. }
  241. }