configuration.ts 18 KB

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