speechrecorderng 3.10.13 → 3.11.0

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 (99) hide show
  1. package/README.md +1 -1
  2. package/fesm2022/speechrecorderng.mjs +204 -201
  3. package/fesm2022/speechrecorderng.mjs.map +1 -1
  4. package/lib/audio/ui/audio_canvas_layer_comp.d.ts +2 -2
  5. package/lib/spr.module.version.d.ts +1 -1
  6. package/lib/ui/canvas_layer_comp.d.ts +1 -1
  7. package/lib/ui/responsive_component.d.ts +1 -1
  8. package/package.json +13 -15
  9. package/esm2022/lib/action/action.mjs +0 -73
  10. package/esm2022/lib/audio/array_audio_buffer.mjs +0 -164
  11. package/esm2022/lib/audio/array_audio_buffer_input_stream.mjs +0 -86
  12. package/esm2022/lib/audio/array_audio_buffer_random_access_stream.mjs +0 -16
  13. package/esm2022/lib/audio/audio_data_holder.mjs +0 -264
  14. package/esm2022/lib/audio/audio_display.mjs +0 -118
  15. package/esm2022/lib/audio/audio_player.mjs +0 -238
  16. package/esm2022/lib/audio/capture/capture.mjs +0 -855
  17. package/esm2022/lib/audio/context.mjs +0 -79
  18. package/esm2022/lib/audio/dsp/level_measure.mjs +0 -517
  19. package/esm2022/lib/audio/format.mjs +0 -20
  20. package/esm2022/lib/audio/impl/wavformat.mjs +0 -7
  21. package/esm2022/lib/audio/impl/wavreader.mjs +0 -144
  22. package/esm2022/lib/audio/impl/wavwriter.mjs +0 -191
  23. package/esm2022/lib/audio/inddb_audio_buffer.mjs +0 -508
  24. package/esm2022/lib/audio/io/stream.mjs +0 -59
  25. package/esm2022/lib/audio/net_audio_buffer.mjs +0 -293
  26. package/esm2022/lib/audio/persistor.mjs +0 -81
  27. package/esm2022/lib/audio/playback/array_audio_buffer_source_node.mjs +0 -126
  28. package/esm2022/lib/audio/playback/audio_source_node.mjs +0 -18
  29. package/esm2022/lib/audio/playback/audio_source_worklet_module_loader.mjs +0 -167
  30. package/esm2022/lib/audio/playback/inddb_audio_buffer_source_node.mjs +0 -167
  31. package/esm2022/lib/audio/playback/net_audio_buffer_source_node.mjs +0 -218
  32. package/esm2022/lib/audio/playback/player.mjs +0 -402
  33. package/esm2022/lib/audio/ui/audio_canvas_layer_comp.mjs +0 -347
  34. package/esm2022/lib/audio/ui/audio_display_control.mjs +0 -150
  35. package/esm2022/lib/audio/ui/audio_display_scroll_pane.mjs +0 -146
  36. package/esm2022/lib/audio/ui/audiosignal.mjs +0 -533
  37. package/esm2022/lib/audio/ui/common.mjs +0 -19
  38. package/esm2022/lib/audio/ui/container.mjs +0 -414
  39. package/esm2022/lib/audio/ui/livelevel.mjs +0 -361
  40. package/esm2022/lib/audio/ui/scroll_pane_horizontal.mjs +0 -11
  41. package/esm2022/lib/audio/ui/sonagram.mjs +0 -900
  42. package/esm2022/lib/db/inddb.mjs +0 -120
  43. package/esm2022/lib/dsp/utils.mjs +0 -48
  44. package/esm2022/lib/environment/environment.defaults.mjs +0 -9
  45. package/esm2022/lib/io/BinaryReader.mjs +0 -93
  46. package/esm2022/lib/io/BinaryWriter.mjs +0 -80
  47. package/esm2022/lib/io/stream.mjs +0 -259
  48. package/esm2022/lib/math/2d/geometry.mjs +0 -28
  49. package/esm2022/lib/math/complex.mjs +0 -58
  50. package/esm2022/lib/math/dft.mjs +0 -196
  51. package/esm2022/lib/media/utils.mjs +0 -14
  52. package/esm2022/lib/net/uploader.mjs +0 -367
  53. package/esm2022/lib/recorder_component.mjs +0 -65
  54. package/esm2022/lib/speechrecorder/project/project.mjs +0 -54
  55. package/esm2022/lib/speechrecorder/project/project.service.mjs +0 -64
  56. package/esm2022/lib/speechrecorder/recording.mjs +0 -124
  57. package/esm2022/lib/speechrecorder/recordings/basic_recording.service.mjs +0 -221
  58. package/esm2022/lib/speechrecorder/recordings/recordings.service.mjs +0 -1014
  59. package/esm2022/lib/speechrecorder/script/script.mjs +0 -114
  60. package/esm2022/lib/speechrecorder/script/script.service.mjs +0 -47
  61. package/esm2022/lib/speechrecorder/session/audiorecorder.mjs +0 -1179
  62. package/esm2022/lib/speechrecorder/session/basicrecorder.mjs +0 -676
  63. package/esm2022/lib/speechrecorder/session/controlpanel.mjs +0 -416
  64. package/esm2022/lib/speechrecorder/session/item.mjs +0 -30
  65. package/esm2022/lib/speechrecorder/session/progress.mjs +0 -135
  66. package/esm2022/lib/speechrecorder/session/prompting.mjs +0 -639
  67. package/esm2022/lib/speechrecorder/session/recorder_combi_pane.mjs +0 -88
  68. package/esm2022/lib/speechrecorder/session/recording_file_cache.mjs +0 -195
  69. package/esm2022/lib/speechrecorder/session/recording_list.mjs +0 -188
  70. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +0 -128
  71. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +0 -114
  72. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +0 -146
  73. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +0 -424
  74. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file.mjs +0 -68
  75. package/esm2022/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +0 -288
  76. package/esm2022/lib/speechrecorder/session/session.mjs +0 -2
  77. package/esm2022/lib/speechrecorder/session/session.service.mjs +0 -69
  78. package/esm2022/lib/speechrecorder/session/session_finished_dialog.mjs +0 -46
  79. package/esm2022/lib/speechrecorder/session/sessionmanager.mjs +0 -1385
  80. package/esm2022/lib/speechrecorder/session/warning_bar.mjs +0 -33
  81. package/esm2022/lib/speechrecorder/spruploader.mjs +0 -22
  82. package/esm2022/lib/speechrecorder/startstopsignal/startstopsignal.mjs +0 -2
  83. package/esm2022/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +0 -57
  84. package/esm2022/lib/speechrecorderng.component.mjs +0 -392
  85. package/esm2022/lib/speechrecorderng.module.mjs +0 -97
  86. package/esm2022/lib/spr.config.mjs +0 -27
  87. package/esm2022/lib/spr.module.version.mjs +0 -2
  88. package/esm2022/lib/ui/canvas_layer_comp.mjs +0 -38
  89. package/esm2022/lib/ui/intersection-observer.directive.mjs +0 -32
  90. package/esm2022/lib/ui/message_dialog.mjs +0 -51
  91. package/esm2022/lib/ui/recordingitem_display.mjs +0 -253
  92. package/esm2022/lib/ui/responsive_component.mjs +0 -24
  93. package/esm2022/lib/utils/scrollIntoViewToBottom.mjs +0 -23
  94. package/esm2022/lib/utils/ua-parser.mjs +0 -190
  95. package/esm2022/lib/utils/utils.mjs +0 -132
  96. package/esm2022/lib/utils/wake_lock.mjs +0 -114
  97. package/esm2022/lib/utils/wake_lock_media.mjs +0 -2
  98. package/esm2022/public-api.mjs +0 -35
  99. package/esm2022/speechrecorderng.mjs +0 -5
@@ -1,517 +0,0 @@
1
- import { DSPUtils } from "../../dsp/utils";
2
- import { Arrays, WorkerHelper } from "../../utils/utils";
3
- import { Observable } from "rxjs";
4
- export const MIN_DB_LEVEL = -40.0;
5
- export class LevelInfo {
6
- constructor(channelCount, startFrame = 0, frameLength = 0, minLinLevels, maxLinLevels) {
7
- this.channelCount = channelCount;
8
- this.startFrame = startFrame;
9
- this.frameLength = frameLength;
10
- this._minLinLevels = this.checkOrInitArray(minLinLevels);
11
- this._maxLinLevels = this.checkOrInitArray(maxLinLevels);
12
- }
13
- get minLinLevels() {
14
- return this._minLinLevels;
15
- }
16
- get maxLinLevels() {
17
- return this._maxLinLevels;
18
- }
19
- checkOrInitArray(arr) {
20
- if (arr) {
21
- if (arr.length !== this.channelCount)
22
- throw new Error("Level arrays must be equal to channel count " + this.channelCount);
23
- return arr;
24
- }
25
- else {
26
- return new Array(this.channelCount);
27
- }
28
- }
29
- merge(levelInfo) {
30
- if (levelInfo === null) {
31
- return;
32
- }
33
- if (this.channelCount !== levelInfo.channelCount) {
34
- throw new Error("Channel count of level info to merge must be equal. (" + this.channelCount + " != " + levelInfo.channelCount + ")");
35
- }
36
- let endFrame = this.startFrame + this.frameLength;
37
- let mergeEndFrame = levelInfo.startFrame + levelInfo.frameLength;
38
- if (levelInfo.startFrame < this.startFrame) {
39
- this.startFrame = levelInfo.startFrame;
40
- }
41
- if (mergeEndFrame > endFrame) {
42
- this.frameLength = mergeEndFrame - this.startFrame;
43
- }
44
- for (let ch = 0; ch < this.channelCount; ch++) {
45
- if (levelInfo.minLinLevels[ch] < this.minLinLevels[ch]) {
46
- this.minLinLevels[ch] = levelInfo.minLinLevels[ch];
47
- }
48
- if (levelInfo.maxLinLevels[ch] > this.maxLinLevels[ch]) {
49
- this.maxLinLevels[ch] = levelInfo.maxLinLevels[ch];
50
- }
51
- }
52
- }
53
- levelsLin() {
54
- let lvlsLin = new Array(this.channelCount);
55
- for (let ch = 0; ch < this.channelCount; ch++) {
56
- lvlsLin[ch] = Math.max(Math.abs(this.minLinLevels[ch]), Math.abs(this.maxLinLevels[ch]));
57
- }
58
- return lvlsLin;
59
- }
60
- powerLevelsDB() {
61
- let lvlsDb = new Array(this.channelCount);
62
- for (let ch = 0; ch < this.channelCount; ch++) {
63
- lvlsDb[ch] = DSPUtils.toPowerLevelInDB(this.levelsLin()[ch]);
64
- }
65
- return lvlsDb;
66
- }
67
- powerLevelDB() {
68
- let pLvlsDb = this.powerLevelsDB();
69
- return Math.max(...pLvlsDb);
70
- }
71
- clone() {
72
- return new LevelInfo(this.channelCount, this.startFrame, this.frameLength, Arrays.cloneNumberArray(this.minLinLevels), Arrays.cloneNumberArray(this.maxLinLevels));
73
- }
74
- }
75
- export class LevelInfos {
76
- constructor(bufferLevelInfos, peakLevelInfo) {
77
- this.bufferLevelInfos = bufferLevelInfos;
78
- this.peakLevelInfo = peakLevelInfo;
79
- }
80
- framesPerBuffer() {
81
- if (this.bufferLevelInfos.length > 0) {
82
- return this.bufferLevelInfos[0].frameLength;
83
- }
84
- return this.peakLevelInfo.frameLength / this.bufferLevelInfos.length;
85
- }
86
- }
87
- export class LevelMeasure {
88
- constructor() {
89
- this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);
90
- }
91
- calcBufferLevelInfos(audioDataHolder, bufferTimeLength) {
92
- return new Observable(subscriber => {
93
- let chs = audioDataHolder.numberOfChannels;
94
- let bufferFrameLength = Math.round(audioDataHolder.sampleRate * bufferTimeLength);
95
- let ais = audioDataHolder.audioInputStream();
96
- // Test: Check CRC
97
- //let crcVal:number=0;
98
- //let crclen:number=0;
99
- if (ais) {
100
- let audioBuffers = new Array(chs);
101
- let trBuffers = new Array(chs);
102
- for (let ch = 0; ch < chs; ch++) {
103
- audioBuffers[ch] = new Float32Array(bufferFrameLength);
104
- }
105
- let bufferLevelInfos = new Array();
106
- let peakLevelInfo = new LevelInfo(chs);
107
- let worker = new Worker(this.workerURL);
108
- worker.onmessage = (me) => {
109
- if (me.data.linLevelBuffers) {
110
- let linLevelArrs = new Array(chs);
111
- for (let ch = 0; ch < chs; ch++) {
112
- linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);
113
- }
114
- let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);
115
- let framePos = 0;
116
- for (let bi = 0; bi < bufferCount; bi++) {
117
- let minLevels = new Array(chs);
118
- let maxLevels = new Array(chs);
119
- for (let ch = 0; ch < chs; ch++) {
120
- let linLvlArrPos = bi * 2;
121
- minLevels[ch] = linLevelArrs[ch][linLvlArrPos];
122
- maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];
123
- }
124
- let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);
125
- bufferLevelInfos.push(bli);
126
- peakLevelInfo.merge(bli);
127
- }
128
- }
129
- if (me.data.eod === true) {
130
- // end of data, terminate worker and return result
131
- //this.terminateWorker();
132
- worker.terminate();
133
- ais?.close();
134
- //console.debug("Audio input stream CRC hex: "+crcVal.toString(16)+", crcLen: "+crclen+", buffer frame len: "+bufferFrameLength);
135
- subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));
136
- subscriber.complete();
137
- }
138
- else {
139
- if (ais) {
140
- let read = ais.read(audioBuffers);
141
- // TEST:
142
- // if(audioBuffers && audioBuffers.length>0) {
143
- // crcVal = crc32(audioBuffers[0].buffer, crcVal);
144
- // crclen += audioBuffers[0].buffer.byteLength;
145
- // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
146
- // }else{
147
- // console.debug("audioBuffers not avail!");
148
- // }
149
- for (let ch = 0; ch < chs; ch++) {
150
- // let copy = new Float32Array(audioBuffers[ch]);
151
- // trBuffers[ch] = copy.buffer;
152
- const arrAbBufCh = audioBuffers[ch];
153
- const adLen = arrAbBufCh.buffer.byteLength;
154
- if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
155
- trBuffers[ch] = new ArrayBuffer(adLen);
156
- }
157
- let fAdaCh = new Float32Array(trBuffers[ch]);
158
- fAdaCh.set(audioBuffers[ch]);
159
- }
160
- worker.postMessage({
161
- bufferFrameLength: bufferFrameLength,
162
- audioData: trBuffers,
163
- chs: chs,
164
- len: read
165
- }, trBuffers);
166
- }
167
- }
168
- };
169
- let read = ais.read(audioBuffers);
170
- // TEST:
171
- // if(audioBuffers && audioBuffers.length>0) {
172
- // crcVal = crc32(audioBuffers[0].buffer, crcVal);
173
- // crclen += audioBuffers[0].buffer.byteLength;
174
- // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
175
- // }else{
176
- // console.debug("audioBuffers not avail!");
177
- // }
178
- for (let ch = 0; ch < chs; ch++) {
179
- // let copy = new Float32Array(audioBuffers[ch]);
180
- // trBuffers[ch] = copy.buffer;
181
- const arrAbBufCh = audioBuffers[ch];
182
- const adLen = arrAbBufCh.buffer.byteLength;
183
- if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
184
- trBuffers[ch] = new ArrayBuffer(adLen);
185
- }
186
- let fAdaCh = new Float32Array(trBuffers[ch]);
187
- fAdaCh.set(audioBuffers[ch]);
188
- }
189
- worker.postMessage({
190
- bufferFrameLength: bufferFrameLength,
191
- audioData: trBuffers,
192
- chs: chs,
193
- len: read
194
- }, trBuffers);
195
- }
196
- else {
197
- let aAis = audioDataHolder.asyncAudioInputStream();
198
- let audioBuffers = new Array(chs);
199
- let trBuffers = new Array(chs);
200
- for (let ch = 0; ch < chs; ch++) {
201
- audioBuffers[ch] = new Float32Array(bufferFrameLength);
202
- }
203
- let bufferLevelInfos = new Array();
204
- let peakLevelInfo = new LevelInfo(chs);
205
- let worker = new Worker(this.workerURL);
206
- worker.onmessage = (me) => {
207
- if (subscriber.closed) {
208
- // subscriber abandoned
209
- worker.terminate();
210
- if (aAis) {
211
- aAis.close();
212
- }
213
- }
214
- else {
215
- if (me.data.linLevelBuffers) {
216
- let linLevelArrs = new Array(chs);
217
- for (let ch = 0; ch < chs; ch++) {
218
- linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);
219
- }
220
- let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);
221
- let framePos = 0;
222
- for (let bi = 0; bi < bufferCount; bi++) {
223
- let minLevels = new Array(chs);
224
- let maxLevels = new Array(chs);
225
- for (let ch = 0; ch < chs; ch++) {
226
- let linLvlArrPos = bi * 2;
227
- minLevels[ch] = linLevelArrs[ch][linLvlArrPos];
228
- maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];
229
- }
230
- let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);
231
- bufferLevelInfos.push(bli);
232
- peakLevelInfo.merge(bli);
233
- }
234
- }
235
- if (me.data.eod === true) {
236
- // end of data, terminate worker and return result
237
- //this.terminateWorker();
238
- worker.terminate();
239
- //ais?.close();
240
- aAis?.close();
241
- //console.debug("Audio input stream CRC hex: "+crcVal.toString(16)+", crcLen: "+crclen+", buffer frame len: "+bufferFrameLength);
242
- subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));
243
- subscriber.complete();
244
- }
245
- else {
246
- if (aAis) {
247
- aAis?.readObs(audioBuffers).subscribe({
248
- next: (read) => {
249
- // TEST:
250
- // if(audioBuffers && audioBuffers.length>0) {
251
- // crcVal = crc32(audioBuffers[0].buffer, crcVal);
252
- // crclen += audioBuffers[0].buffer.byteLength;
253
- // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
254
- // }else{
255
- // console.debug("audioBuffers not avail!");
256
- // }
257
- for (let ch = 0; ch < chs; ch++) {
258
- // let copy = new Float32Array(audioBuffers[ch]);
259
- // trBuffers[ch] = copy.buffer;
260
- const arrAbBufCh = audioBuffers[ch];
261
- const adLen = arrAbBufCh.buffer.byteLength;
262
- if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
263
- trBuffers[ch] = new ArrayBuffer(adLen);
264
- }
265
- let fAdaCh = new Float32Array(trBuffers[ch]);
266
- fAdaCh.set(audioBuffers[ch]);
267
- }
268
- worker.postMessage({
269
- bufferFrameLength: bufferFrameLength,
270
- audioData: trBuffers,
271
- chs: chs,
272
- len: read
273
- }, trBuffers);
274
- }
275
- });
276
- }
277
- }
278
- }
279
- };
280
- aAis?.readObs(audioBuffers).subscribe({
281
- next: (read) => {
282
- // TEST:
283
- // if(audioBuffers && audioBuffers.length>0) {
284
- // crcVal = crc32(audioBuffers[0].buffer, crcVal);
285
- // crclen += audioBuffers[0].buffer.byteLength;
286
- // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
287
- // }else{
288
- // console.debug("audioBuffers not avail!");
289
- // }
290
- for (let ch = 0; ch < chs; ch++) {
291
- // let copy = new Float32Array(audioBuffers[ch]);
292
- // trBuffers[ch] = copy.buffer;
293
- const arrAbBufCh = audioBuffers[ch];
294
- const adLen = arrAbBufCh.buffer.byteLength;
295
- if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
296
- trBuffers[ch] = new ArrayBuffer(adLen);
297
- }
298
- let fAdaCh = new Float32Array(trBuffers[ch]);
299
- fAdaCh.set(audioBuffers[ch]);
300
- }
301
- worker.postMessage({
302
- bufferFrameLength: bufferFrameLength,
303
- audioData: trBuffers,
304
- chs: chs,
305
- len: read
306
- }, trBuffers);
307
- }
308
- });
309
- }
310
- });
311
- }
312
- /*
313
- * Method used as worker code.
314
- */
315
- workerFunction() {
316
- self.onmessage = function (msg) {
317
- let len = msg.data.len;
318
- let bufferFrameLength = msg.data.bufferFrameLength;
319
- if (len == -1) {
320
- // start
321
- postMessage({
322
- eod: false,
323
- bufferFrameLength: bufferFrameLength,
324
- frameLength: len
325
- });
326
- }
327
- if (len == 0) {
328
- postMessage({
329
- eod: true,
330
- bufferFrameLength: bufferFrameLength,
331
- frameLength: len
332
- });
333
- }
334
- else {
335
- let chs = msg.data.chs;
336
- let audioData = new Array(chs);
337
- let linLevels = new Array(chs);
338
- for (let ch = 0; ch < chs; ch++) {
339
- audioData[ch] = new Float32Array(msg.data.audioData[ch]);
340
- }
341
- //let frameLength = audioData[0].length;
342
- let bufferCount = Math.ceil(len / bufferFrameLength);
343
- for (let ch = 0; ch < chs; ch++) {
344
- linLevels[ch] = new Float32Array(bufferCount * 2);
345
- }
346
- if (audioData && chs > 0) {
347
- for (let ch = 0; ch < chs; ch++) {
348
- let chData = audioData[ch];
349
- for (let s = 0; s < len; s++) {
350
- let bi = Math.floor(s / bufferFrameLength);
351
- let lvlArrPos = bi * 2;
352
- //let bs = s % bufferFrameLength;
353
- let chSample = chData[s];
354
- if (chSample < linLevels[ch][lvlArrPos]) {
355
- linLevels[ch][lvlArrPos] = chSample;
356
- }
357
- lvlArrPos++;
358
- if (chSample > linLevels[ch][lvlArrPos]) {
359
- linLevels[ch][lvlArrPos] = chSample;
360
- }
361
- }
362
- }
363
- const linLevelBufs = new Array(chs);
364
- for (let ch = 0; ch < chs; ch++) {
365
- linLevelBufs[ch] = linLevels[ch].buffer;
366
- }
367
- postMessage({
368
- eod: false,
369
- bufferFrameLength: bufferFrameLength,
370
- frameLength: len,
371
- linLevelBuffers: linLevelBufs
372
- }, linLevelBufs);
373
- }
374
- }
375
- };
376
- }
377
- }
378
- export class StreamLevelMeasure {
379
- constructor() {
380
- this.currentLevelInfos = null;
381
- this.peakLevelInfo = null;
382
- this.worker = null;
383
- this.channelCount = 0;
384
- this.bufferIndex = 0;
385
- this.frameCount = 0;
386
- this.levelListener = null;
387
- this.peakLevelListener = null;
388
- this.peakLevelInDb = MIN_DB_LEVEL;
389
- this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);
390
- }
391
- setFormat(channels, sampleRate) {
392
- this.channelCount = channels;
393
- this.currentLevelInfos = new LevelInfo(this.channelCount);
394
- this.peakLevelInfo = new LevelInfo(this.channelCount);
395
- this.worker = new Worker(this.workerURL);
396
- this.worker.onmessage = (me) => {
397
- let streamFinished = me.data.streamFinished;
398
- if (streamFinished) {
399
- if (this.levelListener) {
400
- this.levelListener.streamFinished();
401
- }
402
- }
403
- else {
404
- let minLevels = new Array(this.channelCount);
405
- let maxLevels = new Array(this.channelCount);
406
- for (let ch = 0; ch < this.channelCount; ch++) {
407
- let fls = new Float32Array(me.data.linLevelBuffers[ch]);
408
- minLevels[ch] = fls[0];
409
- maxLevels[ch] = fls[1];
410
- }
411
- let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.frameLength, minLevels, maxLevels);
412
- this.updateLevels(bi);
413
- }
414
- };
415
- }
416
- nextStream() {
417
- this.reset();
418
- }
419
- reset() {
420
- this.currentLevelInfos = new LevelInfo(this.channelCount);
421
- this.peakLevelInfo = new LevelInfo(this.channelCount);
422
- if (this.levelListener) {
423
- this.levelListener.reset();
424
- this.levelListener.channelCount = this.channelCount;
425
- }
426
- if (this.peakLevelListener) {
427
- this.peakLevelInDb = MIN_DB_LEVEL;
428
- this.peakLevelListener(this.peakLevelInDb);
429
- }
430
- }
431
- write(bufferData) {
432
- let bufArrCopies = new Array(bufferData.length);
433
- let buffers = new Array(bufferData.length);
434
- for (let ch = 0; ch < bufferData.length; ch++) {
435
- bufArrCopies[ch] = bufferData[ch].slice();
436
- buffers[ch] = bufArrCopies[ch].buffer;
437
- }
438
- this.worker?.postMessage({
439
- streamFinished: false,
440
- audioData: buffers,
441
- chs: this.channelCount,
442
- bufferIndex: this.bufferIndex
443
- }, buffers);
444
- this.bufferIndex++;
445
- return bufArrCopies[0].length;
446
- }
447
- flush() {
448
- this.worker?.postMessage({ streamFinished: true });
449
- }
450
- close() {
451
- this.worker?.terminate();
452
- }
453
- /*
454
- * Method used as worker code.
455
- */
456
- workerFunction() {
457
- self.onmessage = function (msg) {
458
- let streamFinished = msg.data.streamFinished;
459
- if (streamFinished) {
460
- postMessage({ streamFinished: true });
461
- }
462
- else {
463
- let chs = msg.data.chs;
464
- let frameLength = null;
465
- let audioData = new Array(chs);
466
- let linLevels = new Array(chs);
467
- for (let ch = 0; ch < chs; ch++) {
468
- linLevels[ch] = new Float32Array(2);
469
- audioData[ch] = new Float32Array(msg.data.audioData[ch]);
470
- }
471
- if (audioData) {
472
- for (let ch = 0; ch < chs; ch++) {
473
- let chData = audioData[ch];
474
- if (frameLength === null) {
475
- frameLength = chData.length;
476
- }
477
- for (let s = 0; s < frameLength; s++) {
478
- let chSample = chData[s];
479
- if (chSample < linLevels[ch][0]) {
480
- linLevels[ch][0] = chSample;
481
- }
482
- if (chSample > linLevels[ch][1]) {
483
- linLevels[ch][1] = chSample;
484
- }
485
- }
486
- }
487
- }
488
- let linLevelBufs = new Array(chs);
489
- for (let ch = 0; ch < chs; ch++) {
490
- linLevelBufs[ch] = linLevels[ch].buffer;
491
- }
492
- postMessage({ streamFinished: false, frameLength: frameLength, linLevelBuffers: linLevelBufs }, linLevelBufs);
493
- }
494
- };
495
- }
496
- updateLevels(bufferLevelInfo) {
497
- this.currentLevelInfos = bufferLevelInfo;
498
- if (this.peakLevelInfo) {
499
- this.peakLevelInfo.merge(bufferLevelInfo);
500
- if (this.levelListener) {
501
- this.levelListener.update(this.currentLevelInfos, this.peakLevelInfo.clone());
502
- }
503
- if (this.peakLevelListener) {
504
- let peakDBVal = bufferLevelInfo.powerLevelDB();
505
- if (this.peakLevelInDb < peakDBVal) {
506
- this.peakLevelInDb = peakDBVal;
507
- // the event comes from outside an Angular zone
508
- this.peakLevelListener(this.peakLevelInDb);
509
- }
510
- }
511
- }
512
- }
513
- stop() {
514
- this.worker?.terminate();
515
- }
516
- }
517
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"level_measure.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/dsp/level_measure.ts"],"names":[],"mappings":"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","sourcesContent":["import {DSPUtils} from \"../../dsp/utils\";\r\nimport {SequenceAudioFloat32OutStream} from \"../io/stream\";\r\nimport {Arrays, WorkerHelper} from \"../../utils/utils\";\r\nimport {AudioDataHolder} from \"../audio_data_holder\";\r\nimport {Observable} from \"rxjs\";\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\n\r\nexport class LevelInfo {\r\n\r\n  private readonly _minLinLevels: Array<number>;\r\n  private readonly _maxLinLevels: Array<number>;\r\n\r\n  constructor(public readonly channelCount: number,\r\n              public startFrame: number = 0,\r\n              public frameLength: number = 0,\r\n              minLinLevels?: Array<number>,\r\n              maxLinLevels?: Array<number>) {\r\n    this._minLinLevels = this.checkOrInitArray(minLinLevels);\r\n    this._maxLinLevels = this.checkOrInitArray(maxLinLevels);\r\n  }\r\n\r\n  get minLinLevels() {\r\n    return this._minLinLevels;\r\n  }\r\n\r\n  get maxLinLevels() {\r\n    return this._maxLinLevels;\r\n  }\r\n\r\n  private checkOrInitArray(arr: Array<number> | undefined): Array<number> {\r\n    if (arr) {\r\n      if (arr.length !== this.channelCount)\r\n        throw  new Error(\"Level arrays must be equal to channel count \" + this.channelCount);\r\n      return arr;\r\n    } else {\r\n      return new Array<number>(this.channelCount)\r\n    }\r\n  }\r\n\r\n  merge(levelInfo: LevelInfo) {\r\n    if (levelInfo === null) {\r\n      return;\r\n    }\r\n    if (this.channelCount !== levelInfo.channelCount) {\r\n      throw new Error(\"Channel count of level info to merge must be equal. (\" + this.channelCount + \" != \" + levelInfo.channelCount + \")\");\r\n    }\r\n\r\n    let endFrame = this.startFrame + this.frameLength;\r\n    let mergeEndFrame = levelInfo.startFrame + levelInfo.frameLength;\r\n\r\n    if (levelInfo.startFrame < this.startFrame) {\r\n      this.startFrame = levelInfo.startFrame;\r\n    }\r\n\r\n    if (mergeEndFrame > endFrame) {\r\n      this.frameLength = mergeEndFrame - this.startFrame;\r\n    }\r\n\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n\r\n      if (levelInfo.minLinLevels[ch] < this.minLinLevels[ch]) {\r\n        this.minLinLevels[ch] = levelInfo.minLinLevels[ch];\r\n      }\r\n      if (levelInfo.maxLinLevels[ch] > this.maxLinLevels[ch]) {\r\n        this.maxLinLevels[ch] = levelInfo.maxLinLevels[ch];\r\n      }\r\n    }\r\n  }\r\n\r\n  levelsLin(): Array<number> {\r\n    let lvlsLin = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsLin[ch] = Math.max(Math.abs(this.minLinLevels[ch]), Math.abs(this.maxLinLevels[ch]));\r\n    }\r\n    return lvlsLin;\r\n  }\r\n\r\n  powerLevelsDB(): Array<number> {\r\n    let lvlsDb = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsDb[ch] = DSPUtils.toPowerLevelInDB(this.levelsLin()[ch]);\r\n    }\r\n    return lvlsDb;\r\n  }\r\n\r\n  powerLevelDB(): number {\r\n    let pLvlsDb = this.powerLevelsDB();\r\n    return Math.max(...pLvlsDb);\r\n  }\r\n\r\n  clone(): LevelInfo {\r\n    return new LevelInfo(this.channelCount, this.startFrame, this.frameLength, Arrays.cloneNumberArray(this.minLinLevels),\r\n      Arrays.cloneNumberArray(this.maxLinLevels));\r\n  }\r\n}\r\n\r\nexport class LevelInfos {\r\n  constructor(public readonly bufferLevelInfos: Array<LevelInfo>, public readonly peakLevelInfo: LevelInfo) {\r\n  }\r\n\r\n  framesPerBuffer():number{\r\n    if(this.bufferLevelInfos.length>0){\r\n      return this.bufferLevelInfos[0].frameLength;\r\n    }\r\n    return this.peakLevelInfo.frameLength/this.bufferLevelInfos.length;\r\n  }\r\n}\r\n\r\n\r\nexport interface LevelListener {\r\n  channelCount: number;\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\ndeclare function postMessage(message: any, transfer?: Array<any>): void;\r\n\r\nexport class LevelMeasure {\r\n\r\n  private readonly workerURL: string;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);\r\n  }\r\n\r\n  calcBufferLevelInfos(audioDataHolder:AudioDataHolder, bufferTimeLength: number): Observable<LevelInfos> {\r\n    return new Observable<LevelInfos>(subscriber => {\r\n\r\n      let chs = audioDataHolder.numberOfChannels;\r\n      let bufferFrameLength = Math.round(audioDataHolder.sampleRate * bufferTimeLength);\r\n\r\n      let ais = audioDataHolder.audioInputStream();\r\n      // Test: Check CRC\r\n      //let crcVal:number=0;\r\n      //let crclen:number=0;\r\n      if (ais) {\r\n\r\n        let audioBuffers = new Array<Float32Array>(chs);\r\n        let trBuffers = new Array<ArrayBuffer>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioBuffers[ch] = new Float32Array(bufferFrameLength);\r\n        }\r\n        let bufferLevelInfos = new Array<LevelInfo>();\r\n        let peakLevelInfo = new LevelInfo(chs);\r\n\r\n        let worker = new Worker(this.workerURL);\r\n        worker.onmessage = (me) => {\r\n\r\n          if (me.data.linLevelBuffers) {\r\n            let linLevelArrs = new Array<Float32Array>(chs);\r\n            for (let ch = 0; ch < chs; ch++) {\r\n              linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);\r\n            }\r\n\r\n            let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);\r\n            let framePos = 0;\r\n\r\n            for (let bi = 0; bi < bufferCount; bi++) {\r\n              let minLevels = new Array<number>(chs);\r\n              let maxLevels = new Array<number>(chs);\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                let linLvlArrPos = bi * 2;\r\n                minLevels[ch] = linLevelArrs[ch][linLvlArrPos];\r\n                maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];\r\n              }\r\n              let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);\r\n              bufferLevelInfos.push(bli);\r\n              peakLevelInfo.merge(bli);\r\n            }\r\n\r\n          }\r\n          if (me.data.eod === true) {\r\n            // end of data, terminate worker and return result\r\n            //this.terminateWorker();\r\n            worker.terminate();\r\n            ais?.close();\r\n            //console.debug(\"Audio input stream CRC hex: \"+crcVal.toString(16)+\", crcLen: \"+crclen+\", buffer frame len: \"+bufferFrameLength);\r\n            subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));\r\n            subscriber.complete();\r\n          } else {\r\n            if (ais) {\r\n              let read = ais.read(audioBuffers);\r\n              // TEST:\r\n              // if(audioBuffers && audioBuffers.length>0) {\r\n              //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n              //   crclen += audioBuffers[0].buffer.byteLength;\r\n              //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n              // }else{\r\n              //   console.debug(\"audioBuffers not avail!\");\r\n              // }\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                // let copy = new Float32Array(audioBuffers[ch]);\r\n                // trBuffers[ch] = copy.buffer;\r\n                const arrAbBufCh=audioBuffers[ch];\r\n                const adLen = arrAbBufCh.buffer.byteLength;\r\n                if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n                  trBuffers[ch] = new ArrayBuffer(adLen);\r\n                }\r\n                let fAdaCh=new Float32Array(trBuffers[ch]);\r\n                fAdaCh.set(audioBuffers[ch]);\r\n              }\r\n\r\n              worker.postMessage({\r\n                bufferFrameLength: bufferFrameLength,\r\n                audioData: trBuffers,\r\n                chs: chs,\r\n                len: read\r\n              }, trBuffers);\r\n            }\r\n          }\r\n        };\r\n\r\n        let read = ais.read(audioBuffers);\r\n        // TEST:\r\n        // if(audioBuffers && audioBuffers.length>0) {\r\n        //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n        //   crclen += audioBuffers[0].buffer.byteLength;\r\n        //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n        // }else{\r\n        //   console.debug(\"audioBuffers not avail!\");\r\n        // }\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          // let copy = new Float32Array(audioBuffers[ch]);\r\n          // trBuffers[ch] = copy.buffer;\r\n          const arrAbBufCh=audioBuffers[ch];\r\n          const adLen = arrAbBufCh.buffer.byteLength;\r\n          if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n            trBuffers[ch] = new ArrayBuffer(adLen);\r\n          }\r\n          let fAdaCh=new Float32Array(trBuffers[ch]);\r\n          fAdaCh.set(audioBuffers[ch]);\r\n        }\r\n\r\n        worker.postMessage({\r\n          bufferFrameLength: bufferFrameLength,\r\n          audioData: trBuffers,\r\n          chs: chs,\r\n          len: read\r\n        }, trBuffers);\r\n      } else {\r\n\r\n        let aAis = audioDataHolder.asyncAudioInputStream();\r\n        let audioBuffers = new Array<Float32Array>(chs);\r\n        let trBuffers = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioBuffers[ch] = new Float32Array(bufferFrameLength);\r\n        }\r\n        let bufferLevelInfos = new Array<LevelInfo>();\r\n        let peakLevelInfo = new LevelInfo(chs);\r\n\r\n        let worker = new Worker(this.workerURL);\r\n        worker.onmessage = (me) => {\r\n\r\n          if (subscriber.closed) {\r\n            // subscriber abandoned\r\n            worker.terminate();\r\n            if(aAis) {\r\n              aAis.close();\r\n            }\r\n          }else {\r\n\r\n            if (me.data.linLevelBuffers) {\r\n              let linLevelArrs = new Array<Float32Array>(chs);\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);\r\n              }\r\n\r\n              let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);\r\n              let framePos = 0;\r\n\r\n              for (let bi = 0; bi < bufferCount; bi++) {\r\n                let minLevels = new Array<number>(chs);\r\n                let maxLevels = new Array<number>(chs);\r\n                for (let ch = 0; ch < chs; ch++) {\r\n                  let linLvlArrPos = bi * 2;\r\n                  minLevels[ch] = linLevelArrs[ch][linLvlArrPos];\r\n                  maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];\r\n                }\r\n                let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);\r\n                bufferLevelInfos.push(bli);\r\n                peakLevelInfo.merge(bli);\r\n              }\r\n\r\n            }\r\n            if (me.data.eod === true) {\r\n              // end of data, terminate worker and return result\r\n              //this.terminateWorker();\r\n              worker.terminate();\r\n              //ais?.close();\r\n              aAis?.close();\r\n              //console.debug(\"Audio input stream CRC hex: \"+crcVal.toString(16)+\", crcLen: \"+crclen+\", buffer frame len: \"+bufferFrameLength);\r\n              subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));\r\n              subscriber.complete();\r\n            } else {\r\n\r\n              if (aAis) {\r\n                aAis?.readObs(audioBuffers).subscribe({\r\n                    next: (read) => {\r\n                      // TEST:\r\n                      // if(audioBuffers && audioBuffers.length>0) {\r\n                      //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n                      //   crclen += audioBuffers[0].buffer.byteLength;\r\n                      //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n                      // }else{\r\n                      //   console.debug(\"audioBuffers not avail!\");\r\n                      // }\r\n                      for (let ch = 0; ch < chs; ch++) {\r\n\r\n                        // let copy = new Float32Array(audioBuffers[ch]);\r\n                        // trBuffers[ch] = copy.buffer;\r\n                        const arrAbBufCh=audioBuffers[ch];\r\n                        const adLen = arrAbBufCh.buffer.byteLength;\r\n                        if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n                          trBuffers[ch] = new ArrayBuffer(adLen);\r\n                        }\r\n                        let fAdaCh=new Float32Array(trBuffers[ch]);\r\n                        fAdaCh.set(audioBuffers[ch]);\r\n                      }\r\n\r\n                      worker.postMessage({\r\n                        bufferFrameLength: bufferFrameLength,\r\n                        audioData: trBuffers,\r\n                        chs: chs,\r\n                        len: read\r\n                      }, trBuffers);\r\n                    }\r\n                  }\r\n                );\r\n              }\r\n            }\r\n          }\r\n        };\r\n\r\n        aAis?.readObs(audioBuffers).subscribe({\r\n            next: (read) => {\r\n              // TEST:\r\n              // if(audioBuffers && audioBuffers.length>0) {\r\n              //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n              //   crclen += audioBuffers[0].buffer.byteLength;\r\n              //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n              // }else{\r\n              //   console.debug(\"audioBuffers not avail!\");\r\n              // }\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                // let copy = new Float32Array(audioBuffers[ch]);\r\n                // trBuffers[ch] = copy.buffer;\r\n\r\n                const arrAbBufCh=audioBuffers[ch];\r\n                const adLen = arrAbBufCh.buffer.byteLength;\r\n                if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n                  trBuffers[ch] = new ArrayBuffer(adLen);\r\n                }\r\n                let fAdaCh=new Float32Array(trBuffers[ch]);\r\n                fAdaCh.set(audioBuffers[ch]);\r\n              }\r\n              worker.postMessage({\r\n                bufferFrameLength: bufferFrameLength,\r\n                audioData: trBuffers,\r\n                chs: chs,\r\n                len: read\r\n              }, trBuffers);\r\n            }\r\n          }\r\n        );\r\n      }\r\n    });\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n\r\n      let len=msg.data.len;\r\n      let bufferFrameLength = msg.data.bufferFrameLength;\r\n      if(len==-1){\r\n        // start\r\n        postMessage({\r\n          eod:false,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }\r\n\r\n      if(len==0) {\r\n        postMessage({\r\n          eod:true,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }else{\r\n        let chs = msg.data.chs;\r\n\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        //let frameLength = audioData[0].length;\r\n\r\n        let bufferCount = Math.ceil(len / bufferFrameLength);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(bufferCount * 2);\r\n        }\r\n        if (audioData && chs > 0) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n\r\n            for (let s = 0; s < len; s++) {\r\n              let bi = Math.floor(s / bufferFrameLength);\r\n              let lvlArrPos = bi * 2;\r\n              //let bs = s % bufferFrameLength;\r\n              let chSample = chData[s];\r\n              if (chSample < linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n              lvlArrPos++;\r\n              if (chSample > linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n            }\r\n          }\r\n          const linLevelBufs = new Array<any>(chs);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            linLevelBufs[ch] = linLevels[ch].buffer;\r\n          }\r\n          postMessage({\r\n            eod:false,\r\n            bufferFrameLength: bufferFrameLength,\r\n            frameLength: len,\r\n            linLevelBuffers: linLevelBufs\r\n          }, linLevelBufs);\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport class StreamLevelMeasure implements SequenceAudioFloat32OutStream {\r\n\r\n  currentLevelInfos: LevelInfo|null=null;\r\n  peakLevelInfo: LevelInfo|null=null;\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n  private channelCount: number=0;\r\n  private bufferIndex: number = 0;\r\n  private frameCount: number = 0;\r\n\r\n  levelListener: LevelListener|null=null;\r\n  peakLevelListener: ((peakLvlInDb:number)=>void)|null=null;\r\n  private peakLevelInDb:number=MIN_DB_LEVEL;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  setFormat(channels: number, sampleRate: number) {\r\n    this.channelCount = channels;\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    this.worker = new Worker(this.workerURL);\r\n    this.worker.onmessage = (me) => {\r\n      let streamFinished = me.data.streamFinished;\r\n      if (streamFinished) {\r\n        if (this.levelListener) {\r\n          this.levelListener.streamFinished()\r\n        }\r\n      } else {\r\n\r\n        let minLevels = new Array<number>(this.channelCount);\r\n        let maxLevels = new Array<number>(this.channelCount);\r\n        for (let ch = 0; ch < this.channelCount; ch++) {\r\n          let fls = new Float32Array(me.data.linLevelBuffers[ch]);\r\n          minLevels[ch] = fls[0];\r\n          maxLevels[ch] = fls[1];\r\n        }\r\n        let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.frameLength, minLevels, maxLevels);\r\n        this.updateLevels(bi);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  nextStream() {\r\n    this.reset();\r\n  }\r\n\r\n  private reset() {\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    if (this.levelListener) {\r\n      this.levelListener.reset();\r\n      this.levelListener.channelCount = this.channelCount;\r\n    }\r\n    if (this.peakLevelListener) {\r\n      this.peakLevelInDb=MIN_DB_LEVEL;\r\n      this.peakLevelListener(this.peakLevelInDb);\r\n    }\r\n  }\r\n\r\n  write(bufferData: Array<Float32Array>): number {\r\n    let bufArrCopies = new Array<Float32Array>(bufferData.length);\r\n    let buffers = new Array<any>(bufferData.length);\r\n    for (let ch = 0; ch < bufferData.length; ch++) {\r\n      bufArrCopies[ch] = bufferData[ch].slice();\r\n      buffers[ch] = bufArrCopies[ch].buffer;\r\n    }\r\n    this.worker?.postMessage({\r\n      streamFinished: false,\r\n      audioData: buffers,\r\n      chs: this.channelCount,\r\n      bufferIndex: this.bufferIndex\r\n    }, buffers);\r\n    this.bufferIndex++;\r\n    return bufArrCopies[0].length;\r\n  }\r\n\r\n  flush() {\r\n    this.worker?.postMessage({streamFinished: true});\r\n\r\n  }\r\n\r\n  close() {\r\n      this.worker?.terminate();\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n      let streamFinished = msg.data.streamFinished;\r\n      if (streamFinished) {\r\n        postMessage({streamFinished: true});\r\n      } else {\r\n        let chs = msg.data.chs;\r\n        let frameLength = null;\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(2);\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        if (audioData) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n            if (frameLength === null) {\r\n              frameLength = chData.length;\r\n            }\r\n            for (let s = 0; s < frameLength; s++) {\r\n              let chSample=chData[s];\r\n              if (chSample < linLevels[ch][0]) {\r\n                linLevels[ch][0] = chSample;\r\n              }\r\n              if (chSample > linLevels[ch][1]) {\r\n                linLevels[ch][1] = chSample;\r\n              }\r\n            }\r\n          }\r\n        }\r\n        let linLevelBufs = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevelBufs[ch] = linLevels[ch].buffer;\r\n        }\r\n        postMessage({streamFinished: false, frameLength: frameLength, linLevelBuffers: linLevelBufs}, linLevelBufs);\r\n      }\r\n    }\r\n  }\r\n\r\n  updateLevels(bufferLevelInfo: LevelInfo) {\r\n\r\n    this.currentLevelInfos = bufferLevelInfo;\r\n    if(this.peakLevelInfo) {\r\n      this.peakLevelInfo.merge(bufferLevelInfo);\r\n      if (this.levelListener) {\r\n        this.levelListener.update(this.currentLevelInfos, this.peakLevelInfo.clone());\r\n      }\r\n      if(this.peakLevelListener){\r\n        let peakDBVal = bufferLevelInfo.powerLevelDB();\r\n        if (this.peakLevelInDb < peakDBVal) {\r\n          this.peakLevelInDb = peakDBVal;\r\n          // the event comes from outside an Angular zone\r\n          this.peakLevelListener(this.peakLevelInDb);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  stop() {\r\n    this.worker?.terminate();\r\n  }\r\n\r\n}\r\n"]}
@@ -1,20 +0,0 @@
1
- export class AudioFormat {
2
- constructor(sampleRate, channelCount) {
3
- this.sampleRate = sampleRate;
4
- this.channelCount = channelCount;
5
- }
6
- }
7
- export class PCMAudioFormat extends AudioFormat {
8
- constructor(sampleRate, channelCount, sampleSize, sampleSizeInBits, encodingFloat = false) {
9
- super(sampleRate, channelCount);
10
- this.encodingFloat = false;
11
- this.sampleSize = sampleSize;
12
- this.sampleSizeInBits = sampleSizeInBits;
13
- this.encodingFloat = encodingFloat;
14
- }
15
- toString() {
16
- const encStr = this.encodingFloat ? 'Encoding: float,' : '';
17
- return 'Audio format: PCM,' + encStr + this.sampleRate + ' Hz,' + this.channelCount + ' channels, ' + this.sampleSizeInBits + ' bits';
18
- }
19
- }
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL2Zvcm1hdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDSSxNQUFNLE9BQU8sV0FBVztJQUdwQixZQUFZLFVBQWtCLEVBQUUsWUFBb0I7UUFDaEQsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7UUFDN0IsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDckMsQ0FBQztDQUNKO0FBRUQsTUFBTSxPQUFPLGNBQWUsU0FBUSxXQUFXO0lBSTNDLFlBQVksVUFBa0IsRUFBRSxZQUFvQixFQUFFLFVBQWtCLEVBQUUsZ0JBQXdCLEVBQUMsYUFBYSxHQUFDLEtBQUs7UUFDbEgsS0FBSyxDQUFDLFVBQVUsRUFBRSxZQUFZLENBQUMsQ0FBQztRQUpwQyxrQkFBYSxHQUFTLEtBQUssQ0FBQztRQUt4QixJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztRQUM3QixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsZ0JBQWdCLENBQUM7UUFDekMsSUFBSSxDQUFDLGFBQWEsR0FBQyxhQUFhLENBQUM7SUFDckMsQ0FBQztJQUVELFFBQVE7UUFDSixNQUFNLE1BQU0sR0FBQyxJQUFJLENBQUMsYUFBYSxDQUFBLENBQUMsQ0FBQSxrQkFBa0IsQ0FBQSxDQUFDLENBQUEsRUFBRSxDQUFDO1FBRXRELE9BQU8sb0JBQW9CLEdBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxHQUFHLElBQUksQ0FBQyxZQUFZLEdBQUcsYUFBYSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxPQUFPLENBQUM7SUFDeEksQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbiAgICBleHBvcnQgY2xhc3MgQXVkaW9Gb3JtYXQge1xyXG4gICAgICAgIHNhbXBsZVJhdGU6IG51bWJlcjtcclxuICAgICAgICBjaGFubmVsQ291bnQ6IG51bWJlcjtcclxuICAgICAgICBjb25zdHJ1Y3RvcihzYW1wbGVSYXRlOiBudW1iZXIsIGNoYW5uZWxDb3VudDogbnVtYmVyKSB7XHJcbiAgICAgICAgICAgIHRoaXMuc2FtcGxlUmF0ZSA9IHNhbXBsZVJhdGU7XHJcbiAgICAgICAgICAgIHRoaXMuY2hhbm5lbENvdW50ID0gY2hhbm5lbENvdW50O1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBleHBvcnQgY2xhc3MgUENNQXVkaW9Gb3JtYXQgZXh0ZW5kcyBBdWRpb0Zvcm1hdCB7XHJcbiAgICAgICAgZW5jb2RpbmdGbG9hdDpib29sZWFuPWZhbHNlO1xyXG4gICAgICAgIHNhbXBsZVNpemU6IG51bWJlcjtcclxuICAgICAgICBzYW1wbGVTaXplSW5CaXRzOiBudW1iZXI7XHJcbiAgICAgICAgY29uc3RydWN0b3Ioc2FtcGxlUmF0ZTogbnVtYmVyLCBjaGFubmVsQ291bnQ6IG51bWJlciwgc2FtcGxlU2l6ZTogbnVtYmVyLCBzYW1wbGVTaXplSW5CaXRzOiBudW1iZXIsZW5jb2RpbmdGbG9hdD1mYWxzZSkge1xyXG4gICAgICAgICAgICBzdXBlcihzYW1wbGVSYXRlLCBjaGFubmVsQ291bnQpO1xyXG4gICAgICAgICAgICB0aGlzLnNhbXBsZVNpemUgPSBzYW1wbGVTaXplO1xyXG4gICAgICAgICAgICB0aGlzLnNhbXBsZVNpemVJbkJpdHMgPSBzYW1wbGVTaXplSW5CaXRzO1xyXG4gICAgICAgICAgICB0aGlzLmVuY29kaW5nRmxvYXQ9ZW5jb2RpbmdGbG9hdDtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHRvU3RyaW5nKCk6IHN0cmluZyB7XHJcbiAgICAgICAgICAgIGNvbnN0IGVuY1N0cj10aGlzLmVuY29kaW5nRmxvYXQ/J0VuY29kaW5nOiBmbG9hdCwnOicnO1xyXG5cclxuICAgICAgICAgICAgcmV0dXJuICdBdWRpbyBmb3JtYXQ6IFBDTSwnK2VuY1N0ciArIHRoaXMuc2FtcGxlUmF0ZSArICcgSHosJyArIHRoaXMuY2hhbm5lbENvdW50ICsgJyBjaGFubmVscywgJyArIHRoaXMuc2FtcGxlU2l6ZUluQml0cyArICcgYml0cyc7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuIl19