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.
- package/esm2020/lib/action/action.mjs +2 -1
- package/esm2020/lib/audio/array_audio_buffer.mjs +65 -2
- package/esm2020/lib/audio/array_audio_buffer_input_stream.mjs +2 -2
- package/esm2020/lib/audio/array_audio_buffer_random_access_stream.mjs +16 -0
- package/esm2020/lib/audio/audio_data_holder.mjs +203 -48
- package/esm2020/lib/audio/audio_display.mjs +10 -34
- package/esm2020/lib/audio/audio_player.mjs +18 -45
- package/esm2020/lib/audio/capture/capture.mjs +293 -69
- package/esm2020/lib/audio/dsp/level_measure.mjs +211 -88
- package/esm2020/lib/audio/impl/wavformat.mjs +1 -1
- package/esm2020/lib/audio/impl/wavreader.mjs +134 -0
- package/esm2020/lib/audio/impl/wavwriter.mjs +10 -9
- package/esm2020/lib/audio/inddb_audio_buffer.mjs +508 -0
- package/esm2020/lib/audio/net_audio_buffer.mjs +297 -0
- package/esm2020/lib/audio/persistor.mjs +8 -2
- package/esm2020/lib/audio/playback/array_audio_buffer_source_node.mjs +15 -154
- package/esm2020/lib/audio/playback/audio_source_node.mjs +18 -0
- package/esm2020/lib/audio/playback/audio_source_worklet_module_loader.mjs +167 -0
- package/esm2020/lib/audio/playback/inddb_audio_buffer_source_node.mjs +167 -0
- package/esm2020/lib/audio/playback/net_audio_buffer_source_node.mjs +218 -0
- package/esm2020/lib/audio/playback/player.mjs +190 -171
- package/esm2020/lib/audio/ui/audio_canvas_layer_comp.mjs +35 -76
- package/esm2020/lib/audio/ui/audio_display_control.mjs +12 -24
- package/esm2020/lib/audio/ui/audio_display_scroll_pane.mjs +14 -45
- package/esm2020/lib/audio/ui/audiosignal.mjs +333 -267
- package/esm2020/lib/audio/ui/container.mjs +40 -57
- package/esm2020/lib/audio/ui/livelevel.mjs +53 -52
- package/esm2020/lib/audio/ui/scroll_pane_horizontal.mjs +5 -19
- package/esm2020/lib/audio/ui/sonagram.mjs +386 -339
- package/esm2020/lib/db/inddb.mjs +120 -0
- package/esm2020/lib/io/BinaryReader.mjs +85 -0
- package/esm2020/lib/io/stream.mjs +101 -1
- package/esm2020/lib/net/uploader.mjs +111 -5
- package/esm2020/lib/recorder_component.mjs +59 -1
- package/esm2020/lib/speechrecorder/project/project.mjs +10 -1
- package/esm2020/lib/speechrecorder/project/project.service.mjs +3 -3
- package/esm2020/lib/speechrecorder/recording.mjs +30 -6
- package/esm2020/lib/speechrecorder/recordings/basic_recording.service.mjs +213 -0
- package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +732 -65
- package/esm2020/lib/speechrecorder/script/script.service.mjs +3 -3
- package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +358 -184
- package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +181 -28
- package/esm2020/lib/speechrecorder/session/controlpanel.mjs +47 -129
- package/esm2020/lib/speechrecorder/session/item.mjs +13 -1
- package/esm2020/lib/speechrecorder/session/progress.mjs +26 -55
- package/esm2020/lib/speechrecorder/session/prompting.mjs +33 -176
- package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +6 -6
- package/esm2020/lib/speechrecorder/session/recording_file_cache.mjs +28 -15
- package/esm2020/lib/speechrecorder/session/recording_list.mjs +92 -55
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +9 -13
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +9 -18
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +10 -36
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +10 -37
- package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +80 -56
- package/esm2020/lib/speechrecorder/session/session.service.mjs +3 -3
- package/esm2020/lib/speechrecorder/session/session_finished_dialog.mjs +4 -4
- package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +409 -165
- package/esm2020/lib/speechrecorder/session/warning_bar.mjs +6 -29
- package/esm2020/lib/speechrecorder/spruploader.mjs +3 -3
- package/esm2020/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +6 -41
- package/esm2020/lib/speechrecorderng.component.mjs +42 -31
- package/esm2020/lib/speechrecorderng.module.mjs +5 -5
- package/esm2020/lib/spr.config.mjs +3 -3
- package/esm2020/lib/spr.module.version.mjs +2 -2
- package/esm2020/lib/ui/canvas_layer_comp.mjs +3 -3
- package/esm2020/lib/ui/message_dialog.mjs +7 -7
- package/esm2020/lib/ui/recordingitem_display.mjs +26 -59
- package/esm2020/lib/utils/scrollIntoViewToBottom.mjs +3 -3
- package/esm2020/lib/utils/ua-parser.mjs +28 -4
- package/esm2020/lib/utils/utils.mjs +29 -1
- package/fesm2015/speechrecorderng.mjs +12755 -9195
- package/fesm2015/speechrecorderng.mjs.map +1 -1
- package/fesm2020/speechrecorderng.mjs +12652 -9101
- package/fesm2020/speechrecorderng.mjs.map +1 -1
- package/{speechrecorderng.d.ts → index.d.ts} +0 -0
- package/lib/audio/array_audio_buffer.d.ts +17 -1
- package/lib/audio/array_audio_buffer_random_access_stream.d.ts +9 -0
- package/lib/audio/audio_data_holder.d.ts +69 -14
- package/lib/audio/audio_display.d.ts +1 -1
- package/lib/audio/audio_player.d.ts +3 -7
- package/lib/audio/capture/capture.d.ts +24 -4
- package/lib/audio/dsp/level_measure.d.ts +2 -23
- package/lib/audio/impl/wavformat.d.ts +3 -3
- package/lib/audio/impl/wavreader.d.ts +16 -0
- package/lib/audio/impl/wavwriter.d.ts +1 -4
- package/lib/audio/inddb_audio_buffer.d.ts +68 -0
- package/lib/audio/net_audio_buffer.d.ts +59 -0
- package/lib/audio/persistor.d.ts +3 -9
- package/lib/audio/playback/array_audio_buffer_source_node.d.ts +2 -8
- package/lib/audio/playback/audio_source_node.d.ts +10 -0
- package/lib/audio/playback/audio_source_worklet_module_loader.d.ts +4 -0
- package/lib/audio/playback/inddb_audio_buffer_source_node.d.ts +21 -0
- package/lib/audio/playback/net_audio_buffer_source_node.d.ts +27 -0
- package/lib/audio/playback/player.d.ts +19 -16
- package/lib/audio/ui/audio_canvas_layer_comp.d.ts +3 -3
- package/lib/audio/ui/audio_display_control.d.ts +3 -6
- package/lib/audio/ui/audio_display_scroll_pane.d.ts +1 -1
- package/lib/audio/ui/audiosignal.d.ts +4 -3
- package/lib/audio/ui/container.d.ts +1 -1
- package/lib/audio/ui/livelevel.d.ts +11 -4
- package/lib/audio/ui/scroll_pane_horizontal.d.ts +1 -1
- package/lib/audio/ui/sonagram.d.ts +4 -3
- package/lib/db/inddb.d.ts +21 -0
- package/lib/io/BinaryReader.d.ts +18 -0
- package/lib/io/stream.d.ts +18 -0
- package/lib/net/uploader.d.ts +20 -2
- package/lib/recorder_component.d.ts +5 -0
- package/lib/speechrecorder/project/project.d.ts +9 -0
- package/lib/speechrecorder/recording.d.ts +8 -2
- package/lib/speechrecorder/recordings/basic_recording.service.d.ts +27 -0
- package/lib/speechrecorder/recordings/recordings.service.d.ts +21 -6
- package/lib/speechrecorder/session/audiorecorder.d.ts +7 -18
- package/lib/speechrecorder/session/basicrecorder.d.ts +28 -4
- package/lib/speechrecorder/session/controlpanel.d.ts +7 -7
- package/lib/speechrecorder/session/item.d.ts +1 -0
- package/lib/speechrecorder/session/progress.d.ts +2 -1
- package/lib/speechrecorder/session/prompting.d.ts +5 -5
- package/lib/speechrecorder/session/recorder_combi_pane.d.ts +1 -1
- package/lib/speechrecorder/session/recording_file_cache.d.ts +7 -4
- package/lib/speechrecorder/session/recording_list.d.ts +2 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +1 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-navi.component.d.ts +1 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.d.ts +1 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-view.component.d.ts +1 -1
- package/lib/speechrecorder/session/recordingfile/recordingfile-service.d.ts +4 -5
- package/lib/speechrecorder/session/session_finished_dialog.d.ts +1 -1
- package/lib/speechrecorder/session/sessionmanager.d.ts +10 -10
- package/lib/speechrecorder/session/warning_bar.d.ts +1 -1
- package/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.d.ts +1 -1
- package/lib/speechrecorderng.component.d.ts +2 -1
- package/lib/spr.module.version.d.ts +1 -1
- package/lib/ui/canvas_layer_comp.d.ts +1 -1
- package/lib/ui/message_dialog.d.ts +1 -1
- package/lib/ui/recordingitem_display.d.ts +3 -2
- package/lib/utils/scrollIntoViewToBottom.d.ts +1 -1
- package/lib/utils/ua-parser.d.ts +4 -1
- package/lib/utils/utils.d.ts +6 -0
- package/package.json +5 -4
- package/esm2020/lib/math/utils.mjs +0 -14
- package/esm2020/lib/utils/css_utils.mjs +0 -7
- package/lib/math/utils.d.ts +0 -3
- 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
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
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
|
-
|
|
77
|
-
|
|
78
|
+
const framesPerPixel = frameLength / vw;
|
|
79
|
+
const pointsLen = w * chs;
|
|
78
80
|
// one for min one for max
|
|
79
|
-
|
|
81
|
+
const arrLen = pointsLen * 2;
|
|
80
82
|
psMinMax = new Float32Array(arrLen);
|
|
81
83
|
let chFramePos = 0;
|
|
82
|
-
|
|
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
|
-
|
|
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
|
-
|
|
94
|
+
const framePos = pixelFramePos + ai;
|
|
93
95
|
let a = 0;
|
|
94
|
-
|
|
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
|
-
|
|
109
|
+
const psMinPos = ch * w + pii;
|
|
108
110
|
psMinMax[psMinPos] = pMin;
|
|
109
|
-
|
|
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.
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
this.
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
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
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
let
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
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
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
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
|
-
|
|
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
|
-
|
|
230
|
-
|
|
231
|
-
|
|
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(
|
|
275
|
+
ad.set(audioBuffer.getChannelData(ch), ch * frameLength);
|
|
266
276
|
}
|
|
267
277
|
this.worker.postMessage({
|
|
268
|
-
l:
|
|
269
|
-
w:
|
|
278
|
+
l: leftPos,
|
|
279
|
+
w: w,
|
|
270
280
|
vw: vw,
|
|
271
281
|
chs: chs,
|
|
272
282
|
frameLength: frameLength,
|
|
273
283
|
audioData: ad,
|
|
274
|
-
audioDataOffset:
|
|
275
|
-
eod:
|
|
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
|
-
|
|
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
|
-
|
|
370
|
+
//const arrLen = pointsLen * 2;
|
|
302
371
|
if (this._audioDataHolder) {
|
|
303
|
-
|
|
304
|
-
|
|
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
|
-
|
|
308
|
-
|
|
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
|
-
|
|
317
|
-
|
|
318
|
-
|
|
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
|
-
|
|
390
|
+
const revPixelStart = w - 1;
|
|
323
391
|
for (let pii = revPixelStart; pii >= 0; pii--) {
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
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: "
|
|
433
|
-
AudioSignal.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
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: "
|
|
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"]}
|