@2112-lab/central-plant 0.1.4 → 0.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/dist/bundle/index.js +33146 -1
  2. package/dist/cjs/_virtual/_rollupPluginBabelHelpers.js +432 -1
  3. package/dist/cjs/node_modules/@2112-lab/pathfinder/dist/index.esm.js +1448 -1
  4. package/dist/cjs/node_modules/three/examples/jsm/controls/OrbitControls.js +1853 -1
  5. package/dist/cjs/node_modules/three/examples/jsm/exporters/GLTFExporter.js +3537 -1
  6. package/dist/cjs/node_modules/three/examples/jsm/exporters/OBJExporter.js +305 -1
  7. package/dist/cjs/node_modules/three/examples/jsm/exporters/PLYExporter.js +542 -1
  8. package/dist/cjs/node_modules/three/examples/jsm/exporters/STLExporter.js +218 -1
  9. package/dist/cjs/node_modules/three/examples/jsm/loaders/DRACOLoader.js +683 -1
  10. package/dist/cjs/node_modules/three/examples/jsm/loaders/GLTFLoader.js +4811 -1
  11. package/dist/cjs/node_modules/three/examples/jsm/loaders/RGBELoader.js +480 -1
  12. package/dist/cjs/node_modules/three/examples/jsm/renderers/CSS2DRenderer.js +309 -1
  13. package/dist/cjs/node_modules/three/examples/jsm/utils/BufferGeometryUtils.js +120 -1
  14. package/dist/cjs/src/analysis/analysis.js +560 -1
  15. package/dist/cjs/src/analysis/testing.js +958 -1
  16. package/dist/cjs/src/core/centralPlant.js +1149 -1
  17. package/dist/cjs/src/core/debugLogger.js +175 -1
  18. package/dist/cjs/src/core/mathUtils.js +574 -1
  19. package/dist/cjs/src/core/nameUtils.js +93 -1
  20. package/dist/cjs/src/data/export.js +716 -1
  21. package/dist/cjs/src/data/import.js +380 -1
  22. package/dist/cjs/src/data/numerics.js +522 -1
  23. package/dist/cjs/src/helpers/sceneHelper.js +572 -1
  24. package/dist/cjs/src/index.js +69 -1
  25. package/dist/cjs/src/managers/components/animationManager.js +123 -1
  26. package/dist/cjs/src/managers/components/componentManager.js +332 -1
  27. package/dist/cjs/src/managers/components/pathfindingManager.js +1441 -1
  28. package/dist/cjs/src/managers/controls/TransformControls.js +1063 -1
  29. package/dist/cjs/src/managers/controls/cameraControlsManager.js +79 -1
  30. package/dist/cjs/src/managers/controls/dragDropManager.js +1026 -1
  31. package/dist/cjs/src/managers/controls/keyboardControlsManager.js +395 -1
  32. package/dist/cjs/src/managers/controls/transformControlsManager.js +1807 -1
  33. package/dist/cjs/src/managers/environment/environmentManager.js +714 -1
  34. package/dist/cjs/src/managers/environment/textureConfig.js +229 -1
  35. package/dist/cjs/src/managers/scene/sceneExportManager.js +264 -1
  36. package/dist/cjs/src/managers/scene/sceneInitializationManager.js +346 -1
  37. package/dist/cjs/src/managers/scene/sceneOperationsManager.js +1509 -1
  38. package/dist/cjs/src/managers/scene/sceneTooltipsManager.js +661 -1
  39. package/dist/cjs/src/managers/system/disposalManager.js +444 -1
  40. package/dist/cjs/src/managers/system/hotReloadManager.js +291 -1
  41. package/dist/cjs/src/managers/system/performanceMonitor.js +863 -1
  42. package/dist/cjs/src/rendering/modelPreloader.js +369 -1
  43. package/dist/cjs/src/rendering/rendering2D.js +631 -1
  44. package/dist/cjs/src/rendering/rendering3D.js +685 -1
  45. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js +396 -1
  46. package/dist/esm/node_modules/@2112-lab/pathfinder/dist/index.esm.js +1444 -1
  47. package/dist/esm/node_modules/three/examples/jsm/controls/OrbitControls.js +1849 -1
  48. package/dist/esm/node_modules/three/examples/jsm/exporters/GLTFExporter.js +3533 -1
  49. package/dist/esm/node_modules/three/examples/jsm/exporters/OBJExporter.js +301 -1
  50. package/dist/esm/node_modules/three/examples/jsm/exporters/PLYExporter.js +538 -1
  51. package/dist/esm/node_modules/three/examples/jsm/exporters/STLExporter.js +214 -1
  52. package/dist/esm/node_modules/three/examples/jsm/loaders/DRACOLoader.js +679 -1
  53. package/dist/esm/node_modules/three/examples/jsm/loaders/GLTFLoader.js +4807 -1
  54. package/dist/esm/node_modules/three/examples/jsm/loaders/RGBELoader.js +476 -1
  55. package/dist/esm/node_modules/three/examples/jsm/renderers/CSS2DRenderer.js +304 -1
  56. package/dist/esm/node_modules/three/examples/jsm/utils/BufferGeometryUtils.js +116 -1
  57. package/dist/esm/src/analysis/analysis.js +536 -1
  58. package/dist/esm/src/analysis/testing.js +954 -1
  59. package/dist/esm/src/core/centralPlant.js +1144 -1
  60. package/dist/esm/src/core/debugLogger.js +167 -1
  61. package/dist/esm/src/core/mathUtils.js +570 -1
  62. package/dist/esm/src/core/nameUtils.js +87 -1
  63. package/dist/esm/src/data/export.js +712 -1
  64. package/dist/esm/src/data/import.js +356 -1
  65. package/dist/esm/src/data/numerics.js +518 -1
  66. package/dist/esm/src/helpers/sceneHelper.js +547 -1
  67. package/dist/esm/src/index.js +35 -1
  68. package/dist/esm/src/managers/components/animationManager.js +119 -1
  69. package/dist/esm/src/managers/components/componentManager.js +328 -1
  70. package/dist/esm/src/managers/components/pathfindingManager.js +1417 -1
  71. package/dist/esm/src/managers/controls/TransformControls.js +1057 -1
  72. package/dist/esm/src/managers/controls/cameraControlsManager.js +75 -1
  73. package/dist/esm/src/managers/controls/dragDropManager.js +1002 -1
  74. package/dist/esm/src/managers/controls/keyboardControlsManager.js +371 -1
  75. package/dist/esm/src/managers/controls/transformControlsManager.js +1782 -1
  76. package/dist/esm/src/managers/environment/environmentManager.js +690 -1
  77. package/dist/esm/src/managers/environment/textureConfig.js +202 -1
  78. package/dist/esm/src/managers/scene/sceneExportManager.js +260 -1
  79. package/dist/esm/src/managers/scene/sceneInitializationManager.js +322 -1
  80. package/dist/esm/src/managers/scene/sceneOperationsManager.js +1485 -1
  81. package/dist/esm/src/managers/scene/sceneTooltipsManager.js +637 -1
  82. package/dist/esm/src/managers/system/disposalManager.js +440 -1
  83. package/dist/esm/src/managers/system/hotReloadManager.js +287 -1
  84. package/dist/esm/src/managers/system/performanceMonitor.js +858 -1
  85. package/dist/esm/src/rendering/modelPreloader.js +364 -1
  86. package/dist/esm/src/rendering/rendering2D.js +627 -1
  87. package/dist/esm/src/rendering/rendering3D.js +661 -1
  88. package/package.json +1 -1
@@ -1 +1,480 @@
1
- "use strict";Object.defineProperty(exports,"t",{value:!0});var r=require("three");class e extends r.DataTextureLoader{constructor(e){super(e),this.type=r.HalfFloatType}parse(e){const t=function(r,e){switch(r){case 1:throw new Error("THREE.RGBELoader: Read Error: "+(e||""));case 2:throw new Error("THREE.RGBELoader: Write Error: "+(e||""));case 3:throw new Error("THREE.RGBELoader: Bad File Format: "+(e||""));default:throw new Error("THREE.RGBELoader: Memory Error: "+(e||""))}},n=function(r,e,t){e=e||1024;let n=r.pos,s=-1,a=0,o="",i=String.fromCharCode.apply(null,new Uint16Array(r.subarray(n,n+128)));for(;0>(s=i.indexOf("\n"))&&a<e&&n<r.byteLength;)o+=i,a+=i.length,n+=128,i+=String.fromCharCode.apply(null,new Uint16Array(r.subarray(n,n+128)));return-1<s&&(!1!==t&&(r.pos+=a+s+1),o+i.slice(0,s))},s=function(r,e,t,n){const s=r[e+3],a=Math.pow(2,s-128)/255;t[n+0]=r[e+0]*a,t[n+1]=r[e+1]*a,t[n+2]=r[e+2]*a,t[n+3]=1},a=function(e,t,n,s){const a=e[t+3],o=Math.pow(2,a-128)/255;n[s+0]=r.DataUtils.toHalfFloat(Math.min(e[t+0]*o,65504)),n[s+1]=r.DataUtils.toHalfFloat(Math.min(e[t+1]*o,65504)),n[s+2]=r.DataUtils.toHalfFloat(Math.min(e[t+2]*o,65504)),n[s+3]=r.DataUtils.toHalfFloat(1)},o=new Uint8Array(e);o.pos=0;const i=function(r){const e=/^\s*GAMMA\s*=\s*(\d+(\.\d+)?)\s*$/,s=/^\s*EXPOSURE\s*=\s*(\d+(\.\d+)?)\s*$/,a=/^\s*FORMAT=(\S+)\s*$/,o=/^\s*\-Y\s+(\d+)\s+\+X\s+(\d+)\s*$/,i={valid:0,string:"",comments:"",programtype:"RGBE",format:"",gamma:1,exposure:1,width:0,height:0};let c,l;for((r.pos>=r.byteLength||!(c=n(r)))&&t(1,"no header found"),(l=c.match(/^#\?(\S+)/))||t(3,"bad initial token"),i.valid|=1,i.programtype=l[1],i.string+=c+"\n";c=n(r),!1!==c;)if(i.string+=c+"\n","#"!==c.charAt(0)){if((l=c.match(e))&&(i.gamma=parseFloat(l[1])),(l=c.match(s))&&(i.exposure=parseFloat(l[1])),(l=c.match(a))&&(i.valid|=2,i.format=l[1]),(l=c.match(o))&&(i.valid|=4,i.height=parseInt(l[1],10),i.width=parseInt(l[2],10)),2&i.valid&&4&i.valid)break}else i.comments+=c+"\n";return 2&i.valid||t(3,"missing format specifier"),4&i.valid||t(3,"missing image size specifier"),i}(o),c=i.width,l=i.height,d=function(r,e,n){const s=e;if(s<8||s>32767||2!==r[0]||2!==r[1]||128&r[2])return new Uint8Array(r);s!==(r[2]<<8|r[3])&&t(3,"wrong scanline width");const a=new Uint8Array(4*e*n);a.length||t(4,"unable to allocate buffer space");let o=0,i=0;const c=4*s,l=new Uint8Array(4),d=new Uint8Array(c);let u=n;for(;u>0&&i<r.byteLength;){i+4>r.byteLength&&t(1),l[0]=r[i++],l[1]=r[i++],l[2]=r[i++],l[3]=r[i++],2==l[0]&&2==l[1]&&(l[2]<<8|l[3])==s||t(3,"bad rgbe scanline format");let e,n=0;for(;n<c&&i<r.byteLength;){e=r[i++];const s=e>128;if(s&&(e-=128),(0===e||n+e>c)&&t(3,"bad scanline data"),s){const t=r[i++];for(let r=0;r<e;r++)d[n++]=t}else d.set(r.subarray(i,i+e),n),n+=e,i+=e}const f=s;for(let r=0;r<f;r++){let e=0;a[o]=d[r+e],e+=s,a[o+1]=d[r+e],e+=s,a[o+2]=d[r+e],e+=s,a[o+3]=d[r+e],o+=4}u--}return a}(o.subarray(o.pos),c,l);let u,f,h;switch(this.type){case r.FloatType:h=d.length/4;const e=new Float32Array(4*h);for(let r=0;r<h;r++)s(d,4*r,e,4*r);u=e,f=r.FloatType;break;case r.HalfFloatType:h=d.length/4;const t=new Uint16Array(4*h);for(let r=0;r<h;r++)a(d,4*r,t,4*r);u=t,f=r.HalfFloatType;break;default:throw new Error("THREE.RGBELoader: Unsupported type: "+this.type)}return{width:c,height:l,data:u,header:i.string,gamma:i.gamma,exposure:i.exposure,type:f}}setDataType(r){return this.type=r,this}load(e,t,n,s){return super.load(e,function(e,n){switch(e.type){case r.FloatType:case r.HalfFloatType:e.colorSpace=r.LinearSRGBColorSpace,e.minFilter=r.LinearFilter,e.magFilter=r.LinearFilter,e.generateMipmaps=!1,e.flipY=!0}t&&t(e,n)},n,s)}}exports.RGBELoader=e;
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var THREE = require('three');
6
+
7
+ /**
8
+ * A loader for the RGBE HDR texture format.
9
+ *
10
+ * ```js
11
+ * const loader = new RGBELoader();
12
+ * const envMap = await loader.loadAsync( 'textures/equirectangular/blouberg_sunrise_2_1k.hdr' );
13
+ * envMap.mapping = THREE.EquirectangularReflectionMapping;
14
+ *
15
+ * scene.environment = envMap;
16
+ * ```
17
+ *
18
+ * @augments DataTextureLoader
19
+ * @three_import import { RGBELoader } from 'three/addons/loaders/RGBELoader.js';
20
+ */
21
+ class RGBELoader extends THREE.DataTextureLoader {
22
+
23
+ /**
24
+ * Constructs a new RGBE loader.
25
+ *
26
+ * @param {LoadingManager} [manager] - The loading manager.
27
+ */
28
+ constructor( manager ) {
29
+
30
+ super( manager );
31
+
32
+ /**
33
+ * The texture type.
34
+ *
35
+ * @type {(HalfFloatType|FloatType)}
36
+ * @default HalfFloatType
37
+ */
38
+ this.type = THREE.HalfFloatType;
39
+
40
+ }
41
+
42
+ /**
43
+ * Parses the given RGBE texture data.
44
+ *
45
+ * @param {ArrayBuffer} buffer - The raw texture data.
46
+ * @return {DataTextureLoader~TexData} An object representing the parsed texture data.
47
+ */
48
+ parse( buffer ) {
49
+
50
+ // adapted from http://www.graphics.cornell.edu/~bjw/rgbe.html
51
+
52
+ const
53
+ /* default error routine. change this to change error handling */
54
+ rgbe_read_error = 1,
55
+ rgbe_write_error = 2,
56
+ rgbe_format_error = 3,
57
+ rgbe_memory_error = 4,
58
+ rgbe_error = function ( rgbe_error_code, msg ) {
59
+
60
+ switch ( rgbe_error_code ) {
61
+
62
+ case rgbe_read_error: throw new Error( 'THREE.RGBELoader: Read Error: ' + ( msg || '' ) );
63
+ case rgbe_write_error: throw new Error( 'THREE.RGBELoader: Write Error: ' + ( msg || '' ) );
64
+ case rgbe_format_error: throw new Error( 'THREE.RGBELoader: Bad File Format: ' + ( msg || '' ) );
65
+ default:
66
+ case rgbe_memory_error: throw new Error( 'THREE.RGBELoader: Memory Error: ' + ( msg || '' ) );
67
+
68
+ }
69
+
70
+ },
71
+
72
+ /* offsets to red, green, and blue components in a data (float) pixel */
73
+ //RGBE_DATA_RED = 0,
74
+ //RGBE_DATA_GREEN = 1,
75
+ //RGBE_DATA_BLUE = 2,
76
+
77
+ /* number of floats per pixel, use 4 since stored in rgba image format */
78
+ //RGBE_DATA_SIZE = 4,
79
+
80
+ /* flags indicating which fields in an rgbe_header_info are valid */
81
+ RGBE_VALID_PROGRAMTYPE = 1,
82
+ RGBE_VALID_FORMAT = 2,
83
+ RGBE_VALID_DIMENSIONS = 4,
84
+
85
+ NEWLINE = '\n',
86
+
87
+ fgets = function ( buffer, lineLimit, consume ) {
88
+
89
+ const chunkSize = 128;
90
+
91
+ lineLimit = ! lineLimit ? 1024 : lineLimit;
92
+ let p = buffer.pos,
93
+ i = - 1, len = 0, s = '',
94
+ chunk = String.fromCharCode.apply( null, new Uint16Array( buffer.subarray( p, p + chunkSize ) ) );
95
+
96
+ while ( ( 0 > ( i = chunk.indexOf( NEWLINE ) ) ) && ( len < lineLimit ) && ( p < buffer.byteLength ) ) {
97
+
98
+ s += chunk; len += chunk.length;
99
+ p += chunkSize;
100
+ chunk += String.fromCharCode.apply( null, new Uint16Array( buffer.subarray( p, p + chunkSize ) ) );
101
+
102
+ }
103
+
104
+ if ( - 1 < i ) {
105
+
106
+ /*for (i=l-1; i>=0; i--) {
107
+ byteCode = m.charCodeAt(i);
108
+ if (byteCode > 0x7f && byteCode <= 0x7ff) byteLen++;
109
+ else if (byteCode > 0x7ff && byteCode <= 0xffff) byteLen += 2;
110
+ if (byteCode >= 0xDC00 && byteCode <= 0xDFFF) i--; //trail surrogate
111
+ }*/
112
+ if ( false !== consume ) buffer.pos += len + i + 1;
113
+ return s + chunk.slice( 0, i );
114
+
115
+ }
116
+
117
+ return false;
118
+
119
+ },
120
+
121
+ /* minimal header reading. modify if you want to parse more information */
122
+ RGBE_ReadHeader = function ( buffer ) {
123
+
124
+
125
+ // regexes to parse header info fields
126
+ const magic_token_re = /^#\?(\S+)/,
127
+ gamma_re = /^\s*GAMMA\s*=\s*(\d+(\.\d+)?)\s*$/,
128
+ exposure_re = /^\s*EXPOSURE\s*=\s*(\d+(\.\d+)?)\s*$/,
129
+ format_re = /^\s*FORMAT=(\S+)\s*$/,
130
+ dimensions_re = /^\s*\-Y\s+(\d+)\s+\+X\s+(\d+)\s*$/,
131
+
132
+ // RGBE format header struct
133
+ header = {
134
+
135
+ valid: 0, /* indicate which fields are valid */
136
+
137
+ string: '', /* the actual header string */
138
+
139
+ comments: '', /* comments found in header */
140
+
141
+ programtype: 'RGBE', /* listed at beginning of file to identify it after "#?". defaults to "RGBE" */
142
+
143
+ format: '', /* RGBE format, default 32-bit_rle_rgbe */
144
+
145
+ gamma: 1.0, /* image has already been gamma corrected with given gamma. defaults to 1.0 (no correction) */
146
+
147
+ exposure: 1.0, /* a value of 1.0 in an image corresponds to <exposure> watts/steradian/m^2. defaults to 1.0 */
148
+
149
+ width: 0, height: 0 /* image dimensions, width/height */
150
+
151
+ };
152
+
153
+ let line, match;
154
+
155
+ if ( buffer.pos >= buffer.byteLength || ! ( line = fgets( buffer ) ) ) {
156
+
157
+ rgbe_error( rgbe_read_error, 'no header found' );
158
+
159
+ }
160
+
161
+ /* if you want to require the magic token then uncomment the next line */
162
+ if ( ! ( match = line.match( magic_token_re ) ) ) {
163
+
164
+ rgbe_error( rgbe_format_error, 'bad initial token' );
165
+
166
+ }
167
+
168
+ header.valid |= RGBE_VALID_PROGRAMTYPE;
169
+ header.programtype = match[ 1 ];
170
+ header.string += line + '\n';
171
+
172
+ while ( true ) {
173
+
174
+ line = fgets( buffer );
175
+ if ( false === line ) break;
176
+ header.string += line + '\n';
177
+
178
+ if ( '#' === line.charAt( 0 ) ) {
179
+
180
+ header.comments += line + '\n';
181
+ continue; // comment line
182
+
183
+ }
184
+
185
+ if ( match = line.match( gamma_re ) ) {
186
+
187
+ header.gamma = parseFloat( match[ 1 ] );
188
+
189
+ }
190
+
191
+ if ( match = line.match( exposure_re ) ) {
192
+
193
+ header.exposure = parseFloat( match[ 1 ] );
194
+
195
+ }
196
+
197
+ if ( match = line.match( format_re ) ) {
198
+
199
+ header.valid |= RGBE_VALID_FORMAT;
200
+ header.format = match[ 1 ];//'32-bit_rle_rgbe';
201
+
202
+ }
203
+
204
+ if ( match = line.match( dimensions_re ) ) {
205
+
206
+ header.valid |= RGBE_VALID_DIMENSIONS;
207
+ header.height = parseInt( match[ 1 ], 10 );
208
+ header.width = parseInt( match[ 2 ], 10 );
209
+
210
+ }
211
+
212
+ if ( ( header.valid & RGBE_VALID_FORMAT ) && ( header.valid & RGBE_VALID_DIMENSIONS ) ) break;
213
+
214
+ }
215
+
216
+ if ( ! ( header.valid & RGBE_VALID_FORMAT ) ) {
217
+
218
+ rgbe_error( rgbe_format_error, 'missing format specifier' );
219
+
220
+ }
221
+
222
+ if ( ! ( header.valid & RGBE_VALID_DIMENSIONS ) ) {
223
+
224
+ rgbe_error( rgbe_format_error, 'missing image size specifier' );
225
+
226
+ }
227
+
228
+ return header;
229
+
230
+ },
231
+
232
+ RGBE_ReadPixels_RLE = function ( buffer, w, h ) {
233
+
234
+ const scanline_width = w;
235
+
236
+ if (
237
+ // run length encoding is not allowed so read flat
238
+ ( ( scanline_width < 8 ) || ( scanline_width > 0x7fff ) ) ||
239
+ // this file is not run length encoded
240
+ ( ( 2 !== buffer[ 0 ] ) || ( 2 !== buffer[ 1 ] ) || ( buffer[ 2 ] & 0x80 ) )
241
+ ) {
242
+
243
+ // return the flat buffer
244
+ return new Uint8Array( buffer );
245
+
246
+ }
247
+
248
+ if ( scanline_width !== ( ( buffer[ 2 ] << 8 ) | buffer[ 3 ] ) ) {
249
+
250
+ rgbe_error( rgbe_format_error, 'wrong scanline width' );
251
+
252
+ }
253
+
254
+ const data_rgba = new Uint8Array( 4 * w * h );
255
+
256
+ if ( ! data_rgba.length ) {
257
+
258
+ rgbe_error( rgbe_memory_error, 'unable to allocate buffer space' );
259
+
260
+ }
261
+
262
+ let offset = 0, pos = 0;
263
+
264
+ const ptr_end = 4 * scanline_width;
265
+ const rgbeStart = new Uint8Array( 4 );
266
+ const scanline_buffer = new Uint8Array( ptr_end );
267
+ let num_scanlines = h;
268
+
269
+ // read in each successive scanline
270
+ while ( ( num_scanlines > 0 ) && ( pos < buffer.byteLength ) ) {
271
+
272
+ if ( pos + 4 > buffer.byteLength ) {
273
+
274
+ rgbe_error( rgbe_read_error );
275
+
276
+ }
277
+
278
+ rgbeStart[ 0 ] = buffer[ pos ++ ];
279
+ rgbeStart[ 1 ] = buffer[ pos ++ ];
280
+ rgbeStart[ 2 ] = buffer[ pos ++ ];
281
+ rgbeStart[ 3 ] = buffer[ pos ++ ];
282
+
283
+ if ( ( 2 != rgbeStart[ 0 ] ) || ( 2 != rgbeStart[ 1 ] ) || ( ( ( rgbeStart[ 2 ] << 8 ) | rgbeStart[ 3 ] ) != scanline_width ) ) {
284
+
285
+ rgbe_error( rgbe_format_error, 'bad rgbe scanline format' );
286
+
287
+ }
288
+
289
+ // read each of the four channels for the scanline into the buffer
290
+ // first red, then green, then blue, then exponent
291
+ let ptr = 0, count;
292
+
293
+ while ( ( ptr < ptr_end ) && ( pos < buffer.byteLength ) ) {
294
+
295
+ count = buffer[ pos ++ ];
296
+ const isEncodedRun = count > 128;
297
+ if ( isEncodedRun ) count -= 128;
298
+
299
+ if ( ( 0 === count ) || ( ptr + count > ptr_end ) ) {
300
+
301
+ rgbe_error( rgbe_format_error, 'bad scanline data' );
302
+
303
+ }
304
+
305
+ if ( isEncodedRun ) {
306
+
307
+ // a (encoded) run of the same value
308
+ const byteValue = buffer[ pos ++ ];
309
+ for ( let i = 0; i < count; i ++ ) {
310
+
311
+ scanline_buffer[ ptr ++ ] = byteValue;
312
+
313
+ }
314
+ //ptr += count;
315
+
316
+ } else {
317
+
318
+ // a literal-run
319
+ scanline_buffer.set( buffer.subarray( pos, pos + count ), ptr );
320
+ ptr += count; pos += count;
321
+
322
+ }
323
+
324
+ }
325
+
326
+
327
+ // now convert data from buffer into rgba
328
+ // first red, then green, then blue, then exponent (alpha)
329
+ const l = scanline_width; //scanline_buffer.byteLength;
330
+ for ( let i = 0; i < l; i ++ ) {
331
+
332
+ let off = 0;
333
+ data_rgba[ offset ] = scanline_buffer[ i + off ];
334
+ off += scanline_width; //1;
335
+ data_rgba[ offset + 1 ] = scanline_buffer[ i + off ];
336
+ off += scanline_width; //1;
337
+ data_rgba[ offset + 2 ] = scanline_buffer[ i + off ];
338
+ off += scanline_width; //1;
339
+ data_rgba[ offset + 3 ] = scanline_buffer[ i + off ];
340
+ offset += 4;
341
+
342
+ }
343
+
344
+ num_scanlines --;
345
+
346
+ }
347
+
348
+ return data_rgba;
349
+
350
+ };
351
+
352
+ const RGBEByteToRGBFloat = function ( sourceArray, sourceOffset, destArray, destOffset ) {
353
+
354
+ const e = sourceArray[ sourceOffset + 3 ];
355
+ const scale = Math.pow( 2.0, e - 128.0 ) / 255.0;
356
+
357
+ destArray[ destOffset + 0 ] = sourceArray[ sourceOffset + 0 ] * scale;
358
+ destArray[ destOffset + 1 ] = sourceArray[ sourceOffset + 1 ] * scale;
359
+ destArray[ destOffset + 2 ] = sourceArray[ sourceOffset + 2 ] * scale;
360
+ destArray[ destOffset + 3 ] = 1;
361
+
362
+ };
363
+
364
+ const RGBEByteToRGBHalf = function ( sourceArray, sourceOffset, destArray, destOffset ) {
365
+
366
+ const e = sourceArray[ sourceOffset + 3 ];
367
+ const scale = Math.pow( 2.0, e - 128.0 ) / 255.0;
368
+
369
+ // clamping to 65504, the maximum representable value in float16
370
+ destArray[ destOffset + 0 ] = THREE.DataUtils.toHalfFloat( Math.min( sourceArray[ sourceOffset + 0 ] * scale, 65504 ) );
371
+ destArray[ destOffset + 1 ] = THREE.DataUtils.toHalfFloat( Math.min( sourceArray[ sourceOffset + 1 ] * scale, 65504 ) );
372
+ destArray[ destOffset + 2 ] = THREE.DataUtils.toHalfFloat( Math.min( sourceArray[ sourceOffset + 2 ] * scale, 65504 ) );
373
+ destArray[ destOffset + 3 ] = THREE.DataUtils.toHalfFloat( 1 );
374
+
375
+ };
376
+
377
+ const byteArray = new Uint8Array( buffer );
378
+ byteArray.pos = 0;
379
+ const rgbe_header_info = RGBE_ReadHeader( byteArray );
380
+
381
+ const w = rgbe_header_info.width,
382
+ h = rgbe_header_info.height,
383
+ image_rgba_data = RGBE_ReadPixels_RLE( byteArray.subarray( byteArray.pos ), w, h );
384
+
385
+
386
+ let data, type;
387
+ let numElements;
388
+
389
+ switch ( this.type ) {
390
+
391
+ case THREE.FloatType:
392
+
393
+ numElements = image_rgba_data.length / 4;
394
+ const floatArray = new Float32Array( numElements * 4 );
395
+
396
+ for ( let j = 0; j < numElements; j ++ ) {
397
+
398
+ RGBEByteToRGBFloat( image_rgba_data, j * 4, floatArray, j * 4 );
399
+
400
+ }
401
+
402
+ data = floatArray;
403
+ type = THREE.FloatType;
404
+ break;
405
+
406
+ case THREE.HalfFloatType:
407
+
408
+ numElements = image_rgba_data.length / 4;
409
+ const halfArray = new Uint16Array( numElements * 4 );
410
+
411
+ for ( let j = 0; j < numElements; j ++ ) {
412
+
413
+ RGBEByteToRGBHalf( image_rgba_data, j * 4, halfArray, j * 4 );
414
+
415
+ }
416
+
417
+ data = halfArray;
418
+ type = THREE.HalfFloatType;
419
+ break;
420
+
421
+ default:
422
+
423
+ throw new Error( 'THREE.RGBELoader: Unsupported type: ' + this.type );
424
+
425
+ }
426
+
427
+ return {
428
+ width: w, height: h,
429
+ data: data,
430
+ header: rgbe_header_info.string,
431
+ gamma: rgbe_header_info.gamma,
432
+ exposure: rgbe_header_info.exposure,
433
+ type: type
434
+ };
435
+
436
+ }
437
+
438
+ /**
439
+ * Sets the texture type.
440
+ *
441
+ * @param {(HalfFloatType|FloatType)} value - The texture type to set.
442
+ * @return {RGBELoader} A reference to this loader.
443
+ */
444
+ setDataType( value ) {
445
+
446
+ this.type = value;
447
+ return this;
448
+
449
+ }
450
+
451
+ load( url, onLoad, onProgress, onError ) {
452
+
453
+ function onLoadCallback( texture, texData ) {
454
+
455
+ switch ( texture.type ) {
456
+
457
+ case THREE.FloatType:
458
+ case THREE.HalfFloatType:
459
+
460
+ texture.colorSpace = THREE.LinearSRGBColorSpace;
461
+ texture.minFilter = THREE.LinearFilter;
462
+ texture.magFilter = THREE.LinearFilter;
463
+ texture.generateMipmaps = false;
464
+ texture.flipY = true;
465
+
466
+ break;
467
+
468
+ }
469
+
470
+ if ( onLoad ) onLoad( texture, texData );
471
+
472
+ }
473
+
474
+ return super.load( url, onLoadCallback, onProgress, onError );
475
+
476
+ }
477
+
478
+ }
479
+
480
+ exports.RGBELoader = RGBELoader;