configuration.ts 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  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. [propName: string]: any; // further configuration, like title and creator
  31. } | string,
  32. description?: string | {
  33. title: string;
  34. subtitle?: string;
  35. thumbnail?: string; // URL or data-url
  36. };
  37. scene?: {
  38. autoRotate?: boolean;
  39. rotationSpeed?: number;
  40. defaultCamera?: boolean;
  41. defaultLight?: boolean;
  42. clearColor?: { r: number, g: number, b: number, a: number };
  43. imageProcessingConfiguration?: IImageProcessingConfiguration;
  44. },
  45. // at the moment, support only a single camera.
  46. camera?: {
  47. position?: { x: number, y: number, z: number };
  48. rotation?: { x: number, y: number, z: number, w: number };
  49. fov?: number;
  50. fovMode?: number;
  51. minZ?: number;
  52. maxZ?: number;
  53. inertia?: number;
  54. behaviors?: Array<number | {
  55. type: number;
  56. [propName: string]: any;
  57. }>;
  58. [propName: string]: any;
  59. },
  60. skybox?: {
  61. cubeTexture: {
  62. noMipMap?: boolean;
  63. gammaSpace?: boolean;
  64. url: string | Array<string>;
  65. };
  66. pbr?: boolean;
  67. scale?: number;
  68. blur?: number;
  69. material?: {
  70. imageProcessingConfiguration?: IImageProcessingConfiguration;
  71. };
  72. infiniteDIstance?: boolean;
  73. };
  74. ground?: boolean | {
  75. size?: number;
  76. receiveShadows?: boolean;
  77. shadowOnly?: boolean;
  78. material?: {
  79. [propName: string]: any;
  80. }
  81. };
  82. lights?: Array<{
  83. type: number;
  84. name?: string;
  85. disabled?: boolean;
  86. position?: { x: number, y: number, z: number };
  87. target?: { x: number, y: number, z: number };
  88. direction?: { x: number, y: number, z: number };
  89. diffuse?: { r: number, g: number, b: number };
  90. specular?: { r: number, g: number, b: number };
  91. intensity?: number;
  92. radius?: number;
  93. shadownEnabled?: boolean; // only on specific lights!
  94. shadowConfig?: {
  95. useBlurExponentialShadowMap?: boolean;
  96. useKernelBlur?: boolean;
  97. blurKernel?: number;
  98. blurScale?: number;
  99. [propName: string]: any;
  100. }
  101. [propName: string]: any;
  102. // no behaviors for light at the moment, but allowing configuration for future reference.
  103. behaviors?: Array<number | {
  104. type: number;
  105. [propName: string]: any;
  106. }>
  107. }>
  108. // engine configuration. optional!
  109. engine?: {
  110. antialiasing?: boolean;
  111. },
  112. template?: TemplateConfiguration
  113. // nodes?
  114. }
  115. export interface IImageProcessingConfiguration {
  116. colorGradingEnabled?: boolean;
  117. colorCurvesEnabled?: boolean;
  118. colorCurves?: {
  119. globalHue?: number;
  120. globalDensity?: number;
  121. globalSaturation?: number;
  122. globalExposure?: number;
  123. highlightsHue?: number;
  124. highlightsDensity?: number;
  125. highlightsSaturation?: number;
  126. highlightsExposure?: number;
  127. midtonesHue?: number;
  128. midtonesDensity?: number;
  129. midtonesSaturation?: number;
  130. midtonesExposure?: number;
  131. shadowsHue?: number;
  132. shadowsDensity?: number;
  133. shadowsSaturation?: number;
  134. shadowsExposure?: number;
  135. };
  136. colorGradingWithGreenDepth?: boolean;
  137. colorGradingBGR?: boolean;
  138. exposure?: number;
  139. toneMappingEnabled?: boolean;
  140. contrast?: number;
  141. vignetteEnabled?: boolean;
  142. vignetteStretch?: number;
  143. vignetteCentreX?: number;
  144. vignetteCentreY?: number;
  145. vignetteWeight?: number;
  146. vignetteColor?: { r: number, g: number, b: number, a?: number };
  147. vignetteCameraFov?: number;
  148. vignetteBlendMode?: number;
  149. vignetteM?: boolean;
  150. applyByPostProcess?: boolean;
  151. }
  152. export let defaultConfiguration: ViewerConfiguration = {
  153. version: "0.1",
  154. eventPrefix: 'babylonviewer-',
  155. events: true,
  156. defaultViewer: true,
  157. template: {
  158. html: require("../../assets/templates/default/defaultTemplate.html"),
  159. children: {
  160. loadingScreen: {
  161. html: require("../../assets/templates/default/loadingScreen.html"),
  162. config: {
  163. backgroundColor: "#000000",
  164. loadingImage: require('../../assets/img/loading.png')//""
  165. }
  166. },
  167. viewer: {
  168. html: require("../../assets/templates/default/defaultViewer.html"),
  169. children: {
  170. navBar: {
  171. html: require("../../assets/templates/default/navbar.html"),
  172. config: {
  173. buttons: [
  174. {
  175. id: 'fullscreen-button',
  176. altText: "Fullscreen",
  177. image: require('../../assets/img/fullscreen.png')
  178. }
  179. ]
  180. },
  181. events: {
  182. pointerdown: ['#fullscreen-button']
  183. }
  184. }
  185. }
  186. }
  187. }
  188. },
  189. camera: {
  190. behaviors: [
  191. 0,
  192. {
  193. type: 2,
  194. zoomOnBoundingInfo: true,
  195. zoomStopsAnimation: false
  196. }
  197. ]
  198. },
  199. lights: [
  200. {
  201. type: 1,
  202. shadowEnabled: true,
  203. direction: { x: -0.2, y: -1, z: 0 },
  204. position: { x: 0.017, y: 0.5, z: 0 },
  205. intensity: 4.5,
  206. shadowConfig: {
  207. useBlurExponentialShadowMap: true,
  208. useKernelBlur: true,
  209. blurKernel: 64,
  210. blurScale: 4
  211. }
  212. }
  213. ],
  214. skybox: {
  215. cubeTexture: {
  216. url: 'https://playground.babylonjs.com/textures/environment.dds',
  217. gammaSpace: false
  218. },
  219. pbr: true,
  220. blur: 0.7,
  221. scale: 32,
  222. infiniteDIstance: false,
  223. material: {
  224. imageProcessingConfiguration: {
  225. colorCurves: {
  226. globalDensity: 89,
  227. globalHue: 58.88,
  228. globalSaturation: 94
  229. },
  230. colorCurvesEnabled: true,
  231. exposure: 1.5,
  232. contrast: 1.66,
  233. toneMappingEnabled: true,
  234. vignetteEnabled: true,
  235. vignetteWeight: 5,
  236. vignetteColor: { r: 0.8, g: 0.6, b: 0.4 },
  237. vignetteM: true
  238. }
  239. }
  240. },
  241. ground: true,
  242. engine: {
  243. antialiasing: true
  244. },
  245. scene: {
  246. imageProcessingConfiguration: {
  247. exposure: 1.4,
  248. contrast: 1.66,
  249. toneMappingEnabled: true
  250. }
  251. //autoRotate: true,
  252. //rotationSpeed: 0.1
  253. }
  254. }