speechrecorderng 2.25.3 → 3.0.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.
- package/esm2020/lib/audio/array_audio_buffer.mjs +101 -0
- package/esm2020/lib/audio/array_audio_buffer_input_stream.mjs +86 -0
- package/esm2020/lib/audio/audio_data_holder.mjs +109 -0
- package/esm2020/lib/audio/audio_display.mjs +5 -5
- package/esm2020/lib/audio/audio_player.mjs +9 -7
- package/esm2020/lib/audio/capture/capture.mjs +6 -1
- package/esm2020/lib/audio/dsp/level_measure.mjs +97 -55
- package/esm2020/lib/audio/io/stream.mjs +3 -3
- package/esm2020/lib/audio/persistor.mjs +5 -6
- package/esm2020/lib/audio/playback/array_audio_buffer_source_node.mjs +265 -0
- package/esm2020/lib/audio/playback/player.mjs +184 -50
- package/esm2020/lib/audio/ui/audio_canvas_layer_comp.mjs +25 -13
- package/esm2020/lib/audio/ui/audio_display_scroll_pane.mjs +2 -2
- package/esm2020/lib/audio/ui/audiosignal.mjs +206 -77
- package/esm2020/lib/audio/ui/container.mjs +14 -14
- package/esm2020/lib/audio/ui/livelevel.mjs +15 -2
- package/esm2020/lib/audio/ui/sonagram.mjs +343 -160
- package/esm2020/lib/io/stream.mjs +77 -1
- package/esm2020/lib/net/uploader.mjs +15 -3
- package/esm2020/lib/speechrecorder/recording.mjs +52 -7
- package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +99 -7
- package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +117 -101
- package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +34 -6
- package/esm2020/lib/speechrecorder/session/progress.mjs +2 -2
- package/esm2020/lib/speechrecorder/session/prompting.mjs +2 -2
- package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +6 -3
- package/esm2020/lib/speechrecorder/session/recording_file_cache.mjs +182 -0
- package/esm2020/lib/speechrecorder/session/recording_list.mjs +23 -10
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +12 -6
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +5 -5
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +13 -9
- package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +8 -5
- package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +118 -95
- package/esm2020/lib/speechrecorderng.component.mjs +2 -2
- package/esm2020/lib/speechrecorderng.module.mjs +5 -4
- package/esm2020/lib/spr.module.version.mjs +2 -2
- package/esm2020/lib/ui/recordingitem_display.mjs +2 -2
- package/fesm2015/speechrecorderng.mjs +2321 -743
- package/fesm2015/speechrecorderng.mjs.map +1 -1
- package/fesm2020/speechrecorderng.mjs +2321 -753
- package/fesm2020/speechrecorderng.mjs.map +1 -1
- package/lib/audio/array_audio_buffer.d.ts +15 -0
- package/lib/audio/array_audio_buffer_input_stream.d.ts +14 -0
- package/lib/audio/audio_data_holder.d.ts +29 -0
- package/lib/audio/audio_display.d.ts +2 -1
- package/lib/audio/audio_player.d.ts +2 -1
- package/lib/audio/capture/capture.d.ts +2 -0
- package/lib/audio/dsp/level_measure.d.ts +2 -1
- package/lib/audio/persistor.d.ts +4 -3
- package/lib/audio/playback/array_audio_buffer_source_node.d.ts +24 -0
- package/lib/audio/playback/player.d.ts +6 -0
- package/lib/audio/ui/audio_canvas_layer_comp.d.ts +4 -1
- package/lib/audio/ui/audio_display_scroll_pane.d.ts +2 -1
- package/lib/audio/ui/audiosignal.d.ts +3 -2
- package/lib/audio/ui/container.d.ts +3 -2
- package/lib/audio/ui/livelevel.d.ts +3 -1
- package/lib/audio/ui/sonagram.d.ts +3 -2
- package/lib/io/stream.d.ts +17 -0
- package/lib/net/uploader.d.ts +6 -1
- package/lib/speechrecorder/recording.d.ts +15 -3
- package/lib/speechrecorder/recordings/recordings.service.d.ts +2 -0
- package/lib/speechrecorder/session/audiorecorder.d.ts +2 -7
- package/lib/speechrecorder/session/basicrecorder.d.ts +9 -3
- package/lib/speechrecorder/session/progress.d.ts +1 -1
- package/lib/speechrecorder/session/prompting.d.ts +1 -1
- package/lib/speechrecorder/session/recorder_combi_pane.d.ts +3 -1
- package/lib/speechrecorder/session/recording_file_cache.d.ts +30 -0
- package/lib/speechrecorder/session/recording_list.d.ts +3 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +2 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-view.component.d.ts +1 -0
- package/lib/speechrecorder/session/sessionmanager.d.ts +5 -11
- package/lib/speechrecorderng.module.d.ts +2 -1
- package/lib/spr.module.version.d.ts +1 -1
- package/package.json +1 -1
|
@@ -9,7 +9,7 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
9
9
|
this._playFramePosition = null;
|
|
10
10
|
this.worker = null;
|
|
11
11
|
this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);
|
|
12
|
-
this.
|
|
12
|
+
this._audioDataHolder = null;
|
|
13
13
|
this._bgColor = 'black';
|
|
14
14
|
this._selectColor = 'rgba(255,255,0,0.8)';
|
|
15
15
|
}
|
|
@@ -62,25 +62,26 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
62
62
|
*/
|
|
63
63
|
workerFunction() {
|
|
64
64
|
addEventListener('message', ({ data }) => {
|
|
65
|
-
let audioData = data.audioData;
|
|
66
|
-
let
|
|
67
|
-
let
|
|
68
|
-
let
|
|
69
|
-
let vw = data.vw;
|
|
70
|
-
let chs = data.chs;
|
|
71
|
-
let
|
|
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)
|
|
73
|
+
//console.debug("W: left: "+l+", w:"+w+", vw: "+vw+", chs: "+chs+", frameLength: "+frameLength);
|
|
72
74
|
let psMinMax = new Float32Array(0);
|
|
73
|
-
if (audioData && w >= 0 && vw > 0) {
|
|
75
|
+
if (audioData && audioData.length > 0 && w >= 0 && vw > 0) {
|
|
74
76
|
let framesPerPixel = frameLength / vw;
|
|
75
|
-
let y = 0;
|
|
76
77
|
let pointsLen = w * chs;
|
|
77
78
|
// one for min one for max
|
|
78
79
|
let arrLen = pointsLen * 2;
|
|
79
80
|
psMinMax = new Float32Array(arrLen);
|
|
80
81
|
let chFramePos = 0;
|
|
82
|
+
let chFrameLength = audioData.length / chs;
|
|
81
83
|
for (let ch = 0; ch < chs; ch++) {
|
|
82
|
-
|
|
83
|
-
chFramePos = ch * frameLength;
|
|
84
|
+
chFramePos = ch * chFrameLength;
|
|
84
85
|
for (let pii = 0; pii < w; pii++) {
|
|
85
86
|
let virtPii = l + pii;
|
|
86
87
|
let pMin = Infinity;
|
|
@@ -90,24 +91,28 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
90
91
|
for (let ai = 0; ai < framesPerPixel; ai++) {
|
|
91
92
|
let framePos = pixelFramePos + ai;
|
|
92
93
|
let a = 0;
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
94
|
+
let bufPos = framePos - auOffset;
|
|
95
|
+
//let bufPos=framePos;
|
|
96
|
+
if (bufPos >= 0 && bufPos < audioData.length) {
|
|
97
|
+
a = audioData[bufPos];
|
|
98
|
+
//console.debug("W: ch: "+ch+", pixelFramePos: "+pixelFramePos+", framePos: "+framePos+", auOffset: "+auOffset+", bufPos: "+bufPos+", audioData.length: "+audioData.length+", a: "+a);
|
|
99
|
+
if (a < pMin) {
|
|
100
|
+
pMin = a;
|
|
101
|
+
}
|
|
102
|
+
if (a > pMax) {
|
|
103
|
+
pMax = a;
|
|
104
|
+
}
|
|
101
105
|
}
|
|
102
106
|
}
|
|
103
107
|
let psMinPos = ch * w + pii;
|
|
104
108
|
psMinMax[psMinPos] = pMin;
|
|
105
109
|
let psMaxPos = pointsLen + psMinPos;
|
|
106
110
|
psMinMax[psMaxPos] = pMax;
|
|
111
|
+
//console.debug("psMinMax["+psMinPos+"]="+pMin+",psMinMax["+psMaxPos+"]="+pMax);
|
|
107
112
|
}
|
|
108
113
|
}
|
|
109
114
|
}
|
|
110
|
-
postMessage({ psMinMax: psMinMax, l: data.l,
|
|
115
|
+
postMessage({ psMinMax: psMinMax, l: data.l, w: data.w, chs: data.chs, eod: data.eod }, [psMinMax.buffer]);
|
|
111
116
|
});
|
|
112
117
|
}
|
|
113
118
|
startDraw(clear = true) {
|
|
@@ -135,41 +140,143 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
135
140
|
if (this.bounds && this.bounds.dimension) {
|
|
136
141
|
let w = Math.round(this.bounds.dimension.width);
|
|
137
142
|
let h = Math.round(this.bounds.dimension.height);
|
|
138
|
-
if (this.
|
|
143
|
+
if (this._audioDataHolder && w > 0 && h > 0) {
|
|
139
144
|
//this.wo = new Worker('./audiosignal.worker.js',{type: 'module'});
|
|
140
145
|
this.worker = new Worker(this.workerURL);
|
|
141
146
|
//this.wo = new Worker('worker/audiosignal.worker.ts');
|
|
142
147
|
//let Worker = require('worker!../../../workers/uploader/main');
|
|
143
|
-
let chs = this.
|
|
144
|
-
let
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
let
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
//let
|
|
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;
|
|
153
160
|
if (this.worker) {
|
|
154
161
|
this.worker.onmessage = (me) => {
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
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;
|
|
175
|
+
}
|
|
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]);
|
|
193
|
+
}
|
|
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);
|
|
205
|
+
}
|
|
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
|
+
}
|
|
159
226
|
}
|
|
160
|
-
this.worker = null;
|
|
161
227
|
};
|
|
162
228
|
}
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
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);
|
|
264
|
+
for (let ch = 0; ch < chs; ch++) {
|
|
265
|
+
ad.set(arrAbBuf[ch], ch * framesPerPixel);
|
|
266
|
+
}
|
|
267
|
+
this.worker.postMessage({
|
|
268
|
+
l: renderPos,
|
|
269
|
+
w: rw,
|
|
270
|
+
vw: vw,
|
|
271
|
+
chs: chs,
|
|
272
|
+
frameLength: frameLength,
|
|
273
|
+
audioData: ad,
|
|
274
|
+
audioDataOffset: auOffset,
|
|
275
|
+
eod: (read <= 0)
|
|
276
|
+
}, [ad.buffer]);
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
173
280
|
}
|
|
174
281
|
else {
|
|
175
282
|
let g = this.signalCanvas.getContext("2d");
|
|
@@ -179,42 +286,42 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
179
286
|
}
|
|
180
287
|
}
|
|
181
288
|
}
|
|
182
|
-
drawRendered(
|
|
289
|
+
drawRendered(left, w, h, chs, psMinMax) {
|
|
183
290
|
this.drawBg();
|
|
184
|
-
this.signalCanvas.style.left =
|
|
185
|
-
this.signalCanvas.width =
|
|
186
|
-
this.signalCanvas.height =
|
|
291
|
+
this.signalCanvas.style.left = left.toString() + 'px';
|
|
292
|
+
this.signalCanvas.width = w;
|
|
293
|
+
this.signalCanvas.height = h;
|
|
187
294
|
let g = this.signalCanvas.getContext("2d");
|
|
188
295
|
if (g) {
|
|
189
|
-
g.clearRect(0, 0,
|
|
296
|
+
g.clearRect(0, 0, w, h);
|
|
190
297
|
//g.fillStyle = "black";
|
|
191
298
|
//g.fillRect(0, 0, me.data.w, me.data.h);
|
|
192
|
-
let pointsLen =
|
|
299
|
+
let pointsLen = w * chs;
|
|
193
300
|
// one for min one for max
|
|
194
301
|
let arrLen = pointsLen * 2;
|
|
195
|
-
if (this.
|
|
302
|
+
if (this._audioDataHolder) {
|
|
196
303
|
let std = Date.now();
|
|
197
|
-
let chH =
|
|
304
|
+
let chH = h / chs;
|
|
198
305
|
let y = 0;
|
|
199
|
-
for (let ch = 0; ch <
|
|
306
|
+
for (let ch = 0; ch < chs; ch++) {
|
|
200
307
|
let x = 0;
|
|
201
|
-
let psMinPos = ch *
|
|
308
|
+
let psMinPos = ch * w;
|
|
202
309
|
let psMaxPos = pointsLen + psMinPos;
|
|
203
310
|
g.fillStyle = 'green';
|
|
204
311
|
g.strokeStyle = 'green';
|
|
205
312
|
// draw audio signal as single polygon
|
|
206
313
|
g.beginPath();
|
|
207
|
-
g.moveTo(0, y + (chH / 2) +
|
|
208
|
-
for (let pii = 0; pii <
|
|
209
|
-
let psMax =
|
|
314
|
+
g.moveTo(0, y + (chH / 2) + psMinMax[psMaxPos] * chH / 2);
|
|
315
|
+
for (let pii = 0; pii < w; pii++) {
|
|
316
|
+
let psMax = psMinMax[psMaxPos + pii];
|
|
210
317
|
let pv = psMax * chH / 2;
|
|
211
318
|
let yd = y + (chH / 2) - pv;
|
|
212
319
|
//console.log("LineTo: : "+pii+" "+yd)
|
|
213
320
|
g.lineTo(pii, yd);
|
|
214
321
|
}
|
|
215
|
-
let revPixelStart =
|
|
322
|
+
let revPixelStart = w - 1;
|
|
216
323
|
for (let pii = revPixelStart; pii >= 0; pii--) {
|
|
217
|
-
let psMin =
|
|
324
|
+
let psMin = psMinMax[psMinPos + pii];
|
|
218
325
|
let pv = psMin * chH / 2;
|
|
219
326
|
let yd = y + (chH / 2) - pv;
|
|
220
327
|
//console.log("LineTo: : "+pii+" "+yd)
|
|
@@ -238,13 +345,23 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
238
345
|
g.clearRect(0, 0, w, h);
|
|
239
346
|
//g.fillStyle = "black";
|
|
240
347
|
//g.fillRect(0, 0, w, h);
|
|
241
|
-
if (this.
|
|
348
|
+
if (this._audioDataHolder) {
|
|
242
349
|
let std = Date.now();
|
|
243
|
-
let chs = this.
|
|
350
|
+
let chs = this._audioDataHolder.numberOfChannels;
|
|
244
351
|
let chH = h / chs;
|
|
245
|
-
let frameLength = this.
|
|
352
|
+
let frameLength = this._audioDataHolder.frameLen;
|
|
246
353
|
let framesPerPixel = frameLength / w;
|
|
247
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
|
+
}
|
|
248
365
|
for (let ch = 0; ch < chs; ch++) {
|
|
249
366
|
let x = 0;
|
|
250
367
|
let psMin = new Float32Array(w);
|
|
@@ -253,20 +370,33 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
253
370
|
for (let pii = 0; pii < w; pii++) {
|
|
254
371
|
let pMin = 0;
|
|
255
372
|
let pMax = 0;
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
pMin
|
|
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
|
+
}
|
|
262
384
|
}
|
|
263
|
-
|
|
264
|
-
|
|
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
|
+
}
|
|
265
396
|
}
|
|
266
397
|
}
|
|
267
398
|
psMin[pii] = pMin;
|
|
268
399
|
psMax[pii] = pMax;
|
|
269
|
-
//console.log("Min: ", pMin, " max: ", pMax);
|
|
270
400
|
}
|
|
271
401
|
g.fillStyle = 'green';
|
|
272
402
|
g.strokeStyle = 'green';
|
|
@@ -291,12 +421,11 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
291
421
|
g.stroke();
|
|
292
422
|
y += chH;
|
|
293
423
|
}
|
|
294
|
-
//this.drawPlayPosition();
|
|
295
424
|
}
|
|
296
425
|
}
|
|
297
426
|
}
|
|
298
427
|
setData(audioData) {
|
|
299
|
-
this.
|
|
428
|
+
this._audioDataHolder = audioData;
|
|
300
429
|
this.playFramePosition = 0;
|
|
301
430
|
}
|
|
302
431
|
}
|
|
@@ -335,4 +464,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
335
464
|
type: ViewChild,
|
|
336
465
|
args: ['marker', { static: true }]
|
|
337
466
|
}] } });
|
|
338
|
-
//# 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\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  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._audioData = 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;\r\n      let l= data.l;\r\n      let w = data.w;\r\n      let h = data.h;\r\n      let vw = data.vw;\r\n      let chs = data.chs;\r\n      let frameLength = data.frameLength;\r\n      let psMinMax= new Float32Array(0);\r\n\r\n      if(audioData && w>=0 && vw>0) {\r\n\r\n        let framesPerPixel = frameLength / vw;\r\n\r\n        let y = 0;\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        for (let ch = 0; ch < chs; ch++) {\r\n          let x = 0;\r\n\r\n          chFramePos = ch * frameLength;\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\r\n              let a = 0;\r\n              if(framePos>=0 && framePos<audioData.length){\r\n                a=audioData[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\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\r\n          }\r\n\r\n        }\r\n      }\r\n\r\n\r\n      postMessage({psMinMax: psMinMax, l:data.l,t:data.t,w: data.w, h: data.h, chs: data.chs}, [psMinMax.buffer]);\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._audioData && 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._audioData.numberOfChannels;\r\n\r\n        let frameLength = this._audioData.getChannelData(0).length;\r\n        // if(frameLength != this.audioData.getChannelData(1).length){\r\n        //   alert(\"Ungleiche Länge\");\r\n        // }\r\n        let ad = new Float32Array(chs * frameLength);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          ad.set(this._audioData.getChannelData(ch), ch * frameLength);\r\n        }\r\n        //let start = Date.now();\r\n        if (this.worker) {\r\n          this.worker.onmessage = (me) => {\r\n            //console.log(\"As rendertime: \", Date.now() - start);\r\n            this.drawRendered(me);\r\n            if (this.worker) {\r\n              this.worker.terminate();\r\n            }\r\n            this.worker = null;\r\n          }\r\n        }\r\n        this.worker.postMessage({\r\n          l: Math.round(this.bounds.position.left),\r\n          t: Math.round(this.bounds.position.top),\r\n          w: w,\r\n          h: h,\r\n          vw: Math.round(this.virtualDimension.width),\r\n          chs: chs,\r\n          frameLength: frameLength,\r\n          audioData: ad\r\n        }, [ad.buffer]);\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(me: MessageEvent) {\r\n    this.drawBg();\r\n    this.signalCanvas.style.left=me.data.l.toString()+'px';\r\n    this.signalCanvas.width = me.data.w;\r\n    this.signalCanvas.height = me.data.h;\r\n    let g = this.signalCanvas.getContext(\"2d\");\r\n    if (g) {\r\n      g.clearRect(0, 0, me.data.w, me.data.h);\r\n      //g.fillStyle = \"black\";\r\n      //g.fillRect(0, 0, me.data.w, me.data.h);\r\n      let pointsLen = me.data.w * me.data.chs;\r\n      // one for min one for max\r\n      let arrLen = pointsLen * 2;\r\n      if (this._audioData) {\r\n        let std = Date.now();\r\n\r\n        let chH = me.data.h / me.data.chs;\r\n\r\n        let y = 0;\r\n        for (let ch = 0; ch < me.data.chs; ch++) {\r\n          let x = 0;\r\n\r\n          let psMinPos = ch * me.data.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) + me.data.psMinMax[psMaxPos] * chH / 2);\r\n\r\n          for (let pii = 0; pii < me.data.w; pii++) {\r\n            let psMax = me.data.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=me.data.w-1;\r\n\r\n          for (let pii = revPixelStart; pii >= 0; pii--) {\r\n            let psMin = me.data.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._audioData) {\r\n        let std = Date.now();\r\n        let chs = this._audioData.numberOfChannels;\r\n        let chH = h / chs;\r\n\r\n        let frameLength = this._audioData.getChannelData(0).length;\r\n\r\n        let framesPerPixel = frameLength / w;\r\n        let y = 0;\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            // 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 = this._audioData.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            psMin[pii] = pMin;\r\n            psMax[pii] = pMax;\r\n            //console.log(\"Min: \", pMin, \" max: \", pMax);\r\n\r\n          }\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        //this.drawPlayPosition();\r\n      }\r\n    }\r\n  }\r\n\r\n  setData(audioData: AudioBuffer | null) {\r\n    this._audioData = audioData;\r\n    this.playFramePosition = 0;\r\n  }\r\n}\r\n\r\n"]}
|
|
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"]}
|