speechrecorderng 3.9.10 → 3.10.1
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/README.md +1 -1
- package/esm2022/lib/audio/audio_display.mjs +3 -3
- package/esm2022/lib/audio/audio_player.mjs +3 -3
- package/esm2022/lib/audio/format.mjs +6 -3
- package/esm2022/lib/audio/impl/wavformat.mjs +2 -1
- package/esm2022/lib/audio/impl/wavreader.mjs +17 -7
- package/esm2022/lib/audio/impl/wavwriter.mjs +118 -32
- package/esm2022/lib/audio/ui/audio_canvas_layer_comp.mjs +6 -6
- package/esm2022/lib/audio/ui/audio_display_control.mjs +3 -3
- package/esm2022/lib/audio/ui/audio_display_scroll_pane.mjs +3 -3
- package/esm2022/lib/audio/ui/audiosignal.mjs +3 -3
- package/esm2022/lib/audio/ui/container.mjs +3 -3
- package/esm2022/lib/audio/ui/livelevel.mjs +3 -3
- package/esm2022/lib/audio/ui/scroll_pane_horizontal.mjs +3 -3
- package/esm2022/lib/audio/ui/sonagram.mjs +3 -3
- package/esm2022/lib/db/inddb.mjs +3 -3
- package/esm2022/lib/io/BinaryReader.mjs +9 -1
- package/esm2022/lib/io/BinaryWriter.mjs +7 -1
- package/esm2022/lib/speechrecorder/project/project.mjs +6 -1
- package/esm2022/lib/speechrecorder/project/project.service.mjs +3 -3
- package/esm2022/lib/speechrecorder/recordings/recordings.service.mjs +3 -3
- package/esm2022/lib/speechrecorder/script/script.service.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/audiorecorder.mjs +11 -11
- package/esm2022/lib/speechrecorder/session/basicrecorder.mjs +8 -1
- package/esm2022/lib/speechrecorder/session/controlpanel.mjs +21 -21
- package/esm2022/lib/speechrecorder/session/progress.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/prompting.mjs +15 -15
- package/esm2022/lib/speechrecorder/session/recorder_combi_pane.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/recording_list.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/session.service.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/session_finished_dialog.mjs +3 -3
- package/esm2022/lib/speechrecorder/session/sessionmanager.mjs +9 -10
- package/esm2022/lib/speechrecorder/session/warning_bar.mjs +3 -3
- package/esm2022/lib/speechrecorder/spruploader.mjs +3 -3
- package/esm2022/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +3 -3
- package/esm2022/lib/speechrecorderng.component.mjs +5 -4
- package/esm2022/lib/speechrecorderng.module.mjs +4 -4
- package/esm2022/lib/spr.config.mjs +3 -3
- package/esm2022/lib/spr.module.version.mjs +2 -2
- package/esm2022/lib/ui/canvas_layer_comp.mjs +3 -3
- package/esm2022/lib/ui/intersection-observer.directive.mjs +3 -3
- package/esm2022/lib/ui/message_dialog.mjs +3 -3
- package/esm2022/lib/ui/recordingitem_display.mjs +6 -6
- package/esm2022/lib/ui/responsive_component.mjs +3 -3
- package/esm2022/lib/utils/scrollIntoViewToBottom.mjs +3 -3
- package/fesm2022/speechrecorderng.mjs +334 -207
- package/fesm2022/speechrecorderng.mjs.map +1 -1
- package/lib/audio/format.d.ts +2 -1
- package/lib/audio/impl/wavformat.d.ts +1 -0
- package/lib/audio/impl/wavwriter.d.ts +11 -2
- package/lib/io/BinaryReader.d.ts +1 -0
- package/lib/io/BinaryWriter.d.ts +1 -0
- package/lib/speechrecorder/project/project.d.ts +10 -0
- package/lib/speechrecorder/session/basicrecorder.d.ts +6 -2
- package/lib/speechrecorder/session/sessionmanager.d.ts +1 -1
- package/lib/spr.module.version.d.ts +1 -1
- package/package.json +12 -12
package/README.md
CHANGED
|
@@ -9,7 +9,7 @@ For backwards compatibility to server REST API v1 set the property `apiVersion:
|
|
|
9
9
|
|
|
10
10
|
### Install NPM package
|
|
11
11
|
Speechrecorder module is available as NPM package.
|
|
12
|
-
Add `"speechrecorderng": "3.
|
|
12
|
+
Add `"speechrecorderng": "3.10.0"` to the `dependencies` array property in the `package.json` file of your application. Run `npm install` to install the package.
|
|
13
13
|
### Module integration
|
|
14
14
|
Add SpeechRecorderNg module to imports property of your `AppModule` annotation. The module main component `SpeechRecorder` should be activated by an Angular route.
|
|
15
15
|
|
|
@@ -67,8 +67,8 @@ export class AudioDisplay {
|
|
|
67
67
|
error() {
|
|
68
68
|
this.status = 'ERROR';
|
|
69
69
|
}
|
|
70
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.
|
|
70
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplay, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: AudioDisplay, selector: "app-audiodisplay", inputs: { playStartAction: "playStartAction", playStopAction: "playStopAction", playSelectionAction: "playSelectionAction", autoPlayOnSelectToggleAction: "autoPlayOnSelectToggleAction", audioData: "audioData", audioClip: "audioClip" }, viewQueries: [{ propertyName: "audioDisplayScrollPane", first: true, predicate: AudioDisplayScrollPane, descendants: true, static: true }], ngImport: i0, template: `
|
|
72
72
|
|
|
73
73
|
<audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
|
|
74
74
|
|
|
@@ -83,7 +83,7 @@ export class AudioDisplay {
|
|
|
83
83
|
[zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control>
|
|
84
84
|
`, isInline: true, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0;height:100%;width:100%;overflow:hidden;padding:20px;z-index:5;box-sizing:border-box;background-color:#e6e6e6}\n", "legend{margin-left:1em;padding:.2em .8em;font-size:.8em}\n", "fieldset{border:1px darkgray solid}\n"], dependencies: [{ kind: "component", type: i1.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { kind: "component", type: i2.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] }); }
|
|
85
85
|
}
|
|
86
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplay, decorators: [{
|
|
87
87
|
type: Component,
|
|
88
88
|
args: [{ selector: 'app-audiodisplay', template: `
|
|
89
89
|
|
|
@@ -187,8 +187,8 @@ export class AudioDisplayPlayer {
|
|
|
187
187
|
error() {
|
|
188
188
|
this.status = 'ERROR';
|
|
189
189
|
}
|
|
190
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
191
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.
|
|
190
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplayPlayer, deps: [{ token: i1.ActivatedRoute }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
191
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: AudioDisplayPlayer, selector: "app-audiodisplayplayer", inputs: { playStartAction: "playStartAction", playStopAction: "playStopAction", playSelectionAction: "playSelectionAction", autoPlayOnSelectToggleAction: "autoPlayOnSelectToggleAction", audioData: "audioData", audioClip: "audioClip" }, viewQueries: [{ propertyName: "audioDisplayScrollPane", first: true, predicate: AudioDisplayScrollPane, descendants: true, static: true }], ngImport: i0, template: `
|
|
192
192
|
|
|
193
193
|
<audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
|
|
194
194
|
|
|
@@ -203,7 +203,7 @@ export class AudioDisplayPlayer {
|
|
|
203
203
|
[zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control><p>{{status}}
|
|
204
204
|
`, isInline: true, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0;height:100%;width:100%;overflow:hidden;padding:20px;z-index:5;box-sizing:border-box;background-color:#000000bf}\n"], dependencies: [{ kind: "component", type: i2.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { kind: "component", type: i3.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] }); }
|
|
205
205
|
}
|
|
206
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
206
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplayPlayer, decorators: [{
|
|
207
207
|
type: Component,
|
|
208
208
|
args: [{ selector: 'app-audiodisplayplayer', template: `
|
|
209
209
|
|
|
@@ -5,13 +5,16 @@ export class AudioFormat {
|
|
|
5
5
|
}
|
|
6
6
|
}
|
|
7
7
|
export class PCMAudioFormat extends AudioFormat {
|
|
8
|
-
constructor(sampleRate, channelCount, sampleSize, sampleSizeInBits) {
|
|
8
|
+
constructor(sampleRate, channelCount, sampleSize, sampleSizeInBits, encodingFloat = false) {
|
|
9
9
|
super(sampleRate, channelCount);
|
|
10
|
+
this.encodingFloat = false;
|
|
10
11
|
this.sampleSize = sampleSize;
|
|
11
12
|
this.sampleSizeInBits = sampleSizeInBits;
|
|
13
|
+
this.encodingFloat = encodingFloat;
|
|
12
14
|
}
|
|
13
15
|
toString() {
|
|
14
|
-
|
|
16
|
+
const encStr = this.encodingFloat ? 'Encoding: float,' : '';
|
|
17
|
+
return 'Audio format: PCM,' + encStr + this.sampleRate + ' Hz,' + this.channelCount + ' channels, ' + this.sampleSizeInBits + ' bits';
|
|
15
18
|
}
|
|
16
19
|
}
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL2Zvcm1hdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDSSxNQUFNLE9BQU8sV0FBVztJQUdwQixZQUFZLFVBQWtCLEVBQUUsWUFBb0I7UUFDaEQsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7UUFDN0IsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDckMsQ0FBQztDQUNKO0FBRUQsTUFBTSxPQUFPLGNBQWUsU0FBUSxXQUFXO0lBSTNDLFlBQVksVUFBa0IsRUFBRSxZQUFvQixFQUFFLFVBQWtCLEVBQUUsZ0JBQXdCLEVBQUMsYUFBYSxHQUFDLEtBQUs7UUFDbEgsS0FBSyxDQUFDLFVBQVUsRUFBRSxZQUFZLENBQUMsQ0FBQztRQUpwQyxrQkFBYSxHQUFTLEtBQUssQ0FBQztRQUt4QixJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztRQUM3QixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsZ0JBQWdCLENBQUM7UUFDekMsSUFBSSxDQUFDLGFBQWEsR0FBQyxhQUFhLENBQUM7SUFDckMsQ0FBQztJQUVELFFBQVE7UUFDSixNQUFNLE1BQU0sR0FBQyxJQUFJLENBQUMsYUFBYSxDQUFBLENBQUMsQ0FBQSxrQkFBa0IsQ0FBQSxDQUFDLENBQUEsRUFBRSxDQUFDO1FBRXRELE9BQU8sb0JBQW9CLEdBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxHQUFHLElBQUksQ0FBQyxZQUFZLEdBQUcsYUFBYSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxPQUFPLENBQUM7SUFDeEksQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbiAgICBleHBvcnQgY2xhc3MgQXVkaW9Gb3JtYXQge1xyXG4gICAgICAgIHNhbXBsZVJhdGU6IG51bWJlcjtcclxuICAgICAgICBjaGFubmVsQ291bnQ6IG51bWJlcjtcclxuICAgICAgICBjb25zdHJ1Y3RvcihzYW1wbGVSYXRlOiBudW1iZXIsIGNoYW5uZWxDb3VudDogbnVtYmVyKSB7XHJcbiAgICAgICAgICAgIHRoaXMuc2FtcGxlUmF0ZSA9IHNhbXBsZVJhdGU7XHJcbiAgICAgICAgICAgIHRoaXMuY2hhbm5lbENvdW50ID0gY2hhbm5lbENvdW50O1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBleHBvcnQgY2xhc3MgUENNQXVkaW9Gb3JtYXQgZXh0ZW5kcyBBdWRpb0Zvcm1hdCB7XHJcbiAgICAgICAgZW5jb2RpbmdGbG9hdDpib29sZWFuPWZhbHNlO1xyXG4gICAgICAgIHNhbXBsZVNpemU6IG51bWJlcjtcclxuICAgICAgICBzYW1wbGVTaXplSW5CaXRzOiBudW1iZXI7XHJcbiAgICAgICAgY29uc3RydWN0b3Ioc2FtcGxlUmF0ZTogbnVtYmVyLCBjaGFubmVsQ291bnQ6IG51bWJlciwgc2FtcGxlU2l6ZTogbnVtYmVyLCBzYW1wbGVTaXplSW5CaXRzOiBudW1iZXIsZW5jb2RpbmdGbG9hdD1mYWxzZSkge1xyXG4gICAgICAgICAgICBzdXBlcihzYW1wbGVSYXRlLCBjaGFubmVsQ291bnQpO1xyXG4gICAgICAgICAgICB0aGlzLnNhbXBsZVNpemUgPSBzYW1wbGVTaXplO1xyXG4gICAgICAgICAgICB0aGlzLnNhbXBsZVNpemVJbkJpdHMgPSBzYW1wbGVTaXplSW5CaXRzO1xyXG4gICAgICAgICAgICB0aGlzLmVuY29kaW5nRmxvYXQ9ZW5jb2RpbmdGbG9hdDtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHRvU3RyaW5nKCk6IHN0cmluZyB7XHJcbiAgICAgICAgICAgIGNvbnN0IGVuY1N0cj10aGlzLmVuY29kaW5nRmxvYXQ/J0VuY29kaW5nOiBmbG9hdCwnOicnO1xyXG5cclxuICAgICAgICAgICAgcmV0dXJuICdBdWRpbyBmb3JtYXQ6IFBDTSwnK2VuY1N0ciArIHRoaXMuc2FtcGxlUmF0ZSArICcgSHosJyArIHRoaXMuY2hhbm5lbENvdW50ICsgJyBjaGFubmVscywgJyArIHRoaXMuc2FtcGxlU2l6ZUluQml0cyArICcgYml0cyc7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuIl19
|
|
@@ -2,5 +2,6 @@ export class WavFileFormat {
|
|
|
2
2
|
static { this.RIFF_KEY = 'RIFF'; }
|
|
3
3
|
static { this.WAV_KEY = 'WAVE'; }
|
|
4
4
|
static { this.PCM = 0x0001; }
|
|
5
|
+
static { this.WAVE_FORMAT_IEEE_FLOAT = 0x0003; }
|
|
5
6
|
}
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F2Zm9ybWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL2ltcGwvd2F2Zm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVFLE1BQU0sT0FBTyxhQUFhO2FBQ04sYUFBUSxHQUFVLE1BQU0sQ0FBQzthQUN6QixZQUFPLEdBQVUsTUFBTSxDQUFDO2FBQ3hCLFFBQUcsR0FBVyxNQUFNLENBQUM7YUFDckIsMkJBQXNCLEdBQVUsTUFBTSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXHJcblxyXG4gIGV4cG9ydCBjbGFzcyBXYXZGaWxlRm9ybWF0IHtcclxuICAgICAgc3RhdGljIHJlYWRvbmx5IFJJRkZfS0VZOnN0cmluZyA9ICdSSUZGJztcclxuICAgICAgc3RhdGljIHJlYWRvbmx5IFdBVl9LRVk6c3RyaW5nID0gJ1dBVkUnO1xyXG4gICAgICBzdGF0aWMgcmVhZG9ubHkgUENNOm51bWJlciA9ICAweDAwMDE7XHJcbiAgICAgIHN0YXRpYyByZWFkb25seSBXQVZFX0ZPUk1BVF9JRUVFX0ZMT0FUOm51bWJlciA9IDB4MDAwMztcclxuICAgIH1cclxuXHJcblxyXG5cclxuXHJcbiJdfQ==
|
|
@@ -98,7 +98,7 @@ export class WavReader {
|
|
|
98
98
|
parseFmtChunk() {
|
|
99
99
|
let pcmAf = null;
|
|
100
100
|
const fmt = this.br.readUint16LE();
|
|
101
|
-
if (fmt === WavFileFormat.PCM) {
|
|
101
|
+
if (fmt === WavFileFormat.PCM || fmt == WavFileFormat.WAVE_FORMAT_IEEE_FLOAT) {
|
|
102
102
|
const channels = this.br.readUint16LE();
|
|
103
103
|
const sampleRate = this.br.readUint32LE();
|
|
104
104
|
// skip bandwidth
|
|
@@ -107,7 +107,7 @@ export class WavReader {
|
|
|
107
107
|
const frameSize = this.br.readUint16LE();
|
|
108
108
|
// sample size in bits (PCM format only)
|
|
109
109
|
const sampleSizeInBits = this.br.readUint16LE();
|
|
110
|
-
pcmAf = new PCMAudioFormat(sampleRate, channels, frameSize / channels, sampleSizeInBits);
|
|
110
|
+
pcmAf = new PCMAudioFormat(sampleRate, channels, frameSize / channels, sampleSizeInBits, (fmt === WavFileFormat.WAVE_FORMAT_IEEE_FLOAT));
|
|
111
111
|
}
|
|
112
112
|
return pcmAf;
|
|
113
113
|
}
|
|
@@ -119,11 +119,21 @@ export class WavReader {
|
|
|
119
119
|
for (let ch = 0; ch < this.format.channelCount; ch++) {
|
|
120
120
|
chsArr[ch] = new Float32Array(sampleCount);
|
|
121
121
|
}
|
|
122
|
-
if (this.format.
|
|
123
|
-
|
|
122
|
+
if (this.format.encodingFloat) {
|
|
123
|
+
// Not tested yet!
|
|
124
|
+
for (let i = 0; i < this.totalLength / 4; i++) {
|
|
124
125
|
for (let ch = 0; ch < this.format.channelCount; ch++) {
|
|
125
|
-
|
|
126
|
-
|
|
126
|
+
chsArr[ch][i] = this.br.readFloat32();
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
if (this.format.sampleSize == 2) {
|
|
132
|
+
for (let i = 0; i < this.totalLength / 2; i++) {
|
|
133
|
+
for (let ch = 0; ch < this.format.channelCount; ch++) {
|
|
134
|
+
const s16Ampl = this.br.readInt16LE();
|
|
135
|
+
chsArr[ch][i] = s16Ampl / 32768;
|
|
136
|
+
}
|
|
127
137
|
}
|
|
128
138
|
}
|
|
129
139
|
}
|
|
@@ -131,4 +141,4 @@ export class WavReader {
|
|
|
131
141
|
return chsArr;
|
|
132
142
|
}
|
|
133
143
|
}
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wavreader.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/impl/wavreader.ts"],"names":[],"mappings":"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","sourcesContent":["import { WavFileFormat } from './wavformat'\r\nimport { PCMAudioFormat } from '../format'\r\nimport { BinaryByteReader } from '../../io/BinaryReader'\r\n\r\n    export class WavReader {\r\n\r\n        private br:BinaryByteReader;\r\n        private format:PCMAudioFormat | null=null;\r\n        private totalLength:number=0;\r\n        private dataChunkLength:number|null=null;\r\n\r\n        constructor(data:ArrayBuffer) {\r\n            this.br = new BinaryByteReader(data);\r\n        }\r\n\r\n        private readHeader(){\r\n            const rh = this.br.readAscii(4);\r\n            if (rh !== WavFileFormat.RIFF_KEY) {\r\n                const errMsg=\"Expected RIFF header, not: \"+ rh;\r\n                throw new Error(errMsg);\r\n            }\r\n            const cl = this.br.readUint32LE();\r\n            if (this.br.pos + cl !== this.br.length()) {\r\n                throw new Error(\"Wrong chunksize in RIFF header: \"+cl+\" (expected: \"+(this.br.length() - this.br.pos)+ \" )\");\r\n            }\r\n            this.totalLength = cl;\r\n\r\n            const rt = this.br.readAscii(4);\r\n            if (rt !== WavFileFormat.WAV_KEY) {\r\n                const errMsg=\"Expected \"+WavFileFormat.WAV_KEY+\" not: \"+ rt;\r\n                throw new Error(errMsg);\r\n            }\r\n        }\r\n\r\n        readFormat():PCMAudioFormat|null{\r\n            this.br.pos=0;\r\n            this.readHeader();\r\n          const s = this.navigateToChunk('fmt ');\r\n          if (!s) {\r\n            let errMsg=\"WAV file does not contain a fmt chunk\";\r\n            throw new Error(errMsg);\r\n          }\r\n            this.format = this.parseFmtChunk();\r\n            return this.format;\r\n        }\r\n\r\n        private _frameLength():number|null{\r\n          let fl:number|null=null;\r\n          if(this.format && this.dataChunkLength!=null) {\r\n            fl = this.dataChunkLength / this.format.channelCount / this.format.sampleSize;\r\n          }\r\n          return fl;\r\n        }\r\n\r\n        frameLength():number|null {\r\n          let fl:number|null=this._frameLength();\r\n          if(fl===null){\r\n            this.readFormat();\r\n            this.dataChunkLength=this.navigateToChunk('data');\r\n            fl=this._frameLength();\r\n          }\r\n          return fl;\r\n        }\r\n\r\n        // Not tested yet!!!\r\n        read():AudioBuffer | null{\r\n            this.br.pos=0;\r\n            let ab:AudioBuffer|null=null;\r\n            this.readHeader();\r\n            let s = this.navigateToChunk('fmt ');\r\n            if (!s) {\r\n                let errMsg=\"WAV file does not contain a fmt chunk\";\r\n                throw new Error(errMsg);\r\n            }\r\n            this.format = this.parseFmtChunk();\r\n            this.dataChunkLength = this.navigateToChunk('data');\r\n            let chsArr = this.readData();\r\n            let sr=this.format?.sampleRate;\r\n            let nChs=this.format?.channelCount;\r\n            if(sr && chsArr && nChs && nChs>0 && nChs==chsArr?.length) {\r\n                ab = new AudioBuffer({\r\n                    length: chsArr[0].length,\r\n                    numberOfChannels: this.format?.channelCount,\r\n                    sampleRate: sr\r\n                });\r\n                for(let ch=0;ch<nChs;ch++) {\r\n                    ab.copyToChannel(chsArr[ch], ch);\r\n                }\r\n            }\r\n            return ab;\r\n        }\r\n\r\n        private navigateToChunk(chunkString:string):number {\r\n            // position after RIFF header\r\n          // TODO assumes no other chunks except 'data'\r\n            this.br.pos = 12;\r\n            let chkStr = null;\r\n            let chkLen = -1;\r\n            while (!this.br.eof()) {\r\n                chkStr = this.br.readAscii(4);\r\n                chkLen = this.br.readUint32LE();\r\n                if (chunkString === chkStr) {\r\n                    return chkLen;\r\n                }\r\n                this.br.pos += chkLen;\r\n            }\r\n            return chkLen;\r\n        }\r\n\r\n        private parseFmtChunk():PCMAudioFormat | null {\r\n            let pcmAf:PCMAudioFormat|null=null;\r\n            const fmt = this.br.readUint16LE();\r\n            if (fmt === WavFileFormat.PCM) {\r\n                const channels = this.br.readUint16LE();\r\n                const sampleRate = this.br.readUint32LE();\r\n\r\n                // skip bandwidth\r\n                this.br.skip(4);\r\n\r\n                // frame size\r\n                const frameSize = this.br.readUint16LE();\r\n\r\n                // sample size in bits (PCM format only)\r\n                const sampleSizeInBits = this.br.readUint16LE();\r\n\r\n                pcmAf=new PCMAudioFormat(sampleRate, channels, frameSize / channels, sampleSizeInBits);\r\n            }\r\n            return pcmAf;\r\n        }\r\n\r\n        private readData():Array<Float32Array> | null{\r\n            let chsArr=null;\r\n            if(this.format) {\r\n              chsArr = new Array<Float32Array>(this.format.channelCount);\r\n              const sampleCount = this.totalLength / this.format.channelCount / this.format.sampleSize;\r\n              for (let ch = 0; ch < this.format.channelCount; ch++) {\r\n                chsArr[ch] = new Float32Array(sampleCount);\r\n              }\r\n              if (this.format.sampleSize == 2) {\r\n                for (let i = 0; i < this.totalLength / 2; i++) {\r\n                  for (let ch = 0; ch < this.format.channelCount; ch++) {\r\n                    const s16Ampl = this.br.readInt16LE();\r\n                    chsArr[ch][i] = s16Ampl / 32768;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n            return chsArr;\r\n        }\r\n    }\r\n\r\n\r\n\r\n\r\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wavreader.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/impl/wavreader.ts"],"names":[],"mappings":"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","sourcesContent":["import { WavFileFormat } from './wavformat'\r\nimport { PCMAudioFormat } from '../format'\r\nimport { BinaryByteReader } from '../../io/BinaryReader'\r\n\r\n    export class WavReader {\r\n\r\n        private br:BinaryByteReader;\r\n        private format:PCMAudioFormat | null=null;\r\n        private totalLength:number=0;\r\n        private dataChunkLength:number|null=null;\r\n\r\n        constructor(data:ArrayBuffer) {\r\n            this.br = new BinaryByteReader(data);\r\n        }\r\n\r\n        private readHeader(){\r\n            const rh = this.br.readAscii(4);\r\n            if (rh !== WavFileFormat.RIFF_KEY) {\r\n                const errMsg=\"Expected RIFF header, not: \"+ rh;\r\n                throw new Error(errMsg);\r\n            }\r\n            const cl = this.br.readUint32LE();\r\n            if (this.br.pos + cl !== this.br.length()) {\r\n                throw new Error(\"Wrong chunksize in RIFF header: \"+cl+\" (expected: \"+(this.br.length() - this.br.pos)+ \" )\");\r\n            }\r\n            this.totalLength = cl;\r\n\r\n            const rt = this.br.readAscii(4);\r\n            if (rt !== WavFileFormat.WAV_KEY) {\r\n                const errMsg=\"Expected \"+WavFileFormat.WAV_KEY+\" not: \"+ rt;\r\n                throw new Error(errMsg);\r\n            }\r\n        }\r\n\r\n        readFormat():PCMAudioFormat|null{\r\n            this.br.pos=0;\r\n            this.readHeader();\r\n          const s = this.navigateToChunk('fmt ');\r\n          if (!s) {\r\n            let errMsg=\"WAV file does not contain a fmt chunk\";\r\n            throw new Error(errMsg);\r\n          }\r\n            this.format = this.parseFmtChunk();\r\n            return this.format;\r\n        }\r\n\r\n        private _frameLength():number|null{\r\n          let fl:number|null=null;\r\n          if(this.format && this.dataChunkLength!=null) {\r\n            fl = this.dataChunkLength / this.format.channelCount / this.format.sampleSize;\r\n          }\r\n          return fl;\r\n        }\r\n\r\n        frameLength():number|null {\r\n          let fl:number|null=this._frameLength();\r\n          if(fl===null){\r\n            this.readFormat();\r\n            this.dataChunkLength=this.navigateToChunk('data');\r\n            fl=this._frameLength();\r\n          }\r\n          return fl;\r\n        }\r\n\r\n        // Not tested yet!!!\r\n        read():AudioBuffer | null{\r\n            this.br.pos=0;\r\n            let ab:AudioBuffer|null=null;\r\n            this.readHeader();\r\n            let s = this.navigateToChunk('fmt ');\r\n            if (!s) {\r\n                let errMsg=\"WAV file does not contain a fmt chunk\";\r\n                throw new Error(errMsg);\r\n            }\r\n            this.format = this.parseFmtChunk();\r\n            this.dataChunkLength = this.navigateToChunk('data');\r\n            let chsArr = this.readData();\r\n            let sr=this.format?.sampleRate;\r\n            let nChs=this.format?.channelCount;\r\n            if(sr && chsArr && nChs && nChs>0 && nChs==chsArr?.length) {\r\n                ab = new AudioBuffer({\r\n                    length: chsArr[0].length,\r\n                    numberOfChannels: this.format?.channelCount,\r\n                    sampleRate: sr\r\n                });\r\n                for(let ch=0;ch<nChs;ch++) {\r\n                    ab.copyToChannel(chsArr[ch], ch);\r\n                }\r\n            }\r\n            return ab;\r\n        }\r\n\r\n        private navigateToChunk(chunkString:string):number {\r\n            // position after RIFF header\r\n          // TODO assumes no other chunks except 'data'\r\n            this.br.pos = 12;\r\n            let chkStr = null;\r\n            let chkLen = -1;\r\n            while (!this.br.eof()) {\r\n                chkStr = this.br.readAscii(4);\r\n                chkLen = this.br.readUint32LE();\r\n                if (chunkString === chkStr) {\r\n                    return chkLen;\r\n                }\r\n                this.br.pos += chkLen;\r\n            }\r\n            return chkLen;\r\n        }\r\n\r\n        private parseFmtChunk():PCMAudioFormat | null {\r\n            let pcmAf:PCMAudioFormat|null=null;\r\n            const fmt = this.br.readUint16LE();\r\n            if (fmt === WavFileFormat.PCM || fmt==WavFileFormat.WAVE_FORMAT_IEEE_FLOAT) {\r\n                const channels = this.br.readUint16LE();\r\n                const sampleRate = this.br.readUint32LE();\r\n\r\n                // skip bandwidth\r\n                this.br.skip(4);\r\n\r\n                // frame size\r\n                const frameSize = this.br.readUint16LE();\r\n\r\n                // sample size in bits (PCM format only)\r\n                const sampleSizeInBits = this.br.readUint16LE();\r\n\r\n                pcmAf=new PCMAudioFormat(sampleRate, channels, frameSize / channels, sampleSizeInBits,(fmt===WavFileFormat.WAVE_FORMAT_IEEE_FLOAT));\r\n            }\r\n            return pcmAf;\r\n        }\r\n\r\n        private readData():Array<Float32Array> | null{\r\n            let chsArr=null;\r\n            if(this.format) {\r\n              chsArr = new Array<Float32Array>(this.format.channelCount);\r\n              const sampleCount = this.totalLength / this.format.channelCount / this.format.sampleSize;\r\n              for (let ch = 0; ch < this.format.channelCount; ch++) {\r\n                chsArr[ch] = new Float32Array(sampleCount);\r\n              }\r\n              if(this.format.encodingFloat){\r\n                // Not tested yet!\r\n                for (let i = 0; i < this.totalLength / 4; i++) {\r\n                  for (let ch = 0; ch < this.format.channelCount; ch++) {\r\n                    chsArr[ch][i]=this.br.readFloat32();\r\n                  }\r\n                }\r\n              }else {\r\n                if (this.format.sampleSize == 2) {\r\n                  for (let i = 0; i < this.totalLength / 2; i++) {\r\n                    for (let ch = 0; ch < this.format.channelCount; ch++) {\r\n                      const s16Ampl = this.br.readInt16LE();\r\n                      chsArr[ch][i] = s16Ampl / 32768;\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            }\r\n            return chsArr;\r\n        }\r\n    }\r\n\r\n\r\n\r\n\r\n"]}
|
|
@@ -1,10 +1,36 @@
|
|
|
1
1
|
import { WavFileFormat } from './wavformat';
|
|
2
2
|
import { BinaryByteWriter } from '../../io/BinaryWriter';
|
|
3
3
|
import { WorkerHelper } from "../../utils/utils";
|
|
4
|
+
export var SampleSize;
|
|
5
|
+
(function (SampleSize) {
|
|
6
|
+
SampleSize[SampleSize["INT16"] = 16] = "INT16";
|
|
7
|
+
SampleSize[SampleSize["INT32"] = 32] = "INT32";
|
|
8
|
+
})(SampleSize || (SampleSize = {}));
|
|
4
9
|
export class WavWriter {
|
|
5
|
-
static { this.
|
|
6
|
-
constructor() {
|
|
10
|
+
static { this.DEFAULT_SAMPLE_SIZE = SampleSize.INT16; }
|
|
11
|
+
constructor(encodingFloat, sampleSize) {
|
|
12
|
+
this.sampleSizeInBytes = WavWriter.DEFAULT_SAMPLE_SIZE.valueOf() / 8;
|
|
13
|
+
this.encodingFloat = false;
|
|
14
|
+
this.sampleSize = WavWriter.DEFAULT_SAMPLE_SIZE;
|
|
15
|
+
this.sampleSizeInBits = this.sampleSize.valueOf();
|
|
7
16
|
this.workerURL = null;
|
|
17
|
+
//console.debug("WavWriter: "+encodingFloat+", "+sampleSize);
|
|
18
|
+
if (encodingFloat !== undefined && encodingFloat !== null) {
|
|
19
|
+
this.encodingFloat = encodingFloat;
|
|
20
|
+
if (encodingFloat === true) {
|
|
21
|
+
this.sampleSize = SampleSize.INT32;
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
if (sampleSize) {
|
|
25
|
+
this.sampleSize = sampleSize;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
else if (sampleSize) {
|
|
30
|
+
this.sampleSize = sampleSize;
|
|
31
|
+
}
|
|
32
|
+
this.sampleSizeInBits = this.sampleSize.valueOf();
|
|
33
|
+
this.sampleSizeInBytes = Math.round(this.sampleSizeInBits / 8);
|
|
8
34
|
this.bw = new BinaryByteWriter();
|
|
9
35
|
}
|
|
10
36
|
/*
|
|
@@ -13,16 +39,28 @@ export class WavWriter {
|
|
|
13
39
|
workerFunction() {
|
|
14
40
|
self.onmessage = function (msg) {
|
|
15
41
|
const valView = new DataView(msg.data.buf, msg.data.bufPos);
|
|
42
|
+
const sampleSizeInbytes = Math.round(msg.data.sampleSizeInBits / 8);
|
|
16
43
|
let bufPos = 0;
|
|
17
|
-
|
|
44
|
+
const hDynIntRange = 1 << (msg.data.sampleSizeInBits - 1);
|
|
18
45
|
for (let s = 0; s < msg.data.frameLength; s++) {
|
|
19
46
|
// interleaved channel data
|
|
20
47
|
for (let ch = 0; ch < msg.data.chs; ch++) {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
48
|
+
const srcPos = (ch * msg.data.frameLength) + s;
|
|
49
|
+
const valFlt = msg.data.audioData[srcPos];
|
|
50
|
+
if (msg.data.encodingFloat === true) {
|
|
51
|
+
valView.setFloat32(bufPos, valFlt, true);
|
|
52
|
+
bufPos += 4;
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
const valInt = Math.round(valFlt * hDynIntRange);
|
|
56
|
+
if (msg.data.sampleSizeInBits === 32) {
|
|
57
|
+
valView.setInt32(bufPos, valInt, true);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
valView.setInt16(bufPos, valInt, true);
|
|
61
|
+
}
|
|
62
|
+
bufPos += sampleSizeInbytes;
|
|
63
|
+
}
|
|
26
64
|
}
|
|
27
65
|
}
|
|
28
66
|
postMessage({ buf: msg.data.buf }, [msg.data.buf]);
|
|
@@ -30,27 +68,60 @@ export class WavWriter {
|
|
|
30
68
|
};
|
|
31
69
|
}
|
|
32
70
|
writeFmtChunk(audioBuffer) {
|
|
33
|
-
this.
|
|
34
|
-
|
|
71
|
+
if (this.encodingFloat === true) {
|
|
72
|
+
this.bw.writeUint16(WavFileFormat.WAVE_FORMAT_IEEE_FLOAT, true);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
this.bw.writeUint16(WavFileFormat.PCM, true);
|
|
76
|
+
}
|
|
77
|
+
const frameSize = this.sampleSizeInBytes * audioBuffer.numberOfChannels;
|
|
35
78
|
this.bw.writeUint16(audioBuffer.numberOfChannels, true);
|
|
36
79
|
this.bw.writeUint32(audioBuffer.sampleRate, true);
|
|
37
80
|
// dwAvgBytesPerSec
|
|
38
81
|
this.bw.writeUint32(frameSize * audioBuffer.sampleRate, true);
|
|
39
82
|
this.bw.writeUint16(frameSize, true);
|
|
40
83
|
// sample size in bits (PCM format only)
|
|
41
|
-
this.bw.writeUint16(
|
|
84
|
+
this.bw.writeUint16(this.sampleSizeInBits, true);
|
|
85
|
+
if (this.encodingFloat === true) {
|
|
86
|
+
this.bw.writeUint16(0, true);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
writeFactChunk(audioBuffer) {
|
|
90
|
+
const ch0 = audioBuffer.getChannelData(0);
|
|
91
|
+
let sampleLen = 0;
|
|
92
|
+
if (ch0) {
|
|
93
|
+
sampleLen = ch0.length;
|
|
94
|
+
}
|
|
95
|
+
this.bw.writeUint32(sampleLen, true);
|
|
42
96
|
}
|
|
43
97
|
writeDataChunk(audioBuffer) {
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
98
|
+
const chData0 = audioBuffer.getChannelData(0);
|
|
99
|
+
const dataLen = chData0.length;
|
|
100
|
+
if (this.encodingFloat === true) {
|
|
101
|
+
for (let s = 0; s < dataLen; s++) {
|
|
102
|
+
// interleaved channel data
|
|
103
|
+
for (let ch = 0; ch < audioBuffer.numberOfChannels; ch++) {
|
|
104
|
+
const chData = audioBuffer.getChannelData(ch);
|
|
105
|
+
const valFlt = chData[s];
|
|
106
|
+
this.bw.writeFloat(valFlt);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
const hDynIntRange = 1 << ((this.sampleSizeInBits) - 1);
|
|
112
|
+
for (let s = 0; s < dataLen; s++) {
|
|
113
|
+
// interleaved channel data
|
|
114
|
+
for (let ch = 0; ch < audioBuffer.numberOfChannels; ch++) {
|
|
115
|
+
const chData = audioBuffer.getChannelData(ch);
|
|
116
|
+
const valFlt = chData[s];
|
|
117
|
+
const valInt = Math.round(valFlt * hDynIntRange);
|
|
118
|
+
if (this.sampleSize === SampleSize.INT16) {
|
|
119
|
+
this.bw.writeInt16(valInt, true);
|
|
120
|
+
}
|
|
121
|
+
else if (this.sampleSize === SampleSize.INT32) {
|
|
122
|
+
this.bw.writeInt32(valInt, true);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
54
125
|
}
|
|
55
126
|
}
|
|
56
127
|
}
|
|
@@ -59,14 +130,14 @@ export class WavWriter {
|
|
|
59
130
|
this.bw.writeUint32(chkLen, true);
|
|
60
131
|
}
|
|
61
132
|
writeAsync(audioBuffer, callback) {
|
|
62
|
-
|
|
133
|
+
const dataChkByteLen = this.writeHeader(audioBuffer);
|
|
63
134
|
if (!this.workerURL) {
|
|
64
135
|
this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);
|
|
65
136
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
137
|
+
const wo = new Worker(this.workerURL);
|
|
138
|
+
const chs = audioBuffer.numberOfChannels;
|
|
139
|
+
const frameLength = audioBuffer.getChannelData(0).length;
|
|
140
|
+
const ad = new Float32Array(chs * frameLength);
|
|
70
141
|
for (let ch = 0; ch < chs; ch++) {
|
|
71
142
|
ad.set(audioBuffer.getChannelData(ch), ch * frameLength);
|
|
72
143
|
}
|
|
@@ -76,8 +147,7 @@ export class WavWriter {
|
|
|
76
147
|
callback(me.data.buf);
|
|
77
148
|
wo.terminate();
|
|
78
149
|
};
|
|
79
|
-
|
|
80
|
-
wo.postMessage({ sampleSizeInBits: 16, chs: chs, frameLength: frameLength, audioData: ad, buf: this.bw.buf, bufPos: this.bw.pos }, [ad.buffer, this.bw.buf]);
|
|
150
|
+
wo.postMessage({ encodingFloat: this.encodingFloat, sampleSizeInBits: this.sampleSizeInBits, chs: chs, frameLength: frameLength, audioData: ad, buf: this.bw.buf, bufPos: this.bw.pos }, [ad.buffer, this.bw.buf]);
|
|
81
151
|
}
|
|
82
152
|
write(audioBuffer) {
|
|
83
153
|
this.writeHeader(audioBuffer);
|
|
@@ -91,15 +161,31 @@ export class WavWriter {
|
|
|
91
161
|
const abChs = audioBuffer.numberOfChannels;
|
|
92
162
|
if (abChs > 0) {
|
|
93
163
|
const abCh0 = audioBuffer.getChannelData(0);
|
|
94
|
-
dataChkByteLen = abCh0.length *
|
|
164
|
+
dataChkByteLen = abCh0.length * this.sampleSizeInBytes * abChs;
|
|
95
165
|
}
|
|
96
|
-
|
|
166
|
+
let headerCnts = 3; //Wave,fmt and data
|
|
167
|
+
let fmtChunkSize = 16;
|
|
168
|
+
let factChunkSize = 4;
|
|
169
|
+
if (this.encodingFloat === true) {
|
|
170
|
+
fmtChunkSize = 18;
|
|
171
|
+
headerCnts++; // fact
|
|
172
|
+
} // Float encoding requires fmt extension (with zero length)
|
|
173
|
+
let wavChunkByteLen = (4 + 4) * headerCnts;
|
|
174
|
+
wavChunkByteLen += fmtChunkSize;
|
|
175
|
+
wavChunkByteLen += factChunkSize;
|
|
176
|
+
wavChunkByteLen += dataChkByteLen;
|
|
177
|
+
console.debug("Write WAV header: Wav chunk len: " + wavChunkByteLen);
|
|
97
178
|
this.bw.writeUint32(wavChunkByteLen, true); // must be set to file length-8 later
|
|
98
179
|
this.bw.writeAscii(WavFileFormat.WAV_KEY);
|
|
99
|
-
this.writeChunkHeader('fmt ',
|
|
180
|
+
this.writeChunkHeader('fmt ', fmtChunkSize);
|
|
100
181
|
this.writeFmtChunk(audioBuffer);
|
|
182
|
+
if (this.encodingFloat === true) {
|
|
183
|
+
console.debug("Write WAV header: Write 'fact' chunk.");
|
|
184
|
+
this.writeChunkHeader('fact', 4);
|
|
185
|
+
this.writeFactChunk(audioBuffer);
|
|
186
|
+
}
|
|
101
187
|
this.writeChunkHeader('data', dataChkByteLen);
|
|
102
188
|
return dataChkByteLen;
|
|
103
189
|
}
|
|
104
190
|
}
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wavwriter.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/impl/wavwriter.ts"],"names":[],"mappings":"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","sourcesContent":["import { WavFileFormat } from './wavformat'\r\nimport { BinaryByteWriter } from '../../io/BinaryWriter'\r\nimport {WorkerHelper} from \"../../utils/utils\";\r\ndeclare function postMessage (message:any, transfer:Array<any>):void;\r\n\r\n\r\n   export class WavWriter {\r\n\r\n     static readonly DEFAULT_SAMPLE_SIZE_BYTES:number = 2;\r\n     private bw:BinaryByteWriter;\r\n     private workerURL: string|null=null;\r\n     constructor() {\r\n       this.bw = new BinaryByteWriter();\r\n     }\r\n\r\n     /*\r\n      *  Method used as worker code.\r\n      */\r\n     workerFunction() {\r\n       self.onmessage = function (msg:MessageEvent) {\r\n\r\n         const valView = new DataView(msg.data.buf,msg.data.bufPos);\r\n\r\n         let bufPos = 0;\r\n         let hDynIntRange = 1 << (msg.data.sampleSizeInBits - 1);\r\n         for (let s = 0; s < msg.data.frameLength; s++) {\r\n           // interleaved channel data\r\n\r\n           for (let ch = 0; ch < msg.data.chs; ch++) {\r\n             let srcPos=(ch*msg.data.frameLength)+s;\r\n             let valFlt = msg.data.audioData[srcPos];\r\n             let valInt = Math.round(valFlt * hDynIntRange);\r\n             valView.setInt16(bufPos, valInt, true);\r\n             bufPos+=2;\r\n           }\r\n         }\r\n         postMessage({buf:msg.data.buf}, [msg.data.buf]);\r\n         //self.close()\r\n       }\r\n     }\r\n\r\n\r\n     writeFmtChunk(audioBuffer:AudioBuffer){\r\n\r\n       this.bw.writeUint16(WavFileFormat.PCM,true);\r\n       let frameSize=WavWriter.DEFAULT_SAMPLE_SIZE_BYTES*audioBuffer.numberOfChannels; // fixed 16-bit for now\r\n       this.bw.writeUint16(audioBuffer.numberOfChannels,true);\r\n       this.bw.writeUint32(audioBuffer.sampleRate,true);\r\n         // dwAvgBytesPerSec\r\n       this.bw.writeUint32(frameSize*audioBuffer.sampleRate,true);\r\n       this.bw.writeUint16(frameSize,true);\r\n       // sample size in bits (PCM format only)\r\n       this.bw.writeUint16(WavWriter.DEFAULT_SAMPLE_SIZE_BYTES*8,true);\r\n     }\r\n\r\n     writeDataChunk(audioBuffer:AudioBuffer){\r\n\r\n       let chData0=audioBuffer.getChannelData(0);\r\n       let dataLen=chData0.length;\r\n        let hDynIntRange=1 << ((WavWriter.DEFAULT_SAMPLE_SIZE_BYTES*8)-1);\r\n       for(let s=0;s<dataLen;s++) {\r\n         // interleaved channel data\r\n         for (let ch = 0; ch < audioBuffer.numberOfChannels; ch++) {\r\n           let chData = audioBuffer.getChannelData(ch);\r\n           let valFlt=chData[s];\r\n           let valInt=Math.round(valFlt*hDynIntRange);\r\n           this.bw.writeInt16(valInt,true);\r\n         }\r\n       }\r\n\r\n     }\r\n\r\n     writeChunkHeader(name:string,chkLen:number){\r\n       this.bw.writeAscii(name);\r\n       this.bw.writeUint32(chkLen,true);\r\n     }\r\n\r\n     writeAsync(audioBuffer:AudioBuffer,callback: (wavFileData:Uint8Array)=> any){\r\n\r\n       let dataChkByteLen=this.writeHeader(audioBuffer);\r\n       if (!this.workerURL) {\r\n         this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n        }\r\n       let wo = new Worker(this.workerURL);\r\n\r\n       let chs = audioBuffer.numberOfChannels;\r\n\r\n       let frameLength = audioBuffer.getChannelData(0).length;\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         // ensureCapacity blocks !!!\r\n       this.bw.ensureCapacity(dataChkByteLen);\r\n       wo.onmessage = (me) => {\r\n         callback(me.data.buf);\r\n         wo.terminate();\r\n       }\r\n       //TODO Fixed sample size of 16 bits\r\n       wo.postMessage({sampleSizeInBits:16, chs: chs, frameLength: frameLength, audioData: ad,buf:this.bw.buf,bufPos:this.bw.pos}, [ad.buffer,this.bw.buf]);\r\n\r\n     }\r\n\r\n     write(audioBuffer:AudioBuffer):Uint8Array{\r\n       this.writeHeader(audioBuffer);\r\n       this.writeDataChunk(audioBuffer);\r\n       return this.bw.finish();\r\n     }\r\n\r\n\r\n      writeHeader(audioBuffer:AudioBuffer):number{\r\n        this.bw.writeAscii(WavFileFormat.RIFF_KEY);\r\n        let dataChkByteLen=0;\r\n        //const dataChkByteLen=audioBuffer.getChannelData(0).length*WavWriter.DEFAULT_SAMPLE_SIZE_BYTES*audioBuffer.numberOfChannels;\r\n        const abChs=audioBuffer.numberOfChannels;\r\n        if(abChs>0){\r\n          const abCh0=audioBuffer.getChannelData(0);\r\n          dataChkByteLen=abCh0.length*WavWriter.DEFAULT_SAMPLE_SIZE_BYTES*abChs;\r\n        }\r\n        const wavChunkByteLen=(4+4)*3+16+dataChkByteLen;\r\n        this.bw.writeUint32(wavChunkByteLen,true); // must be set to file length-8 later\r\n        this.bw.writeAscii(WavFileFormat.WAV_KEY);\r\n        this.writeChunkHeader('fmt ',16);\r\n        this.writeFmtChunk(audioBuffer);\r\n        this.writeChunkHeader('data',dataChkByteLen);\r\n        return dataChkByteLen;\r\n      }\r\n\r\n   }\r\n\r\n\r\n\r\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wavwriter.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/impl/wavwriter.ts"],"names":[],"mappings":"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","sourcesContent":["import { WavFileFormat } from './wavformat'\r\nimport { BinaryByteWriter } from '../../io/BinaryWriter'\r\nimport {WorkerHelper} from \"../../utils/utils\";\r\ndeclare function postMessage (message:any, transfer:Array<any>):void;\r\n\r\n\r\nexport enum SampleSize {INT16=16,INT32=32}\r\n   export class WavWriter {\r\n\r\n     static readonly DEFAULT_SAMPLE_SIZE:SampleSize = SampleSize.INT16;\r\n     private readonly sampleSizeInBytes:number=WavWriter.DEFAULT_SAMPLE_SIZE.valueOf()/8;\r\n     private encodingFloat:boolean=false;\r\n     private sampleSize=WavWriter.DEFAULT_SAMPLE_SIZE;\r\n     private sampleSizeInBits=this.sampleSize.valueOf();\r\n     private bw:BinaryByteWriter;\r\n     private workerURL: string|null=null;\r\n\r\n     constructor(encodingFloat?:boolean,sampleSize?:SampleSize) {\r\n       //console.debug(\"WavWriter: \"+encodingFloat+\", \"+sampleSize);\r\n       if(encodingFloat!==undefined && encodingFloat!==null){\r\n         this.encodingFloat=encodingFloat;\r\n         if(encodingFloat===true) {\r\n           this.sampleSize = SampleSize.INT32;\r\n         }else{\r\n           if(sampleSize) {\r\n             this.sampleSize = sampleSize;\r\n           }\r\n         }\r\n       }else if(sampleSize){\r\n         this.sampleSize=sampleSize;\r\n       }\r\n       this.sampleSizeInBits=this.sampleSize.valueOf();\r\n       this.sampleSizeInBytes=Math.round(this.sampleSizeInBits/8);\r\n\r\n       this.bw = new BinaryByteWriter();\r\n     }\r\n\r\n     /*\r\n      *  Method used as worker code.\r\n      */\r\n     workerFunction() {\r\n       self.onmessage = function (msg:MessageEvent) {\r\n\r\n         const valView = new DataView(msg.data.buf,msg.data.bufPos);\r\n         const sampleSizeInbytes=Math.round(msg.data.sampleSizeInBits/8);\r\n         let bufPos = 0;\r\n         const hDynIntRange = 1 << (msg.data.sampleSizeInBits - 1);\r\n         for (let s = 0; s < msg.data.frameLength; s++) {\r\n           // interleaved channel data\r\n\r\n           for (let ch = 0; ch < msg.data.chs; ch++) {\r\n             const srcPos=(ch*msg.data.frameLength)+s;\r\n             const valFlt = msg.data.audioData[srcPos];\r\n             if(msg.data.encodingFloat===true){\r\n               valView.setFloat32(bufPos,valFlt,true);\r\n               bufPos+=4;\r\n             }else {\r\n               const valInt = Math.round(valFlt * hDynIntRange);\r\n               if (msg.data.sampleSizeInBits === 32) {\r\n                 valView.setInt32(bufPos, valInt, true);\r\n               } else {\r\n                 valView.setInt16(bufPos, valInt, true);\r\n               }\r\n               bufPos+=sampleSizeInbytes;\r\n             }\r\n\r\n           }\r\n         }\r\n         postMessage({buf:msg.data.buf}, [msg.data.buf]);\r\n         //self.close()\r\n       }\r\n     }\r\n\r\n\r\n     writeFmtChunk(audioBuffer:AudioBuffer){\r\n\r\n       if(this.encodingFloat===true){\r\n         this.bw.writeUint16(WavFileFormat.WAVE_FORMAT_IEEE_FLOAT, true);\r\n       }else {\r\n         this.bw.writeUint16(WavFileFormat.PCM, true);\r\n       }\r\n       const frameSize=this.sampleSizeInBytes*audioBuffer.numberOfChannels;\r\n       this.bw.writeUint16(audioBuffer.numberOfChannels,true);\r\n       this.bw.writeUint32(audioBuffer.sampleRate,true);\r\n         // dwAvgBytesPerSec\r\n       this.bw.writeUint32(frameSize*audioBuffer.sampleRate,true);\r\n       this.bw.writeUint16(frameSize,true);\r\n       // sample size in bits (PCM format only)\r\n       this.bw.writeUint16(this.sampleSizeInBits,true);\r\n       if(this.encodingFloat===true){\r\n         this.bw.writeUint16(0,true);\r\n       }\r\n     }\r\n\r\n     writeFactChunk(audioBuffer:AudioBuffer){\r\n       const ch0=audioBuffer.getChannelData(0);\r\n       let sampleLen=0;\r\n       if(ch0){\r\n         sampleLen=ch0.length;\r\n       }\r\n        this.bw.writeUint32(sampleLen,true);\r\n     }\r\n\r\n     writeDataChunk(audioBuffer:AudioBuffer){\r\n\r\n       const chData0=audioBuffer.getChannelData(0);\r\n       const dataLen=chData0.length;\r\n       if(this.encodingFloat===true){\r\n         for (let s = 0; s < dataLen; s++) {\r\n           // interleaved channel data\r\n           for (let ch = 0; ch < audioBuffer.numberOfChannels; ch++) {\r\n             const chData = audioBuffer.getChannelData(ch);\r\n             const valFlt = chData[s];\r\n             this.bw.writeFloat(valFlt);\r\n           }\r\n         }\r\n       }else {\r\n         const hDynIntRange = 1 << ((this.sampleSizeInBits) - 1);\r\n         for (let s = 0; s < dataLen; s++) {\r\n           // interleaved channel data\r\n           for (let ch = 0; ch < audioBuffer.numberOfChannels; ch++) {\r\n             const chData = audioBuffer.getChannelData(ch);\r\n             const valFlt = chData[s];\r\n             const valInt = Math.round(valFlt * hDynIntRange);\r\n             if (this.sampleSize === SampleSize.INT16) {\r\n               this.bw.writeInt16(valInt, true);\r\n             } else if (this.sampleSize === SampleSize.INT32) {\r\n               this.bw.writeInt32(valInt, true);\r\n             }\r\n           }\r\n         }\r\n       }\r\n\r\n     }\r\n\r\n     writeChunkHeader(name:string,chkLen:number){\r\n       this.bw.writeAscii(name);\r\n       this.bw.writeUint32(chkLen,true);\r\n     }\r\n\r\n     writeAsync(audioBuffer:AudioBuffer,callback: (wavFileData:Uint8Array)=> any){\r\n\r\n       const dataChkByteLen=this.writeHeader(audioBuffer);\r\n       if (!this.workerURL) {\r\n         this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n        }\r\n       const wo = new Worker(this.workerURL);\r\n\r\n       const chs = audioBuffer.numberOfChannels;\r\n\r\n       const frameLength = audioBuffer.getChannelData(0).length;\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         // ensureCapacity blocks !!!\r\n       this.bw.ensureCapacity(dataChkByteLen);\r\n       wo.onmessage = (me) => {\r\n         callback(me.data.buf);\r\n         wo.terminate();\r\n       }\r\n\r\n\r\n       wo.postMessage({encodingFloat:this.encodingFloat,sampleSizeInBits:this.sampleSizeInBits, chs: chs, frameLength: frameLength, audioData: ad,buf:this.bw.buf,bufPos:this.bw.pos}, [ad.buffer,this.bw.buf]);\r\n\r\n     }\r\n\r\n     write(audioBuffer:AudioBuffer):Uint8Array{\r\n       this.writeHeader(audioBuffer);\r\n       this.writeDataChunk(audioBuffer);\r\n       return this.bw.finish();\r\n     }\r\n\r\n\r\n      writeHeader(audioBuffer:AudioBuffer):number{\r\n        this.bw.writeAscii(WavFileFormat.RIFF_KEY);\r\n        let dataChkByteLen=0;\r\n        //const dataChkByteLen=audioBuffer.getChannelData(0).length*WavWriter.DEFAULT_SAMPLE_SIZE_BYTES*audioBuffer.numberOfChannels;\r\n        const abChs=audioBuffer.numberOfChannels;\r\n        if(abChs>0){\r\n          const abCh0=audioBuffer.getChannelData(0);\r\n          dataChkByteLen=abCh0.length*this.sampleSizeInBytes*abChs;\r\n        }\r\n        let headerCnts=3; //Wave,fmt and data\r\n\r\n        let fmtChunkSize=16;\r\n        let factChunkSize=4;\r\n        if(this.encodingFloat===true){\r\n          fmtChunkSize=18;\r\n          headerCnts++; // fact\r\n        }// Float encoding requires fmt extension (with zero length)\r\n        let wavChunkByteLen=(4+4)*headerCnts;\r\n\r\n        wavChunkByteLen+=fmtChunkSize;\r\n        wavChunkByteLen+=factChunkSize;\r\n        wavChunkByteLen+=dataChkByteLen;\r\n\r\n        console.debug(\"Write WAV header: Wav chunk len: \"+wavChunkByteLen);\r\n        this.bw.writeUint32(wavChunkByteLen,true); // must be set to file length-8 later\r\n        this.bw.writeAscii(WavFileFormat.WAV_KEY);\r\n\r\n        this.writeChunkHeader('fmt ',fmtChunkSize);\r\n        this.writeFmtChunk(audioBuffer);\r\n        if(this.encodingFloat===true){\r\n          console.debug(\"Write WAV header: Write 'fact' chunk.\");\r\n          this.writeChunkHeader('fact',4);\r\n          this.writeFactChunk(audioBuffer);\r\n        }\r\n        this.writeChunkHeader('data',dataChkByteLen);\r\n        return dataChkByteLen;\r\n      }\r\n\r\n   }\r\n\r\n\r\n\r\n"]}
|
|
@@ -138,10 +138,10 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
|
|
|
138
138
|
}
|
|
139
139
|
}
|
|
140
140
|
}
|
|
141
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
142
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.
|
|
141
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: BasicAudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
142
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: BasicAudioCanvasLayerComponent, usesInheritance: true, ngImport: i0 }); }
|
|
143
143
|
}
|
|
144
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
144
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: BasicAudioCanvasLayerComponent, decorators: [{
|
|
145
145
|
type: Directive
|
|
146
146
|
}] });
|
|
147
147
|
export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
|
|
@@ -317,10 +317,10 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
|
|
|
317
317
|
}
|
|
318
318
|
}
|
|
319
319
|
}
|
|
320
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
321
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.
|
|
320
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
321
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: AudioCanvasLayerComponent, inputs: { pointerPosition: "pointerPosition", selecting: "selecting", selection: "selection" }, outputs: { pointerPositionEventEmitter: "pointerPositionEventEmitter", selectingEventEmitter: "selectingEventEmitter", selectedEventEmitter: "selectedEventEmitter" }, host: { listeners: { "document:mouseup": "onMouseup($event)" } }, viewQueries: [{ propertyName: "bgCanvasRef", first: true, predicate: ["bg"], descendants: true, static: true }, { propertyName: "cursorCanvasRef", first: true, predicate: ["cursor"], descendants: true, static: true }], usesInheritance: true, ngImport: i0 }); }
|
|
322
322
|
}
|
|
323
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
323
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioCanvasLayerComponent, decorators: [{
|
|
324
324
|
type: Directive
|
|
325
325
|
}], propDecorators: { bgCanvasRef: [{
|
|
326
326
|
type: ViewChild,
|
|
@@ -33,8 +33,8 @@ export class AudioDisplayControl {
|
|
|
33
33
|
error() {
|
|
34
34
|
this.status = 'ERROR';
|
|
35
35
|
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplayControl, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: AudioDisplayControl, selector: "audio-display-control", inputs: { audioClip: "audioClip", playStartAction: "playStartAction", playSelectionAction: "playSelectionAction", playStopAction: "playStopAction", zoomInAction: "zoomInAction", zoomOutAction: "zoomOutAction", zoomFitToPanelAction: "zoomFitToPanelAction", zoomSelectedAction: "zoomSelectedAction", autoPlayOnSelectToggleAction: "autoPlayOnSelectToggleAction" }, viewQueries: [{ propertyName: "autoplaySelectedCheckbox", first: true, predicate: MatCheckbox, descendants: true, static: true }], ngImport: i0, template: `
|
|
38
38
|
<div #controlPanel style="display:flex;flex-direction: row;">
|
|
39
39
|
<fieldset>
|
|
40
40
|
|
|
@@ -79,7 +79,7 @@ export class AudioDisplayControl {
|
|
|
79
79
|
</fieldset>
|
|
80
80
|
</div>`, isInline: true, styles: [":host{flex:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i4.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }] }); }
|
|
81
81
|
}
|
|
82
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplayControl, decorators: [{
|
|
83
83
|
type: Component,
|
|
84
84
|
args: [{ selector: 'audio-display-control', template: `
|
|
85
85
|
<div #controlPanel style="display:flex;flex-direction: row;">
|
|
@@ -109,14 +109,14 @@ export class AudioDisplayScrollPane {
|
|
|
109
109
|
set playFramePosition(framePos) {
|
|
110
110
|
this.ac.playFramePosition = framePos;
|
|
111
111
|
}
|
|
112
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
113
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.
|
|
112
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplayScrollPane, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
113
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: { audioClip: "audioClip" }, outputs: { zoomInAction: "zoomInAction", zoomOutAction: "zoomOutAction", zoomSelectedAction: "zoomSelectedAction", zoomFitToPanelAction: "zoomFitToPanelAction" }, host: { listeners: { "scroll": "onScroll($event)", "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "ac", first: true, predicate: AudioClipUIContainer, descendants: true, static: true }], ngImport: i0, template: `
|
|
114
114
|
|
|
115
115
|
<app-audio #audioSignalContainer (selectionEventEmitter)="selectionChanged($event)"></app-audio>
|
|
116
116
|
|
|
117
117
|
`, isInline: true, styles: [":host{flex:2;width:100%;background:#a9a9a9;box-sizing:border-box;height:100%;position:relative;overflow-x:scroll;overflow-y:auto}\n", "app-audio{margin:0;padding:0;top:0;left:0;width:100%;height:100%;box-sizing:border-box}\n"], dependencies: [{ kind: "component", type: i1.AudioClipUIContainer, selector: "app-audio", inputs: ["audioData", "audioClip"], outputs: ["selectionEventEmitter"] }] }); }
|
|
118
118
|
}
|
|
119
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
119
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioDisplayScrollPane, decorators: [{
|
|
120
120
|
type: Component,
|
|
121
121
|
args: [{ selector: 'audio-display-scroll-pane', template: `
|
|
122
122
|
|
|
@@ -507,15 +507,15 @@ export class AudioSignal extends AudioCanvasLayerComponent {
|
|
|
507
507
|
this._audioDataHolder = audioData;
|
|
508
508
|
this.playFramePosition = 0;
|
|
509
509
|
}
|
|
510
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
511
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.
|
|
510
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioSignal, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
511
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", 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: `
|
|
512
512
|
<canvas #bg height="10"></canvas>
|
|
513
513
|
<canvas #audioSignal height="10"></canvas>
|
|
514
514
|
<canvas #cursor height="10" (mousedown)="selectionStart($event)" (mouseover)="updateCursorCanvas($event)" (mousemove)="updateCursorCanvas($event)"
|
|
515
515
|
(mouseleave)="updateCursorCanvas($event, false)"></canvas>
|
|
516
516
|
<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"] }); }
|
|
517
517
|
}
|
|
518
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
518
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AudioSignal, decorators: [{
|
|
519
519
|
type: Component,
|
|
520
520
|
args: [{ selector: 'audio-signal', template: `
|
|
521
521
|
<canvas #bg height="10"></canvas>
|