speechrecorderng 3.0.0 → 3.3.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 (142) hide show
  1. package/esm2020/lib/action/action.mjs +2 -1
  2. package/esm2020/lib/audio/array_audio_buffer.mjs +65 -2
  3. package/esm2020/lib/audio/array_audio_buffer_input_stream.mjs +2 -2
  4. package/esm2020/lib/audio/array_audio_buffer_random_access_stream.mjs +16 -0
  5. package/esm2020/lib/audio/audio_data_holder.mjs +203 -48
  6. package/esm2020/lib/audio/audio_display.mjs +10 -34
  7. package/esm2020/lib/audio/audio_player.mjs +18 -45
  8. package/esm2020/lib/audio/capture/capture.mjs +293 -69
  9. package/esm2020/lib/audio/dsp/level_measure.mjs +211 -88
  10. package/esm2020/lib/audio/impl/wavformat.mjs +1 -1
  11. package/esm2020/lib/audio/impl/wavreader.mjs +134 -0
  12. package/esm2020/lib/audio/impl/wavwriter.mjs +10 -9
  13. package/esm2020/lib/audio/inddb_audio_buffer.mjs +508 -0
  14. package/esm2020/lib/audio/net_audio_buffer.mjs +297 -0
  15. package/esm2020/lib/audio/persistor.mjs +8 -2
  16. package/esm2020/lib/audio/playback/array_audio_buffer_source_node.mjs +15 -154
  17. package/esm2020/lib/audio/playback/audio_source_node.mjs +18 -0
  18. package/esm2020/lib/audio/playback/audio_source_worklet_module_loader.mjs +167 -0
  19. package/esm2020/lib/audio/playback/inddb_audio_buffer_source_node.mjs +167 -0
  20. package/esm2020/lib/audio/playback/net_audio_buffer_source_node.mjs +218 -0
  21. package/esm2020/lib/audio/playback/player.mjs +190 -171
  22. package/esm2020/lib/audio/ui/audio_canvas_layer_comp.mjs +35 -76
  23. package/esm2020/lib/audio/ui/audio_display_control.mjs +12 -24
  24. package/esm2020/lib/audio/ui/audio_display_scroll_pane.mjs +14 -45
  25. package/esm2020/lib/audio/ui/audiosignal.mjs +333 -267
  26. package/esm2020/lib/audio/ui/container.mjs +40 -57
  27. package/esm2020/lib/audio/ui/livelevel.mjs +53 -52
  28. package/esm2020/lib/audio/ui/scroll_pane_horizontal.mjs +5 -19
  29. package/esm2020/lib/audio/ui/sonagram.mjs +386 -339
  30. package/esm2020/lib/db/inddb.mjs +120 -0
  31. package/esm2020/lib/io/BinaryReader.mjs +85 -0
  32. package/esm2020/lib/io/stream.mjs +101 -1
  33. package/esm2020/lib/net/uploader.mjs +111 -5
  34. package/esm2020/lib/recorder_component.mjs +59 -1
  35. package/esm2020/lib/speechrecorder/project/project.mjs +10 -1
  36. package/esm2020/lib/speechrecorder/project/project.service.mjs +3 -3
  37. package/esm2020/lib/speechrecorder/recording.mjs +30 -6
  38. package/esm2020/lib/speechrecorder/recordings/basic_recording.service.mjs +213 -0
  39. package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +732 -65
  40. package/esm2020/lib/speechrecorder/script/script.service.mjs +3 -3
  41. package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +358 -184
  42. package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +181 -28
  43. package/esm2020/lib/speechrecorder/session/controlpanel.mjs +47 -129
  44. package/esm2020/lib/speechrecorder/session/item.mjs +13 -1
  45. package/esm2020/lib/speechrecorder/session/progress.mjs +26 -55
  46. package/esm2020/lib/speechrecorder/session/prompting.mjs +33 -176
  47. package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +6 -6
  48. package/esm2020/lib/speechrecorder/session/recording_file_cache.mjs +28 -15
  49. package/esm2020/lib/speechrecorder/session/recording_list.mjs +92 -55
  50. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +9 -13
  51. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +9 -18
  52. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +10 -36
  53. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +10 -37
  54. package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +80 -56
  55. package/esm2020/lib/speechrecorder/session/session.service.mjs +3 -3
  56. package/esm2020/lib/speechrecorder/session/session_finished_dialog.mjs +4 -4
  57. package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +409 -165
  58. package/esm2020/lib/speechrecorder/session/warning_bar.mjs +6 -29
  59. package/esm2020/lib/speechrecorder/spruploader.mjs +3 -3
  60. package/esm2020/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +6 -41
  61. package/esm2020/lib/speechrecorderng.component.mjs +42 -31
  62. package/esm2020/lib/speechrecorderng.module.mjs +5 -5
  63. package/esm2020/lib/spr.config.mjs +3 -3
  64. package/esm2020/lib/spr.module.version.mjs +2 -2
  65. package/esm2020/lib/ui/canvas_layer_comp.mjs +3 -3
  66. package/esm2020/lib/ui/message_dialog.mjs +7 -7
  67. package/esm2020/lib/ui/recordingitem_display.mjs +26 -59
  68. package/esm2020/lib/utils/scrollIntoViewToBottom.mjs +3 -3
  69. package/esm2020/lib/utils/ua-parser.mjs +28 -4
  70. package/esm2020/lib/utils/utils.mjs +29 -1
  71. package/fesm2015/speechrecorderng.mjs +12755 -9195
  72. package/fesm2015/speechrecorderng.mjs.map +1 -1
  73. package/fesm2020/speechrecorderng.mjs +12652 -9101
  74. package/fesm2020/speechrecorderng.mjs.map +1 -1
  75. package/{speechrecorderng.d.ts → index.d.ts} +0 -0
  76. package/lib/audio/array_audio_buffer.d.ts +17 -1
  77. package/lib/audio/array_audio_buffer_random_access_stream.d.ts +9 -0
  78. package/lib/audio/audio_data_holder.d.ts +69 -14
  79. package/lib/audio/audio_display.d.ts +1 -1
  80. package/lib/audio/audio_player.d.ts +3 -7
  81. package/lib/audio/capture/capture.d.ts +24 -4
  82. package/lib/audio/dsp/level_measure.d.ts +2 -23
  83. package/lib/audio/impl/wavformat.d.ts +3 -3
  84. package/lib/audio/impl/wavreader.d.ts +16 -0
  85. package/lib/audio/impl/wavwriter.d.ts +1 -4
  86. package/lib/audio/inddb_audio_buffer.d.ts +68 -0
  87. package/lib/audio/net_audio_buffer.d.ts +59 -0
  88. package/lib/audio/persistor.d.ts +3 -9
  89. package/lib/audio/playback/array_audio_buffer_source_node.d.ts +2 -8
  90. package/lib/audio/playback/audio_source_node.d.ts +10 -0
  91. package/lib/audio/playback/audio_source_worklet_module_loader.d.ts +4 -0
  92. package/lib/audio/playback/inddb_audio_buffer_source_node.d.ts +21 -0
  93. package/lib/audio/playback/net_audio_buffer_source_node.d.ts +27 -0
  94. package/lib/audio/playback/player.d.ts +19 -16
  95. package/lib/audio/ui/audio_canvas_layer_comp.d.ts +3 -3
  96. package/lib/audio/ui/audio_display_control.d.ts +3 -6
  97. package/lib/audio/ui/audio_display_scroll_pane.d.ts +1 -1
  98. package/lib/audio/ui/audiosignal.d.ts +4 -3
  99. package/lib/audio/ui/container.d.ts +1 -1
  100. package/lib/audio/ui/livelevel.d.ts +11 -4
  101. package/lib/audio/ui/scroll_pane_horizontal.d.ts +1 -1
  102. package/lib/audio/ui/sonagram.d.ts +4 -3
  103. package/lib/db/inddb.d.ts +21 -0
  104. package/lib/io/BinaryReader.d.ts +18 -0
  105. package/lib/io/stream.d.ts +18 -0
  106. package/lib/net/uploader.d.ts +20 -2
  107. package/lib/recorder_component.d.ts +5 -0
  108. package/lib/speechrecorder/project/project.d.ts +9 -0
  109. package/lib/speechrecorder/recording.d.ts +8 -2
  110. package/lib/speechrecorder/recordings/basic_recording.service.d.ts +27 -0
  111. package/lib/speechrecorder/recordings/recordings.service.d.ts +21 -6
  112. package/lib/speechrecorder/session/audiorecorder.d.ts +7 -18
  113. package/lib/speechrecorder/session/basicrecorder.d.ts +28 -4
  114. package/lib/speechrecorder/session/controlpanel.d.ts +7 -7
  115. package/lib/speechrecorder/session/item.d.ts +1 -0
  116. package/lib/speechrecorder/session/progress.d.ts +2 -1
  117. package/lib/speechrecorder/session/prompting.d.ts +5 -5
  118. package/lib/speechrecorder/session/recorder_combi_pane.d.ts +1 -1
  119. package/lib/speechrecorder/session/recording_file_cache.d.ts +7 -4
  120. package/lib/speechrecorder/session/recording_list.d.ts +2 -1
  121. package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +1 -1
  122. package/lib/speechrecorder/session/recordingfile/recording-file-navi.component.d.ts +1 -1
  123. package/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.d.ts +1 -1
  124. package/lib/speechrecorder/session/recordingfile/recording-file-view.component.d.ts +1 -1
  125. package/lib/speechrecorder/session/recordingfile/recordingfile-service.d.ts +4 -5
  126. package/lib/speechrecorder/session/session_finished_dialog.d.ts +1 -1
  127. package/lib/speechrecorder/session/sessionmanager.d.ts +10 -10
  128. package/lib/speechrecorder/session/warning_bar.d.ts +1 -1
  129. package/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.d.ts +1 -1
  130. package/lib/speechrecorderng.component.d.ts +2 -1
  131. package/lib/spr.module.version.d.ts +1 -1
  132. package/lib/ui/canvas_layer_comp.d.ts +1 -1
  133. package/lib/ui/message_dialog.d.ts +1 -1
  134. package/lib/ui/recordingitem_display.d.ts +3 -2
  135. package/lib/utils/scrollIntoViewToBottom.d.ts +1 -1
  136. package/lib/utils/ua-parser.d.ts +4 -1
  137. package/lib/utils/utils.d.ts +6 -0
  138. package/package.json +5 -4
  139. package/esm2020/lib/math/utils.mjs +0 -14
  140. package/esm2020/lib/utils/css_utils.mjs +0 -7
  141. package/lib/math/utils.d.ts +0 -3
  142. package/lib/utils/css_utils.d.ts +0 -3
@@ -1,6 +1,7 @@
1
1
  import { Component, ViewChild } from '@angular/core';
2
2
  import { AudioCanvasLayerComponent } from "./audio_canvas_layer_comp";
3
3
  import { WorkerHelper } from "../../utils/utils";
4
+ import { AudioBufferSource } from "../audio_data_holder";
4
5
  import * as i0 from "@angular/core";
5
6
  export class AudioSignal extends AudioCanvasLayerComponent {
6
7
  constructor(ref) {
@@ -8,6 +9,7 @@ export class AudioSignal extends AudioCanvasLayerComponent {
8
9
  this.ref = ref;
9
10
  this._playFramePosition = null;
10
11
  this.worker = null;
12
+ this.raAsSubsc = null;
11
13
  this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);
12
14
  this._audioDataHolder = null;
13
15
  this._bgColor = 'black';
@@ -62,36 +64,36 @@ export class AudioSignal extends AudioCanvasLayerComponent {
62
64
  */
63
65
  workerFunction() {
64
66
  addEventListener('message', ({ data }) => {
65
- let audioData = data.audioData; // audio data part required to render view port
66
- let auOffset = data.audioDataOffset;
67
- let l = data.l; // left pixel position of view port
68
- let w = data.w; // width of viewport
69
- let vw = data.vw; // total width of (virtual) audio view (not viewport width)
70
- let chs = data.chs; // number of channels
71
- let dataFrameLength = data.audioDataFrameLength; // frame length of audio data part required for view port
72
- let frameLength = data.frameLength; // total frame length (of audio clip)
67
+ const audioData = data.audioData; // audio data part required to render view port
68
+ const auOffset = data.audioDataOffset;
69
+ const l = data.l; // left pixel position of view port
70
+ const w = data.w; // width of viewport
71
+ const vw = data.vw; // total width of (virtual) audio view (not viewport width)
72
+ const chs = data.chs; // number of channels
73
+ //const dataFrameLength = data.audioDataFrameLength; // frame length of audio data part required for view port
74
+ const frameLength = data.frameLength; // total frame length (of audio clip)
73
75
  //console.debug("W: left: "+l+", w:"+w+", vw: "+vw+", chs: "+chs+", frameLength: "+frameLength);
74
76
  let psMinMax = new Float32Array(0);
75
77
  if (audioData && audioData.length > 0 && w >= 0 && vw > 0) {
76
- let framesPerPixel = frameLength / vw;
77
- let pointsLen = w * chs;
78
+ const framesPerPixel = frameLength / vw;
79
+ const pointsLen = w * chs;
78
80
  // one for min one for max
79
- let arrLen = pointsLen * 2;
81
+ const arrLen = pointsLen * 2;
80
82
  psMinMax = new Float32Array(arrLen);
81
83
  let chFramePos = 0;
82
- let chFrameLength = audioData.length / chs;
84
+ const chFrameLength = audioData.length / chs;
83
85
  for (let ch = 0; ch < chs; ch++) {
84
86
  chFramePos = ch * chFrameLength;
85
87
  for (let pii = 0; pii < w; pii++) {
86
- let virtPii = l + pii;
88
+ const virtPii = l + pii;
87
89
  let pMin = Infinity;
88
90
  let pMax = -Infinity;
89
91
  let pixelFramePos = Math.round(chFramePos + (virtPii * framesPerPixel));
90
92
  // calculate pixel min/max amplitude
91
93
  for (let ai = 0; ai < framesPerPixel; ai++) {
92
- let framePos = pixelFramePos + ai;
94
+ const framePos = pixelFramePos + ai;
93
95
  let a = 0;
94
- let bufPos = framePos - auOffset;
96
+ const bufPos = framePos - auOffset;
95
97
  //let bufPos=framePos;
96
98
  if (bufPos >= 0 && bufPos < audioData.length) {
97
99
  a = audioData[bufPos];
@@ -104,9 +106,9 @@ export class AudioSignal extends AudioCanvasLayerComponent {
104
106
  }
105
107
  }
106
108
  }
107
- let psMinPos = ch * w + pii;
109
+ const psMinPos = ch * w + pii;
108
110
  psMinMax[psMinPos] = pMin;
109
- let psMaxPos = pointsLen + psMinPos;
111
+ const psMaxPos = pointsLen + psMinPos;
110
112
  psMinMax[psMaxPos] = pMax;
111
113
  //console.debug("psMinMax["+psMinPos+"]="+pMin+",psMinMax["+psMaxPos+"]="+pMax);
112
114
  }
@@ -137,148 +139,204 @@ export class AudioSignal extends AudioCanvasLayerComponent {
137
139
  this.worker.terminate();
138
140
  this.worker = null;
139
141
  }
140
- if (this.bounds && this.bounds.dimension) {
141
- let w = Math.round(this.bounds.dimension.width);
142
- let h = Math.round(this.bounds.dimension.height);
143
- if (this._audioDataHolder && w > 0 && h > 0) {
144
- //this.wo = new Worker('./audiosignal.worker.js',{type: 'module'});
145
- this.worker = new Worker(this.workerURL);
146
- //this.wo = new Worker('worker/audiosignal.worker.ts');
147
- //let Worker = require('worker!../../../workers/uploader/main');
148
- let chs = this._audioDataHolder.numberOfChannels;
149
- let leftPos = Math.round(this.bounds.position.left);
150
- let renderPos = leftPos;
151
- let vw = Math.round(this.virtualDimension.width);
152
- let frameLength = this._audioDataHolder.frameLen;
153
- let framesPerPixel = Math.ceil(frameLength / vw);
154
- let audioBuffer = this._audioDataHolder.buffer;
155
- //let arrayAudioBuffer=this._audioDataHolder.arrayBuffer;
156
- let arrAbBuf;
157
- //let ais:ArrayAudioBufferInputStream|null=null;
158
- //let aisBuf:Float32Array[]|null=null;
159
- let psMinMax = null;
160
- if (this.worker) {
161
- this.worker.onmessage = (me) => {
162
- if (me.data.eod === true) {
163
- let psMinMaxTmp;
164
- if (psMinMax) {
165
- psMinMaxTmp = psMinMax;
166
- }
167
- else {
168
- psMinMaxTmp = me.data.psMinMax;
169
- }
170
- this.drawRendered(leftPos, w, h, chs, psMinMaxTmp);
171
- if (this.worker) {
172
- this.worker.terminate();
173
- }
174
- this.worker = null;
142
+ if (this.raAsSubsc) {
143
+ this.raAsSubsc.unsubscribe();
144
+ }
145
+ if (this._audioDataHolder) {
146
+ this._audioDataHolder.addOnReadyListener(() => {
147
+ if (this._audioDataHolder && this.bounds && this.bounds.dimension) {
148
+ let w = Math.round(this.bounds.dimension.width);
149
+ let h = Math.round(this.bounds.dimension.height);
150
+ let vw = Math.round(this.virtualDimension.width);
151
+ if (w > 0 && h > 0 && vw > 0) {
152
+ //this.wo = new Worker('./audiosignal.worker.js',{type: 'module'});
153
+ this.worker = new Worker(this.workerURL);
154
+ //this.wo = new Worker('worker/audiosignal.worker.ts');
155
+ //let Worker = require('worker!../../../workers/uploader/main');
156
+ let chs = this._audioDataHolder.numberOfChannels;
157
+ let leftPos = Math.round(this.bounds.position.left);
158
+ let renderPos = leftPos;
159
+ let frameLength = this._audioDataHolder.frameLen;
160
+ let framesPerPixel = Math.ceil(frameLength / vw);
161
+ //console.debug("Chs: " + chs + ", vw: " + vw + ", frameLength: " + frameLength + ", framesPerPixel: " + framesPerPixel);
162
+ let ad = new Float32Array(chs * framesPerPixel);
163
+ let raAs = this._audioDataHolder.randomAccessAudioStream();
164
+ let audioBuffer = null;
165
+ let audioSource = this._audioDataHolder.audioSource;
166
+ if (audioSource instanceof AudioBufferSource) {
167
+ audioBuffer = audioSource.audioBuffer;
175
168
  }
176
- else if (this._audioDataHolder && arrAbBuf) {
177
- let rw = me.data.w;
178
- let rPointsLen = chs * rw;
179
- let pointsLen = chs * w;
180
- for (let ch = 0; ch < chs; ch++) {
181
- if (psMinMax) {
182
- let rBasePos = ch * rw;
183
- let basePos = ch * w;
184
- let rPosMin = rBasePos;
185
- let rPosMax = rPointsLen + rPosMin;
186
- let posMin = basePos + (renderPos - leftPos);
187
- let posMax = pointsLen + posMin;
188
- psMinMax[posMin] = me.data.psMinMax[rPosMin];
189
- //console.debug('Min: ('+pos+'): '+me.data.psMinMax[0]);
190
- psMinMax[posMax] = me.data.psMinMax[rPosMax];
191
- // console.debug('Max: ('+(pointsLen+pos)+'): '+me.data.psMinMax[1]);
192
- //console.debug("psMinMax["+posMin+"]="+me.data.psMinMax[rPosMin]+" (rPosMin="+rPosMin+"),psMinMax["+posMax+"]="+me.data.psMinMax[rPosMax]);
169
+ //let arrayAudioBuffer=this._audioDataHolder.arrayBuffer;
170
+ let arrAbBuf;
171
+ //let ais:ArrayAudioBufferInputStream|null=null;
172
+ //let aisBuf:Float32Array[]|null=null;
173
+ let psMinMax = null;
174
+ if (this.worker) {
175
+ this.worker.onmessage = (me) => {
176
+ if (me.data.eod === true) {
177
+ let psMinMaxTmp;
178
+ if (psMinMax) {
179
+ psMinMaxTmp = psMinMax;
180
+ }
181
+ else {
182
+ psMinMaxTmp = me.data.psMinMax;
183
+ }
184
+ this.drawRendered(leftPos, w, h, chs, psMinMaxTmp);
185
+ if (this.worker) {
186
+ this.worker.terminate();
187
+ }
188
+ raAs.close();
193
189
  }
194
- }
195
- let eod = false;
196
- renderPos++;
197
- let ad;
198
- let leftFramePos = Math.floor(frameLength * renderPos / vw);
199
- if (renderPos < leftPos + w) {
200
- let read = this._audioDataHolder.frames(leftFramePos, framesPerPixel, arrAbBuf);
201
- //console.debug("First read frame: "+arrAbBuf[0][0]);
202
- ad = new Float32Array(chs * framesPerPixel);
203
- for (let ch = 0; ch < chs; ch++) {
204
- ad.set(arrAbBuf[ch], ch * framesPerPixel);
190
+ else if (this._audioDataHolder && arrAbBuf) {
191
+ const rw = me.data.w;
192
+ const rPointsLen = chs * rw;
193
+ const pointsLen = chs * w;
194
+ for (let ch = 0; ch < chs; ch++) {
195
+ if (psMinMax) {
196
+ let rBasePos = ch * rw;
197
+ let basePos = ch * w;
198
+ let rPosMin = rBasePos;
199
+ let rPosMax = rPointsLen + rPosMin;
200
+ let posMin = basePos + (renderPos - leftPos);
201
+ let posMax = pointsLen + posMin;
202
+ psMinMax[posMin] = me.data.psMinMax[rPosMin];
203
+ //console.debug('Min: ('+posMin+'): '+me.data.psMinMax[rPosMin]);
204
+ psMinMax[posMax] = me.data.psMinMax[rPosMax];
205
+ //console.debug('Max: ('+(posMax)+'): '+me.data.psMinMax[rPosMax]);
206
+ //console.debug("psMinMax["+posMin+"]="+me.data.psMinMax[rPosMin]+" (rPosMin="+rPosMin+"),psMinMax["+posMax+"]="+me.data.psMinMax[rPosMax]);
207
+ }
208
+ }
209
+ let eod = false;
210
+ renderPos++;
211
+ //let ad:Float32Array;
212
+ const leftFramePos = Math.floor(frameLength * renderPos / vw);
213
+ if (renderPos < leftPos + w) {
214
+ const raAsObs = raAs.framesObs(leftFramePos, framesPerPixel, arrAbBuf);
215
+ this.raAsSubsc = raAsObs.subscribe({
216
+ next: (read) => {
217
+ //console.debug("First read frame: "+arrAbBuf[0][0]);
218
+ if (arrAbBuf) {
219
+ const adLen = chs * framesPerPixel;
220
+ if (!ad || ad.length !== adLen) {
221
+ ad = new Float32Array(adLen);
222
+ }
223
+ for (let ch = 0; ch < chs; ch++) {
224
+ ad.set(arrAbBuf[ch], ch * framesPerPixel);
225
+ }
226
+ }
227
+ eod = (read <= 0);
228
+ let adBuf = ad.buffer;
229
+ if (this.worker) {
230
+ this.worker.postMessage({
231
+ l: renderPos,
232
+ w: me.data.w,
233
+ h: h,
234
+ vw: vw,
235
+ chs: chs,
236
+ frameLength: frameLength,
237
+ audioData: ad,
238
+ audioDataOffset: leftFramePos,
239
+ eod: eod
240
+ }, [adBuf]);
241
+ }
242
+ },
243
+ error: (err) => {
244
+ console.error("AudioSignal: Error reading audio data: " + err);
245
+ }
246
+ });
247
+ }
248
+ else {
249
+ ad = new Float32Array();
250
+ eod = true;
251
+ const adBuf = ad.buffer;
252
+ if (this.worker) {
253
+ this.worker.postMessage({
254
+ l: renderPos,
255
+ w: me.data.w,
256
+ h: h,
257
+ vw: vw,
258
+ chs: chs,
259
+ frameLength: frameLength,
260
+ audioData: ad,
261
+ audioDataOffset: leftFramePos,
262
+ eod: eod
263
+ }, [adBuf]);
264
+ }
265
+ }
205
266
  }
206
- eod = (read <= 0);
207
- }
208
- else {
209
- ad = new Float32Array();
210
- eod = true;
211
- }
212
- let adBuf = ad.buffer;
213
- if (this.worker) {
214
- this.worker.postMessage({
215
- l: renderPos,
216
- w: me.data.w,
217
- h: h,
218
- vw: vw,
219
- chs: chs,
220
- frameLength: frameLength,
221
- audioData: ad,
222
- audioDataOffset: leftFramePos,
223
- eod: eod
224
- }, [adBuf]);
225
- }
267
+ };
226
268
  }
227
- };
228
- }
229
- if (audioBuffer && audioBuffer.length * audioBuffer.numberOfChannels < AudioCanvasLayerComponent.ENABLE_STREAMING_NUMBER_OF_SAMPLES_THRESHOLD) {
230
- // Render whole clip at once
231
- arrAbBuf = null;
232
- psMinMax = null;
233
- let ad = new Float32Array(chs * frameLength);
234
- for (let ch = 0; ch < chs; ch++) {
235
- ad.set(audioBuffer.getChannelData(ch), ch * frameLength);
236
- }
237
- this.worker.postMessage({
238
- l: leftPos,
239
- w: w,
240
- vw: vw,
241
- chs: chs,
242
- frameLength: frameLength,
243
- audioData: ad,
244
- audioDataOffset: 0,
245
- eod: true
246
- }, [ad.buffer]);
247
- }
248
- else {
249
- // Render pixel by pixel
250
- if (w > 0) {
251
- if (framesPerPixel > 0) {
252
- let rw = 1;
253
- //ais = new ArrayAudioBufferInputStream(arrayAudioBuffer);
254
- arrAbBuf = new Array(chs);
255
- psMinMax = new Float32Array(chs * w * 2);
256
- for (let ch = 0; ch < chs; ch++) {
257
- arrAbBuf[ch] = new Float32Array(framesPerPixel);
258
- }
259
- let leftFramePos = Math.floor(frameLength * renderPos / vw);
260
- let auOffset = leftFramePos; // should always be 0
261
- //let read=arrayAudioBuffer.frames(leftFramePos,framesPerPixel,arrAbBuf);
262
- let read = this._audioDataHolder.frames(leftFramePos, framesPerPixel, arrAbBuf);
263
- let ad = new Float32Array(chs * framesPerPixel);
269
+ if (audioBuffer && audioBuffer.length * audioBuffer.numberOfChannels < AudioCanvasLayerComponent.ENABLE_STREAMING_NUMBER_OF_SAMPLES_THRESHOLD) {
270
+ // Render whole clip at once
271
+ arrAbBuf = null;
272
+ psMinMax = null;
273
+ const ad = new Float32Array(chs * frameLength);
264
274
  for (let ch = 0; ch < chs; ch++) {
265
- ad.set(arrAbBuf[ch], ch * framesPerPixel);
275
+ ad.set(audioBuffer.getChannelData(ch), ch * frameLength);
266
276
  }
267
277
  this.worker.postMessage({
268
- l: renderPos,
269
- w: rw,
278
+ l: leftPos,
279
+ w: w,
270
280
  vw: vw,
271
281
  chs: chs,
272
282
  frameLength: frameLength,
273
283
  audioData: ad,
274
- audioDataOffset: auOffset,
275
- eod: (read <= 0)
284
+ audioDataOffset: 0,
285
+ eod: true
276
286
  }, [ad.buffer]);
277
287
  }
288
+ else {
289
+ // Render pixel by pixel
290
+ if (w > 0) {
291
+ if (framesPerPixel > 0) {
292
+ let rw = 1;
293
+ arrAbBuf = new Array(chs);
294
+ psMinMax = new Float32Array(chs * w * 2);
295
+ //console.debug("Audiosignal: Allocating buffers: "+framesPerPixel);
296
+ for (let ch = 0; ch < chs; ch++) {
297
+ arrAbBuf[ch] = new Float32Array(framesPerPixel);
298
+ }
299
+ const leftFramePos = Math.floor(frameLength * renderPos / vw);
300
+ const auOffset = leftFramePos; // should always be 0
301
+ const raAsObs = raAs.framesObs(leftFramePos, framesPerPixel, arrAbBuf);
302
+ this.drawStateText("Loading/Rendering...");
303
+ this.raAsSubsc = raAsObs.subscribe({
304
+ next: (read) => {
305
+ if (arrAbBuf && this.worker) {
306
+ const adLen = chs * framesPerPixel;
307
+ if (!ad || ad.length !== adLen) {
308
+ ad = new Float32Array(adLen);
309
+ }
310
+ for (let ch = 0; ch < chs; ch++) {
311
+ ad.set(arrAbBuf[ch], ch * framesPerPixel);
312
+ }
313
+ this.worker.postMessage({
314
+ l: renderPos,
315
+ w: rw,
316
+ vw: vw,
317
+ chs: chs,
318
+ frameLength: frameLength,
319
+ audioData: ad,
320
+ audioDataOffset: auOffset,
321
+ eod: (read <= 0)
322
+ }, [ad.buffer]);
323
+ }
324
+ },
325
+ error: (err) => {
326
+ console.error("AudioSignal: Error reading audio data: " + err);
327
+ }
328
+ });
329
+ }
330
+ }
331
+ }
278
332
  }
279
333
  }
280
- }
281
- else {
334
+ });
335
+ }
336
+ else {
337
+ if (this.bounds && this.bounds.dimension) {
338
+ let w = Math.round(this.bounds.dimension.width);
339
+ let h = Math.round(this.bounds.dimension.height);
282
340
  let g = this.signalCanvas.getContext("2d");
283
341
  if (g) {
284
342
  g.clearRect(0, 0, w, h);
@@ -286,6 +344,19 @@ export class AudioSignal extends AudioCanvasLayerComponent {
286
344
  }
287
345
  }
288
346
  }
347
+ drawStateText(stateText) {
348
+ if (stateText) {
349
+ const g = this.signalCanvas.getContext("2d");
350
+ const w = this.signalCanvas.width;
351
+ const h = this.signalCanvas.height;
352
+ if (g && w && h) {
353
+ g.strokeStyle = 'white';
354
+ g.fillStyle = 'white';
355
+ g.font = '20px sans-serif';
356
+ g.fillText(stateText, 10, 25);
357
+ }
358
+ }
359
+ }
289
360
  drawRendered(left, w, h, chs, psMinMax) {
290
361
  this.drawBg();
291
362
  this.signalCanvas.style.left = left.toString() + 'px';
@@ -294,36 +365,33 @@ export class AudioSignal extends AudioCanvasLayerComponent {
294
365
  let g = this.signalCanvas.getContext("2d");
295
366
  if (g) {
296
367
  g.clearRect(0, 0, w, h);
297
- //g.fillStyle = "black";
298
- //g.fillRect(0, 0, me.data.w, me.data.h);
299
368
  let pointsLen = w * chs;
300
369
  // one for min one for max
301
- let arrLen = pointsLen * 2;
370
+ //const arrLen = pointsLen * 2;
302
371
  if (this._audioDataHolder) {
303
- let std = Date.now();
304
- let chH = h / chs;
372
+ //const std = Date.now();
373
+ const chH = h / chs;
305
374
  let y = 0;
306
375
  for (let ch = 0; ch < chs; ch++) {
307
- let x = 0;
308
- let psMinPos = ch * w;
309
- let psMaxPos = pointsLen + psMinPos;
376
+ const psMinPos = ch * w;
377
+ const psMaxPos = pointsLen + psMinPos;
310
378
  g.fillStyle = 'green';
311
379
  g.strokeStyle = 'green';
312
380
  // draw audio signal as single polygon
313
381
  g.beginPath();
314
382
  g.moveTo(0, y + (chH / 2) + psMinMax[psMaxPos] * chH / 2);
315
383
  for (let pii = 0; pii < w; pii++) {
316
- let psMax = psMinMax[psMaxPos + pii];
317
- let pv = psMax * chH / 2;
318
- let yd = y + (chH / 2) - pv;
384
+ const psMax = psMinMax[psMaxPos + pii];
385
+ const pv = psMax * chH / 2;
386
+ const yd = y + (chH / 2) - pv;
319
387
  //console.log("LineTo: : "+pii+" "+yd)
320
388
  g.lineTo(pii, yd);
321
389
  }
322
- let revPixelStart = w - 1;
390
+ const revPixelStart = w - 1;
323
391
  for (let pii = revPixelStart; pii >= 0; pii--) {
324
- let psMin = psMinMax[psMinPos + pii];
325
- let pv = psMin * chH / 2;
326
- let yd = y + (chH / 2) - pv;
392
+ const psMin = psMinMax[psMinPos + pii];
393
+ const pv = psMin * chH / 2;
394
+ const yd = y + (chH / 2) - pv;
327
395
  //console.log("LineTo: : "+pii+" "+yd)
328
396
  g.lineTo(pii, yd);
329
397
  }
@@ -332,131 +400,129 @@ export class AudioSignal extends AudioCanvasLayerComponent {
332
400
  g.stroke();
333
401
  y += chH;
334
402
  }
335
- //this.drawPlayPosition();
336
- }
337
- }
338
- }
339
- redraw() {
340
- this.drawBg();
341
- let g = this.signalCanvas.getContext("2d");
342
- if (g) {
343
- let w = this.signalCanvas.width;
344
- let h = this.signalCanvas.height;
345
- g.clearRect(0, 0, w, h);
346
- //g.fillStyle = "black";
347
- //g.fillRect(0, 0, w, h);
348
- if (this._audioDataHolder) {
349
- let std = Date.now();
350
- let chs = this._audioDataHolder.numberOfChannels;
351
- let chH = h / chs;
352
- let frameLength = this._audioDataHolder.frameLen;
353
- let framesPerPixel = frameLength / w;
354
- let y = 0;
355
- let ais = null;
356
- let audioBuffer = this._audioDataHolder.buffer;
357
- let aisBuffer = null;
358
- if (!audioBuffer) {
359
- ais = this._audioDataHolder.audioInputStream();
360
- aisBuffer = new Array(chs);
361
- for (let ch = 0; ch < chs; ch++) {
362
- aisBuffer[ch] = new Float32Array(framesPerPixel);
363
- }
364
- }
365
- for (let ch = 0; ch < chs; ch++) {
366
- let x = 0;
367
- let psMin = new Float32Array(w);
368
- let psMax = new Float32Array(w);
369
- let framePos = 0;
370
- for (let pii = 0; pii < w; pii++) {
371
- let pMin = 0;
372
- let pMax = 0;
373
- if (audioBuffer) {
374
- // calculate pixel min/max amplitude
375
- for (let ai = 0; ai < framesPerPixel; ai++) {
376
- //let framePos=(pii*framesPerPixel)+ai;
377
- let a = audioBuffer.getChannelData(ch)[framePos++];
378
- if (a < pMin) {
379
- pMin = a;
380
- }
381
- if (a > pMax) {
382
- pMax = a;
383
- }
384
- }
385
- }
386
- else if (ais && aisBuffer) {
387
- let r = ais.read(aisBuffer);
388
- for (let ai = 0; ai < r; ai++) {
389
- let a = aisBuffer[ch][ai];
390
- if (a < pMin) {
391
- pMin = a;
392
- }
393
- if (a > pMax) {
394
- pMax = a;
395
- }
396
- }
397
- }
398
- psMin[pii] = pMin;
399
- psMax[pii] = pMax;
400
- }
401
- g.fillStyle = 'green';
402
- g.strokeStyle = 'green';
403
- // draw audio signal as single polygon
404
- g.beginPath();
405
- g.moveTo(0, y + (chH / 2) + psMin[0] * chH / 2);
406
- for (let pii = 0; pii < w; pii++) {
407
- let pv = psMin[pii] * chH / 2;
408
- //console.log("Min: ",pv);
409
- g.lineTo(pii, y + (chH / 2) + pv);
410
- }
411
- for (let pii = w; pii >= 0; pii--) {
412
- let pv = psMax[pii] * chH / 2;
413
- //console.log("Max: ",pv);
414
- g.lineTo(pii, y + (chH / 2) + pv);
415
- }
416
- g.closePath();
417
- //g.lineTo()
418
- g.fill();
419
- g.stroke();
420
- g.fillStyle = "yellow";
421
- g.stroke();
422
- y += chH;
423
- }
424
403
  }
425
404
  }
426
405
  }
406
+ // redraw() {
407
+ // this.drawBg()
408
+ // let g = this.signalCanvas.getContext("2d");
409
+ // if (g) {
410
+ // let w = this.signalCanvas.width;
411
+ // let h = this.signalCanvas.height;
412
+ // g.clearRect(0, 0, w, h);
413
+ // //g.fillStyle = "black";
414
+ // //g.fillRect(0, 0, w, h);
415
+ // if (this._audioDataHolder) {
416
+ // let std = Date.now();
417
+ // let chs = this._audioDataHolder.numberOfChannels;
418
+ // let chH = h / chs;
419
+ //
420
+ // let frameLength = this._audioDataHolder.frameLen;
421
+ //
422
+ // let framesPerPixel = frameLength / w;
423
+ // let y = 0;
424
+ // let ais:Float32ArrayInputStream|null=null;
425
+ // let audioSource=this._audioDataHolder.audioSource;
426
+ // let audioBuffer:AudioBuffer|null=null;
427
+ // if(audioSource instanceof AudioBufferSource){
428
+ // audioBuffer=audioSource.audioBuffer;
429
+ // }
430
+ // let aisBuffer:Array<Float32Array>|null=null;
431
+ // if(!audioBuffer) {
432
+ // ais=this._audioDataHolder.audioInputStream();
433
+ // aisBuffer=new Array<Float32Array>(chs);
434
+ // for(let ch=0;ch<chs;ch++) {
435
+ // aisBuffer[ch] = new Float32Array(framesPerPixel);
436
+ // }
437
+ // }
438
+ // for (let ch = 0; ch < chs; ch++) {
439
+ // let x = 0;
440
+ // let psMin = new Float32Array(w);
441
+ // let psMax = new Float32Array(w);
442
+ // let framePos = 0;
443
+ // for (let pii = 0; pii < w; pii++) {
444
+ // let pMin = 0;
445
+ // let pMax = 0;
446
+ //
447
+ // if (audioBuffer){
448
+ // // calculate pixel min/max amplitude
449
+ // for (let ai = 0; ai < framesPerPixel; ai++) {
450
+ // //let framePos=(pii*framesPerPixel)+ai;
451
+ // let a = audioBuffer.getChannelData(ch)[framePos++];
452
+ //
453
+ // if (a < pMin) {
454
+ // pMin = a;
455
+ // }
456
+ // if (a > pMax) {
457
+ // pMax = a;
458
+ // }
459
+ // }
460
+ // }else if(ais && aisBuffer) {
461
+ // let r = ais.read(aisBuffer);
462
+ // for (let ai = 0; ai < r; ai++) {
463
+ //
464
+ // let a = aisBuffer[ch][ai];
465
+ //
466
+ // if (a < pMin) {
467
+ // pMin = a;
468
+ // }
469
+ // if (a > pMax) {
470
+ // pMax = a;
471
+ // }
472
+ // }
473
+ // }
474
+ // psMin[pii] = pMin;
475
+ // psMax[pii] = pMax;
476
+ // }
477
+ // g.fillStyle = 'green';
478
+ // g.strokeStyle = 'green';
479
+ //
480
+ // // draw audio signal as single polygon
481
+ // g.beginPath();
482
+ // g.moveTo(0, y + (chH / 2) + psMin[0] * chH / 2);
483
+ //
484
+ // for (let pii = 0; pii < w; pii++) {
485
+ // let pv = psMin[pii] * chH / 2;
486
+ // //console.log("Min: ",pv);
487
+ // g.lineTo(pii, y + (chH / 2) + pv);
488
+ // }
489
+ // for (let pii = w; pii >= 0; pii--) {
490
+ // let pv = psMax[pii] * chH / 2;
491
+ // //console.log("Max: ",pv);
492
+ // g.lineTo(pii, y + (chH / 2) + pv);
493
+ // }
494
+ // g.closePath();
495
+ // //g.lineTo()
496
+ // g.fill();
497
+ // g.stroke();
498
+ // g.fillStyle = "yellow";
499
+ // g.stroke();
500
+ // y += chH;
501
+ // }
502
+ // ais?.close();
503
+ // }
504
+ // }
505
+ // }
427
506
  setData(audioData) {
428
507
  this._audioDataHolder = audioData;
429
508
  this.playFramePosition = 0;
430
509
  }
431
510
  }
432
- AudioSignal.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AudioSignal, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
433
- AudioSignal.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AudioSignal, selector: "audio-signal", viewQueries: [{ propertyName: "audioSignalCanvasRef", first: true, predicate: ["audioSignal"], descendants: true, static: true }, { propertyName: "playPosCanvasRef", first: true, predicate: ["marker"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
511
+ AudioSignal.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioSignal, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
512
+ AudioSignal.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: AudioSignal, selector: "audio-signal", viewQueries: [{ propertyName: "audioSignalCanvasRef", first: true, predicate: ["audioSignal"], descendants: true, static: true }, { propertyName: "playPosCanvasRef", first: true, predicate: ["marker"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
434
513
  <canvas #bg height="10"></canvas>
435
514
  <canvas #audioSignal height="10"></canvas>
436
515
  <canvas #cursor height="10" (mousedown)="selectionStart($event)" (mouseover)="updateCursorCanvas($event)" (mousemove)="updateCursorCanvas($event)"
437
516
  (mouseleave)="updateCursorCanvas($event, false)"></canvas>
438
517
  <canvas #marker height="10"></canvas>`, isInline: true, styles: [":host{min-height:0px}\n", "canvas{top:0;left:0;width:0;height:0;min-height:0px;position:absolute}\n"] });
439
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AudioSignal, decorators: [{
518
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioSignal, decorators: [{
440
519
  type: Component,
441
- args: [{
442
- selector: 'audio-signal',
443
- template: `
520
+ args: [{ selector: 'audio-signal', template: `
444
521
  <canvas #bg height="10"></canvas>
445
522
  <canvas #audioSignal height="10"></canvas>
446
523
  <canvas #cursor height="10" (mousedown)="selectionStart($event)" (mouseover)="updateCursorCanvas($event)" (mousemove)="updateCursorCanvas($event)"
447
524
  (mouseleave)="updateCursorCanvas($event, false)"></canvas>
448
- <canvas #marker height="10"></canvas>`,
449
- styles: [`:host{
450
- min-height: 0px;
451
- }`, `canvas {
452
- top: 0;
453
- left: 0;
454
- width: 0;
455
- height: 0;
456
- min-height: 0px;
457
- position: absolute;
458
- }`]
459
- }]
525
+ <canvas #marker height="10"></canvas>`, styles: [":host{min-height:0px}\n", "canvas{top:0;left:0;width:0;height:0;min-height:0px;position:absolute}\n"] }]
460
526
  }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { audioSignalCanvasRef: [{
461
527
  type: ViewChild,
462
528
  args: ['audioSignal', { static: true }]
@@ -464,4 +530,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
464
530
  type: ViewChild,
465
531
  args: ['marker', { static: true }]
466
532
  }] } });
467
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audiosignal.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/audiosignal.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ViewChild, ElementRef} from '@angular/core';\r\nimport {AudioCanvasLayerComponent} from \"./audio_canvas_layer_comp\";\r\nimport {WorkerHelper} from \"../../utils/utils\";\r\nimport {AudioDataHolder} from \"../audio_data_holder\";\r\nimport { Float32ArrayInputStream} from \"../../io/stream\";\r\n\r\ndeclare function postMessage(message: any, transfer: Array<any>): void;\r\n\r\n@Component({\r\n\r\n  selector: 'audio-signal',\r\n  template: `\r\n    <canvas #bg height=\"10\"></canvas>\r\n    <canvas #audioSignal height=\"10\"></canvas>\r\n    <canvas #cursor height=\"10\" (mousedown)=\"selectionStart($event)\" (mouseover)=\"updateCursorCanvas($event)\" (mousemove)=\"updateCursorCanvas($event)\"\r\n            (mouseleave)=\"updateCursorCanvas($event, false)\"></canvas>\r\n    <canvas #marker height=\"10\"></canvas>`,\r\n\r\n  styles: [`:host{\r\n      min-height: 0px;\r\n    }`,`canvas {\r\n    top: 0;\r\n    left: 0;\r\n    width: 0;\r\n    height: 0;\r\n    min-height: 0px;\r\n    position: absolute;\r\n  }`]\r\n\r\n})\r\nexport class AudioSignal extends AudioCanvasLayerComponent{\r\n\r\n  n: any;\r\n  ce!: HTMLDivElement;\r\n  @ViewChild('audioSignal', { static: true }) audioSignalCanvasRef!: ElementRef;\r\n  @ViewChild('marker', { static: true }) playPosCanvasRef!: ElementRef;\r\n  signalCanvas!: HTMLCanvasElement;\r\n\r\n  markerCanvas!: HTMLCanvasElement;\r\n\r\n  private _playFramePosition: number|null=null;\r\n\r\n  //private ais:ArrayAudioBufferInputsStream|null=null;\r\n  //private aisBuf:Float32Array[]|null=null;\r\n  //private psMinMax:Float32Array[]|null=null;\r\n  private worker: Worker | null;\r\n  private workerURL: string;\r\n\r\n  constructor(private ref: ElementRef) {\r\n    super();\r\n    this.worker = null;\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n    this._audioDataHolder = null;\r\n    this._bgColor='black';\r\n    this._selectColor='rgba(255,255,0,0.8)'\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n    this.ce = this.ref.nativeElement;\r\n    this.bgCanvas = this.bgCanvasRef.nativeElement;\r\n    this.bgCanvas.style.zIndex = '1';\r\n    this.signalCanvas = this.audioSignalCanvasRef.nativeElement;\r\n    this.signalCanvas.style.zIndex = '2';\r\n    this.markerCanvas = this.playPosCanvasRef.nativeElement;\r\n    this.markerCanvas.style.zIndex = '3';\r\n    this.cursorCanvas = this.cursorCanvasRef.nativeElement;\r\n    this.cursorCanvas.style.zIndex = '4';\r\n\r\n    this.canvasLayers[0]=this.bgCanvas;\r\n    this.canvasLayers[1]=this.signalCanvas;\r\n    this.canvasLayers[2]=this.cursorCanvas;\r\n    this.canvasLayers[3]=this.markerCanvas;\r\n\r\n  }\r\n\r\n  get playFramePosition(): number |null{\r\n    return this._playFramePosition;\r\n  }\r\n\r\n  set playFramePosition(playFramePosition: number|null) {\r\n    this._playFramePosition = playFramePosition;\r\n    this.drawPlayPosition();\r\n  }\r\n\r\n\r\n\r\n  drawPlayPosition() {\r\n    if (this.markerCanvas) {\r\n      let w = this.markerCanvas.width;\r\n      let h = this.markerCanvas.height;\r\n      let g = this.markerCanvas.getContext(\"2d\");\r\n      if (g) {\r\n        g.clearRect(0, 0, w, h);\r\n        if(this._playFramePosition) {\r\n          let pixelPos = this.frameToViewPortXPixelPosition(this._playFramePosition);\r\n          if (pixelPos) {\r\n            g.fillStyle = 'red';\r\n            g.strokeStyle = 'red';\r\n            g.beginPath();\r\n            g.moveTo(pixelPos, 0);\r\n            g.lineTo(pixelPos, h);\r\n            g.closePath();\r\n            g.stroke();\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    addEventListener('message', ({ data }) => {\r\n\r\n      let audioData = data.audioData; // audio data part required to render view port\r\n      let auOffset:number=data.audioDataOffset;\r\n      let l= data.l; // left pixel position of view port\r\n      let w = data.w;  // width of viewport\r\n      let vw = data.vw; //  total width of (virtual) audio view (not viewport width)\r\n      let chs = data.chs; // number of channels\r\n      let dataFrameLength = data.audioDataFrameLength;  // frame length of audio data part required for view port\r\n      let frameLength = data.frameLength;  // total frame length (of audio clip)\r\n\r\n      //console.debug(\"W: left: \"+l+\", w:\"+w+\", vw: \"+vw+\", chs: \"+chs+\", frameLength: \"+frameLength);\r\n\r\n      let psMinMax= new Float32Array(0);\r\n\r\n      if(audioData && audioData.length>0 && w>=0 && vw>0) {\r\n\r\n        let framesPerPixel = frameLength / vw;\r\n\r\n        let pointsLen = w * chs;\r\n        // one for min one for max\r\n        let arrLen = pointsLen * 2;\r\n        psMinMax = new Float32Array(arrLen);\r\n        let chFramePos = 0;\r\n        let chFrameLength=audioData.length/chs;\r\n        for (let ch = 0; ch < chs; ch++) {\r\n\r\n          chFramePos = ch * chFrameLength;\r\n          for (let pii = 0; pii < w; pii++) {\r\n            let virtPii=l+pii;\r\n            let pMin = Infinity;\r\n            let pMax = -Infinity;\r\n            let pixelFramePos = Math.round(chFramePos + (virtPii * framesPerPixel));\r\n\r\n            // calculate pixel min/max amplitude\r\n            for (let ai = 0; ai < framesPerPixel; ai++) {\r\n              let framePos = pixelFramePos + ai;\r\n              let a = 0;\r\n              let bufPos=framePos-auOffset;\r\n              //let bufPos=framePos;\r\n              if(bufPos>=0 && bufPos<audioData.length){\r\n                a=audioData[bufPos];\r\n                //console.debug(\"W: ch: \"+ch+\", pixelFramePos: \"+pixelFramePos+\", framePos: \"+framePos+\", auOffset: \"+auOffset+\", bufPos: \"+bufPos+\", audioData.length: \"+audioData.length+\", a: \"+a);\r\n                if (a < pMin) {\r\n                  pMin = a;\r\n                }\r\n                if (a > pMax) {\r\n                  pMax = a;\r\n                }\r\n              }\r\n            }\r\n\r\n            let psMinPos = ch * w + pii;\r\n            psMinMax[psMinPos] = pMin;\r\n            let psMaxPos = pointsLen + psMinPos;\r\n            psMinMax[psMaxPos] = pMax;\r\n            //console.debug(\"psMinMax[\"+psMinPos+\"]=\"+pMin+\",psMinMax[\"+psMaxPos+\"]=\"+pMax);\r\n\r\n          }\r\n\r\n        }\r\n      }\r\n      postMessage({psMinMax: psMinMax, l:data.l,w: data.w, chs: data.chs,eod:data.eod}, [psMinMax.buffer]);\r\n    })\r\n  }\r\n\r\n\r\n\r\n  startDraw(clear = true) {\r\n    if (clear) {\r\n      if(this.bounds) {\r\n        this.signalCanvas.style.left = Math.round(this.bounds.position.left).toString() + 'px';\r\n        this.signalCanvas.width = Math.round(this.bounds.dimension.width);\r\n        this.signalCanvas.height = Math.round(this.bounds.dimension.height);\r\n\r\n        let g = this.signalCanvas.getContext(\"2d\");\r\n        if (g) {\r\n          //g.clearRect(0, 0,w, h);\r\n          g.fillStyle = \"black\";\r\n          g.fillRect(0, 0, Math.round(this.bounds.dimension.width), Math.round(this.bounds.dimension.height));\r\n        }\r\n      }\r\n    }\r\n    this.startRender();\r\n    this.drawCursorLayer()\r\n  }\r\n\r\n\r\n  private startRender() {\r\n\r\n    if (this.worker) {\r\n      this.worker.terminate();\r\n      this.worker = null;\r\n    }\r\n    if (this.bounds && this.bounds.dimension) {\r\n\r\n      let w = Math.round(this.bounds.dimension.width);\r\n      let h = Math.round(this.bounds.dimension.height);\r\n\r\n      if (this._audioDataHolder && w>0 && h>0) {\r\n        //this.wo = new Worker('./audiosignal.worker.js',{type: 'module'});\r\n        this.worker = new Worker(this.workerURL);\r\n        //this.wo = new Worker('worker/audiosignal.worker.ts');\r\n\r\n        //let Worker = require('worker!../../../workers/uploader/main');\r\n        let chs = this._audioDataHolder.numberOfChannels;\r\n        let leftPos= Math.round(this.bounds.position.left);\r\n        let renderPos=leftPos;\r\n        let vw=Math.round(this.virtualDimension.width);\r\n        let frameLength = this._audioDataHolder.frameLen;\r\n        let framesPerPixel = Math.ceil(frameLength / vw);\r\n        let audioBuffer=this._audioDataHolder.buffer;\r\n        //let arrayAudioBuffer=this._audioDataHolder.arrayBuffer;\r\n        let arrAbBuf:Float32Array[]|null;\r\n\r\n        //let ais:ArrayAudioBufferInputStream|null=null;\r\n        //let aisBuf:Float32Array[]|null=null;\r\n        let psMinMax:Float32Array|null=null;\r\n\r\n        if (this.worker) {\r\n          this.worker.onmessage = (me) => {\r\n            if(me.data.eod===true){\r\n              let psMinMaxTmp;\r\n              if(psMinMax){\r\n                psMinMaxTmp=psMinMax;\r\n              }else{\r\n                psMinMaxTmp=me.data.psMinMax;\r\n              }\r\n              this.drawRendered(leftPos,w,h,chs,psMinMaxTmp);\r\n              if (this.worker) {\r\n                this.worker.terminate();\r\n              }\r\n              this.worker = null;\r\n            }else if(this._audioDataHolder && arrAbBuf){\r\n              let rw=me.data.w;\r\n              let rPointsLen=chs*rw;\r\n              let pointsLen=chs*w;\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                if(psMinMax){\r\n                  let rBasePos=ch*rw;\r\n                  let basePos=ch*w;\r\n                  let rPosMin =rBasePos;\r\n                  let rPosMax=rPointsLen+rPosMin;\r\n                  let posMin =basePos+(renderPos-leftPos);\r\n                  let posMax=pointsLen+posMin;\r\n\r\n                  psMinMax[posMin]=me.data.psMinMax[rPosMin];\r\n                  //console.debug('Min: ('+pos+'): '+me.data.psMinMax[0]);\r\n                  psMinMax[posMax]=me.data.psMinMax[rPosMax];\r\n                  // console.debug('Max: ('+(pointsLen+pos)+'): '+me.data.psMinMax[1]);\r\n                  //console.debug(\"psMinMax[\"+posMin+\"]=\"+me.data.psMinMax[rPosMin]+\"  (rPosMin=\"+rPosMin+\"),psMinMax[\"+posMax+\"]=\"+me.data.psMinMax[rPosMax]);\r\n                }\r\n              }\r\n              let eod=false;\r\n              renderPos++;\r\n              let ad:Float32Array;\r\n\r\n              let leftFramePos = Math.floor(frameLength * renderPos / vw);\r\n              if(renderPos<leftPos+w) {\r\n                let read = this._audioDataHolder.frames(leftFramePos, framesPerPixel, arrAbBuf);\r\n                //console.debug(\"First read frame: \"+arrAbBuf[0][0]);\r\n                ad = new Float32Array(chs * framesPerPixel);\r\n                for (let ch = 0; ch < chs; ch++) {\r\n                  ad.set(arrAbBuf[ch], ch * framesPerPixel);\r\n                }\r\n                eod=(read<=0);\r\n              }else{\r\n                ad=new Float32Array();\r\n                eod=true;\r\n              }\r\n              let adBuf=ad.buffer;\r\n              if (this.worker) {\r\n                this.worker.postMessage({\r\n                  l: renderPos,\r\n                  w: me.data.w,\r\n                  h:h,\r\n                  vw: vw,\r\n                  chs: chs,\r\n                  frameLength: frameLength,\r\n                  audioData: ad,\r\n                  audioDataOffset: leftFramePos,\r\n                  eod:eod\r\n                }, [adBuf]);\r\n              }\r\n            }\r\n          }\r\n        }\r\n\r\n        if (audioBuffer && audioBuffer.length*audioBuffer.numberOfChannels < AudioCanvasLayerComponent.ENABLE_STREAMING_NUMBER_OF_SAMPLES_THRESHOLD) {\r\n\r\n          // Render whole clip at once\r\n          arrAbBuf=null;\r\n          psMinMax=null;\r\n          let ad = new Float32Array(chs * frameLength);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            ad.set(audioBuffer.getChannelData(ch), ch * frameLength);\r\n          }\r\n          this.worker.postMessage({\r\n            l: leftPos,\r\n            w: w,\r\n            vw: vw,\r\n            chs: chs,\r\n            frameLength: frameLength,\r\n            audioData: ad,\r\n            audioDataOffset:0,\r\n            eod:true\r\n          }, [ad.buffer]);\r\n\r\n        }else{\r\n\r\n          // Render pixel by pixel\r\n          if(w>0) {\r\n\r\n            if (framesPerPixel > 0) {\r\n              let rw=1;\r\n              //ais = new ArrayAudioBufferInputStream(arrayAudioBuffer);\r\n              arrAbBuf = new Array<Float32Array>(chs);\r\n              psMinMax=new Float32Array(chs*w*2);\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                arrAbBuf[ch] = new Float32Array(framesPerPixel);\r\n              }\r\n              let leftFramePos=Math.floor(frameLength*renderPos/vw);\r\n              let auOffset=leftFramePos; // should always be 0\r\n              //let read=arrayAudioBuffer.frames(leftFramePos,framesPerPixel,arrAbBuf);\r\n              let read=this._audioDataHolder.frames(leftFramePos,framesPerPixel,arrAbBuf);\r\n              let ad=new Float32Array(chs*framesPerPixel);\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                ad.set(arrAbBuf[ch],ch*framesPerPixel);\r\n              }\r\n\r\n              this.worker.postMessage({\r\n                l: renderPos,\r\n                w: rw,\r\n                vw: vw,\r\n                chs: chs,\r\n                frameLength: frameLength,\r\n                audioData: ad,\r\n                audioDataOffset:auOffset,\r\n                eod:(read<=0)\r\n              }, [ad.buffer]);\r\n            }\r\n          }\r\n        }\r\n\r\n      } else {\r\n        let g = this.signalCanvas.getContext(\"2d\");\r\n        if (g) {\r\n          g.clearRect(0, 0, w, h);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  drawRendered(left:number,w:number,h:number,chs:number,psMinMax:Float32Array) {\r\n    this.drawBg();\r\n    this.signalCanvas.style.left=left.toString()+'px';\r\n    this.signalCanvas.width = w;\r\n    this.signalCanvas.height = h;\r\n    let g = this.signalCanvas.getContext(\"2d\");\r\n    if (g) {\r\n      g.clearRect(0, 0, w, h);\r\n      //g.fillStyle = \"black\";\r\n      //g.fillRect(0, 0, me.data.w, me.data.h);\r\n      let pointsLen = w * chs;\r\n      // one for min one for max\r\n      let arrLen = pointsLen * 2;\r\n      if (this._audioDataHolder) {\r\n        let std = Date.now();\r\n\r\n        let chH = h / chs;\r\n\r\n        let y = 0;\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          let x = 0;\r\n\r\n          let psMinPos = ch * w;\r\n          let psMaxPos = pointsLen + psMinPos;\r\n\r\n          g.fillStyle = 'green';\r\n          g.strokeStyle = 'green';\r\n\r\n          // draw audio signal as single polygon\r\n          g.beginPath();\r\n          g.moveTo(0, y + (chH / 2) + psMinMax[psMaxPos] * chH / 2);\r\n\r\n          for (let pii = 0; pii < w; pii++) {\r\n            let psMax = psMinMax[psMaxPos + pii];\r\n            let pv = psMax * chH / 2;\r\n            let yd=y + (chH / 2) - pv;\r\n            //console.log(\"LineTo: : \"+pii+\" \"+yd)\r\n            g.lineTo(pii, yd);\r\n          }\r\n          let revPixelStart=w-1;\r\n\r\n          for (let pii = revPixelStart; pii >= 0; pii--) {\r\n            let psMin = psMinMax[psMinPos + pii];\r\n            let pv = psMin * chH / 2;\r\n            let yd=y + (chH / 2) - pv;\r\n            //console.log(\"LineTo: : \"+pii+\" \"+yd)\r\n            g.lineTo(pii, yd);\r\n          }\r\n          g.closePath();\r\n\r\n          g.fill();\r\n          g.stroke();\r\n          y += chH;\r\n        }\r\n\r\n        //this.drawPlayPosition();\r\n      }\r\n    }\r\n  }\r\n\r\n  redraw() {\r\n    this.drawBg()\r\n    let g = this.signalCanvas.getContext(\"2d\");\r\n    if (g) {\r\n      let w = this.signalCanvas.width;\r\n      let h = this.signalCanvas.height;\r\n      g.clearRect(0, 0, w, h);\r\n      //g.fillStyle = \"black\";\r\n      //g.fillRect(0, 0, w, h);\r\n      if (this._audioDataHolder) {\r\n        let std = Date.now();\r\n        let chs = this._audioDataHolder.numberOfChannels;\r\n        let chH = h / chs;\r\n\r\n        let frameLength = this._audioDataHolder.frameLen;\r\n\r\n        let framesPerPixel = frameLength / w;\r\n        let y = 0;\r\n        let ais:Float32ArrayInputStream|null=null;\r\n        let audioBuffer=this._audioDataHolder.buffer;\r\n        let aisBuffer:Array<Float32Array>|null=null;\r\n        if(!audioBuffer) {\r\n          ais=this._audioDataHolder.audioInputStream();\r\n          aisBuffer=new Array<Float32Array>(chs);\r\n          for(let ch=0;ch<chs;ch++) {\r\n            aisBuffer[ch] = new Float32Array(framesPerPixel);\r\n          }\r\n        }\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let x = 0;\r\n            let psMin = new Float32Array(w);\r\n            let psMax = new Float32Array(w);\r\n            let framePos = 0;\r\n            for (let pii = 0; pii < w; pii++) {\r\n              let pMin = 0;\r\n              let pMax = 0;\r\n\r\n              if (audioBuffer){\r\n                // calculate pixel min/max amplitude\r\n                for (let ai = 0; ai < framesPerPixel; ai++) {\r\n                  //let framePos=(pii*framesPerPixel)+ai;\r\n                  let a = audioBuffer.getChannelData(ch)[framePos++];\r\n\r\n                  if (a < pMin) {\r\n                    pMin = a;\r\n                  }\r\n                  if (a > pMax) {\r\n                    pMax = a;\r\n                  }\r\n                }\r\n            }else if(ais && aisBuffer) {\r\n                let r = ais.read(aisBuffer);\r\n                for (let ai = 0; ai < r; ai++) {\r\n\r\n                  let a = aisBuffer[ch][ai];\r\n\r\n                  if (a < pMin) {\r\n                    pMin = a;\r\n                  }\r\n                  if (a > pMax) {\r\n                    pMax = a;\r\n                  }\r\n                }\r\n              }\r\n              psMin[pii] = pMin;\r\n              psMax[pii] = pMax;\r\n            }\r\n            g.fillStyle = 'green';\r\n            g.strokeStyle = 'green';\r\n\r\n            // draw audio signal as single polygon\r\n            g.beginPath();\r\n            g.moveTo(0, y + (chH / 2) + psMin[0] * chH / 2);\r\n\r\n            for (let pii = 0; pii < w; pii++) {\r\n              let pv = psMin[pii] * chH / 2;\r\n              //console.log(\"Min: \",pv);\r\n              g.lineTo(pii, y + (chH / 2) + pv);\r\n            }\r\n            for (let pii = w; pii >= 0; pii--) {\r\n              let pv = psMax[pii] * chH / 2;\r\n              //console.log(\"Max: \",pv);\r\n              g.lineTo(pii, y + (chH / 2) + pv);\r\n            }\r\n            g.closePath();\r\n            //g.lineTo()\r\n            g.fill();\r\n            g.stroke();\r\n            g.fillStyle = \"yellow\";\r\n            g.stroke();\r\n            y += chH;\r\n          }\r\n\r\n      }\r\n    }\r\n  }\r\n\r\n  setData(audioData: AudioDataHolder | null) {\r\n    this._audioDataHolder = audioData;\r\n    this.playFramePosition = 0;\r\n  }\r\n}\r\n\r\n"]}
533
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audiosignal.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/audiosignal.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ViewChild, ElementRef} from '@angular/core';\r\nimport {AudioCanvasLayerComponent} from \"./audio_canvas_layer_comp\";\r\nimport {WorkerHelper} from \"../../utils/utils\";\r\nimport {AudioBufferSource, AudioDataHolder} from \"../audio_data_holder\";\r\nimport {Subscription} from \"rxjs\";\r\n\r\ndeclare function postMessage(message: any, transfer: Array<any>): void;\r\n\r\n@Component({\r\n\r\n  selector: 'audio-signal',\r\n  template: `\r\n    <canvas #bg height=\"10\"></canvas>\r\n    <canvas #audioSignal height=\"10\"></canvas>\r\n    <canvas #cursor height=\"10\" (mousedown)=\"selectionStart($event)\" (mouseover)=\"updateCursorCanvas($event)\" (mousemove)=\"updateCursorCanvas($event)\"\r\n            (mouseleave)=\"updateCursorCanvas($event, false)\"></canvas>\r\n    <canvas #marker height=\"10\"></canvas>`,\r\n\r\n  styles: [`:host{\r\n      min-height: 0px;\r\n    }`,`canvas {\r\n    top: 0;\r\n    left: 0;\r\n    width: 0;\r\n    height: 0;\r\n    min-height: 0px;\r\n    position: absolute;\r\n  }`]\r\n\r\n})\r\nexport class AudioSignal extends AudioCanvasLayerComponent{\r\n\r\n  n: any;\r\n  ce!: HTMLDivElement;\r\n  @ViewChild('audioSignal', { static: true }) audioSignalCanvasRef!: ElementRef;\r\n  @ViewChild('marker', { static: true }) playPosCanvasRef!: ElementRef;\r\n  signalCanvas!: HTMLCanvasElement;\r\n\r\n  markerCanvas!: HTMLCanvasElement;\r\n\r\n  private _playFramePosition: number|null=null;\r\n\r\n  private worker: Worker | null=null;\r\n  private readonly workerURL: string;\r\n\r\n  private raAsSubsc:Subscription|null=null;\r\n\r\n  constructor(private ref: ElementRef) {\r\n    super();\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n    this._audioDataHolder = null;\r\n    this._bgColor='black';\r\n    this._selectColor='rgba(255,255,0,0.8)'\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n    this.ce = this.ref.nativeElement;\r\n    this.bgCanvas = this.bgCanvasRef.nativeElement;\r\n    this.bgCanvas.style.zIndex = '1';\r\n    this.signalCanvas = this.audioSignalCanvasRef.nativeElement;\r\n    this.signalCanvas.style.zIndex = '2';\r\n    this.markerCanvas = this.playPosCanvasRef.nativeElement;\r\n    this.markerCanvas.style.zIndex = '3';\r\n    this.cursorCanvas = this.cursorCanvasRef.nativeElement;\r\n    this.cursorCanvas.style.zIndex = '4';\r\n\r\n    this.canvasLayers[0]=this.bgCanvas;\r\n    this.canvasLayers[1]=this.signalCanvas;\r\n    this.canvasLayers[2]=this.cursorCanvas;\r\n    this.canvasLayers[3]=this.markerCanvas;\r\n\r\n  }\r\n\r\n  get playFramePosition(): number |null{\r\n    return this._playFramePosition;\r\n  }\r\n\r\n  set playFramePosition(playFramePosition: number|null) {\r\n    this._playFramePosition = playFramePosition;\r\n    this.drawPlayPosition();\r\n  }\r\n\r\n\r\n\r\n  drawPlayPosition() {\r\n    if (this.markerCanvas) {\r\n      let w = this.markerCanvas.width;\r\n      let h = this.markerCanvas.height;\r\n      let g = this.markerCanvas.getContext(\"2d\");\r\n      if (g) {\r\n        g.clearRect(0, 0, w, h);\r\n        if(this._playFramePosition) {\r\n          let pixelPos = this.frameToViewPortXPixelPosition(this._playFramePosition);\r\n          if (pixelPos) {\r\n            g.fillStyle = 'red';\r\n            g.strokeStyle = 'red';\r\n            g.beginPath();\r\n            g.moveTo(pixelPos, 0);\r\n            g.lineTo(pixelPos, h);\r\n            g.closePath();\r\n            g.stroke();\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    addEventListener('message', ({ data }) => {\r\n\r\n      const audioData = data.audioData; // audio data part required to render view port\r\n      const auOffset:number=data.audioDataOffset;\r\n      const l= data.l; // left pixel position of view port\r\n      const w = data.w;  // width of viewport\r\n      const vw = data.vw; //  total width of (virtual) audio view (not viewport width)\r\n      const chs = data.chs; // number of channels\r\n      //const dataFrameLength = data.audioDataFrameLength;  // frame length of audio data part required for view port\r\n      const frameLength = data.frameLength;  // total frame length (of audio clip)\r\n\r\n      //console.debug(\"W: left: \"+l+\", w:\"+w+\", vw: \"+vw+\", chs: \"+chs+\", frameLength: \"+frameLength);\r\n\r\n      let psMinMax= new Float32Array(0);\r\n\r\n      if(audioData && audioData.length>0 && w>=0 && vw>0) {\r\n\r\n        const framesPerPixel = frameLength / vw;\r\n\r\n        const pointsLen = w * chs;\r\n        // one for min one for max\r\n        const arrLen = pointsLen * 2;\r\n        psMinMax = new Float32Array(arrLen);\r\n        let chFramePos = 0;\r\n        const chFrameLength=audioData.length/chs;\r\n        for (let ch = 0; ch < chs; ch++) {\r\n\r\n          chFramePos = ch * chFrameLength;\r\n          for (let pii = 0; pii < w; pii++) {\r\n            const virtPii=l+pii;\r\n            let pMin = Infinity;\r\n            let pMax = -Infinity;\r\n            let pixelFramePos = Math.round(chFramePos + (virtPii * framesPerPixel));\r\n\r\n            // calculate pixel min/max amplitude\r\n            for (let ai = 0; ai < framesPerPixel; ai++) {\r\n              const framePos = pixelFramePos + ai;\r\n              let a = 0;\r\n              const bufPos=framePos-auOffset;\r\n              //let bufPos=framePos;\r\n              if(bufPos>=0 && bufPos<audioData.length){\r\n                a=audioData[bufPos];\r\n                //console.debug(\"W: ch: \"+ch+\", pixelFramePos: \"+pixelFramePos+\", framePos: \"+framePos+\", auOffset: \"+auOffset+\", bufPos: \"+bufPos+\", audioData.length: \"+audioData.length+\", a: \"+a);\r\n                if (a < pMin) {\r\n                  pMin = a;\r\n                }\r\n                if (a > pMax) {\r\n                  pMax = a;\r\n                }\r\n              }\r\n            }\r\n\r\n            const psMinPos = ch * w + pii;\r\n            psMinMax[psMinPos] = pMin;\r\n            const psMaxPos = pointsLen + psMinPos;\r\n            psMinMax[psMaxPos] = pMax;\r\n            //console.debug(\"psMinMax[\"+psMinPos+\"]=\"+pMin+\",psMinMax[\"+psMaxPos+\"]=\"+pMax);\r\n\r\n          }\r\n        }\r\n      }\r\n      postMessage({psMinMax: psMinMax, l:data.l,w: data.w, chs: data.chs,eod:data.eod}, [psMinMax.buffer]);\r\n    })\r\n  }\r\n\r\n\r\n\r\n  startDraw(clear = true) {\r\n    if (clear) {\r\n      if(this.bounds) {\r\n        this.signalCanvas.style.left = Math.round(this.bounds.position.left).toString() + 'px';\r\n        this.signalCanvas.width = Math.round(this.bounds.dimension.width);\r\n        this.signalCanvas.height = Math.round(this.bounds.dimension.height);\r\n\r\n        let g = this.signalCanvas.getContext(\"2d\");\r\n        if (g) {\r\n          //g.clearRect(0, 0,w, h);\r\n          g.fillStyle = \"black\";\r\n          g.fillRect(0, 0, Math.round(this.bounds.dimension.width), Math.round(this.bounds.dimension.height));\r\n        }\r\n      }\r\n    }\r\n    this.startRender();\r\n    this.drawCursorLayer()\r\n  }\r\n\r\n\r\n  private startRender() {\r\n\r\n    if (this.worker) {\r\n      this.worker.terminate();\r\n      this.worker = null;\r\n    }\r\n    if(this.raAsSubsc){\r\n      this.raAsSubsc.unsubscribe();\r\n    }\r\n      if (this._audioDataHolder) {\r\n        this._audioDataHolder.addOnReadyListener(()=>{\r\n          if(this._audioDataHolder && this.bounds && this.bounds.dimension) {\r\n            let w = Math.round(this.bounds.dimension.width);\r\n            let h = Math.round(this.bounds.dimension.height);\r\n            let vw = Math.round(this.virtualDimension.width);\r\n\r\n            if (w > 0 && h > 0 && vw > 0) {\r\n\r\n              //this.wo = new Worker('./audiosignal.worker.js',{type: 'module'});\r\n              this.worker = new Worker(this.workerURL);\r\n              //this.wo = new Worker('worker/audiosignal.worker.ts');\r\n\r\n              //let Worker = require('worker!../../../workers/uploader/main');\r\n              let chs = this._audioDataHolder.numberOfChannels;\r\n              let leftPos = Math.round(this.bounds.position.left);\r\n              let renderPos = leftPos;\r\n\r\n              let frameLength = this._audioDataHolder.frameLen;\r\n              let framesPerPixel = Math.ceil(frameLength / vw);\r\n              //console.debug(\"Chs: \" + chs + \", vw: \" + vw + \", frameLength: \" + frameLength + \", framesPerPixel: \" + framesPerPixel);\r\n              let ad: Float32Array = new Float32Array(chs * framesPerPixel);\r\n              let raAs = this._audioDataHolder.randomAccessAudioStream();\r\n              let audioBuffer: AudioBuffer | null = null;\r\n              let audioSource = this._audioDataHolder.audioSource;\r\n              if (audioSource instanceof AudioBufferSource) {\r\n                audioBuffer = audioSource.audioBuffer;\r\n              }\r\n              //let arrayAudioBuffer=this._audioDataHolder.arrayBuffer;\r\n              let arrAbBuf: Float32Array[] | null;\r\n\r\n              //let ais:ArrayAudioBufferInputStream|null=null;\r\n              //let aisBuf:Float32Array[]|null=null;\r\n              let psMinMax: Float32Array | null = null;\r\n\r\n              if (this.worker) {\r\n                this.worker.onmessage = (me) => {\r\n                  if (me.data.eod === true) {\r\n                    let psMinMaxTmp;\r\n                    if (psMinMax) {\r\n                      psMinMaxTmp = psMinMax;\r\n                    } else {\r\n                      psMinMaxTmp = me.data.psMinMax;\r\n                    }\r\n                    this.drawRendered(leftPos, w, h, chs, psMinMaxTmp);\r\n                    if (this.worker) {\r\n                      this.worker.terminate();\r\n                    }\r\n                    raAs.close();\r\n                  } else if (this._audioDataHolder && arrAbBuf) {\r\n                    const rw = me.data.w;\r\n                    const rPointsLen = chs * rw;\r\n                    const pointsLen = chs * w;\r\n                    for (let ch = 0; ch < chs; ch++) {\r\n                      if (psMinMax) {\r\n                        let rBasePos = ch * rw;\r\n                        let basePos = ch * w;\r\n                        let rPosMin = rBasePos;\r\n                        let rPosMax = rPointsLen + rPosMin;\r\n                        let posMin = basePos + (renderPos - leftPos);\r\n                        let posMax = pointsLen + posMin;\r\n\r\n                        psMinMax[posMin] = me.data.psMinMax[rPosMin];\r\n                        //console.debug('Min: ('+posMin+'): '+me.data.psMinMax[rPosMin]);\r\n                        psMinMax[posMax] = me.data.psMinMax[rPosMax];\r\n                        //console.debug('Max: ('+(posMax)+'): '+me.data.psMinMax[rPosMax]);\r\n                        //console.debug(\"psMinMax[\"+posMin+\"]=\"+me.data.psMinMax[rPosMin]+\"  (rPosMin=\"+rPosMin+\"),psMinMax[\"+posMax+\"]=\"+me.data.psMinMax[rPosMax]);\r\n                      }\r\n                    }\r\n                    let eod = false;\r\n                    renderPos++;\r\n                    //let ad:Float32Array;\r\n\r\n                    const leftFramePos = Math.floor(frameLength * renderPos / vw);\r\n                    if (renderPos < leftPos + w) {\r\n\r\n                      const raAsObs = raAs.framesObs(leftFramePos, framesPerPixel, arrAbBuf)\r\n\r\n                      this.raAsSubsc = raAsObs.subscribe(\r\n                        {\r\n                          next: (read) => {\r\n                            //console.debug(\"First read frame: \"+arrAbBuf[0][0]);\r\n                            if (arrAbBuf) {\r\n                              const adLen = chs * framesPerPixel;\r\n                              if (!ad || ad.length !== adLen) {\r\n                                ad = new Float32Array(adLen);\r\n                              }\r\n                              for (let ch = 0; ch < chs; ch++) {\r\n                                ad.set(arrAbBuf[ch], ch * framesPerPixel);\r\n                              }\r\n                            }\r\n                            eod = (read <= 0);\r\n                            let adBuf = ad.buffer;\r\n                            if (this.worker) {\r\n                              this.worker.postMessage({\r\n                                l: renderPos,\r\n                                w: me.data.w,\r\n                                h: h,\r\n                                vw: vw,\r\n                                chs: chs,\r\n                                frameLength: frameLength,\r\n                                audioData: ad,\r\n                                audioDataOffset: leftFramePos,\r\n                                eod: eod\r\n                              }, [adBuf]);\r\n                            }\r\n                          },\r\n                          error: (err) => {\r\n                            console.error(\"AudioSignal: Error reading audio data: \" + err);\r\n                          }\r\n                        }\r\n                      )\r\n\r\n                    } else {\r\n                      ad = new Float32Array();\r\n                      eod = true;\r\n                      const adBuf = ad.buffer;\r\n                      if (this.worker) {\r\n                        this.worker.postMessage({\r\n                          l: renderPos,\r\n                          w: me.data.w,\r\n                          h: h,\r\n                          vw: vw,\r\n                          chs: chs,\r\n                          frameLength: frameLength,\r\n                          audioData: ad,\r\n                          audioDataOffset: leftFramePos,\r\n                          eod: eod\r\n                        }, [adBuf]);\r\n                      }\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n\r\n              if (audioBuffer && audioBuffer.length * audioBuffer.numberOfChannels < AudioCanvasLayerComponent.ENABLE_STREAMING_NUMBER_OF_SAMPLES_THRESHOLD) {\r\n\r\n                // Render whole clip at once\r\n                arrAbBuf = null;\r\n                psMinMax = null;\r\n                const ad = new Float32Array(chs * frameLength);\r\n                for (let ch = 0; ch < chs; ch++) {\r\n                  ad.set(audioBuffer.getChannelData(ch), ch * frameLength);\r\n                }\r\n                this.worker.postMessage({\r\n                  l: leftPos,\r\n                  w: w,\r\n                  vw: vw,\r\n                  chs: chs,\r\n                  frameLength: frameLength,\r\n                  audioData: ad,\r\n                  audioDataOffset: 0,\r\n                  eod: true\r\n                }, [ad.buffer]);\r\n\r\n              } else {\r\n\r\n                // Render pixel by pixel\r\n                if (w > 0) {\r\n\r\n                  if (framesPerPixel > 0) {\r\n                    let rw = 1;\r\n                    arrAbBuf = new Array<Float32Array>(chs);\r\n                    psMinMax = new Float32Array(chs * w * 2);\r\n                    //console.debug(\"Audiosignal: Allocating buffers: \"+framesPerPixel);\r\n                    for (let ch = 0; ch < chs; ch++) {\r\n                      arrAbBuf[ch] = new Float32Array(framesPerPixel);\r\n                    }\r\n                    const leftFramePos = Math.floor(frameLength * renderPos / vw);\r\n                    const auOffset = leftFramePos; // should always be 0\r\n\r\n                    const raAsObs = raAs.framesObs(leftFramePos, framesPerPixel, arrAbBuf);\r\n\r\n                    this.drawStateText(\"Loading/Rendering...\");\r\n\r\n                    this.raAsSubsc = raAsObs.subscribe(\r\n                      {\r\n                        next: (read) => {\r\n\r\n                          if (arrAbBuf && this.worker) {\r\n                            const adLen = chs * framesPerPixel;\r\n                            if (!ad || ad.length !== adLen) {\r\n                              ad = new Float32Array(adLen);\r\n                            }\r\n                            for (let ch = 0; ch < chs; ch++) {\r\n                              ad.set(arrAbBuf[ch], ch * framesPerPixel);\r\n                            }\r\n\r\n                            this.worker.postMessage({\r\n                              l: renderPos,\r\n                              w: rw,\r\n                              vw: vw,\r\n                              chs: chs,\r\n                              frameLength: frameLength,\r\n                              audioData: ad,\r\n                              audioDataOffset: auOffset,\r\n                              eod: (read <= 0)\r\n                            }, [ad.buffer]);\r\n                          }\r\n                        },\r\n                        error: (err) => {\r\n                          console.error(\"AudioSignal: Error reading audio data: \" + err);\r\n                        }\r\n                      }\r\n                    );\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        });\r\n      } else {\r\n        if (this.bounds && this.bounds.dimension) {\r\n          let w = Math.round(this.bounds.dimension.width);\r\n          let h = Math.round(this.bounds.dimension.height);\r\n          let g = this.signalCanvas.getContext(\"2d\");\r\n          if (g) {\r\n            g.clearRect(0, 0, w, h);\r\n          }\r\n        }\r\n      }\r\n\r\n  }\r\n\r\ndrawStateText(stateText:string) {\r\n    if(stateText) {\r\n      const g = this.signalCanvas.getContext(\"2d\");\r\n      const w=this.signalCanvas.width;\r\n      const h=this.signalCanvas.height;\r\n      if (g && w && h) {\r\n        g.strokeStyle = 'white';\r\n        g.fillStyle = 'white';\r\n        g.font = '20px sans-serif';\r\n        g.fillText(stateText, 10, 25);\r\n      }\r\n    }\r\n}\r\n  drawRendered(left:number,w:number,h:number,chs:number,psMinMax:Float32Array) {\r\n    this.drawBg();\r\n    this.signalCanvas.style.left=left.toString()+'px';\r\n    this.signalCanvas.width = w;\r\n    this.signalCanvas.height = h;\r\n    let g = this.signalCanvas.getContext(\"2d\");\r\n    if (g) {\r\n      g.clearRect(0, 0, w, h);\r\n      let pointsLen = w * chs;\r\n      // one for min one for max\r\n      //const arrLen = pointsLen * 2;\r\n      if (this._audioDataHolder) {\r\n        //const std = Date.now();\r\n\r\n        const chH = h / chs;\r\n\r\n        let y = 0;\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          const psMinPos = ch * w;\r\n          const psMaxPos = pointsLen + psMinPos;\r\n\r\n          g.fillStyle = 'green';\r\n          g.strokeStyle = 'green';\r\n\r\n          // draw audio signal as single polygon\r\n          g.beginPath();\r\n          g.moveTo(0, y + (chH / 2) + psMinMax[psMaxPos] * chH / 2);\r\n\r\n          for (let pii = 0; pii < w; pii++) {\r\n            const psMax = psMinMax[psMaxPos + pii];\r\n            const pv = psMax * chH / 2;\r\n            const yd=y + (chH / 2) - pv;\r\n            //console.log(\"LineTo: : \"+pii+\" \"+yd)\r\n            g.lineTo(pii, yd);\r\n          }\r\n          const revPixelStart=w-1;\r\n\r\n          for (let pii = revPixelStart; pii >= 0; pii--) {\r\n            const psMin = psMinMax[psMinPos + pii];\r\n            const pv = psMin * chH / 2;\r\n            const yd=y + (chH / 2) - pv;\r\n            //console.log(\"LineTo: : \"+pii+\" \"+yd)\r\n            g.lineTo(pii, yd);\r\n          }\r\n          g.closePath();\r\n\r\n          g.fill();\r\n          g.stroke();\r\n          y += chH;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  // redraw() {\r\n  //   this.drawBg()\r\n  //   let g = this.signalCanvas.getContext(\"2d\");\r\n  //   if (g) {\r\n  //     let w = this.signalCanvas.width;\r\n  //     let h = this.signalCanvas.height;\r\n  //     g.clearRect(0, 0, w, h);\r\n  //     //g.fillStyle = \"black\";\r\n  //     //g.fillRect(0, 0, w, h);\r\n  //     if (this._audioDataHolder) {\r\n  //       let std = Date.now();\r\n  //       let chs = this._audioDataHolder.numberOfChannels;\r\n  //       let chH = h / chs;\r\n  //\r\n  //       let frameLength = this._audioDataHolder.frameLen;\r\n  //\r\n  //       let framesPerPixel = frameLength / w;\r\n  //       let y = 0;\r\n  //       let ais:Float32ArrayInputStream|null=null;\r\n  //       let audioSource=this._audioDataHolder.audioSource;\r\n  //       let audioBuffer:AudioBuffer|null=null;\r\n  //       if(audioSource instanceof AudioBufferSource){\r\n  //         audioBuffer=audioSource.audioBuffer;\r\n  //       }\r\n  //       let aisBuffer:Array<Float32Array>|null=null;\r\n  //       if(!audioBuffer) {\r\n  //         ais=this._audioDataHolder.audioInputStream();\r\n  //         aisBuffer=new Array<Float32Array>(chs);\r\n  //         for(let ch=0;ch<chs;ch++) {\r\n  //           aisBuffer[ch] = new Float32Array(framesPerPixel);\r\n  //         }\r\n  //       }\r\n  //         for (let ch = 0; ch < chs; ch++) {\r\n  //           let x = 0;\r\n  //           let psMin = new Float32Array(w);\r\n  //           let psMax = new Float32Array(w);\r\n  //           let framePos = 0;\r\n  //           for (let pii = 0; pii < w; pii++) {\r\n  //             let pMin = 0;\r\n  //             let pMax = 0;\r\n  //\r\n  //             if (audioBuffer){\r\n  //               // calculate pixel min/max amplitude\r\n  //               for (let ai = 0; ai < framesPerPixel; ai++) {\r\n  //                 //let framePos=(pii*framesPerPixel)+ai;\r\n  //                 let a = audioBuffer.getChannelData(ch)[framePos++];\r\n  //\r\n  //                 if (a < pMin) {\r\n  //                   pMin = a;\r\n  //                 }\r\n  //                 if (a > pMax) {\r\n  //                   pMax = a;\r\n  //                 }\r\n  //               }\r\n  //           }else if(ais && aisBuffer) {\r\n  //               let r = ais.read(aisBuffer);\r\n  //               for (let ai = 0; ai < r; ai++) {\r\n  //\r\n  //                 let a = aisBuffer[ch][ai];\r\n  //\r\n  //                 if (a < pMin) {\r\n  //                   pMin = a;\r\n  //                 }\r\n  //                 if (a > pMax) {\r\n  //                   pMax = a;\r\n  //                 }\r\n  //               }\r\n  //             }\r\n  //             psMin[pii] = pMin;\r\n  //             psMax[pii] = pMax;\r\n  //           }\r\n  //           g.fillStyle = 'green';\r\n  //           g.strokeStyle = 'green';\r\n  //\r\n  //           // draw audio signal as single polygon\r\n  //           g.beginPath();\r\n  //           g.moveTo(0, y + (chH / 2) + psMin[0] * chH / 2);\r\n  //\r\n  //           for (let pii = 0; pii < w; pii++) {\r\n  //             let pv = psMin[pii] * chH / 2;\r\n  //             //console.log(\"Min: \",pv);\r\n  //             g.lineTo(pii, y + (chH / 2) + pv);\r\n  //           }\r\n  //           for (let pii = w; pii >= 0; pii--) {\r\n  //             let pv = psMax[pii] * chH / 2;\r\n  //             //console.log(\"Max: \",pv);\r\n  //             g.lineTo(pii, y + (chH / 2) + pv);\r\n  //           }\r\n  //           g.closePath();\r\n  //           //g.lineTo()\r\n  //           g.fill();\r\n  //           g.stroke();\r\n  //           g.fillStyle = \"yellow\";\r\n  //           g.stroke();\r\n  //           y += chH;\r\n  //         }\r\n  //       ais?.close();\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n  setData(audioData: AudioDataHolder | null) {\r\n    this._audioDataHolder = audioData;\r\n    this.playFramePosition = 0;\r\n  }\r\n}\r\n\r\n"]}