@ezuikit/player-ezopen 0.1.0-alpha.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.
@@ -0,0 +1,1164 @@
1
+ import * as _ezuikit_utils_service_dist_types_fetch from '@ezuikit/utils-service/dist/types/fetch';
2
+ import { LoggerCls } from '@ezuikit/utils-logger/dist/types/logger';
3
+ import { LoggerOptions } from '@ezuikit/utils-logger';
4
+ import * as I18n from '@ezuikit/utils-i18n';
5
+ import I18n__default from '@ezuikit/utils-i18n';
6
+ import Service, { DeviceCapacityRes, DeviceInfoRes } from '@ezuikit/utils-service';
7
+ import { EzopenURL } from '@ezuikit/utils-tools';
8
+ import EventEmitter from 'eventemitter3';
9
+ import PlayerRecordPlugin from '@ezuikit/player-plugin-record';
10
+
11
+ interface IResult$1<T> {
12
+ data?: T;
13
+ code?: number;
14
+ msg?: string;
15
+ }
16
+ /**
17
+ * 播放器标准接口
18
+ */
19
+ interface PlayerInterface {
20
+ playing: boolean;
21
+ volume: number;
22
+ playbackRate: number;
23
+ deviceCapacity: Record<string, any>;
24
+ i18n: any;
25
+ logger: any;
26
+ event: EventEmitter;
27
+ /**
28
+ * 播放
29
+ * @param options
30
+ * @returns {Promise}
31
+ */
32
+ play: (options?: any) => Promise<unknown>;
33
+ /**
34
+ * 暂停播放
35
+ * @returns
36
+ */
37
+ pause: (bool?: boolean) => Promise<unknown>;
38
+ /**
39
+ * 销毁并断流
40
+ * @returns
41
+ */
42
+ destroy: () => Promise<unknown>;
43
+ /**
44
+ * 截图
45
+ * @param {string} name 文件名 默认时间戳(new Date().getTime())
46
+ * @param {"png" | "jpeg"} fmt 图片格式
47
+ * @param {"base64"} type 文件格式 默认base64
48
+ * @param {boolean} download 是否直接下载 默认不直接下载
49
+ * @returns 返回base64字符
50
+ */
51
+ snapshot: (name?: string, fmt?: 'jpeg', type?: 'base64', download?: boolean) => Promise<IResult$1<{
52
+ fileName?: string;
53
+ base64?: string;
54
+ } | null>>;
55
+ /**
56
+ * 开始录制视频
57
+ * @param {string} name 文件名 默认时间戳(new Date().getTime())
58
+ * @param {"mp4"} fmt 图片格式 默认mp4
59
+ * @returns
60
+ */
61
+ startRecord?: (name?: string, fmt?: 'mp4') => Promise<any>;
62
+ /**
63
+ * 停止录制
64
+ * @returns
65
+ */
66
+ stopRecord?: () => Promise<any>;
67
+ /**
68
+ * 全屏
69
+ * @returns
70
+ */
71
+ fullScreen: () => Promise<void>;
72
+ /**
73
+ * 退出全屏
74
+ * @returns
75
+ */
76
+ exitScreen: () => Promise<void>;
77
+ /**
78
+ * 设置画布/视频的尺寸 不设置 默认使用容器的高宽(充满容器)
79
+ * @param {number=} width 画布的宽度
80
+ * @param {number=} height 画布的高度
81
+ * @returns
82
+ */
83
+ resize: (width?: number, height?: number) => Promise<{
84
+ width: number;
85
+ height: number;
86
+ }>;
87
+ /**
88
+ * 设置音量
89
+ * @param volume 音量 [0-1], 0:表示静音
90
+ * @returns {void}
91
+ */
92
+ setVolume: (volume: number) => void;
93
+ /**
94
+ * 设置封面
95
+ * @param url
96
+ * @returns
97
+ */
98
+ setPoster?: (postUrl: string) => void;
99
+ /**
100
+ * 设置播放速度
101
+ * @param rate
102
+ * @returns
103
+ */
104
+ setPlaybackRate?: (rate: number) => void;
105
+ /**
106
+ * 当前版本号
107
+ * @returns
108
+ */
109
+ getVersion: () => object;
110
+ /**
111
+ * 设置日志打印的级别 INFO | LOG | WARN | ERROR
112
+ *
113
+ *
114
+ * @param {string} level 日志级别 一次从大到小 3 -> 0 (为了更好的扩展)
115
+ * @returns
116
+ */
117
+ setDebug?: (level: 'INFO' | 'LOG' | 'WARN' | 'ERROR') => void;
118
+ }
119
+
120
+ interface PlayerPlugin {
121
+ name: string;
122
+ init?: (player?: PlayerInterface) => void;
123
+ beforeExec?: (player?: PlayerInterface) => boolean | Promise<boolean>;
124
+ exec: (player?: PlayerInterface) => void;
125
+ afterExec?: (player?: PlayerInterface) => void;
126
+ destroy?: (player?: PlayerInterface) => void;
127
+ }
128
+
129
+ /**
130
+ * 环境
131
+ */
132
+ interface PlayerEnv {
133
+ domain: string;
134
+ wsUrl?: string;
135
+ }
136
+ interface PlayerOptions {
137
+ /**
138
+ * dom id
139
+ */
140
+ id: string;
141
+ /**
142
+ * 视频封面
143
+ */
144
+ poster?: string;
145
+ /**
146
+ * 播放地址
147
+ */
148
+ url: string;
149
+ /**
150
+ *
151
+ */
152
+ accessToken?: string;
153
+ deviceSerial?: string;
154
+ /**
155
+ * 自动播放
156
+ */
157
+ autoPlay?: boolean;
158
+ /**
159
+ * 是否开启音频
160
+ */
161
+ audio?: boolean;
162
+ /**
163
+ * 环境变量
164
+ */
165
+ env?: PlayerEnv;
166
+ }
167
+ interface IResult<T> {
168
+ data?: T;
169
+ code?: number;
170
+ msg?: string;
171
+ }
172
+
173
+ declare class ESCanvas {
174
+ constructor(szCanvasId: any);
175
+ m_iCanvasWidth: any;
176
+ m_iCanvasHeight: any;
177
+ m_iHorizontalResolution: number;
178
+ m_iVerticalResolution: number;
179
+ m_szDisplayMode: string;
180
+ m_szVideoFormat: string;
181
+ setDrawMutiShapeOneTime(bDrawMuti: any): void;
182
+ setMaxShapeSupport(iMax: any): void;
183
+ getMaxShapeSupport(): number;
184
+ setDrawStatus(bDrawStatus: any, cbCallback?: any): void;
185
+ setShapeType(szType: any): void;
186
+ setCurrentShapeInfo(oShapeInfo: any): void;
187
+ getShapeType(): string;
188
+ getAllShapesInfo(): (
189
+ | {
190
+ szType: any;
191
+ szGridMap: any;
192
+ iGridColNum: any;
193
+ iGridRowNum: any;
194
+ szText?: undefined;
195
+ szEnabled?: undefined;
196
+ szOSDType?: undefined;
197
+ iPositionX?: undefined;
198
+ iPositionY?: undefined;
199
+ szDateStyle?: undefined;
200
+ szClockType?: undefined;
201
+ szDisplayWeek?: undefined;
202
+ szId?: undefined;
203
+ szAlignment?: undefined;
204
+ aPoint?: undefined;
205
+ bChoosed?: undefined;
206
+ }
207
+ | {
208
+ szType: any;
209
+ szText: any;
210
+ szEnabled: any;
211
+ szOSDType: any;
212
+ iPositionX: any;
213
+ iPositionY: any;
214
+ szDateStyle: any;
215
+ szClockType: any;
216
+ szDisplayWeek: any;
217
+ szId: any;
218
+ szAlignment: any;
219
+ szGridMap?: undefined;
220
+ iGridColNum?: undefined;
221
+ iGridRowNum?: undefined;
222
+ aPoint?: undefined;
223
+ bChoosed?: undefined;
224
+ }
225
+ | {
226
+ szType: any;
227
+ aPoint: any;
228
+ szId: any;
229
+ bChoosed: any;
230
+ szGridMap?: undefined;
231
+ iGridColNum?: undefined;
232
+ iGridRowNum?: undefined;
233
+ szText?: undefined;
234
+ szEnabled?: undefined;
235
+ szOSDType?: undefined;
236
+ iPositionX?: undefined;
237
+ iPositionY?: undefined;
238
+ szDateStyle?: undefined;
239
+ szClockType?: undefined;
240
+ szDisplayWeek?: undefined;
241
+ szAlignment?: undefined;
242
+ }
243
+ )[];
244
+ deleteRepeatPolyonById(id: any): void;
245
+ getShapesInfoByType(szType: any): (
246
+ | {
247
+ szType: any;
248
+ szGridMap: any;
249
+ iGridColNum: any;
250
+ iGridRowNum: any;
251
+ szText?: undefined;
252
+ szEnabled?: undefined;
253
+ szOSDType?: undefined;
254
+ iPositionX?: undefined;
255
+ iPositionY?: undefined;
256
+ szDateStyle?: undefined;
257
+ szClockType?: undefined;
258
+ szDisplayWeek?: undefined;
259
+ szId?: undefined;
260
+ szAlignment?: undefined;
261
+ iPolygonType?: undefined;
262
+ iMinClosed?: undefined;
263
+ iMaxPointNum?: undefined;
264
+ iEditType?: undefined;
265
+ aPoint?: undefined;
266
+ bClosed?: undefined;
267
+ szTips?: undefined;
268
+ szDrawColor?: undefined;
269
+ szFillColor?: undefined;
270
+ iTranslucent?: undefined;
271
+ iLineType?: undefined;
272
+ iDirection?: undefined;
273
+ iArrowType?: undefined;
274
+ aCrossArrowPoint?: undefined;
275
+ }
276
+ | {
277
+ szType: any;
278
+ szText: any;
279
+ szEnabled: any;
280
+ szOSDType: any;
281
+ iPositionX: any;
282
+ iPositionY: any;
283
+ szDateStyle: any;
284
+ szClockType: any;
285
+ szDisplayWeek: any;
286
+ szId: any;
287
+ szAlignment: any;
288
+ szGridMap?: undefined;
289
+ iGridColNum?: undefined;
290
+ iGridRowNum?: undefined;
291
+ iPolygonType?: undefined;
292
+ iMinClosed?: undefined;
293
+ iMaxPointNum?: undefined;
294
+ iEditType?: undefined;
295
+ aPoint?: undefined;
296
+ bClosed?: undefined;
297
+ szTips?: undefined;
298
+ szDrawColor?: undefined;
299
+ szFillColor?: undefined;
300
+ iTranslucent?: undefined;
301
+ iLineType?: undefined;
302
+ iDirection?: undefined;
303
+ iArrowType?: undefined;
304
+ aCrossArrowPoint?: undefined;
305
+ }
306
+ | {
307
+ szType: any;
308
+ szId: any;
309
+ iPolygonType: any;
310
+ iMinClosed: any;
311
+ iMaxPointNum: any;
312
+ iEditType: any;
313
+ aPoint: any;
314
+ bClosed: any;
315
+ szTips: any;
316
+ szDrawColor: any;
317
+ szFillColor: any;
318
+ iTranslucent: any;
319
+ szGridMap?: undefined;
320
+ iGridColNum?: undefined;
321
+ iGridRowNum?: undefined;
322
+ szText?: undefined;
323
+ szEnabled?: undefined;
324
+ szOSDType?: undefined;
325
+ iPositionX?: undefined;
326
+ iPositionY?: undefined;
327
+ szDateStyle?: undefined;
328
+ szClockType?: undefined;
329
+ szDisplayWeek?: undefined;
330
+ szAlignment?: undefined;
331
+ iLineType?: undefined;
332
+ iDirection?: undefined;
333
+ iArrowType?: undefined;
334
+ aCrossArrowPoint?: undefined;
335
+ }
336
+ | {
337
+ szType: any;
338
+ szId: any;
339
+ aPoint: any;
340
+ szTips: any;
341
+ iLineType: any;
342
+ iDirection: any;
343
+ iArrowType: any;
344
+ szDrawColor: any;
345
+ aCrossArrowPoint: any;
346
+ szGridMap?: undefined;
347
+ iGridColNum?: undefined;
348
+ iGridRowNum?: undefined;
349
+ szText?: undefined;
350
+ szEnabled?: undefined;
351
+ szOSDType?: undefined;
352
+ iPositionX?: undefined;
353
+ iPositionY?: undefined;
354
+ szDateStyle?: undefined;
355
+ szClockType?: undefined;
356
+ szDisplayWeek?: undefined;
357
+ szAlignment?: undefined;
358
+ iPolygonType?: undefined;
359
+ iMinClosed?: undefined;
360
+ iMaxPointNum?: undefined;
361
+ iEditType?: undefined;
362
+ bClosed?: undefined;
363
+ szFillColor?: undefined;
364
+ iTranslucent?: undefined;
365
+ }
366
+ | {
367
+ szType: any;
368
+ iEditType: any;
369
+ aPoint: any;
370
+ szTips: any;
371
+ szDrawColor: any;
372
+ szFillColor: any;
373
+ iTranslucent: any;
374
+ szGridMap?: undefined;
375
+ iGridColNum?: undefined;
376
+ iGridRowNum?: undefined;
377
+ szText?: undefined;
378
+ szEnabled?: undefined;
379
+ szOSDType?: undefined;
380
+ iPositionX?: undefined;
381
+ iPositionY?: undefined;
382
+ szDateStyle?: undefined;
383
+ szClockType?: undefined;
384
+ szDisplayWeek?: undefined;
385
+ szId?: undefined;
386
+ szAlignment?: undefined;
387
+ iPolygonType?: undefined;
388
+ iMinClosed?: undefined;
389
+ iMaxPointNum?: undefined;
390
+ bClosed?: undefined;
391
+ iLineType?: undefined;
392
+ iDirection?: undefined;
393
+ iArrowType?: undefined;
394
+ aCrossArrowPoint?: undefined;
395
+ }
396
+ | {
397
+ szType: any;
398
+ aPoint: any;
399
+ szGridMap?: undefined;
400
+ iGridColNum?: undefined;
401
+ iGridRowNum?: undefined;
402
+ szText?: undefined;
403
+ szEnabled?: undefined;
404
+ szOSDType?: undefined;
405
+ iPositionX?: undefined;
406
+ iPositionY?: undefined;
407
+ szDateStyle?: undefined;
408
+ szClockType?: undefined;
409
+ szDisplayWeek?: undefined;
410
+ szId?: undefined;
411
+ szAlignment?: undefined;
412
+ iPolygonType?: undefined;
413
+ iMinClosed?: undefined;
414
+ iMaxPointNum?: undefined;
415
+ iEditType?: undefined;
416
+ bClosed?: undefined;
417
+ szTips?: undefined;
418
+ szDrawColor?: undefined;
419
+ szFillColor?: undefined;
420
+ iTranslucent?: undefined;
421
+ iLineType?: undefined;
422
+ iDirection?: undefined;
423
+ iArrowType?: undefined;
424
+ aCrossArrowPoint?: undefined;
425
+ }
426
+ )[];
427
+ setShapesInfoByType(szType: any, aShapesInfo: any): void;
428
+ addOSDShape(szText: any, szEnabled: any, iStartX: any, iStartY: any, oExtend: any): void;
429
+ selectShapeById(szShapeType: any, szId: any): void;
430
+ setCanvasSize(iWidth: any, iHeight: any): void;
431
+ setDrawStyle(szBorderColor: any, szFillColor: any, iTranslucent: any): void;
432
+ clearAllShape(): void;
433
+ clearShapeByType(szType: any): void;
434
+ deleteShape(iShapeIndex: any): void;
435
+ updateCanvas(szCanvasId: any): void;
436
+ resizeCanvas(): void;
437
+ canvasRedraw(): void;
438
+ [CANVAS]: any;
439
+ [CONTEXT]: any;
440
+ [SHAPES]: any[];
441
+ [DRAWSTATUS]: boolean;
442
+ [SHAPETYPE]: string;
443
+ [MAXSHAPENUMSUPPORT]: number;
444
+ [DRAWSHAPEMULTIONETIME]: boolean;
445
+ [CURRENTSHAPEINFO]: {};
446
+ [EVENTCALLBACK]: any;
447
+ [SHAPESTYLE]: {
448
+ szDrawColor: string;
449
+ szFillColor: string;
450
+ iTranslucent: number;
451
+ };
452
+ [POLYGONDRAWING]: boolean;
453
+ }
454
+ declare const CANVAS: unique symbol;
455
+ declare const CONTEXT: unique symbol;
456
+ declare const SHAPES: unique symbol;
457
+ declare const DRAWSTATUS: unique symbol;
458
+ declare const SHAPETYPE: unique symbol;
459
+ declare const MAXSHAPENUMSUPPORT: unique symbol;
460
+ declare const DRAWSHAPEMULTIONETIME: unique symbol;
461
+ declare const CURRENTSHAPEINFO: unique symbol;
462
+ declare const EVENTCALLBACK: unique symbol;
463
+ declare const SHAPESTYLE: unique symbol;
464
+ declare const POLYGONDRAWING: unique symbol;
465
+
466
+ declare const JSPlayCtrl: any;
467
+
468
+ /**
469
+ * @description 播放器窗口
470
+ * @warn 后续会弱化 id
471
+ */
472
+ declare class PlayerWindow {
473
+ id: string;
474
+ width: number;
475
+ height: number;
476
+ style: Record<string, string>;
477
+ $playerWnd: HTMLDivElement;
478
+ canvasId: string;
479
+ constructor(id: string, width: number, height: number, style?: Record<string, string>);
480
+ /**
481
+ * @description 渲染播放器窗口
482
+ * @returns
483
+ */
484
+ render(): void;
485
+ /**
486
+ * @description canvas 隐藏 (由于 v3 切换播放地址时 上个canvas 还在 页面resize canvas 会崩溃 变成白色, 使用改方法配合 reRenderCanvas)
487
+ */
488
+ hide(): void;
489
+ /**
490
+ * @description 销毁播放器窗口
491
+ */
492
+ destroy(): void;
493
+ /**
494
+ * @description 窗口resize
495
+ * @param {number} width 窗口的宽 (画布, 不包括自定义主题)
496
+ * @param {number} height 窗口的高 (画布, 不包括自定义主题)
497
+ * @returns {void}
498
+ */
499
+ resize(width: number, height: number): void;
500
+ /**
501
+ *
502
+ * @param {boolean} remove 是否移除
503
+ * @returns
504
+ */
505
+ reRenderCanvas(remove?: boolean): void;
506
+ }
507
+
508
+ interface WasmDecoderStatue {
509
+ bSupHardOrSoft: boolean;
510
+ bSupHardDecAVC: boolean;
511
+ bSupHardDecHEVC: boolean;
512
+ cmd: 'loaded' | 'onebyone';
513
+ errorCode: number;
514
+ status: any;
515
+ }
516
+
517
+ type Zoom3DCallback = (oRECT?: any) => void;
518
+
519
+ type SnapshotFmt = 'jpeg';
520
+
521
+ /**
522
+ * @description 插件管理系统
523
+ */
524
+ declare class PluginManager {
525
+ context: EZopenPlayer;
526
+ plugins: Map<string, PlayerPlugin>;
527
+ constructor(player: EZopenPlayer);
528
+ /**
529
+ * @description 注册插件做个插件
530
+ * @param plugins
531
+ */
532
+ usePlugins(plugins: PlayerPlugin[]): Promise<void>;
533
+ /**
534
+ * @description 注册插件
535
+ * @param plugins
536
+ */
537
+ use(plugin: PlayerPlugin): Promise<void>;
538
+ /**
539
+ * @description 通过name销毁指定插件
540
+ * @param {string} name 插件名
541
+ */
542
+ destroyByName(name: string): void;
543
+ /**
544
+ * @description 销毁插件
545
+ */
546
+ destroy(): void;
547
+ }
548
+
549
+ /***
550
+ * 鱼眼矫正
551
+ *
552
+ */
553
+ declare class FECCorrect {
554
+ _FECSplitIds: string | undefined;
555
+ _canvasFECSubPort: Map<any, any>;
556
+ _correctType: any;
557
+ private readonly _player;
558
+ constructor(player: EZopenPlayer);
559
+ _supportFEC(): boolean | undefined;
560
+ init(): void;
561
+ /**
562
+ * @description 设置矫正类型
563
+ * @param type
564
+ * @param ids
565
+ * @returns
566
+ */
567
+ setFECCorrectType(type: any, ids?: string): Promise<unknown>;
568
+ /**
569
+ * @description 设置 2D 鱼眼矫正旋转参数
570
+ * @param {number} port 鱼眼端口 主屏默认为 0
571
+ * @param {Object} param2d
572
+ */
573
+ setFEC2DParam(port: number, param2d: any): any;
574
+ /**
575
+ * @description 设置 3D 矫正视角参数
576
+ * @param {FECViewParam} param
577
+ * @returns {Promise<boolean>} true: 成功 false: 失败 undefined: 不支持
578
+ */
579
+ setFEC3DViewParam(param: any): Promise<boolean>;
580
+ /**
581
+ * @description 获取 3D 矫正视角参数
582
+ * @param {FECGetViewParam} param
583
+ * @returns {Promise<object>}
584
+ */
585
+ get3DViewParam(param: any): Promise<unknown>;
586
+ getFECSubPortMap(): Map<any, any>;
587
+ /**
588
+ * @description 创建分屏画面
589
+ * @returns
590
+ */
591
+ private _createSplitCanvas;
592
+ private _matchUpDateType;
593
+ /**
594
+ * @description 给分屏添加mouse事件
595
+ * @param {string} canvasId
596
+ * @param {{correctType: string}} type
597
+ * @returns
598
+ */
599
+ private _spliceCanvasMouseEvents;
600
+ /**
601
+ * @description 清空所有鱼眼子端口 不包括主窗口
602
+ */
603
+ private _closeFECAllSubWnd;
604
+ }
605
+
606
+ /**
607
+ * 设置水印参数
608
+ */
609
+ interface WaterMarkParams {
610
+ /** 文本信息(必填) */
611
+ fontString: string[];
612
+ /** 文本位置 字体的位置,fX 表示横坐标,fY 表示纵坐标,取值范围为[0,1],左上角是原点。 */
613
+ startPos?: {
614
+ fX: number;
615
+ fY: number;
616
+ };
617
+ /** 字体颜色信息,取值范围 [0,1] (number/255)。其中 fA 表示透明度,0 时完全透明不显示。 */
618
+ fontColor?: {
619
+ fR: number;
620
+ fG: number;
621
+ fB: number;
622
+ fA: number;
623
+ };
624
+ /** 字体大小,字体宽高设置不一样时,显示出来字体大小为宽高中较小值。建议取值 [0~canvasWidth */
625
+ fontSize?: {
626
+ nFontWidth: number;
627
+ nFontHeight: number;
628
+ };
629
+ /** 字体旋转角度 字体旋 转参数,①fRotateAngle 为旋转角度,单位度(0~360 度)。②fFillFullScreen 为 true 表示铺满全屏,会在 canvas 中斜体显示 n 个,false 表示只显示一行。 */
630
+ fontRotate?: {
631
+ fRotateAngle: number;
632
+ fFillFullScreen: boolean;
633
+ };
634
+ /** 字体 */
635
+ fontFamily?: string;
636
+ /** 当平铺斜体水印时,即 FontRotate. fFillFullScreen 为 true 时,需要用到此参数。nRowNumber 表示行数,nColNumber 列数。会显示 4 行 5 列的斜体水印。取值范围[3,13]。 */
637
+ fontNumber?: {
638
+ nRowNumber: number;
639
+ nColNumber: number;
640
+ };
641
+ /** 多行字间距:建议取值范围[1~2]。 */
642
+ space?: number;
643
+ }
644
+
645
+ type MirrorFlipCommand = 0 | 1 | 2;
646
+
647
+ interface EZopenPlayerOptions extends PlayerOptions {
648
+ logger?: Pick<LoggerOptions, 'level' | 'showTime'>;
649
+ i18n?: any;
650
+ staticPath?: string;
651
+ width?: number;
652
+ height?: number;
653
+ /** 全屏节点 */
654
+ fullScreenEle?: HTMLElement;
655
+ /** 指定解码类型, v1 软解 v3 包括硬解和多线程 */
656
+ decoderType?: 'auto' | 'v1' | 'v3';
657
+ extraParams?: {
658
+ ezopenParams?: Record<string, any>;
659
+ wsParams?: string | Record<string, any>;
660
+ };
661
+ }
662
+ declare class EZopenPlayer implements PlayerInterface {
663
+ _options: EZopenPlayerOptions;
664
+ static EVENT_TYPE: {
665
+ initializing: string;
666
+ loadstart: string;
667
+ abort: string;
668
+ waiting: string;
669
+ canplay: string;
670
+ rateChange: string;
671
+ volumeChange: string;
672
+ debug: string;
673
+ error: string;
674
+ videoInfo: string;
675
+ decoder: string;
676
+ urlChange: string;
677
+ API: {
678
+ play: string;
679
+ pause: string;
680
+ rateChange: string;
681
+ volumeChange: string;
682
+ destroy: string;
683
+ snapshot: string;
684
+ fullScreen: string;
685
+ exitScreen: string;
686
+ resize: string;
687
+ seek: string;
688
+ resume: string;
689
+ };
690
+ NETWORK: {
691
+ deviceCapacity: string;
692
+ deviceInfo: string;
693
+ videoFragmentFiles: string;
694
+ error: {
695
+ error: string;
696
+ deviceCapacity: string;
697
+ deviceInfo: string;
698
+ realPlayUrl: string;
699
+ videoFragmentFiles: string;
700
+ };
701
+ };
702
+ SOCKET: {
703
+ autoClose: string;
704
+ openStream: string;
705
+ startPlay: string;
706
+ stopAll: string;
707
+ setPlayRate: string;
708
+ seek: string;
709
+ close: string;
710
+ };
711
+ CALLBACK: {
712
+ pluginErrorHandler: string;
713
+ getStreamHeaderCallback: string;
714
+ getVideoStreamCallback: string;
715
+ appearFirstFrameCallback: string;
716
+ averageStreamSuccessCallback: string;
717
+ setRunTimeInfoCallBack: string;
718
+ openStreamCallback: string;
719
+ };
720
+ FECCorrect: {
721
+ setFEC2DParam: string;
722
+ };
723
+ };
724
+ logger: LoggerCls;
725
+ i18n: I18n__default;
726
+ event: EventEmitter;
727
+ wasmplayer: typeof JSPlayCtrl;
728
+ initializing: boolean;
729
+ loading: boolean;
730
+ /** 播放速度 */
731
+ playbackRate: number;
732
+ /** 是否在播放中 */
733
+ playing: boolean;
734
+ /** 音量 [0-1] */
735
+ volume: number;
736
+ /** 已经销毁 */
737
+ destroyed: boolean;
738
+ /** 播放地址 query */
739
+ urlInfo: Partial<EzopenURL>;
740
+ /** 设备能力集 */
741
+ deviceCapacity: Partial<DeviceCapacityRes>;
742
+ deviceInfo: Partial<DeviceInfoRes>;
743
+ /** 当前播放出现的错误 */
744
+ error: object | null;
745
+ /** 服务端接口 */
746
+ service: Service;
747
+ $container: HTMLElement;
748
+ esCanvas: ESCanvas;
749
+ fECCorrect: FECCorrect;
750
+ _oStreamClient: StreamClient;
751
+ _aHead: Uint8Array;
752
+ private _wasmDecoderInfo;
753
+ _g_port: number | null;
754
+ _secretKey: string;
755
+ _tempPauseDate: number | null;
756
+ _tempPauseTime: string;
757
+ _validateCode: string;
758
+ /** 视频信息 */
759
+ __videoInfo: any;
760
+ _waterMarkParams: any;
761
+ _decoderStatus: Partial<WasmDecoderStatue>;
762
+ _wss_info: {
763
+ wssUrl: string;
764
+ oParams: {
765
+ playURL: string;
766
+ };
767
+ };
768
+ __fCallback: Zoom3DCallback;
769
+ __b3DZoom: boolean;
770
+ pluginManager: PluginManager;
771
+ _playerWindow: PlayerWindow;
772
+ private readonly _playerFullScreen;
773
+ constructor(options: EZopenPlayerOptions);
774
+ private _playerInit;
775
+ /**
776
+ * @description 播放
777
+ * @param options
778
+ * @returns
779
+ */
780
+ play(options?: Partial<Pick<EZopenPlayerOptions, 'url' | 'accessToken'>>): Promise<unknown>;
781
+ _wss_play(szUrl: string, oParams?: {
782
+ playURL: string;
783
+ }, iWndNum?: number): Promise<unknown>;
784
+ /**
785
+ * 暂停播放 并断流???
786
+ * @param {boolean} bool 是否断流
787
+ * @returns
788
+ */
789
+ pause(bool?: boolean): Promise<unknown>;
790
+ /**
791
+ * 恢复
792
+ * @param time
793
+ * @returns
794
+ */
795
+ resume(time: string): Promise<unknown>;
796
+ /**
797
+ * @description 销毁并断流
798
+ * @returns
799
+ */
800
+ destroy(): Promise<void>;
801
+ /**
802
+ * @private
803
+ */
804
+ _destroyed(): void;
805
+ stop(): Promise<unknown>;
806
+ /**
807
+ * @description 截图
808
+ * @param {string} name 文件名 默认时间戳(new Date().getTime())
809
+ * @param {"jpeg"} fmt 图片格式 只支持 jpeg
810
+ * @param {"base64"} type 文件格式 默认base64
811
+ * @param {boolean} download 是否直接下载 默认不直接下载
812
+ * @returns 返回base64字符
813
+ */
814
+ snapshot(name?: string, fmt?: SnapshotFmt, type?: 'base64', download?: boolean): Promise<IResult<{
815
+ fileName?: string | undefined;
816
+ base64?: string | undefined;
817
+ } | null>>;
818
+ /**
819
+ * @description 全屏
820
+ * @param {number} width resize 当前画布的宽 (不存在 需手动resize)
821
+ * @param {number} height resize 当前画布的高 (不存在 需手动resize)
822
+ * @returns
823
+ */
824
+ fullScreen(width?: number, height?: number): Promise<void>;
825
+ /**
826
+ * @description 退出全屏
827
+ * @returns
828
+ */
829
+ exitScreen(): Promise<void>;
830
+ /**
831
+ * 设置画布/视频的尺寸 不设置 默认使用容器的高宽(充满容器)
832
+ * @param {number=} width 画布的宽度
833
+ * @param {number=} height 画布的高度
834
+ * @returns
835
+ */
836
+ resize(width?: number, height?: number): Promise<{
837
+ width: number;
838
+ height: number;
839
+ }>;
840
+ /**
841
+ * 设置音量
842
+ * @param {number} volume 音量[0-1], 0:表示静音
843
+ * @returns {0 | 1} 1 成功 0 失败
844
+ */
845
+ setVolume(volume: number): number;
846
+ /**
847
+ * @description 插件管理
848
+ * @param plugin 插件
849
+ */
850
+ use(plugin: PlayerPlugin): void;
851
+ /**
852
+ *
853
+ * @param {Object} type 矫正类型 参考 src/ezopen/constants.js
854
+ * @param {string=} ids 如果分屏矫正,需要传入分屏canvas的id字符串列表 如 canvas1,canvas2,canvas3
855
+ * @returns {Array<{code: number, msg: string, port: number, id: string}>} // code= 0 成功, -1 失败
856
+ * @returns
857
+ */
858
+ setFECCorrectType(type: any, ids?: string): Promise<unknown>;
859
+ /**
860
+ * @description 设置 2D 鱼眼矫正旋转参数
861
+ * @param {number} fishSubPort 鱼眼端口 主屏默认为 0
862
+ * @param {Object} param2d
863
+ */
864
+ setFEC2DParam(fishSubPort: number, param2d: object): any;
865
+ /**
866
+ * @description 设置 3D 矫正视角参数
867
+ * @param {object} param
868
+ * @returns {Promise<boolean>} true: 成功 false: 失败 undefined: 不支持
869
+ */
870
+ setFEC3DViewParam(param: object): Promise<boolean>;
871
+ /**
872
+ * @description 获取 3D 矫正视角参数
873
+ * @param {object} param
874
+ * @returns {Promise<object>}
875
+ */
876
+ get3DViewParam(param: object): Promise<unknown>;
877
+ /**
878
+ * 设置封面
879
+ * @param {string} poster 封面封面地址
880
+ * @returns {void}
881
+ */
882
+ setPoster(poster: string): void;
883
+ /**
884
+ * 设置播放速度
885
+ * @param {0.5 | 1 | 2 | 4} rate 2的倍数
886
+ * @returns
887
+ */
888
+ setPlaybackRate(rate: number): void;
889
+ /**
890
+ * @description seek 新的位置 需要设备支持
891
+ * @param {string} startTime 开始时间 YYYYMMDDThhmmssZ
892
+ * @param {string} stopTime 结束时间 YYYYMMDDThhmmssZ
893
+ * @returns {Promise<void>}
894
+ */
895
+ seek(startTime: string, stopTime: string): Promise<void>;
896
+ private _setOptions;
897
+ /**
898
+ * @description 打开3D放大
899
+ * @param cb
900
+ * @returns
901
+ */
902
+ enable3DZoom(cb: Zoom3DCallback): -1 | 0;
903
+ /**
904
+ * @description 关闭3D放大
905
+ * @returns
906
+ */
907
+ disable3DZoom(): -1 | 0;
908
+ getOSDTime(): number;
909
+ /**
910
+ * @description 获取帧信息
911
+ * @returns {object}
912
+ */
913
+ getFrameInfo(): {
914
+ codecType: number;
915
+ width: number;
916
+ height: number;
917
+ year: number;
918
+ month: number;
919
+ day: number;
920
+ hour: number;
921
+ minute: number;
922
+ second: number;
923
+ };
924
+ /**
925
+ * @description 设置播放视频区域 (仅视频不是画布)
926
+ * @param {number} left 视频展示区域 x轴开始位置
927
+ * @param {number} right 视频展示区域 x轴结束位置
928
+ * @param {number} top 视频展示区域 y轴开始位置
929
+ * @param {number} bottom 视频展示区域 y轴结束位置
930
+ * @param {boolean} flag
931
+ * @param {boolean} isFullscreen 当页面旋转 90° 时 需要宽高互换 需要 设置为true
932
+ * @returns {boolean}
933
+ */
934
+ setDisplayRegion(left: number, right: number, top: number, bottom: number, flag?: boolean, isFullscreen?: boolean): boolean;
935
+ /**
936
+ * @description 设置解密密钥 (如果在封装时设置了密钥,那么在播放之前需要调用该接口设置密钥才能正常解码。)
937
+ * @param secretKey 密钥
938
+ * @returns {number} 1 成功 0 失败
939
+ */
940
+ setSecretKey(secretKey: string): any;
941
+ /**
942
+ *
943
+ * @returns
944
+ */
945
+ getOptions(): EZopenPlayerOptions;
946
+ /**
947
+ * @description 切换调试日志等级
948
+ * @param {LoggerOptions} loggerOptions 日志等级
949
+ */
950
+ setLogger(options: LoggerOptions): void;
951
+ version: string;
952
+ /**
953
+ * @description 获取版本号
954
+ * @returns
955
+ */
956
+ getVersion(): {
957
+ version: string;
958
+ decoder: string;
959
+ decoderVersion: any;
960
+ };
961
+ /**
962
+ * @description 设置水印
963
+ * @param {WaterMarkParams} params
964
+ * @returns {Promise<any>}
965
+ */
966
+ setWaterMark(params: WaterMarkParams): Promise<unknown>;
967
+ /**
968
+ * @description 镜像翻转 (需要设备本身支持, 可以重能力集中获取)
969
+ * @link https://open.ys7.com/help/59?h=%E9%95%9C%E5%83%8F%E7%BF%BB%E8%BD%AC#device_ptz-api3
970
+ * @param {0 | 1 | 2} command 0-上下, 1-左右, 2-中心
971
+ *
972
+ * @returns {Promise}
973
+ */
974
+ setMirrorFlip(command: MirrorFlipCommand): Promise<_ezuikit_utils_service_dist_types_fetch.Response<any, undefined>>;
975
+ }
976
+
977
+ declare class StreamClient {
978
+ private readonly _player;
979
+ private _streamClient;
980
+ _streamUUID: string;
981
+ constructor(player: EZopenPlayer);
982
+ /**
983
+ * @description 开流, 此时设备的流还没有发出来
984
+ * @param {string} szUrl 取流路径,如ws://hostname:port/channel
985
+ * @param {object} oParams 取流需要涉及的相关参数
986
+ * @param {function} cbMessage 消息回调函数
987
+ * @param {function} cbClose 失败回调
988
+ * @returns {Promise<string>} 返回Promise对象 // 取流uuid,用于区分每条取流连接
989
+ */
990
+ openStream(szUrl: string, oParams: object, cbMessage: (msg: object) => void, cbClose: (id?: string) => void): Promise<string>;
991
+ /**
992
+ * @description 开始取流
993
+ *
994
+ * @param {string} id websocket id,在openStream的时候生成
995
+ * @param {string} szStartTime 开始时间
996
+ * @param {string} szStopTime 结束时间
997
+ * @param {function} cbMessage 码流回调函数
998
+ *
999
+ * @returns {Promise<unknown>} 返回Promise对象
1000
+ */
1001
+ startPlay(id?: string): Promise<void>;
1002
+ /**
1003
+ * @description 设置播放速度
1004
+ * @param rate 播放速度
1005
+ * @param uuid websocket id,在openStream的时候生成
1006
+ * @returns
1007
+ */
1008
+ setPlayRate(rate: number, id?: string): Promise<void>;
1009
+ /**
1010
+ * @description 定位回放
1011
+ *
1012
+ * @param {string} id websocket id在openStream的时候生成
1013
+ * @param {string} startTime 开始时间
1014
+ * @param {string} stopTime 结束时间
1015
+ *
1016
+ * @returns {Promise<unknown>} Promise
1017
+ */
1018
+ seek(startTime: string, stopTime: string, id?: string): Promise<void>;
1019
+ /**
1020
+ * @description 停止所有流
1021
+ * @returns
1022
+ */
1023
+ stopAll(): Promise<void>;
1024
+ /**
1025
+ * @description 客户端销毁
1026
+ */
1027
+ destroy(): void;
1028
+ }
1029
+
1030
+ declare class JSPlugin {
1031
+ constructor(props: any);
1032
+ iWidth: any;
1033
+ iHeight: any;
1034
+ player: EZopenPlayer;
1035
+ i18n: I18n.default;
1036
+ _recordPlugin: PlayerRecordPlugin;
1037
+ nWidth: number;
1038
+ nHeight: number;
1039
+ oStreamClient: StreamClient;
1040
+ g_port: number;
1041
+ oStyle: any;
1042
+ get bPlay(): boolean;
1043
+ get iRate(): number;
1044
+ set playURL(arg: string);
1045
+ get playURL(): string;
1046
+ set FECSplitIds(arg: string | undefined);
1047
+ get FECSplitIds(): string | undefined;
1048
+ set correctType(arg: any);
1049
+ get correctType(): any;
1050
+ _initEventCallback(): void;
1051
+ JSPlayM4_SetDecodeEngine(useHard: any): void;
1052
+ useHard: any;
1053
+ /**
1054
+ *
1055
+ * @param {*} szUrl "示例:wss://jsdecoder-aeye.hwwt2.com:443"
1056
+ * @param {*} oParams "示例: {playURL: "/live?dev=F99467170&chn=9&stream=1&ssn=ot.9oovv27v00lck3ft0krfw61n8ugr4j5b-1ao1cqq1fm-1od8d0d-h1lnhi0w0&auth=1&biz=4&cln=100"}"
1057
+ * @param {*} iWndNum
1058
+ * @param {*} szStartTime
1059
+ * @param {*} szStopTime
1060
+ * @returns
1061
+ */
1062
+ JS_Play(szUrl: any, oParams: any, iWndNum: any, szStartTime: any, szStopTime: any): Promise<unknown>;
1063
+ JS_SetSecretKey(iWndNum: any, secretKey: any): void;
1064
+ secretKey: any;
1065
+ JS_OpenSound(): number;
1066
+ JS_CloseSound(): number;
1067
+ /**
1068
+ * @synopsis 打开3D放大
1069
+ *
1070
+ * @param {function} fCallback 回调函数
1071
+ *
1072
+ * @returns {none} 无
1073
+ */
1074
+ JS_Enable3DZoom(iWin: any, fCallback: Function): none;
1075
+ JSPlayM4_SetDisplayRegion(left: any, right: any, top: any, bottom: any): void;
1076
+ /**
1077
+ * @synopsis 关闭3D放大
1078
+ *
1079
+ * @returns {none} 无
1080
+ */
1081
+ JS_Disable3DZoom(): none;
1082
+ JS_StartSave(g_port: any, fileName?: string): Promise<void>;
1083
+ JS_StopSave(): Promise<unknown>;
1084
+ _JSPlayM4_GetFrameInfo(): {
1085
+ codecType: number;
1086
+ width: number;
1087
+ height: number;
1088
+ year: number;
1089
+ month: number;
1090
+ day: number;
1091
+ hour: number;
1092
+ minute: number;
1093
+ second: number;
1094
+ };
1095
+ _JSPlayM4_SetDisplayRegion(left: any, right: any, top: any, bottom: any, flag: boolean | undefined, isFullScreen: any): boolean;
1096
+ JS_CapturePicture(port: any, fileName: any, format: any, callback: any, flag: any): Promise<any>;
1097
+ JS_GetOSDTime(): Promise<number>;
1098
+ JS_Resize(width: any, height: any): void;
1099
+ JS_GetSDKVersion(): any;
1100
+ JS_Stop(): Promise<unknown>;
1101
+ JS_DestroyWorker(): void;
1102
+ JS_Speed(nextRate: any): void;
1103
+ JS_Seek(iWndNum: any, szStartTime: any, szStopTime: any): Promise<void>;
1104
+ /**
1105
+ * @synopsis 暂停
1106
+ *
1107
+ * @param {number} iWndNum 窗口号
1108
+ *
1109
+ * @returns {none} 无
1110
+ */
1111
+ JS_Pause(iWndNum: number, date: any): none;
1112
+ /**
1113
+ * @synopsis 恢复
1114
+ *
1115
+ * @param {number} iWndNum 窗口号
1116
+ *
1117
+ * @returns {none} 无
1118
+ */
1119
+ JS_Resume(resumeTime: any): none;
1120
+ /**
1121
+ * @description
1122
+ * @param {Object} type 矫正类型 参考 src/ezopen/constants.js
1123
+ * @param {string} ids 如果分屏矫正,需要传入分屏canvas的id字符串列表 如 canvas1,canvas2,canvas3
1124
+ * @returns {Array<{code: number, msg: string, port: number, id: string}>} // code= 0 成功, -1 失败
1125
+ */
1126
+ JS_FECCorrectType(type: any, ids: string): Array<{
1127
+ code: number;
1128
+ msg: string;
1129
+ port: number;
1130
+ id: string;
1131
+ }>;
1132
+ /**
1133
+ * @description 设置 2D 鱼眼矫正旋转参数
1134
+ * @param {number} fishSubPort 鱼眼端口 主屏默认为 0
1135
+ * @param {Object} param2d
1136
+ */
1137
+ JS_FECSetParam2D(fishSubPort: number, param2d: any): any;
1138
+ /**
1139
+ * @description 设置 3D 矫正视角参数
1140
+ * @param {FECViewParam} param
1141
+ * @returns {Promise<boolean>} true: 成功 false: 失败 undefined: 不支持
1142
+ */
1143
+ FEC_Set3DViewParam(param: FECViewParam): Promise<boolean>;
1144
+ /**
1145
+ * @description 获取 3D 矫正视角参数
1146
+ * @param {FECGetViewParam} param
1147
+ * @returns {Promise<object>}
1148
+ */
1149
+ FEC_Get3DViewParam(param: FECGetViewParam): Promise<object>;
1150
+ /**
1151
+ * @description 开启水印
1152
+ * @param {object} params 开启水印参数
1153
+ * fontString:文本信息(必填)
1154
+ * startPos:文本位置
1155
+ * fontColor:字体颜色
1156
+ * fontSize:字体大小
1157
+ * fontRotate:字体旋转角度
1158
+ * fontFamily:字体
1159
+ * @returns {Promise<object>}
1160
+ */
1161
+ JS_SetWaterMarkFont(params: object): Promise<object>;
1162
+ }
1163
+
1164
+ export { JSPlugin as default };