lemon-mse 0.2.7 → 0.2.8

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.
@@ -0,0 +1,587 @@
1
+ export { Flv }
2
+ /** 并非所有事件都可用 */
3
+ export type EventTypes = 'loadstart' | 'loadeddata'|'play'|'pause'|'ended'
4
+ |'error'|'playing'|'seeking'|'seeked'|'timeupdate'|'waiting'|'canplay'
5
+ |'canplaythrough'|'durationchange'|'volumechange' |'ratechange'
6
+ |'video_resize'|'definition_change'|'user_action'|'rotate'
7
+ |'definition_change'|'retry'|'replay'|'destroy'|'mini_state_change'
8
+ |'cssFullscreen_change'|'fullscreen_change'|'blur'|'focus'|'complete'
9
+ |'autoplay_started'|'autoplay_was_prevented'|'ready'|'pip_change'
10
+
11
+ declare class Flv extends EventEmitter<EventTypes> {
12
+ static isSupported(mediaType: ('video' | 'audio') | null): boolean;
13
+ static enableLogger(): void;
14
+ static disableLogger(): void;
15
+
16
+ constructor(opts: FlvOption);
17
+ media: HTMLMediaElement | null;
18
+ _loading: boolean;
19
+ _opts: FlvOption;
20
+ _bufferService: K.BufferService;
21
+ _gapService: K.GapService;
22
+ _stats: K.MediaStatsService;
23
+ _mediaLoader: K.NetLoader;
24
+ _maxChunkWaitTimer: any;
25
+ _tickTimer: any;
26
+ _tickInterval: number;
27
+ _urlSwitching: boolean;
28
+ _seamlessSwitching: boolean;
29
+ _disconnectRetryCount: number;
30
+ _preLoadEndPoint: number;
31
+ _keyframes: any;
32
+ _acceptRanges: boolean;
33
+ _firstProgressEmit: boolean;
34
+ _seiService: K.SeiService;
35
+ _bandwidthService: K.BandwidthService;
36
+ get version(): any;
37
+ get isLive(): boolean;
38
+ get baseDts(): number;
39
+ get seekable(): boolean;
40
+ get loader(): K.NetLoader;
41
+ get blobUrl(): any;
42
+ speedInfo(): {
43
+ speed: any;
44
+ avgSpeed: number;
45
+ };
46
+ getStats(): K.Stats;
47
+ bufferInfo(maxHole?: number): {
48
+ start: number;
49
+ end: number;
50
+ buffers: [number, number][];
51
+ remaining: number;
52
+ index?: number;
53
+ nextStart?: number;
54
+ nextEnd?: number;
55
+ prevStart?: number;
56
+ prevEnd?: number;
57
+ };
58
+ playbackQuality(): {
59
+ droppedVideoFrames?: undefined;
60
+ totalVideoFrames?: undefined;
61
+ creationTime?: undefined;
62
+ } | {
63
+ droppedVideoFrames: any;
64
+ totalVideoFrames: any;
65
+ creationTime: any;
66
+ };
67
+ load(url?: string, reuseMse?: boolean): Promise<any>;
68
+ replay(seamlesslyReload: boolean, isPlayEmit: any): Promise<any>;
69
+ disconnect(): Promise<void>;
70
+ switchURL(url: string, seamless?: boolean): Promise<void>;
71
+ destroy(): Promise<any>;
72
+ _emitError(error: any, endOfStream?: boolean): void;
73
+ _reset(reuseMse?: boolean): Promise<void>;
74
+ _loadData(url: any, range: any): Promise<void>;
75
+ /**
76
+ * startTime: 当前流式分段开始read时间
77
+ * endTime: 当前流式分段结束read时间
78
+ * st: 拉流开始时间
79
+ * firstByteTime: 首字节响应时间
80
+ */
81
+ _onProgress: (chunk: ArrayBuffer, done: boolean, { startTime, endTime, st, firstByteTime }: {
82
+ startTime: number;
83
+ endTime: number;
84
+ st: number;
85
+ firstByteTime: number;
86
+ }, response: Response) => Promise<void>;
87
+ _onRetryError: (error: any, retryTime: any) => void;
88
+ _clear(): Promise<void>;
89
+ _end: () => void;
90
+ _resetDisconnectCount: () => void;
91
+ _tick: () => void;
92
+ _onPlay: () => void;
93
+ _onSeeking: () => Promise<void>;
94
+ _onTimeupdate: () => void;
95
+ _onWaiting: () => void;
96
+ _onBufferUpdate: () => void;
97
+ _checkPreload: () => Promise<void>;
98
+ _onFlvScriptData: (sample: any) => void;
99
+ }
100
+
101
+
102
+ export function getOption(opts: FlvOption): FlvOption;
103
+ export type FlvOption = {
104
+ media: HTMLMediaElement;
105
+ url?: string;
106
+ isLive?: boolean;
107
+ softDecode?: boolean;
108
+ analyzeDuration?: number;
109
+ maxJumpDistance?: number;
110
+ maxLatency?: number;
111
+ targetLatency?: number;
112
+ bufferBehind?: number;
113
+ retryCount?: number;
114
+ retryDelay?: number;
115
+ disconnectRetryCount?: number;
116
+ loadTimeout?: number;
117
+ maxReaderInterval?: number;
118
+ preloadTime?: number;
119
+ defaultVodLoadSize?: number;
120
+ disconnectTime?: number;
121
+ fetchOptions?: RequestInit;
122
+ seamlesslyReload: boolean;
123
+ keepStatusAfterSwitch?: boolean;
124
+ onlyVideo?: boolean;
125
+ onlyAudio?: boolean;
126
+ preferMMS?: boolean;
127
+ preProcessUrl?: (url: string, ext?: {
128
+ [propName: string]: any;
129
+ }) => {
130
+ [propName: string]: any;
131
+ url: string;
132
+ };
133
+ };
134
+
135
+ declare namespace K {
136
+
137
+ type StatsInfo = {
138
+ downloadSpeed: number;
139
+ avgSpeed: number;
140
+ currentTime: number;
141
+ bufferEnd: number;
142
+ decodeFps: number;
143
+ encodeType: string;
144
+ audioCodec: string;
145
+ videoCodec: string;
146
+ domain: string;
147
+ fps: number;
148
+ bitrate: number;
149
+ width: number;
150
+ height: number;
151
+ samplerate: number;
152
+ channelCount: number;
153
+ gop: number;
154
+ };
155
+
156
+ export class BufferService {
157
+ constructor(flv: Flv, softVideo?: any, opts?: any);
158
+ flv: Flv | null;
159
+ _demuxer: FlvDemuxer;
160
+ _remuxer: any;
161
+ _mse: any;
162
+ _softVideo: any;
163
+ _sourceCreated: boolean;
164
+ _needInitSegment: boolean;
165
+ _discontinuity: boolean;
166
+ _contiguous: boolean;
167
+ _initSegmentId: string;
168
+ _cachedBuffer: any;
169
+ _demuxStartTime: number;
170
+ _opts: any;
171
+ get baseDts(): number;
172
+ get blobUrl(): any;
173
+ isFull(mediaType?: string): any;
174
+ seamlessSwitch(): void;
175
+ unContiguous(startTime: any): void;
176
+ reset(reuseMse?: boolean): Promise<void>;
177
+ endOfStream(): Promise<void>;
178
+ updateDuration(duration: any): Promise<void>;
179
+ destroy(): Promise<void>;
180
+ appendBuffer(chunk: any): Promise<any[]>;
181
+ evictBuffer(bufferBehind: any): Promise<any>;
182
+ _emitMetaParsedEvent(videoTrack: any, audioTrack: any): void;
183
+ _fireEvents(videoTrack: any, audioTrack: any, metadataTrack: any): void;
184
+ }
185
+
186
+ export class FlvDemuxer {
187
+ static AUDIO_RATE: number[];
188
+ static probe(data: Uint8Array): boolean;
189
+ /**
190
+ * @param {VideoTrack} [videoTrack]
191
+ * @param {AudioTrack} [audioTrack]
192
+ * @param {MetadataTrack} [metadataTrack]
193
+ */
194
+ constructor(videoTrack?: VideoTrack, audioTrack?: AudioTrack, metadataTrack?: MetadataTrack);
195
+ _headerParsed: boolean;
196
+ _remainingData: any;
197
+ _gopId: number;
198
+ _needAddMetaBeforeKeyFrameNal: boolean;
199
+ videoTrack: VideoTrack;
200
+ audioTrack: AudioTrack;
201
+ metadataTrack: MetadataTrack;
202
+ _fixer: FlvFixer;
203
+ /**
204
+ * @param {Uint8Array} data
205
+ * @param {boolean} [discontinuity=false] 切流
206
+ * @param {boolean} [contiguous=true]
207
+ * @returns {DemuxResult}
208
+ */
209
+ demux(data: Uint8Array, discontinuity?: boolean, contiguous?: boolean): DemuxResult;
210
+
211
+ fix(startTime?: number, discontinuity?: boolean, contiguous?: boolean): DemuxResult;
212
+
213
+ demuxAndFix(data: Uint8Array, discontinuity?: boolean, contiguous?: boolean, startTime?: number): DemuxResult;
214
+ _parseAudio(data: any, pts: any): void;
215
+ _parseG711(data: any, pts: any, format: any): void;
216
+ _parseAac(data: any, pts: any): void;
217
+ _parseVideo(data: any, dts: any): void;
218
+ _checkAddMetaNalToUnits(hevc: any, units: any, track: any): any;
219
+ _parseScript(data: any, pts: any): void;
220
+ }
221
+
222
+ export type DemuxResult = {
223
+ videoTrack: VideoTrack;
224
+ audioTrack: AudioTrack;
225
+ metadataTrack: MetadataTrack;
226
+ };
227
+ export class FlvFixer {
228
+ constructor(videoTrack: any, audioTrack: any, metadataTrack: any);
229
+ videoTrack: any;
230
+ audioTrack: any;
231
+ metadataTrack: any;
232
+ _baseDts: number;
233
+ _baseDtsInited: boolean;
234
+ _audioNextPts: any;
235
+ _videoNextDts: any;
236
+ _audioTimestampBreak: number;
237
+ _videoTimestampBreak: number;
238
+ _lastVideoDuration: number;
239
+ _keyFrameInNextChunk: boolean;
240
+ _lastAudioExceptionGapDot: number;
241
+ _lastAudioExceptionOverlapDot: number;
242
+ _lastAudioExceptionLargeGapDot: number;
243
+ _lastVideoExceptionLargeGapDot: number;
244
+ _lastVideoExceptionChunkFirstDtsDot: number;
245
+ /**
246
+ * @param {number} startTime 点播seek到的时间点
247
+ * @param {boolean} discontinuity 是否换流
248
+ * @param {boolean} contiguous 前后chunk时间戳是否连续
249
+ */
250
+ fix(startTime?: number, discontinuity?: boolean, contiguous?: boolean): void;
251
+ _videoLastSample: any;
252
+ _fixVideo(videoTrack: any): void;
253
+ _fixAudio(audioTrack: any): void;
254
+ _calculateBaseDts(audioTrack: any, videoTrack: any): boolean;
255
+ _resetBaseDtsWhenStreamBreaked(): void;
256
+ _doFixAudioInternal(audioTrack: any, samples: any, timescale: any): void;
257
+ _getG711Duration(track: any): number;
258
+ _getSilentFrame(track: any): Uint8Array;
259
+ }
260
+
261
+
262
+
263
+ class SeiService {
264
+ constructor(emitter: any);
265
+ _seiSet: Set<any>;
266
+ emitter: any;
267
+ throw(currentTime: any, isLive: any): void;
268
+ reset(): void;
269
+ }
270
+
271
+ export class BandwidthService {
272
+ _chunkSpeeds: any[];
273
+ _speeds: any[];
274
+ addRecord(totalByte: any, ms: any): void;
275
+ addChunkRecord(totalByte: any, ms: any): void;
276
+ getAvgSpeed(): number;
277
+ getLatestSpeed(): any;
278
+ reset(): void;
279
+ }
280
+
281
+ export class NetLoader {
282
+ static isFetchSupport(): boolean;
283
+ constructor(cfg: any);
284
+ type: string;
285
+ _queue: any[];
286
+ _alive: any[];
287
+ _currentTask: any;
288
+ _finnalUrl: string;
289
+ _config: any;
290
+ log: any;
291
+ isFetch(): boolean;
292
+ load(url: any, config?: {}): Promise<any>;
293
+ cancel(): Promise<void>;
294
+ _processTask(): void;
295
+ }
296
+
297
+ export class GapService {
298
+ _prevCurrentTime: number;
299
+ do(media: any, maxJumpDistance: number, isLive: any, seekThreshold?: number): void;
300
+ }
301
+
302
+
303
+ class MediaStatsService {
304
+ constructor(core: any, timescale?: number);
305
+ _core: any;
306
+ _samples: any[];
307
+ _timescale: number;
308
+ _stats: Stats;
309
+ getStats(): StatsInfo;
310
+ _bindEvents(): void;
311
+ reset(): void;
312
+ }
313
+
314
+ type Stats = StatsInfo
315
+
316
+ class VideoTrack {
317
+ id: number;
318
+ /** @readonly */
319
+ readonly type: string;
320
+ codecType: string;
321
+ pid: number;
322
+ /** @type {Uint8Array | Object} */
323
+ hvcC: Uint8Array | any;
324
+ codec: string;
325
+ timescale: number;
326
+ formatTimescale: number;
327
+ sequenceNumber: number;
328
+ baseMediaDecodeTime: number;
329
+ baseDts: number;
330
+ duration: number;
331
+ warnings: any[];
332
+ // VideoSample
333
+ samples: any[];
334
+ /** @type {Uint8Array[]} */
335
+ pps: Uint8Array[];
336
+ /** @type {Uint8Array[]} */
337
+ sps: Uint8Array[];
338
+ /** @type {Uint8Array[]} */
339
+ vps: Uint8Array[];
340
+ fpsNum: number;
341
+ fpsDen: number;
342
+ /** @type {[number, number]} */
343
+ sarRatio: [number, number];
344
+ width: number;
345
+ height: number;
346
+ nalUnitSize: number;
347
+ present: boolean;
348
+ isVideoEncryption: boolean;
349
+ isAudioEncryption: boolean;
350
+ isVideo: boolean;
351
+ kid: any;
352
+ pssh: any;
353
+ /** @type {any} */
354
+ ext: any;
355
+ reset(): void;
356
+ /**
357
+ * @returns {boolean}
358
+ */
359
+ exist(): boolean;
360
+ /**
361
+ * @returns {boolean}
362
+ */
363
+ hasSample(): boolean;
364
+ get isEncryption(): boolean;
365
+ }
366
+
367
+
368
+ class AudioTrack {
369
+ id: number;
370
+ /** @readonly */
371
+ readonly type: string;
372
+ codecType: string;
373
+ pid: number;
374
+ codec: string;
375
+ sequenceNumber: number;
376
+ sampleDuration: number;
377
+ timescale: number;
378
+ formatTimescale: number;
379
+ baseMediaDecodeTime: number;
380
+ duration: number;
381
+ warnings: any[];
382
+ samples: AudioSample[];
383
+ baseDts: number;
384
+ sampleSize: number;
385
+ sampleRate: number;
386
+ channelCount: number;
387
+ objectType: number;
388
+ sampleRateIndex: number;
389
+ config: number[];
390
+ present: boolean;
391
+ isVideoEncryption: boolean;
392
+ isAudioEncryption: boolean;
393
+ kid: any;
394
+ /** @type {any} */
395
+ ext: any;
396
+ reset(): void;
397
+ /**
398
+ * @returns {boolean}
399
+ */
400
+ exist(): boolean;
401
+ /**
402
+ * @returns {boolean}
403
+ */
404
+ hasSample(): boolean;
405
+ get isEncryption(): boolean;
406
+ }
407
+
408
+
409
+ class AudioSample {
410
+ /**
411
+ * @param {number} pts
412
+ * @param {Uint8Array} data
413
+ * @param {number} [duration=1024]
414
+ */
415
+ constructor(pts: number, data: Uint8Array, duration?: number, sampleOffset?: any);
416
+ duration: number;
417
+ flag: {
418
+ dependsOn: number;
419
+ isNonSyncSample: number;
420
+ };
421
+ keyframe: boolean;
422
+ originPts: number;
423
+ pts: number;
424
+ dts: number;
425
+ data: Uint8Array;
426
+ size: number;
427
+ sampleOffset: any;
428
+ }
429
+
430
+ class FlvScriptSample extends Sample {
431
+ }
432
+ class SeiSample extends Sample {
433
+ }
434
+ class MetadataTrack {
435
+ readonly id: 3;
436
+ readonly type: string;
437
+ timescale: number;
438
+ flvScriptSamples: FlvScriptSample[];
439
+ seiSamples: SeiSample[];
440
+ exist(): boolean;
441
+ reset(): void;
442
+ hasSample(): boolean;
443
+ }
444
+ class Sample {
445
+ constructor(data: any, pts: number);
446
+ time: number;
447
+ data: any;
448
+ originPts: number;
449
+ pts: number;
450
+ }
451
+
452
+ }
453
+
454
+
455
+ /**
456
+ * Minimal `EventEmitter` interface that is molded against the Node.js
457
+ * `EventEmitter` interface.
458
+ */
459
+ declare class EventEmitter<
460
+ EventTypes extends E.ValidEventTypes = string | symbol,
461
+ Context extends any = any
462
+ > {
463
+ static prefixed: string | boolean;
464
+
465
+ /**
466
+ * Return an array listing the events for which the emitter has registered
467
+ * listeners.
468
+ */
469
+ eventNames(): Array<E.EventNames<EventTypes>>;
470
+
471
+ /**
472
+ * Return the listeners registered for a given event.
473
+ */
474
+ listeners<T extends E.EventNames<EventTypes>>(
475
+ event: T
476
+ ): Array<E.EventListener<EventTypes, T>>;
477
+
478
+ /**
479
+ * Return the number of listeners listening to a given event.
480
+ */
481
+ listenerCount(event: E.EventNames<EventTypes>): number;
482
+
483
+ /**
484
+ * Calls each of the listeners registered for a given event.
485
+ */
486
+ emit<T extends E.EventNames<EventTypes>>(
487
+ event: T,
488
+ ...args: E.EventArgs<EventTypes, T>
489
+ ): boolean;
490
+
491
+ /**
492
+ * Add a listener for a given event.
493
+ */
494
+ on<T extends E.EventNames<EventTypes>>(
495
+ event: T,
496
+ fn: E.EventListener<EventTypes, T>,
497
+ context?: Context
498
+ ): this;
499
+ addListener<T extends E.EventNames<EventTypes>>(
500
+ event: T,
501
+ fn: E.EventListener<EventTypes, T>,
502
+ context?: Context
503
+ ): this;
504
+
505
+ /**
506
+ * Add a one-time listener for a given event.
507
+ */
508
+ once<T extends E.EventNames<EventTypes>>(
509
+ event: T,
510
+ fn: E.EventListener<EventTypes, T>,
511
+ context?: Context
512
+ ): this;
513
+
514
+ /**
515
+ * Remove the listeners of a given event.
516
+ */
517
+ removeListener<T extends E.EventNames<EventTypes>>(
518
+ event: T,
519
+ fn?: E.EventListener<EventTypes, T>,
520
+ context?: Context,
521
+ once?: boolean
522
+ ): this;
523
+ off<T extends E.EventNames<EventTypes>>(
524
+ event: T,
525
+ fn?: E.EventListener<EventTypes, T>,
526
+ context?: Context,
527
+ once?: boolean
528
+ ): this;
529
+
530
+ /**
531
+ * Remove all listeners, or those of the specified event.
532
+ */
533
+ removeAllListeners(event?: E.EventNames<EventTypes>): this;
534
+ }
535
+
536
+ declare namespace E {
537
+ export interface ListenerFn<Args extends any[] = any[]> {
538
+ (...args: Args): void;
539
+ }
540
+
541
+ export interface EventEmitterStatic {
542
+ new <
543
+ EventTypes extends ValidEventTypes = string | symbol,
544
+ Context = any
545
+ >(): EventEmitter<EventTypes, Context>;
546
+ }
547
+
548
+ /**
549
+ * `object` should be in either of the following forms:
550
+ * ```
551
+ * interface EventTypes {
552
+ * 'event-with-parameters': any[]
553
+ * 'event-with-example-handler': (...args: any[]) => void
554
+ * }
555
+ * ```
556
+ */
557
+ export type ValidEventTypes = string | symbol | object;
558
+
559
+ export type EventNames<T extends ValidEventTypes> = T extends string | symbol
560
+ ? T
561
+ : keyof T;
562
+
563
+ export type ArgumentMap<T extends object> = {
564
+ [K in keyof T]: T[K] extends (...args: any[]) => void
565
+ ? Parameters<T[K]>
566
+ : T[K] extends any[]
567
+ ? T[K]
568
+ : any[];
569
+ };
570
+
571
+ export type EventListener<
572
+ T extends ValidEventTypes,
573
+ K extends EventNames<T>
574
+ > = T extends string | symbol
575
+ ? (...args: any[]) => void
576
+ : (
577
+ ...args: ArgumentMap<Exclude<T, string | symbol>>[Extract<K, keyof T>]
578
+ ) => void;
579
+
580
+ export type EventArgs<
581
+ T extends ValidEventTypes,
582
+ K extends EventNames<T>
583
+ > = Parameters<EventListener<T, K>>;
584
+
585
+ export const EventEmitter: EventEmitterStatic;
586
+ }
587
+