werift 0.13.1 → 0.13.2
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/lib/common/src/binary.d.ts +1 -0
- package/lib/common/src/binary.js +6 -0
- package/lib/common/src/binary.js.map +1 -1
- package/lib/rtp/src/codec/vp8.d.ts +10 -10
- package/lib/rtp/src/codec/vp8.js +30 -30
- package/lib/rtp/src/codec/vp8.js.map +1 -1
- package/lib/rtp/src/codec/vp9.d.ts +38 -10
- package/lib/rtp/src/codec/vp9.js +115 -26
- package/lib/rtp/src/codec/vp9.js.map +1 -1
- package/lib/webrtc/src/nonstandard/webm.js +39 -8
- package/lib/webrtc/src/nonstandard/webm.js.map +1 -1
- package/package.json +1 -1
- package/src/nonstandard/webm.ts +50 -12
|
@@ -6,6 +6,7 @@ export declare class BitWriter {
|
|
|
6
6
|
value: number;
|
|
7
7
|
constructor(bitLength: number);
|
|
8
8
|
set(size: number, startIndex: number, value: number): this;
|
|
9
|
+
get buffer(): Buffer;
|
|
9
10
|
}
|
|
10
11
|
export declare function getBit(bits: number, startIndex: number, length?: number): number;
|
|
11
12
|
export declare function paddingByte(bits: number): string;
|
package/lib/common/src/binary.js
CHANGED
|
@@ -21,6 +21,12 @@ class BitWriter {
|
|
|
21
21
|
this.value |= value << (this.bitLength - size - startIndex);
|
|
22
22
|
return this;
|
|
23
23
|
}
|
|
24
|
+
get buffer() {
|
|
25
|
+
const length = Math.ceil(this.bitLength / 8);
|
|
26
|
+
const buf = Buffer.alloc(length);
|
|
27
|
+
buf.writeUIntBE(this.value, 0, length);
|
|
28
|
+
return buf;
|
|
29
|
+
}
|
|
24
30
|
}
|
|
25
31
|
exports.BitWriter = BitWriter;
|
|
26
32
|
function getBit(bits, startIndex, length = 1) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"binary.js","sourceRoot":"","sources":["../../../../common/src/binary.ts"],"names":[],"mappings":";;;AAAA,mCAAqC;AACrC,mCAAgC;AAEhC,SAAgB,QAAQ;IACtB,OAAO,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,oBAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChD,CAAC;AAFD,4BAEC;AAED,SAAgB,QAAQ;IACtB,OAAO,MAAM,CAAC,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,oBAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACxD,CAAC;AAFD,4BAEC;AAED,MAAa,SAAS;IAGpB,YAAoB,SAAiB;QAAjB,cAAS,GAAT,SAAS,CAAQ;QAFrC,UAAK,GAAG,CAAC,CAAC;IAE8B,CAAC;IAEzC,GAAG,CAAC,IAAY,EAAE,UAAkB,EAAE,KAAa;QACjD,KAAK,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC;QACzB,IAAI,CAAC,KAAK,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,GAAG,UAAU,CAAC,CAAC;QAE5D,OAAO,IAAI,CAAC;IACd,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"binary.js","sourceRoot":"","sources":["../../../../common/src/binary.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomBytes } from \"crypto\";\nimport { jspack } from \"jspack\";\n\nexport function random16() {\n return jspack.Unpack(\"!H\", randomBytes(2))[0];\n}\n\nexport function random32() {\n return BigInt(jspack.Unpack(\"!L\", randomBytes(4))[0]);\n}\n\nexport class BitWriter {\n value = 0;\n\n constructor(private bitLength: number) {}\n\n set(size: number, startIndex: number, value: number) {\n value &= (1 << size) - 1;\n this.value |= value << (this.bitLength - size - startIndex);\n\n return this;\n }\n\n get buffer() {\n const length = Math.ceil(this.bitLength / 8);\n const buf = Buffer.alloc(length);\n buf.writeUIntBE(this.value, 0, length);\n return buf;\n }\n}\n\nexport function getBit(bits: number, startIndex: number, length: number = 1) {\n let bin = bits.toString(2).split(\"\");\n bin = [...Array(8 - bin.length).fill(\"0\"), ...bin];\n const s = bin.slice(startIndex, startIndex + length).join(\"\");\n const v = parseInt(s, 2);\n return v;\n}\n\nexport function paddingByte(bits: number) {\n const dec = bits.toString(2).split(\"\");\n return [...[...Array(8 - dec.length)].map(() => \"0\"), ...dec].join(\"\");\n}\n\nexport function bufferWriter(bytes: number[], values: (number | bigint)[]) {\n const length = bytes.reduce((acc, cur) => acc + cur, 0);\n const buf = Buffer.alloc(length);\n let offset = 0;\n\n values.forEach((v, i) => {\n const size = bytes[i];\n if (size === 8) buf.writeBigUInt64BE(v as bigint, offset);\n else buf.writeUIntBE(v as number, offset, size);\n\n offset += size;\n });\n return buf;\n}\n\nexport function bufferWriterLE(bytes: number[], values: (number | bigint)[]) {\n const length = bytes.reduce((acc, cur) => acc + cur, 0);\n const buf = Buffer.alloc(length);\n let offset = 0;\n\n values.forEach((v, i) => {\n const size = bytes[i];\n if (size === 8) buf.writeBigUInt64LE(v as bigint, offset);\n else buf.writeUIntLE(v as number, offset, size);\n\n offset += size;\n });\n return buf;\n}\n\nexport function bufferReader(buf: Buffer, bytes: number[]) {\n let offset = 0;\n return bytes.map((v) => {\n let read: number | bigint;\n if (v === 8) {\n read = buf.readBigUInt64BE(offset);\n } else {\n read = buf.readUIntBE(offset, v);\n }\n\n offset += v;\n\n return read as any;\n });\n}\n\nexport class BufferChain {\n buffer = Buffer.alloc(this.size);\n\n constructor(private size: number) {}\n\n writeInt16BE(value: number, offset?: number | undefined) {\n this.buffer.writeInt16BE(value, offset);\n return this;\n }\n\n writeUInt8(value: number, offset?: number | undefined) {\n this.buffer.writeUInt8(value, offset);\n return this;\n }\n}\n"]}
|
|
@@ -2,21 +2,21 @@
|
|
|
2
2
|
import { RtpHeader } from "../rtp/rtp";
|
|
3
3
|
import { DePacketizerBase } from "./base";
|
|
4
4
|
export declare class Vp8RtpPayload implements DePacketizerBase {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
xBit: number;
|
|
6
|
+
nBit: number;
|
|
7
|
+
sBit: number;
|
|
8
8
|
pid: number;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
9
|
+
iBit?: number;
|
|
10
|
+
lBit?: number;
|
|
11
|
+
tBit?: number;
|
|
12
|
+
kBit?: number;
|
|
13
|
+
mBit?: number;
|
|
14
14
|
pictureId?: number;
|
|
15
15
|
payload: Buffer;
|
|
16
16
|
size0?: number;
|
|
17
|
-
|
|
17
|
+
hBit?: number;
|
|
18
18
|
ver?: number;
|
|
19
|
-
|
|
19
|
+
pBit?: number;
|
|
20
20
|
size1?: number;
|
|
21
21
|
size2?: number;
|
|
22
22
|
static deSerialize(buf: Buffer): Vp8RtpPayload;
|
package/lib/rtp/src/codec/vp8.js
CHANGED
|
@@ -35,65 +35,65 @@ const src_1 = require("../../../common/src");
|
|
|
35
35
|
// +-+-+-+-+-+-+-+-+
|
|
36
36
|
class Vp8RtpPayload {
|
|
37
37
|
static deSerialize(buf) {
|
|
38
|
-
const
|
|
38
|
+
const p = new Vp8RtpPayload();
|
|
39
39
|
let offset = 0;
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
40
|
+
p.xBit = src_1.getBit(buf[offset], 0);
|
|
41
|
+
p.nBit = src_1.getBit(buf[offset], 2);
|
|
42
|
+
p.sBit = src_1.getBit(buf[offset], 3);
|
|
43
|
+
p.pid = src_1.getBit(buf[offset], 5, 3);
|
|
44
44
|
offset++;
|
|
45
|
-
if (
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
45
|
+
if (p.xBit) {
|
|
46
|
+
p.iBit = src_1.getBit(buf[offset], 0);
|
|
47
|
+
p.lBit = src_1.getBit(buf[offset], 1);
|
|
48
|
+
p.tBit = src_1.getBit(buf[offset], 2);
|
|
49
|
+
p.kBit = src_1.getBit(buf[offset], 3);
|
|
50
50
|
offset++;
|
|
51
51
|
}
|
|
52
|
-
if (
|
|
53
|
-
|
|
54
|
-
if (
|
|
52
|
+
if (p.iBit) {
|
|
53
|
+
p.mBit = src_1.getBit(buf[offset], 0);
|
|
54
|
+
if (p.mBit) {
|
|
55
55
|
const _7 = src_1.paddingByte(src_1.getBit(buf[offset], 1, 7));
|
|
56
56
|
const _8 = src_1.paddingByte(buf[offset + 1]);
|
|
57
|
-
|
|
57
|
+
p.pictureId = parseInt(_7 + _8, 2);
|
|
58
58
|
offset += 2;
|
|
59
59
|
}
|
|
60
60
|
else {
|
|
61
|
-
|
|
61
|
+
p.pictureId = src_1.getBit(buf[offset], 1, 7);
|
|
62
62
|
offset++;
|
|
63
63
|
}
|
|
64
64
|
}
|
|
65
|
-
if (
|
|
65
|
+
if (p.lBit) {
|
|
66
66
|
offset++;
|
|
67
67
|
}
|
|
68
|
-
if (
|
|
69
|
-
if (
|
|
68
|
+
if (p.lBit || p.kBit) {
|
|
69
|
+
if (p.tBit) {
|
|
70
70
|
}
|
|
71
|
-
if (
|
|
71
|
+
if (p.kBit) {
|
|
72
72
|
}
|
|
73
73
|
offset++;
|
|
74
74
|
}
|
|
75
|
-
|
|
76
|
-
if (
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
75
|
+
p.payload = buf.slice(offset);
|
|
76
|
+
if (p.sBit === 1 && p.pid === 0) {
|
|
77
|
+
p.size0 = src_1.getBit(buf[offset], 0, 3);
|
|
78
|
+
p.hBit = src_1.getBit(buf[offset], 3);
|
|
79
|
+
p.ver = src_1.getBit(buf[offset], 4, 3);
|
|
80
|
+
p.pBit = src_1.getBit(buf[offset], 7);
|
|
81
81
|
offset++;
|
|
82
82
|
}
|
|
83
|
-
|
|
83
|
+
p.size1 = buf[offset];
|
|
84
84
|
offset++;
|
|
85
|
-
|
|
85
|
+
p.size2 = buf[offset];
|
|
86
86
|
offset++;
|
|
87
|
-
return
|
|
87
|
+
return p;
|
|
88
88
|
}
|
|
89
89
|
static isDetectedFinalPacketInSequence(header) {
|
|
90
90
|
return header.marker;
|
|
91
91
|
}
|
|
92
92
|
get isKeyframe() {
|
|
93
|
-
return this.
|
|
93
|
+
return this.pBit === 0;
|
|
94
94
|
}
|
|
95
95
|
get isPartitionHead() {
|
|
96
|
-
return this.
|
|
96
|
+
return this.sBit === 1;
|
|
97
97
|
}
|
|
98
98
|
}
|
|
99
99
|
exports.Vp8RtpPayload = Vp8RtpPayload;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vp8.js","sourceRoot":"","sources":["../../../../../rtp/src/codec/vp8.ts"],"names":[],"mappings":";;;AAAA,6CAA0D;AAI1D,8CAA8C;AAE9C,8DAA8D;AAC9D,8DAA8D;AAC9D,yEAAyE;AACzE,8DAA8D;AAC9D,yEAAyE;AACzE,8DAA8D;AAC9D,yEAAyE;AACzE,8DAA8D;AAC9D,8DAA8D;AAC9D,8DAA8D;AAC9D,yEAAyE;AACzE,8DAA8D;AAC9D,yEAAyE;AACzE,8DAA8D;AAE9D,kBAAkB;AAClB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AAEpB,MAAa,aAAa;IAmBxB,MAAM,CAAC,WAAW,CAAC,GAAW;QAC5B,MAAM,CAAC,GAAG,IAAI,aAAa,EAAE,CAAC;QAE9B,IAAI,MAAM,GAAG,CAAC,CAAC;QAEf,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"vp8.js","sourceRoot":"","sources":["../../../../../rtp/src/codec/vp8.ts"],"names":[],"mappings":"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","sourcesContent":["import { getBit, paddingByte } from \"../../../common/src\";\nimport { RtpHeader } from \"../rtp/rtp\";\nimport { DePacketizerBase } from \"./base\";\n\n// RFC 7741 - RTP Payload Format for VP8 Video\n\n// 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7\n// +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+\n// |X|R|N|S|R| PID | (REQUIRED) |X|R|N|S|R| PID | (REQUIRED)\n// +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+\n// X: |I|L|T|K| RSV | (OPTIONAL) X: |I|L|T|K| RSV | (OPTIONAL)\n// +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+\n// I: |M| PictureID | (OPTIONAL) I: |M| PictureID | (OPTIONAL)\n// +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+\n// L: | TL0PICIDX | (OPTIONAL) | PictureID |\n// +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+\n// T/K: |TID|Y| KEYIDX | (OPTIONAL) L: | TL0PICIDX | (OPTIONAL)\n// +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+\n// T/K: |TID|Y| KEYIDX | (OPTIONAL)\n// +-+-+-+-+-+-+-+-+\n\n// 0 1 2 3 4 5 6 7\n// +-+-+-+-+-+-+-+-+\n// |Size0|H| VER |P|\n// +-+-+-+-+-+-+-+-+\n// | Size1 |\n// +-+-+-+-+-+-+-+-+\n// | Size2 |\n// +-+-+-+-+-+-+-+-+\n// | Octets 4..N of|\n// | VP8 payload |\n// : :\n// +-+-+-+-+-+-+-+-+\n// | OPTIONAL RTP |\n// | padding |\n// : :\n// +-+-+-+-+-+-+-+-+\n\nexport class Vp8RtpPayload implements DePacketizerBase {\n xBit!: number;\n nBit!: number;\n sBit!: number;\n pid!: number;\n iBit?: number;\n lBit?: number;\n tBit?: number;\n kBit?: number;\n mBit?: number;\n pictureId?: number;\n payload!: Buffer;\n size0?: number;\n hBit?: number;\n ver?: number;\n pBit?: number;\n size1?: number;\n size2?: number;\n\n static deSerialize(buf: Buffer) {\n const p = new Vp8RtpPayload();\n\n let offset = 0;\n\n p.xBit = getBit(buf[offset], 0);\n p.nBit = getBit(buf[offset], 2);\n p.sBit = getBit(buf[offset], 3);\n p.pid = getBit(buf[offset], 5, 3);\n offset++;\n\n if (p.xBit) {\n p.iBit = getBit(buf[offset], 0);\n p.lBit = getBit(buf[offset], 1);\n p.tBit = getBit(buf[offset], 2);\n p.kBit = getBit(buf[offset], 3);\n offset++;\n }\n\n if (p.iBit) {\n p.mBit = getBit(buf[offset], 0);\n if (p.mBit) {\n const _7 = paddingByte(getBit(buf[offset], 1, 7));\n const _8 = paddingByte(buf[offset + 1]);\n p.pictureId = parseInt(_7 + _8, 2);\n offset += 2;\n } else {\n p.pictureId = getBit(buf[offset], 1, 7);\n offset++;\n }\n }\n\n if (p.lBit) {\n offset++;\n }\n\n if (p.lBit || p.kBit) {\n if (p.tBit) {\n }\n if (p.kBit) {\n }\n offset++;\n }\n\n p.payload = buf.slice(offset);\n\n if (p.sBit === 1 && p.pid === 0) {\n p.size0 = getBit(buf[offset], 0, 3);\n p.hBit = getBit(buf[offset], 3);\n p.ver = getBit(buf[offset], 4, 3);\n p.pBit = getBit(buf[offset], 7);\n offset++;\n }\n\n p.size1 = buf[offset];\n offset++;\n p.size2 = buf[offset];\n offset++;\n\n return p;\n }\n\n static isDetectedFinalPacketInSequence(header: RtpHeader) {\n return header.marker;\n }\n\n get isKeyframe() {\n return this.pBit === 0;\n }\n\n get isPartitionHead() {\n return this.sBit === 1;\n }\n}\n"]}
|
|
@@ -1,19 +1,47 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
2
|
+
import { RtpHeader } from "../rtp/rtp";
|
|
3
|
+
import { DePacketizerBase } from "./base";
|
|
4
|
+
export declare class Vp9RtpPayload implements DePacketizerBase {
|
|
5
|
+
/**Picture ID (PID) present */
|
|
6
|
+
iBit: number;
|
|
7
|
+
/**Inter-picture predicted frame */
|
|
8
|
+
pBit: number;
|
|
9
|
+
/**Layer indices present */
|
|
10
|
+
lBit: number;
|
|
11
|
+
/**Flexible mode */
|
|
12
|
+
fBit: number;
|
|
13
|
+
/**Start of a frame */
|
|
14
|
+
bBit: number;
|
|
15
|
+
/**End of a frame */
|
|
16
|
+
eBit: number;
|
|
17
|
+
/**Scalability structure */
|
|
18
|
+
vBit: number;
|
|
19
|
+
zBit: number;
|
|
11
20
|
m?: number;
|
|
12
21
|
pictureId?: number;
|
|
13
22
|
tid?: number;
|
|
14
23
|
u?: number;
|
|
15
24
|
sid?: number;
|
|
25
|
+
/**inter_layer_predicted */
|
|
16
26
|
d?: number;
|
|
27
|
+
tl0PicIdx?: number;
|
|
28
|
+
pDiff: number[];
|
|
29
|
+
n_s?: number;
|
|
30
|
+
y?: number;
|
|
31
|
+
g?: number;
|
|
32
|
+
width: number[];
|
|
33
|
+
height: number[];
|
|
34
|
+
n_g: number;
|
|
35
|
+
pgT: number[];
|
|
36
|
+
pgU: number[];
|
|
37
|
+
pgP_Diff: number[][];
|
|
38
|
+
payload: Buffer;
|
|
17
39
|
static deSerialize(buf: Buffer): Vp9RtpPayload;
|
|
18
|
-
|
|
40
|
+
static parseRtpPayload(buf: Buffer): {
|
|
41
|
+
offset: number;
|
|
42
|
+
p: Vp9RtpPayload;
|
|
43
|
+
};
|
|
44
|
+
static isDetectedFinalPacketInSequence(header: RtpHeader): boolean;
|
|
45
|
+
get isKeyframe(): boolean;
|
|
46
|
+
get isPartitionHead(): boolean | 0;
|
|
19
47
|
}
|
package/lib/rtp/src/codec/vp9.js
CHANGED
|
@@ -34,39 +34,128 @@ const src_1 = require("../../../common/src");
|
|
|
34
34
|
// | .. |
|
|
35
35
|
// +-+-+-+-+-+-+-+-+
|
|
36
36
|
class Vp9RtpPayload {
|
|
37
|
+
constructor() {
|
|
38
|
+
this.pDiff = [];
|
|
39
|
+
this.width = [];
|
|
40
|
+
this.height = [];
|
|
41
|
+
this.n_g = 0;
|
|
42
|
+
this.pgT = [];
|
|
43
|
+
this.pgU = [];
|
|
44
|
+
this.pgP_Diff = [];
|
|
45
|
+
}
|
|
37
46
|
static deSerialize(buf) {
|
|
38
|
-
const
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
47
|
+
const { p, offset } = this.parseRtpPayload(buf);
|
|
48
|
+
p.payload = buf.slice(offset);
|
|
49
|
+
return p;
|
|
50
|
+
}
|
|
51
|
+
static parseRtpPayload(buf) {
|
|
52
|
+
const p = new Vp9RtpPayload();
|
|
53
|
+
let offset = 0;
|
|
54
|
+
p.iBit = src_1.getBit(buf[offset], 0); // PictureId present .
|
|
55
|
+
p.pBit = src_1.getBit(buf[offset], 1); // Inter-picture predicted.
|
|
56
|
+
p.lBit = src_1.getBit(buf[offset], 2); // Layer indices present.
|
|
57
|
+
p.fBit = src_1.getBit(buf[offset], 3); // Flexible mode.
|
|
58
|
+
p.bBit = src_1.getBit(buf[offset], 4); // Begins frame flag.
|
|
59
|
+
p.eBit = src_1.getBit(buf[offset], 5); // Ends frame flag.
|
|
60
|
+
p.vBit = src_1.getBit(buf[offset], 6); // Scalability structure present.
|
|
61
|
+
p.zBit = src_1.getBit(buf[offset], 7); // Not used for inter-layer prediction
|
|
62
|
+
offset++;
|
|
63
|
+
if (p.iBit) {
|
|
64
|
+
p.m = src_1.getBit(buf[offset], 0);
|
|
65
|
+
if (p.m) {
|
|
66
|
+
const _7 = src_1.paddingByte(src_1.getBit(buf[offset], 1, 7));
|
|
67
|
+
const _8 = src_1.paddingByte(buf[offset + 1]);
|
|
68
|
+
p.pictureId = parseInt(_7 + _8, 2);
|
|
69
|
+
offset += 2;
|
|
56
70
|
}
|
|
57
71
|
else {
|
|
58
|
-
|
|
59
|
-
|
|
72
|
+
p.pictureId = src_1.getBit(buf[offset], 1, 7);
|
|
73
|
+
offset++;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
if (p.lBit) {
|
|
77
|
+
p.tid = src_1.getBit(buf[offset], 0, 3);
|
|
78
|
+
p.u = src_1.getBit(buf[offset], 3);
|
|
79
|
+
p.sid = src_1.getBit(buf[offset], 4, 3);
|
|
80
|
+
p.d = src_1.getBit(buf[offset], 7);
|
|
81
|
+
offset++;
|
|
82
|
+
if (p.fBit === 0) {
|
|
83
|
+
p.tl0PicIdx = buf[offset];
|
|
84
|
+
offset++;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
if (p.fBit && p.pBit) {
|
|
88
|
+
for (;;) {
|
|
89
|
+
p.pDiff = [...p.pDiff, src_1.getBit(buf[offset], 0, 7)];
|
|
90
|
+
const n = src_1.getBit(buf[offset], 7);
|
|
91
|
+
offset++;
|
|
92
|
+
if (n === 0)
|
|
93
|
+
break;
|
|
60
94
|
}
|
|
61
95
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
96
|
+
// Scalability structure (SS):
|
|
97
|
+
//
|
|
98
|
+
// +-+-+-+-+-+-+-+-+
|
|
99
|
+
// V: | N_S |Y|G|-|-|-|
|
|
100
|
+
// +-+-+-+-+-+-+-+-+ -|
|
|
101
|
+
// Y: | WIDTH | (OPTIONAL) .
|
|
102
|
+
// + + .
|
|
103
|
+
// | | (OPTIONAL) .
|
|
104
|
+
// +-+-+-+-+-+-+-+-+ . N_S + 1 times
|
|
105
|
+
// | HEIGHT | (OPTIONAL) .
|
|
106
|
+
// + + .
|
|
107
|
+
// | | (OPTIONAL) .
|
|
108
|
+
// +-+-+-+-+-+-+-+-+ -|
|
|
109
|
+
// G: | N_G | (OPTIONAL)
|
|
110
|
+
// +-+-+-+-+-+-+-+-+ -|
|
|
111
|
+
// N_G: | T |U| R |-|-| (OPTIONAL) .
|
|
112
|
+
// +-+-+-+-+-+-+-+-+ -| . N_G times
|
|
113
|
+
// | P_DIFF | (OPTIONAL) . R times .
|
|
114
|
+
// +-+-+-+-+-+-+-+-+ -| -|
|
|
115
|
+
//
|
|
116
|
+
if (p.vBit) {
|
|
117
|
+
p.n_s = src_1.getBit(buf[offset], 0, 3);
|
|
118
|
+
p.y = src_1.getBit(buf[offset], 3);
|
|
119
|
+
p.g = src_1.getBit(buf[offset], 4);
|
|
120
|
+
offset++;
|
|
121
|
+
if (p.y) {
|
|
122
|
+
[...Array(p.n_s + 1)].forEach(() => {
|
|
123
|
+
p.width.push(buf.readUInt16BE(offset));
|
|
124
|
+
offset += 2;
|
|
125
|
+
p.height.push(buf.readUInt16BE(offset));
|
|
126
|
+
offset += 2;
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
if (p.g) {
|
|
130
|
+
p.n_g = buf[offset];
|
|
131
|
+
offset++;
|
|
132
|
+
}
|
|
133
|
+
if (p.n_g > 0) {
|
|
134
|
+
[...Array(p.n_g).keys()].forEach((i) => {
|
|
135
|
+
p.pgT.push(src_1.getBit(buf[offset], 0, 3));
|
|
136
|
+
p.pgU.push(src_1.getBit(buf[offset], 3));
|
|
137
|
+
const r = src_1.getBit(buf[offset], 4, 2);
|
|
138
|
+
offset++;
|
|
139
|
+
p.pgP_Diff[i] = [];
|
|
140
|
+
if (r > 0) {
|
|
141
|
+
[...Array(r)].forEach(() => {
|
|
142
|
+
p.pgP_Diff[i].push(buf[offset]);
|
|
143
|
+
offset++;
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return { offset, p };
|
|
150
|
+
}
|
|
151
|
+
static isDetectedFinalPacketInSequence(header) {
|
|
152
|
+
return header.marker;
|
|
67
153
|
}
|
|
68
154
|
get isKeyframe() {
|
|
69
|
-
return !this.
|
|
155
|
+
return !!(!this.pBit && this.bBit && (!this.sid || !this.lBit));
|
|
156
|
+
}
|
|
157
|
+
get isPartitionHead() {
|
|
158
|
+
return this.bBit && (!this.lBit || !this.d);
|
|
70
159
|
}
|
|
71
160
|
}
|
|
72
161
|
exports.Vp9RtpPayload = Vp9RtpPayload;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vp9.js","sourceRoot":"","sources":["../../../../../rtp/src/codec/vp9.ts"],"names":[],"mappings":"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","sourcesContent":["// RTP Payload Format for VP9 Video draft-ietf-payload-vp9-16 https://datatracker.ietf.org/doc/html/draft-ietf-payload-vp9\n\nimport { getBit, paddingByte } from \"../../../common/src\";\n\n// 0 1 2 3 4 5 6 7\n// +-+-+-+-+-+-+-+-+\n// |I|P|L|F|B|E|V|Z| (REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// I: |M| PICTURE ID | (REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// M: | EXTENDED PID | (RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// L: | TID |U| SID |D| (Conditionally RECOMMENDED)\n// +-+-+-+-+-+-+-+-+ -\\\n// P,F: | P_DIFF |N| (Conditionally REQUIRED) - up to 3 times\n// +-+-+-+-+-+-+-+-+ -/\n// V: | SS |\n// | .. |\n// +-+-+-+-+-+-+-+-+\n\n// 0 1 2 3 4 5 6 7\n// +-+-+-+-+-+-+-+-+\n// |I|P|L|F|B|E|V|Z| (REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// I: |M| PICTURE ID | (RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// M: | EXTENDED PID | (RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// L: | TID |U| SID |D| (Conditionally RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// | TL0PICIDX | (Conditionally REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// V: | SS |\n// | .. |\n// +-+-+-+-+-+-+-+-+\n\nexport class Vp9RtpPayload {\n i!: number;\n p!: number;\n l!: number;\n f!: number;\n b!: number;\n e!: number;\n v!: number;\n z!: number;\n m?: number;\n pictureId?: number;\n tid?: number;\n u?: number;\n sid?: number;\n d?: number;\n\n static deSerialize(buf: Buffer) {\n const c = new Vp9RtpPayload();\n\n let index = 0;\n\n c.i = getBit(buf[index], 0);\n c.p = getBit(buf[index], 1);\n c.l = getBit(buf[index], 2);\n c.f = getBit(buf[index], 3);\n c.b = getBit(buf[index], 4);\n c.e = getBit(buf[index], 5);\n c.v = getBit(buf[index], 6);\n c.z = getBit(buf[index], 7);\n\n index++;\n\n if (c.i === 1) {\n c.m = getBit(buf[index], 0);\n\n if (c.m === 1) {\n const _7 = paddingByte(getBit(buf[index], 1, 7));\n const _8 = paddingByte(buf[index + 1]);\n c.pictureId = parseInt(_7 + _8, 2);\n index += 2;\n } else {\n c.pictureId = getBit(buf[index], 1, 7);\n index++;\n }\n }\n\n c.tid = getBit(buf[index], 0, 3);\n c.u = getBit(buf[index], 3);\n c.sid = getBit(buf[index], 4, 3);\n c.d = getBit(buf[index], 7);\n\n return c;\n }\n\n get isKeyframe() {\n return !this.p && this.b && (!this.sid || !this.l);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"vp9.js","sourceRoot":"","sources":["../../../../../rtp/src/codec/vp9.ts"],"names":[],"mappings":"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","sourcesContent":["// RTP Payload Format for VP9 Video draft-ietf-payload-vp9-16 https://datatracker.ietf.org/doc/html/draft-ietf-payload-vp9\n\nimport { getBit, paddingByte } from \"../../../common/src\";\nimport { RtpHeader } from \"../rtp/rtp\";\nimport { DePacketizerBase } from \"./base\";\n\n// 0 1 2 3 4 5 6 7\n// +-+-+-+-+-+-+-+-+\n// |I|P|L|F|B|E|V|Z| (REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// I: |M| PICTURE ID | (REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// M: | EXTENDED PID | (RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// L: | TID |U| SID |D| (Conditionally RECOMMENDED)\n// +-+-+-+-+-+-+-+-+ -\\\n// P,F: | P_DIFF |N| (Conditionally REQUIRED) - up to 3 times\n// +-+-+-+-+-+-+-+-+ -/\n// V: | SS |\n// | .. |\n// +-+-+-+-+-+-+-+-+\n\n// 0 1 2 3 4 5 6 7\n// +-+-+-+-+-+-+-+-+\n// |I|P|L|F|B|E|V|Z| (REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// I: |M| PICTURE ID | (RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// M: | EXTENDED PID | (RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// L: | TID |U| SID |D| (Conditionally RECOMMENDED)\n// +-+-+-+-+-+-+-+-+\n// | TL0PICIDX | (Conditionally REQUIRED)\n// +-+-+-+-+-+-+-+-+\n// V: | SS |\n// | .. |\n// +-+-+-+-+-+-+-+-+\n\nexport class Vp9RtpPayload implements DePacketizerBase {\n /**Picture ID (PID) present */\n iBit!: number;\n /**Inter-picture predicted frame */\n pBit!: number;\n /**Layer indices present */\n lBit!: number;\n /**Flexible mode */\n fBit!: number;\n /**Start of a frame */\n bBit!: number;\n /**End of a frame */\n eBit!: number;\n /**Scalability structure */\n vBit!: number;\n zBit!: number;\n m?: number;\n pictureId?: number;\n tid?: number;\n u?: number;\n sid?: number;\n /**inter_layer_predicted */\n d?: number;\n tl0PicIdx?: number;\n pDiff: number[] = [];\n n_s?: number;\n y?: number;\n g?: number;\n width: number[] = [];\n height: number[] = [];\n n_g: number = 0;\n pgT: number[] = [];\n pgU: number[] = [];\n pgP_Diff: number[][] = [];\n payload!: Buffer;\n\n static deSerialize(buf: Buffer) {\n const { p, offset } = this.parseRtpPayload(buf);\n p.payload = buf.slice(offset);\n return p;\n }\n\n static parseRtpPayload(buf: Buffer) {\n const p = new Vp9RtpPayload();\n let offset = 0;\n\n p.iBit = getBit(buf[offset], 0); // PictureId present .\n p.pBit = getBit(buf[offset], 1); // Inter-picture predicted.\n p.lBit = getBit(buf[offset], 2); // Layer indices present.\n p.fBit = getBit(buf[offset], 3); // Flexible mode.\n p.bBit = getBit(buf[offset], 4); // Begins frame flag.\n p.eBit = getBit(buf[offset], 5); // Ends frame flag.\n p.vBit = getBit(buf[offset], 6); // Scalability structure present.\n p.zBit = getBit(buf[offset], 7); // Not used for inter-layer prediction\n offset++;\n\n if (p.iBit) {\n p.m = getBit(buf[offset], 0);\n\n if (p.m) {\n const _7 = paddingByte(getBit(buf[offset], 1, 7));\n const _8 = paddingByte(buf[offset + 1]);\n p.pictureId = parseInt(_7 + _8, 2);\n offset += 2;\n } else {\n p.pictureId = getBit(buf[offset], 1, 7);\n offset++;\n }\n }\n\n if (p.lBit) {\n p.tid = getBit(buf[offset], 0, 3);\n p.u = getBit(buf[offset], 3);\n p.sid = getBit(buf[offset], 4, 3);\n p.d = getBit(buf[offset], 7);\n offset++;\n if (p.fBit === 0) {\n p.tl0PicIdx = buf[offset];\n offset++;\n }\n }\n\n if (p.fBit && p.pBit) {\n for (;;) {\n p.pDiff = [...p.pDiff, getBit(buf[offset], 0, 7)];\n const n = getBit(buf[offset], 7);\n offset++;\n if (n === 0) break;\n }\n }\n\n // Scalability structure (SS):\n //\n // +-+-+-+-+-+-+-+-+\n // V: | N_S |Y|G|-|-|-|\n // +-+-+-+-+-+-+-+-+ -|\n // Y: | WIDTH | (OPTIONAL) .\n // + + .\n // | | (OPTIONAL) .\n // +-+-+-+-+-+-+-+-+ . N_S + 1 times\n // | HEIGHT | (OPTIONAL) .\n // + + .\n // | | (OPTIONAL) .\n // +-+-+-+-+-+-+-+-+ -|\n // G: | N_G | (OPTIONAL)\n // +-+-+-+-+-+-+-+-+ -|\n // N_G: | T |U| R |-|-| (OPTIONAL) .\n // +-+-+-+-+-+-+-+-+ -| . N_G times\n // | P_DIFF | (OPTIONAL) . R times .\n // +-+-+-+-+-+-+-+-+ -| -|\n //\n if (p.vBit) {\n p.n_s = getBit(buf[offset], 0, 3);\n p.y = getBit(buf[offset], 3);\n p.g = getBit(buf[offset], 4);\n offset++;\n\n if (p.y) {\n [...Array(p.n_s + 1)].forEach(() => {\n p.width.push(buf.readUInt16BE(offset));\n offset += 2;\n p.height.push(buf.readUInt16BE(offset));\n offset += 2;\n });\n }\n\n if (p.g) {\n p.n_g = buf[offset];\n offset++;\n }\n\n if (p.n_g > 0) {\n [...Array(p.n_g).keys()].forEach((i) => {\n p.pgT.push(getBit(buf[offset], 0, 3));\n p.pgU.push(getBit(buf[offset], 3));\n const r = getBit(buf[offset], 4, 2);\n offset++;\n\n p.pgP_Diff[i] = [];\n if (r > 0) {\n [...Array(r)].forEach(() => {\n p.pgP_Diff[i].push(buf[offset]);\n offset++;\n });\n }\n });\n }\n }\n return { offset, p };\n }\n\n static isDetectedFinalPacketInSequence(header: RtpHeader) {\n return header.marker;\n }\n\n get isKeyframe() {\n return !!(!this.pBit && this.bBit && (!this.sid || !this.lBit));\n }\n\n get isPartitionHead() {\n return this.bBit && (!this.lBit || !this.d);\n }\n}\n"]}
|
|
@@ -47,6 +47,8 @@ class WebmFactory {
|
|
|
47
47
|
return new sampleBuilder_1.SampleBuilder(src_2.Vp8RtpPayload, 90000);
|
|
48
48
|
case "h264":
|
|
49
49
|
return new sampleBuilder_1.SampleBuilder(src_2.H264RtpPayload, 90000);
|
|
50
|
+
case "vp9":
|
|
51
|
+
return new sampleBuilder_1.SampleBuilder(src_2.Vp9RtpPayload, 90000);
|
|
50
52
|
}
|
|
51
53
|
}
|
|
52
54
|
else {
|
|
@@ -193,22 +195,50 @@ function createSimpleBlock(data, isKeyframe, relativeTimestamp, trackNumber) {
|
|
|
193
195
|
function createTrackEntries(tracks, options = {}) {
|
|
194
196
|
return tracks.map((track, i) => {
|
|
195
197
|
if (track.kind === "video") {
|
|
198
|
+
const codec = track.codec?.name.toLocaleLowerCase();
|
|
196
199
|
const codecName = (() => {
|
|
197
|
-
switch (
|
|
200
|
+
switch (codec) {
|
|
198
201
|
case "vp8":
|
|
199
202
|
return "VP8";
|
|
200
203
|
case "h264":
|
|
201
204
|
return "MPEG4/ISO/AVC";
|
|
205
|
+
case "vp9":
|
|
206
|
+
return "VP9";
|
|
202
207
|
default:
|
|
203
208
|
throw new Error();
|
|
204
209
|
}
|
|
205
210
|
})();
|
|
206
|
-
|
|
211
|
+
const trackElements = [
|
|
207
212
|
EBML.element(EBML.ID.Video, [
|
|
208
213
|
EBML.element(EBML.ID.PixelWidth, EBML.number(options.width)),
|
|
209
214
|
EBML.element(EBML.ID.PixelHeight, EBML.number(options.height)),
|
|
210
215
|
]),
|
|
211
|
-
]
|
|
216
|
+
];
|
|
217
|
+
if (codec === "vp9") {
|
|
218
|
+
const profile = Buffer.concat([
|
|
219
|
+
new src_1.BitWriter(8).set(1, 0, 0).set(7, 1, 1).buffer,
|
|
220
|
+
src_1.bufferWriter([1, 1], [1, 0]),
|
|
221
|
+
]);
|
|
222
|
+
// const level = Buffer.concat([
|
|
223
|
+
// new BitWriter(8).set(1, 0, 0).set(7, 1, 2).buffer,
|
|
224
|
+
// bufferWriter([1, 1], [1, 10]),
|
|
225
|
+
// ]);
|
|
226
|
+
// const bitDepth = Buffer.concat([
|
|
227
|
+
// new BitWriter(8).set(1, 0, 0).set(7, 1, 3).buffer,
|
|
228
|
+
// bufferWriter([1, 1], [1, 8]),
|
|
229
|
+
// ]);
|
|
230
|
+
// const chroma = Buffer.concat([
|
|
231
|
+
// new BitWriter(8).set(1, 0, 0).set(7, 1, 4).buffer,
|
|
232
|
+
// bufferWriter([1, 1], [1, 0]),
|
|
233
|
+
// ]);
|
|
234
|
+
// trackElements.push(
|
|
235
|
+
// EBML.element(
|
|
236
|
+
// EBML.ID.CodecPrivate,
|
|
237
|
+
// EBML.bytes(Buffer.concat([profile]))
|
|
238
|
+
// )
|
|
239
|
+
// );
|
|
240
|
+
}
|
|
241
|
+
return createTrackEntry(i + 1, codecName, "video", trackElements);
|
|
212
242
|
}
|
|
213
243
|
else {
|
|
214
244
|
return createTrackEntry(i + 1, "OPUS", "audio", [
|
|
@@ -240,16 +270,13 @@ function createSegment(entries, infoElements = []) {
|
|
|
240
270
|
EBML.element(EBML.ID.SeekHead, []),
|
|
241
271
|
EBML.element(EBML.ID.Info, [
|
|
242
272
|
EBML.element(EBML.ID.TimecodeScale, EBML.number(millisecond)),
|
|
243
|
-
EBML.element(EBML.ID.MuxingApp, EBML.string("
|
|
244
|
-
EBML.element(EBML.ID.WritingApp, EBML.string("
|
|
273
|
+
EBML.element(EBML.ID.MuxingApp, EBML.string("webrtc")),
|
|
274
|
+
EBML.element(EBML.ID.WritingApp, EBML.string("webrtc")),
|
|
245
275
|
...infoElements,
|
|
246
276
|
]),
|
|
247
277
|
EBML.element(EBML.ID.Tracks, entries),
|
|
248
278
|
]);
|
|
249
279
|
}
|
|
250
|
-
const millisecond = 1000000;
|
|
251
|
-
/**32767 */
|
|
252
|
-
const MaxSinged16Int = (0x01 << 16) / 2 - 1;
|
|
253
280
|
class CuePoint {
|
|
254
281
|
constructor(trackNumber, relativeTimestamp, position) {
|
|
255
282
|
this.trackNumber = trackNumber;
|
|
@@ -274,4 +301,8 @@ class CuePoint {
|
|
|
274
301
|
function getCues(cuePoints) {
|
|
275
302
|
return EBML.build(EBML.element(EBML.ID.Cues, cuePoints.map((cue) => cue.build())));
|
|
276
303
|
}
|
|
304
|
+
const millisecond = 1000000;
|
|
305
|
+
/**32767 */
|
|
306
|
+
const MaxSinged16Int = (0x01 << 16) / 2 - 1;
|
|
307
|
+
const supportedVideoCodecs = ["h264", "vp8", "vp9"];
|
|
277
308
|
//# sourceMappingURL=webm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"webm.js","sourceRoot":"","sources":["../../../../src/nonstandard/webm.ts"],"names":[],"mappings":"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","sourcesContent":["import * as EBML from \"@shinyoshiaki/ebml-builder\";\nimport { debug } from \"debug\";\nimport { appendFile, readFile, writeFile } from \"fs/promises\";\n\nimport {\n BitWriter,\n BufferChain,\n bufferWriter,\n bufferWriterLE,\n} from \"../../../common/src\";\nimport {\n H264RtpPayload,\n OpusRtpPayload,\n Vp8RtpPayload,\n} from \"../../../rtp/src\";\nimport { PromiseQueue } from \"../helper\";\nimport { MediaStreamTrack } from \"../media/track\";\nimport { SampleBuilder } from \"./sampleBuilder\";\n\nconst log = debug(\"werift:packages/webrtc/src/nonstandard/webm.ts\");\n\nexport class WebmFactory {\n private relativeTimestamp = 0;\n private disposer?: () => void;\n private position = 0;\n private staticPartOffset = 0;\n private queue = new PromiseQueue();\n\n /**video cuePoints (keyframe) */\n private cuePoints: CuePoint[] = [];\n private tracks: {\n audio?: {\n trackNumber: number;\n track: MediaStreamTrack;\n sampleBuilder: SampleBuilder;\n };\n video?: {\n trackNumber: number;\n track: MediaStreamTrack;\n sampleBuilder: SampleBuilder;\n };\n } = {};\n\n constructor(\n tracks: MediaStreamTrack[],\n public path: string,\n public options: TrackOptions = {}\n ) {\n tracks.forEach((track, i) => {\n const sampleBuilder = (() => {\n if (track.kind === \"video\") {\n switch (track.codec?.name.toLocaleLowerCase()) {\n case \"vp8\":\n return new SampleBuilder(Vp8RtpPayload, 90000);\n case \"h264\":\n return new SampleBuilder(H264RtpPayload, 90000);\n }\n } else {\n return new SampleBuilder(OpusRtpPayload, 48000);\n }\n })();\n this.tracks[track.kind] = { track, trackNumber: i + 1, sampleBuilder };\n });\n }\n\n async start() {\n const entries = createTrackEntries(\n Object.values(this.tracks).map(({ track }) => track),\n this.options\n );\n const segment = EBML.build(createSegment(entries));\n const staticPart = Buffer.concat([ebmlHeader, segment]);\n this.staticPartOffset = staticPart.length;\n\n await writeFile(this.path, staticPart);\n this.position += staticPart.length;\n\n const length = await this.appendCluster(0.0);\n this.appendCuePoint(0.0);\n this.position += length;\n\n const disposers = Object.values(this.tracks).map(\n ({ track, sampleBuilder, trackNumber }) => {\n const appendCluster = async () => {\n if (sampleBuilder.relativeTimestamp === 0) return;\n\n this.relativeTimestamp += sampleBuilder.relativeTimestamp;\n\n const length = await this.appendCluster(this.relativeTimestamp);\n this.appendCuePoint(this.relativeTimestamp);\n this.position += length;\n\n Object.values(this.tracks).forEach(({ sampleBuilder }) =>\n sampleBuilder.resetTimestamp()\n );\n };\n\n const { unSubscribe } = track.onReceiveRtp.subscribe((rtp) => {\n this.queue.push(async () => {\n {\n const frame = sampleBuilder.DePacketizer.deSerialize(rtp.payload);\n if (track.kind === \"video\" && frame.isKeyframe) {\n await appendCluster();\n } else if (sampleBuilder.relativeTimestamp >= MaxSinged16Int) {\n await appendCluster();\n }\n\n sampleBuilder.push(rtp);\n const res = sampleBuilder.build();\n if (!res) return;\n const { data, relativeTimestamp, isKeyframe } = res;\n if (relativeTimestamp >= MaxSinged16Int) {\n log(\"relativeTimestamp exceeded\", relativeTimestamp);\n return;\n }\n\n if (track.kind === \"video\") {\n const [cuePoint] = this.cuePoints.slice(-1);\n cuePoint.blockNumber++;\n }\n\n await this.write(\n data,\n isKeyframe,\n relativeTimestamp,\n trackNumber\n );\n }\n });\n });\n return unSubscribe;\n }\n );\n this.disposer = () => {\n disposers.forEach((unSubscribe) => unSubscribe());\n };\n }\n\n async stop() {\n await this.queue.push(async () => {\n if (!this.disposer) {\n throw new Error();\n }\n this.disposer();\n\n const latestTimestamp = Object.values(this.tracks)\n .map(({ sampleBuilder }) => sampleBuilder)\n .sort(\n (a, b) => a.relativeTimestamp - b.relativeTimestamp\n )[0].relativeTimestamp;\n const duration = this.relativeTimestamp + latestTimestamp;\n\n const entries = createTrackEntries(\n Object.values(this.tracks).map(({ track }) => track),\n this.options\n );\n const segment = EBML.build(\n createSegment(entries, [\n EBML.element(EBML.ID.Duration, EBML.float(duration)),\n ])\n );\n\n const staticPart = Buffer.concat([ebmlHeader, segment]);\n const staticPartGap = staticPart.length - this.staticPartOffset;\n\n let cueSize = 0;\n let cues = getCues(this.cuePoints);\n while (cueSize !== cues.length) {\n cueSize = cues.length;\n this.cuePoints.forEach((cue) => {\n cue.clusterOffset = staticPartGap + cueSize;\n });\n cues = getCues(this.cuePoints);\n }\n\n const clusters = (await readFile(this.path)).slice(this.staticPartOffset);\n\n await writeFile(this.path, staticPart);\n await appendFile(this.path, cues);\n await appendFile(this.path, clusters);\n });\n }\n\n private async write(\n data: Buffer,\n isKeyframe: boolean,\n relativeTimestamp: number,\n trackNumber: number\n ) {\n const simpleBlock = createSimpleBlock(\n data,\n isKeyframe,\n relativeTimestamp,\n trackNumber\n );\n this.position += simpleBlock.length;\n\n await appendFile(this.path, simpleBlock);\n }\n\n private async appendCluster(timecode: number) {\n const buf = EBML.build(\n EBML.unknownSizeElement(EBML.ID.Cluster, [\n EBML.element(EBML.ID.Timecode, EBML.number(timecode)),\n ])\n );\n await appendFile(this.path, buf);\n return buf.length;\n }\n\n private appendCuePoint(timecode: number) {\n const trackNumber = this.tracks?.video?.trackNumber;\n if (trackNumber != undefined) {\n this.cuePoints.push(new CuePoint(trackNumber, timecode, this.position));\n }\n }\n}\n\n///////////////////////////////////////////////\n\nconst ebmlHeader = EBML.build(\n EBML.element(EBML.ID.EBML, [\n EBML.element(EBML.ID.EBMLVersion, EBML.number(1)),\n EBML.element(EBML.ID.EBMLReadVersion, EBML.number(1)),\n EBML.element(EBML.ID.EBMLMaxIDLength, EBML.number(4)),\n EBML.element(EBML.ID.EBMLMaxSizeLength, EBML.number(8)),\n EBML.element(EBML.ID.DocType, EBML.string(\"webm\")),\n EBML.element(EBML.ID.DocTypeVersion, EBML.number(2)),\n EBML.element(EBML.ID.DocTypeReadVersion, EBML.number(2)),\n ])\n);\n\nfunction createSimpleBlock(\n data: Buffer,\n isKeyframe: boolean,\n relativeTimestamp: number,\n trackNumber: number\n) {\n const elementId = Buffer.from([0xa3]);\n const contentSize: Uint8Array = EBML.vintEncodedNumber(\n 1 + 2 + 1 + data.length\n ).bytes;\n\n const flags = new BitWriter(8);\n const keyframe = isKeyframe ? 1 : 0;\n flags.set(1, 0, keyframe);\n flags.set(3, 1, 0);\n flags.set(1, 4, 0);\n flags.set(2, 5, 0);\n flags.set(1, 7, 0);\n\n const simpleBlock = Buffer.concat([\n elementId,\n contentSize,\n EBML.vintEncodedNumber(trackNumber).bytes,\n new BufferChain(2).writeInt16BE(relativeTimestamp).buffer,\n new BufferChain(1).writeUInt8(flags.value).buffer,\n data,\n ]);\n return simpleBlock;\n}\n\nfunction createTrackEntries(\n tracks: MediaStreamTrack[],\n options: TrackOptions = {}\n) {\n return tracks.map((track, i) => {\n if (track.kind === \"video\") {\n const codecName = (() => {\n switch (track.codec?.name.toLocaleLowerCase()) {\n case \"vp8\":\n return \"VP8\";\n case \"h264\":\n return \"MPEG4/ISO/AVC\";\n default:\n throw new Error();\n }\n })();\n return createTrackEntry(i + 1, codecName, \"video\", [\n EBML.element(EBML.ID.Video, [\n EBML.element(EBML.ID.PixelWidth, EBML.number(options.width)),\n EBML.element(EBML.ID.PixelHeight, EBML.number(options.height)),\n ]),\n ]);\n } else {\n return createTrackEntry(i + 1, \"OPUS\", \"audio\", [\n EBML.element(EBML.ID.Audio, [\n EBML.element(EBML.ID.SamplingFrequency, EBML.float(48000.0)),\n EBML.element(EBML.ID.Channels, EBML.number(2)),\n ]),\n EBML.element(\n EBML.ID.CodecPrivate,\n EBML.bytes(\n Buffer.concat([\n Buffer.from(\"OpusHead\"),\n bufferWriter([1, 1], [1, 2]),\n bufferWriterLE([2, 4, 2, 1], [312, 48000, 0, 0]),\n ])\n )\n ),\n ]);\n }\n });\n}\n\nfunction createTrackEntry(\n trackNumber: number,\n codec: string,\n type: \"audio\" | \"video\",\n elements: EBML.EBMLData[] = []\n) {\n return EBML.element(EBML.ID.TrackEntry, [\n EBML.element(EBML.ID.TrackNumber, EBML.number(trackNumber)),\n EBML.element(EBML.ID.TrackUID, EBML.number(trackNumber)),\n EBML.element(EBML.ID.CodecName, EBML.string(codec)),\n EBML.element(EBML.ID.TrackType, EBML.number(type === \"video\" ? 1 : 2)),\n EBML.element(\n EBML.ID.CodecID,\n EBML.string(`${type === \"video\" ? \"V\" : \"A\"}_${codec}`)\n ),\n ...elements,\n ]);\n}\n\nfunction createSegment(\n entries: EBML.EBMLData[],\n infoElements: EBML.EBMLData[] = []\n) {\n return EBML.unknownSizeElement(EBML.ID.Segment, [\n EBML.element(EBML.ID.SeekHead, []),\n EBML.element(EBML.ID.Info, [\n EBML.element(EBML.ID.TimecodeScale, EBML.number(millisecond)),\n EBML.element(EBML.ID.MuxingApp, EBML.string(\"werift\")),\n EBML.element(EBML.ID.WritingApp, EBML.string(\"werift\")),\n ...infoElements,\n ]),\n EBML.element(EBML.ID.Tracks, entries),\n ]);\n}\n\nconst millisecond = 1000000;\n/**32767 */\nconst MaxSinged16Int = (0x01 << 16) / 2 - 1;\n\ntype TrackOptions = Partial<{ width: number; height: number }>;\n\nclass CuePoint {\n private readonly seekHeadPosition = 48;\n clusterOffset: number = 0;\n blockNumber = 0;\n\n constructor(\n private trackNumber: number,\n private relativeTimestamp: number,\n private position: number\n ) {}\n\n build() {\n const cue = EBML.element(EBML.ID.CuePoint, [\n EBML.element(EBML.ID.CueTime, EBML.number(this.relativeTimestamp)),\n EBML.element(EBML.ID.CueTrackPositions, [\n EBML.element(EBML.ID.CueTrack, EBML.number(this.trackNumber)),\n EBML.element(\n EBML.ID.CueClusterPosition,\n EBML.number(\n this.clusterOffset + this.position - this.seekHeadPosition\n )\n ),\n EBML.element(EBML.ID.CueBlockNumber, EBML.number(this.blockNumber)),\n ]),\n ]);\n return cue;\n }\n}\n\nfunction getCues(cuePoints: CuePoint[]) {\n return EBML.build(\n EBML.element(\n EBML.ID.Cues,\n cuePoints.map((cue) => cue.build())\n )\n );\n}\n"]}
|
|
1
|
+
{"version":3,"file":"webm.js","sourceRoot":"","sources":["../../../../src/nonstandard/webm.ts"],"names":[],"mappings":"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","sourcesContent":["import * as EBML from \"@shinyoshiaki/ebml-builder\";\nimport { debug } from \"debug\";\nimport { appendFile, readFile, writeFile } from \"fs/promises\";\n\nimport {\n BitWriter,\n BufferChain,\n bufferWriter,\n bufferWriterLE,\n} from \"../../../common/src\";\nimport {\n H264RtpPayload,\n OpusRtpPayload,\n Vp8RtpPayload,\n Vp9RtpPayload,\n} from \"../../../rtp/src\";\nimport { PromiseQueue } from \"../helper\";\nimport { MediaStreamTrack } from \"../media/track\";\nimport { SampleBuilder } from \"./sampleBuilder\";\n\nconst log = debug(\"werift:packages/webrtc/src/nonstandard/webm.ts\");\n\nexport class WebmFactory {\n private relativeTimestamp = 0;\n private disposer?: () => void;\n private position = 0;\n private staticPartOffset = 0;\n private queue = new PromiseQueue();\n\n /**video cuePoints (keyframe) */\n private cuePoints: CuePoint[] = [];\n private tracks: {\n audio?: {\n trackNumber: number;\n track: MediaStreamTrack;\n sampleBuilder: SampleBuilder;\n };\n video?: {\n trackNumber: number;\n track: MediaStreamTrack;\n sampleBuilder: SampleBuilder;\n };\n } = {};\n\n constructor(\n tracks: MediaStreamTrack[],\n public path: string,\n public options: TrackOptions = {}\n ) {\n tracks.forEach((track, i) => {\n const sampleBuilder = (() => {\n if (track.kind === \"video\") {\n switch (\n track.codec?.name.toLocaleLowerCase() as SupportedVideoCodec\n ) {\n case \"vp8\":\n return new SampleBuilder(Vp8RtpPayload, 90000);\n case \"h264\":\n return new SampleBuilder(H264RtpPayload, 90000);\n case \"vp9\":\n return new SampleBuilder(Vp9RtpPayload, 90000);\n }\n } else {\n return new SampleBuilder(OpusRtpPayload, 48000);\n }\n })();\n this.tracks[track.kind] = { track, trackNumber: i + 1, sampleBuilder };\n });\n }\n\n async start() {\n const entries = createTrackEntries(\n Object.values(this.tracks).map(({ track }) => track),\n this.options\n );\n const segment = EBML.build(createSegment(entries));\n const staticPart = Buffer.concat([ebmlHeader, segment]);\n this.staticPartOffset = staticPart.length;\n\n await writeFile(this.path, staticPart);\n this.position += staticPart.length;\n\n const length = await this.appendCluster(0.0);\n this.appendCuePoint(0.0);\n this.position += length;\n\n const disposers = Object.values(this.tracks).map(\n ({ track, sampleBuilder, trackNumber }) => {\n const appendCluster = async () => {\n if (sampleBuilder.relativeTimestamp === 0) return;\n\n this.relativeTimestamp += sampleBuilder.relativeTimestamp;\n\n const length = await this.appendCluster(this.relativeTimestamp);\n this.appendCuePoint(this.relativeTimestamp);\n this.position += length;\n\n Object.values(this.tracks).forEach(({ sampleBuilder }) =>\n sampleBuilder.resetTimestamp()\n );\n };\n\n const { unSubscribe } = track.onReceiveRtp.subscribe((rtp) => {\n this.queue.push(async () => {\n {\n const frame = sampleBuilder.DePacketizer.deSerialize(rtp.payload);\n if (track.kind === \"video\" && frame.isKeyframe) {\n await appendCluster();\n } else if (sampleBuilder.relativeTimestamp >= MaxSinged16Int) {\n await appendCluster();\n }\n\n sampleBuilder.push(rtp);\n const res = sampleBuilder.build();\n if (!res) return;\n const { data, relativeTimestamp, isKeyframe } = res;\n if (relativeTimestamp >= MaxSinged16Int) {\n log(\"relativeTimestamp exceeded\", relativeTimestamp);\n return;\n }\n\n if (track.kind === \"video\") {\n const [cuePoint] = this.cuePoints.slice(-1);\n cuePoint.blockNumber++;\n }\n\n await this.write(\n data,\n isKeyframe,\n relativeTimestamp,\n trackNumber\n );\n }\n });\n });\n return unSubscribe;\n }\n );\n this.disposer = () => {\n disposers.forEach((unSubscribe) => unSubscribe());\n };\n }\n\n async stop() {\n await this.queue.push(async () => {\n if (!this.disposer) {\n throw new Error();\n }\n this.disposer();\n\n const latestTimestamp = Object.values(this.tracks)\n .map(({ sampleBuilder }) => sampleBuilder)\n .sort(\n (a, b) => a.relativeTimestamp - b.relativeTimestamp\n )[0].relativeTimestamp;\n const duration = this.relativeTimestamp + latestTimestamp;\n\n const entries = createTrackEntries(\n Object.values(this.tracks).map(({ track }) => track),\n this.options\n );\n const segment = EBML.build(\n createSegment(entries, [\n EBML.element(EBML.ID.Duration, EBML.float(duration)),\n ])\n );\n\n const staticPart = Buffer.concat([ebmlHeader, segment]);\n const staticPartGap = staticPart.length - this.staticPartOffset;\n\n let cueSize = 0;\n let cues = getCues(this.cuePoints);\n while (cueSize !== cues.length) {\n cueSize = cues.length;\n this.cuePoints.forEach((cue) => {\n cue.clusterOffset = staticPartGap + cueSize;\n });\n cues = getCues(this.cuePoints);\n }\n\n const clusters = (await readFile(this.path)).slice(this.staticPartOffset);\n\n await writeFile(this.path, staticPart);\n await appendFile(this.path, cues);\n await appendFile(this.path, clusters);\n });\n }\n\n private async write(\n data: Buffer,\n isKeyframe: boolean,\n relativeTimestamp: number,\n trackNumber: number\n ) {\n const simpleBlock = createSimpleBlock(\n data,\n isKeyframe,\n relativeTimestamp,\n trackNumber\n );\n this.position += simpleBlock.length;\n\n await appendFile(this.path, simpleBlock);\n }\n\n private async appendCluster(timecode: number) {\n const buf = EBML.build(\n EBML.unknownSizeElement(EBML.ID.Cluster, [\n EBML.element(EBML.ID.Timecode, EBML.number(timecode)),\n ])\n );\n await appendFile(this.path, buf);\n return buf.length;\n }\n\n private appendCuePoint(timecode: number) {\n const trackNumber = this.tracks?.video?.trackNumber;\n if (trackNumber != undefined) {\n this.cuePoints.push(new CuePoint(trackNumber, timecode, this.position));\n }\n }\n}\n\n///////////////////////////////////////////////\n\nconst ebmlHeader = EBML.build(\n EBML.element(EBML.ID.EBML, [\n EBML.element(EBML.ID.EBMLVersion, EBML.number(1)),\n EBML.element(EBML.ID.EBMLReadVersion, EBML.number(1)),\n EBML.element(EBML.ID.EBMLMaxIDLength, EBML.number(4)),\n EBML.element(EBML.ID.EBMLMaxSizeLength, EBML.number(8)),\n EBML.element(EBML.ID.DocType, EBML.string(\"webm\")),\n EBML.element(EBML.ID.DocTypeVersion, EBML.number(2)),\n EBML.element(EBML.ID.DocTypeReadVersion, EBML.number(2)),\n ])\n);\n\nfunction createSimpleBlock(\n data: Buffer,\n isKeyframe: boolean,\n relativeTimestamp: number,\n trackNumber: number\n) {\n const elementId = Buffer.from([0xa3]);\n const contentSize: Uint8Array = EBML.vintEncodedNumber(\n 1 + 2 + 1 + data.length\n ).bytes;\n\n const flags = new BitWriter(8);\n const keyframe = isKeyframe ? 1 : 0;\n flags.set(1, 0, keyframe);\n flags.set(3, 1, 0);\n flags.set(1, 4, 0);\n flags.set(2, 5, 0);\n flags.set(1, 7, 0);\n\n const simpleBlock = Buffer.concat([\n elementId,\n contentSize,\n EBML.vintEncodedNumber(trackNumber).bytes,\n new BufferChain(2).writeInt16BE(relativeTimestamp).buffer,\n new BufferChain(1).writeUInt8(flags.value).buffer,\n data,\n ]);\n return simpleBlock;\n}\n\nfunction createTrackEntries(\n tracks: MediaStreamTrack[],\n options: TrackOptions = {}\n) {\n return tracks.map((track, i) => {\n if (track.kind === \"video\") {\n const codec =\n track.codec?.name.toLocaleLowerCase() as SupportedVideoCodec;\n const codecName = (() => {\n switch (codec) {\n case \"vp8\":\n return \"VP8\";\n case \"h264\":\n return \"MPEG4/ISO/AVC\";\n case \"vp9\":\n return \"VP9\";\n default:\n throw new Error();\n }\n })();\n const trackElements = [\n EBML.element(EBML.ID.Video, [\n EBML.element(EBML.ID.PixelWidth, EBML.number(options.width)),\n EBML.element(EBML.ID.PixelHeight, EBML.number(options.height)),\n ]),\n ];\n if (codec === \"vp9\") {\n const profile = Buffer.concat([\n new BitWriter(8).set(1, 0, 0).set(7, 1, 1).buffer,\n bufferWriter([1, 1], [1, 0]),\n ]);\n // const level = Buffer.concat([\n // new BitWriter(8).set(1, 0, 0).set(7, 1, 2).buffer,\n // bufferWriter([1, 1], [1, 10]),\n // ]);\n // const bitDepth = Buffer.concat([\n // new BitWriter(8).set(1, 0, 0).set(7, 1, 3).buffer,\n // bufferWriter([1, 1], [1, 8]),\n // ]);\n // const chroma = Buffer.concat([\n // new BitWriter(8).set(1, 0, 0).set(7, 1, 4).buffer,\n // bufferWriter([1, 1], [1, 0]),\n // ]);\n\n // trackElements.push(\n // EBML.element(\n // EBML.ID.CodecPrivate,\n // EBML.bytes(Buffer.concat([profile]))\n // )\n // );\n }\n return createTrackEntry(i + 1, codecName, \"video\", trackElements);\n } else {\n return createTrackEntry(i + 1, \"OPUS\", \"audio\", [\n EBML.element(EBML.ID.Audio, [\n EBML.element(EBML.ID.SamplingFrequency, EBML.float(48000.0)),\n EBML.element(EBML.ID.Channels, EBML.number(2)),\n ]),\n EBML.element(\n EBML.ID.CodecPrivate,\n EBML.bytes(\n Buffer.concat([\n Buffer.from(\"OpusHead\"),\n bufferWriter([1, 1], [1, 2]),\n bufferWriterLE([2, 4, 2, 1], [312, 48000, 0, 0]),\n ])\n )\n ),\n ]);\n }\n });\n}\n\nfunction createTrackEntry(\n trackNumber: number,\n codec: string,\n type: \"audio\" | \"video\",\n elements: EBML.EBMLData[] = []\n) {\n return EBML.element(EBML.ID.TrackEntry, [\n EBML.element(EBML.ID.TrackNumber, EBML.number(trackNumber)),\n EBML.element(EBML.ID.TrackUID, EBML.number(trackNumber)),\n EBML.element(EBML.ID.CodecName, EBML.string(codec)),\n EBML.element(EBML.ID.TrackType, EBML.number(type === \"video\" ? 1 : 2)),\n EBML.element(\n EBML.ID.CodecID,\n EBML.string(`${type === \"video\" ? \"V\" : \"A\"}_${codec}`)\n ),\n ...elements,\n ]);\n}\n\nfunction createSegment(\n entries: EBML.EBMLData[],\n infoElements: EBML.EBMLData[] = []\n) {\n return EBML.unknownSizeElement(EBML.ID.Segment, [\n EBML.element(EBML.ID.SeekHead, []),\n EBML.element(EBML.ID.Info, [\n EBML.element(EBML.ID.TimecodeScale, EBML.number(millisecond)),\n EBML.element(EBML.ID.MuxingApp, EBML.string(\"webrtc\")),\n EBML.element(EBML.ID.WritingApp, EBML.string(\"webrtc\")),\n ...infoElements,\n ]),\n EBML.element(EBML.ID.Tracks, entries),\n ]);\n}\n\nclass CuePoint {\n private readonly seekHeadPosition = 48;\n clusterOffset: number = 0;\n blockNumber = 0;\n\n constructor(\n private trackNumber: number,\n private relativeTimestamp: number,\n private position: number\n ) {}\n\n build() {\n const cue = EBML.element(EBML.ID.CuePoint, [\n EBML.element(EBML.ID.CueTime, EBML.number(this.relativeTimestamp)),\n EBML.element(EBML.ID.CueTrackPositions, [\n EBML.element(EBML.ID.CueTrack, EBML.number(this.trackNumber)),\n EBML.element(\n EBML.ID.CueClusterPosition,\n EBML.number(\n this.clusterOffset + this.position - this.seekHeadPosition\n )\n ),\n EBML.element(EBML.ID.CueBlockNumber, EBML.number(this.blockNumber)),\n ]),\n ]);\n return cue;\n }\n}\n\nfunction getCues(cuePoints: CuePoint[]) {\n return EBML.build(\n EBML.element(\n EBML.ID.Cues,\n cuePoints.map((cue) => cue.build())\n )\n );\n}\n\nconst millisecond = 1000000;\n/**32767 */\nconst MaxSinged16Int = (0x01 << 16) / 2 - 1;\n\ntype TrackOptions = Partial<{ width: number; height: number }>;\n\nconst supportedVideoCodecs = [\"h264\", \"vp8\", \"vp9\"] as const;\ntype SupportedVideoCodec = typeof supportedVideoCodecs[number];\n"]}
|
package/package.json
CHANGED
package/src/nonstandard/webm.ts
CHANGED
|
@@ -12,6 +12,7 @@ import {
|
|
|
12
12
|
H264RtpPayload,
|
|
13
13
|
OpusRtpPayload,
|
|
14
14
|
Vp8RtpPayload,
|
|
15
|
+
Vp9RtpPayload,
|
|
15
16
|
} from "../../../rtp/src";
|
|
16
17
|
import { PromiseQueue } from "../helper";
|
|
17
18
|
import { MediaStreamTrack } from "../media/track";
|
|
@@ -49,11 +50,15 @@ export class WebmFactory {
|
|
|
49
50
|
tracks.forEach((track, i) => {
|
|
50
51
|
const sampleBuilder = (() => {
|
|
51
52
|
if (track.kind === "video") {
|
|
52
|
-
switch (
|
|
53
|
+
switch (
|
|
54
|
+
track.codec?.name.toLocaleLowerCase() as SupportedVideoCodec
|
|
55
|
+
) {
|
|
53
56
|
case "vp8":
|
|
54
57
|
return new SampleBuilder(Vp8RtpPayload, 90000);
|
|
55
58
|
case "h264":
|
|
56
59
|
return new SampleBuilder(H264RtpPayload, 90000);
|
|
60
|
+
case "vp9":
|
|
61
|
+
return new SampleBuilder(Vp9RtpPayload, 90000);
|
|
57
62
|
}
|
|
58
63
|
} else {
|
|
59
64
|
return new SampleBuilder(OpusRtpPayload, 48000);
|
|
@@ -266,22 +271,52 @@ function createTrackEntries(
|
|
|
266
271
|
) {
|
|
267
272
|
return tracks.map((track, i) => {
|
|
268
273
|
if (track.kind === "video") {
|
|
274
|
+
const codec =
|
|
275
|
+
track.codec?.name.toLocaleLowerCase() as SupportedVideoCodec;
|
|
269
276
|
const codecName = (() => {
|
|
270
|
-
switch (
|
|
277
|
+
switch (codec) {
|
|
271
278
|
case "vp8":
|
|
272
279
|
return "VP8";
|
|
273
280
|
case "h264":
|
|
274
281
|
return "MPEG4/ISO/AVC";
|
|
282
|
+
case "vp9":
|
|
283
|
+
return "VP9";
|
|
275
284
|
default:
|
|
276
285
|
throw new Error();
|
|
277
286
|
}
|
|
278
287
|
})();
|
|
279
|
-
|
|
288
|
+
const trackElements = [
|
|
280
289
|
EBML.element(EBML.ID.Video, [
|
|
281
290
|
EBML.element(EBML.ID.PixelWidth, EBML.number(options.width)),
|
|
282
291
|
EBML.element(EBML.ID.PixelHeight, EBML.number(options.height)),
|
|
283
292
|
]),
|
|
284
|
-
]
|
|
293
|
+
];
|
|
294
|
+
if (codec === "vp9") {
|
|
295
|
+
const profile = Buffer.concat([
|
|
296
|
+
new BitWriter(8).set(1, 0, 0).set(7, 1, 1).buffer,
|
|
297
|
+
bufferWriter([1, 1], [1, 0]),
|
|
298
|
+
]);
|
|
299
|
+
// const level = Buffer.concat([
|
|
300
|
+
// new BitWriter(8).set(1, 0, 0).set(7, 1, 2).buffer,
|
|
301
|
+
// bufferWriter([1, 1], [1, 10]),
|
|
302
|
+
// ]);
|
|
303
|
+
// const bitDepth = Buffer.concat([
|
|
304
|
+
// new BitWriter(8).set(1, 0, 0).set(7, 1, 3).buffer,
|
|
305
|
+
// bufferWriter([1, 1], [1, 8]),
|
|
306
|
+
// ]);
|
|
307
|
+
// const chroma = Buffer.concat([
|
|
308
|
+
// new BitWriter(8).set(1, 0, 0).set(7, 1, 4).buffer,
|
|
309
|
+
// bufferWriter([1, 1], [1, 0]),
|
|
310
|
+
// ]);
|
|
311
|
+
|
|
312
|
+
// trackElements.push(
|
|
313
|
+
// EBML.element(
|
|
314
|
+
// EBML.ID.CodecPrivate,
|
|
315
|
+
// EBML.bytes(Buffer.concat([profile]))
|
|
316
|
+
// )
|
|
317
|
+
// );
|
|
318
|
+
}
|
|
319
|
+
return createTrackEntry(i + 1, codecName, "video", trackElements);
|
|
285
320
|
} else {
|
|
286
321
|
return createTrackEntry(i + 1, "OPUS", "audio", [
|
|
287
322
|
EBML.element(EBML.ID.Audio, [
|
|
@@ -330,20 +365,14 @@ function createSegment(
|
|
|
330
365
|
EBML.element(EBML.ID.SeekHead, []),
|
|
331
366
|
EBML.element(EBML.ID.Info, [
|
|
332
367
|
EBML.element(EBML.ID.TimecodeScale, EBML.number(millisecond)),
|
|
333
|
-
EBML.element(EBML.ID.MuxingApp, EBML.string("
|
|
334
|
-
EBML.element(EBML.ID.WritingApp, EBML.string("
|
|
368
|
+
EBML.element(EBML.ID.MuxingApp, EBML.string("webrtc")),
|
|
369
|
+
EBML.element(EBML.ID.WritingApp, EBML.string("webrtc")),
|
|
335
370
|
...infoElements,
|
|
336
371
|
]),
|
|
337
372
|
EBML.element(EBML.ID.Tracks, entries),
|
|
338
373
|
]);
|
|
339
374
|
}
|
|
340
375
|
|
|
341
|
-
const millisecond = 1000000;
|
|
342
|
-
/**32767 */
|
|
343
|
-
const MaxSinged16Int = (0x01 << 16) / 2 - 1;
|
|
344
|
-
|
|
345
|
-
type TrackOptions = Partial<{ width: number; height: number }>;
|
|
346
|
-
|
|
347
376
|
class CuePoint {
|
|
348
377
|
private readonly seekHeadPosition = 48;
|
|
349
378
|
clusterOffset: number = 0;
|
|
@@ -381,3 +410,12 @@ function getCues(cuePoints: CuePoint[]) {
|
|
|
381
410
|
)
|
|
382
411
|
);
|
|
383
412
|
}
|
|
413
|
+
|
|
414
|
+
const millisecond = 1000000;
|
|
415
|
+
/**32767 */
|
|
416
|
+
const MaxSinged16Int = (0x01 << 16) / 2 - 1;
|
|
417
|
+
|
|
418
|
+
type TrackOptions = Partial<{ width: number; height: number }>;
|
|
419
|
+
|
|
420
|
+
const supportedVideoCodecs = ["h264", "vp8", "vp9"] as const;
|
|
421
|
+
type SupportedVideoCodec = typeof supportedVideoCodecs[number];
|