@volcengine/veplayer 1.9.7 → 1.9.8-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.d.ts CHANGED
@@ -2,7 +2,7 @@ import VeStrategy from '@byted/volcengine-vestrategy';
2
2
  import { StrategyRecommendation } from '@byted/volcengine-vestrategy';
3
3
  import { VeStrategyH265Config } from '@byted/volcengine-vestrategy-h265';
4
4
  import { PreloaderManager as PreloaderManagerOrigin } from '@byted/volcengine-vestrategy-preload';
5
- import VodLogger from '@byted/xgplayer-app-logger/es/logger.js';
5
+ import VodLogger from '@byted/xgplayer-app-logger/es/logger';
6
6
  import EventEmitter from 'eventemitter3';
7
7
  import Player from 'xgplayer';
8
8
  import { BasePlugin, I18N, IXGI18nText, Plugin } from 'xgplayer';
@@ -1253,6 +1253,75 @@ export declare type IDefinition = {
1253
1253
  [propName: string]: any;
1254
1254
  };
1255
1255
  };
1256
+ /**
1257
+ * @brief 音量配置。
1258
+ * @list Options
1259
+ * @kind property
1260
+ */
1261
+ export declare type IVolume = number | {
1262
+ /**
1263
+ * @brief 插件Dom挂载的位置,默认播放器底部控制栏右侧
1264
+ * @default POSITIONS.CONTROLS_RIGHT
1265
+ */
1266
+ position?: POSITIONS;
1267
+ /**
1268
+ * @brief 插件在挂载的位置的排序权重
1269
+ * @default 1
1270
+ */
1271
+ index?: number;
1272
+ /**
1273
+ * @brief 是否禁用插件交互行为,即是否隐藏音量调节按钮
1274
+ * @default false
1275
+ */
1276
+ disable?: boolean;
1277
+ /**
1278
+ * @brief 是否在音量调节slider上方显示当前音量数值
1279
+ * @default false
1280
+ */
1281
+ showValueLabel?: boolean;
1282
+ /**
1283
+ * @brief 默认音量大小,取值范围0-1
1284
+ * @default 0.6
1285
+ */
1286
+ default?: number;
1287
+ /**
1288
+ * @brief 静音恢复的时候最小音量
1289
+ * @default 0.2
1290
+ */
1291
+ miniVolume?: number;
1292
+ };
1293
+ /**
1294
+ * @brief 进度条标记点配置。
1295
+ * @list Options
1296
+ * @kind property
1297
+ */
1298
+ export interface IDot {
1299
+ /**
1300
+ * @brief 进度条标记点
1301
+ * @default 1
1302
+ */
1303
+ id: string | number;
1304
+ /**
1305
+ * @brief 标记点所在的播放时间
1306
+ * @default 0
1307
+ */
1308
+ time: number;
1309
+ /**
1310
+ * @brief 进度条自定义文案
1311
+ * @default -
1312
+ */
1313
+ text?: string;
1314
+ /**
1315
+ * @brief 标记点持续的时间,单位秒
1316
+ * @default 1
1317
+ */
1318
+ duration?: number;
1319
+ /**
1320
+ * @brief 进度条自定义的CSS Style样式
1321
+ * @default -
1322
+ */
1323
+ style?: CSSStyleDeclaration;
1324
+ }
1256
1325
  /**
1257
1326
  * @hidden
1258
1327
  */
@@ -1371,10 +1440,6 @@ export declare type IPlayerOptions = {
1371
1440
  };
1372
1441
  /**
1373
1442
  * @brief mobile端交互配置。
1374
- * @hidden
1375
- */
1376
- /** {en}
1377
- * @hidden
1378
1443
  */
1379
1444
  export interface IMobileConfig {
1380
1445
  /**
@@ -1391,7 +1456,7 @@ export interface IMobileConfig {
1391
1456
  */
1392
1457
  gestureX?: boolean;
1393
1458
  /**
1394
- * @brief 是否启用垂直手势处理, 垂直手势包括屏幕右侧和屏幕左侧,默认左侧调节亮度,右侧调节音量,左右范围比例通过scopeL和scopeR设置
1459
+ * @brief 是否启用垂直手势处理,默认不启用, 垂直手势包括屏幕右侧和屏幕左侧,默认左侧调节亮度,右侧调节音量,左右范围比例通过scopeL和scopeR设置
1395
1460
  * @default false
1396
1461
  */
1397
1462
  gestureY?: boolean;
@@ -1483,10 +1548,6 @@ export interface IMobileConfig {
1483
1548
  }
1484
1549
  /**
1485
1550
  * @brief 播放器中间切换暂停/播放的按钮。
1486
- * @hidden
1487
- */
1488
- /** {en}
1489
- * @hidden
1490
1551
  */
1491
1552
  export interface IStartConfig {
1492
1553
  /**
@@ -2062,7 +2123,9 @@ export declare class MemoryPlay extends Plugin {
2062
2123
  */
2063
2124
  export declare const enum EDRMTYPE {
2064
2125
  DRM_ENCRYPT = "drm_encrypt",
2065
- PRIVATE_ENCRYPT = "private_encrypt"
2126
+ PRIVATE_ENCRYPT = "private_encrypt",
2127
+ PRIVATE_ENCRYPT_UPGRADE = "private_encrypt_upgrade",
2128
+ STANDARD_ENCRYPT = "standard_encrypt"
2066
2129
  }
2067
2130
  /** {zh}
2068
2131
  * @hidden
@@ -2810,7 +2873,7 @@ export interface IPlayerConfig extends IPlayerOptions {
2810
2873
  fitVideoSize?: "fixWidth" | "fixHeight" | "fixed";
2811
2874
  /** {zh}
2812
2875
  * @brief 视频画面填充模式。取值如下:
2813
- * - `fillwidth`: 填充宽度,高度溢出则裁剪高度。
2876
+ * - `fillWidth`: 填充宽度,高度溢出则裁剪高度。
2814
2877
  * - `fillHeight`: 填充高度,宽度溢出则裁剪宽度。
2815
2878
  * - `fill`: 拉伸视频以填充容器。
2816
2879
  * - `cover`: 保持视频宽高比的同时填充元素的整个内容框。
@@ -3224,6 +3287,11 @@ export interface IPlayerConfig extends IPlayerOptions {
3224
3287
  * @default -
3225
3288
  */
3226
3289
  thumbnail?: IThumbnailConfig;
3290
+ /** {zh}
3291
+ * @brief 进度条标记配置
3292
+ * @default -
3293
+ */
3294
+ progressDot?: IDot[];
3227
3295
  }
3228
3296
  /**
3229
3297
  * @brief 播放源数据。支持传入视频播放地址 `url`、播放列表 `playList` 或者 `vid` 和 `playAuthToken`,还需包含新地址的过期时间戳 `urlExpireTimestamp`。
@@ -3272,12 +3340,11 @@ export interface IDefaultConfig {
3272
3340
  */
3273
3341
  startTime?: number;
3274
3342
  /** {zh}
3275
- * @brief 音量
3276
- *
3277
- * @type {number}
3278
- * @memberof IDefaultConfig
3343
+ * @brief 音量配置,如果为数字则表示默认音量大小,取值0-1,
3344
+ * 如果是对象则可以对音量控制插件进行各型特性单独配置
3345
+ * @default 0.6
3279
3346
  */
3280
- volume?: number;
3347
+ volume?: IVolume;
3281
3348
  /** {zh}
3282
3349
  * @brief 弹幕插件配置
3283
3350
  *
@@ -3461,6 +3528,48 @@ export interface definitionItem {
3461
3528
  */
3462
3529
  definitionTextKey?: string;
3463
3530
  }
3531
+ /** {zh}
3532
+ * @brief 插件按钮位置
3533
+ */
3534
+ export declare const enum POSITIONS {
3535
+ /** {zh}
3536
+ * @brief 播放器根节点
3537
+ */
3538
+ ROOT = "root",
3539
+ /** {zh}
3540
+ * @brief 播放器根节点左侧
3541
+ */
3542
+ ROOT_LEFT = "rootLeft",
3543
+ /** {zh}
3544
+ * @brief 播放器根节点右侧
3545
+ */
3546
+ ROOT_RIGHT = "rootRight",
3547
+ /** {zh}
3548
+ * @brief 播放器根节点顶部
3549
+ */
3550
+ ROOT_TOP = "rootTop",
3551
+ /** {zh}
3552
+ * @brief 播控栏左侧
3553
+ */
3554
+ CONTROLS_LEFT = "controlsLeft",
3555
+ /** {zh}
3556
+ * @brief 播控栏左侧
3557
+ */
3558
+ CONTROLS_RIGTH = "controlsRight",
3559
+ /** {zh}
3560
+ * @brief 播控栏右侧
3561
+ */
3562
+ CONTROLS_RIGHT = "controlsRight",
3563
+ /** {zh}
3564
+ * @brief 播控栏中间
3565
+ */
3566
+ CONTROLS_CENTER = "controlsCenter",
3567
+ /** {zh}
3568
+ * @hidden
3569
+ * @brief 播控栏左侧
3570
+ */
3571
+ CONTROLS = "controls"
3572
+ }
3464
3573
  /**
3465
3574
  * @brief Plugin类插件基础配置
3466
3575
  */
@@ -4042,51 +4151,6 @@ declare class VeStrategyWrapper {
4042
4151
  private initPreloaderConfig;
4043
4152
  }
4044
4153
  declare const _default: VeStrategyWrapper;
4045
- /** {zh}
4046
- * @hidden
4047
- */
4048
- export declare type IRes = IGetPlayInfoRes & {
4049
- Data: IGetPlayInfoRes & {
4050
- VideoID?: string;
4051
- };
4052
- };
4053
- /** {zh}
4054
- * @hidden
4055
- */
4056
- export interface IDefItem extends Stream {
4057
- vid: string;
4058
- lineId?: number;
4059
- lineName?: string;
4060
- url: string;
4061
- streamType: string;
4062
- backupUrl: string;
4063
- backUrlList: string[];
4064
- fileType?: "video" | "audio" | "evideo" | "eaudio";
4065
- format: string;
4066
- bitrate?: number;
4067
- size?: number;
4068
- kid?: string;
4069
- vwidth?: number;
4070
- vheight?: number;
4071
- }
4072
- /** {zh}
4073
- * @hidden
4074
- */
4075
- export interface VideoInfoRes {
4076
- playList: IDefItem[];
4077
- type?: string;
4078
- poster: string;
4079
- vid: string;
4080
- duration: number;
4081
- dashOpts: IRes | {
4082
- Data: IRes;
4083
- };
4084
- thumbs: IThumbInfoItem[];
4085
- barrageMaskUrl: string;
4086
- enableAdaptive?: boolean;
4087
- adaptiveBitrateStreamingInfo?: ABRInfo;
4088
- }
4089
- declare function isMSESupport(mime?: string): boolean;
4090
4154
  /** {zh}
4091
4155
  * @hidden
4092
4156
  */
@@ -4518,6 +4582,10 @@ declare class VePlayer {
4518
4582
  * @memberof VePlayer
4519
4583
  */
4520
4584
  static sdkVersion: string;
4585
+ /**
4586
+ * @hidden
4587
+ */
4588
+ private veErrorIns;
4521
4589
  /** {zh}
4522
4590
  * @brief 播放策略预初始化配置
4523
4591
  * @param options 初始化配置,详情见{@link StrategyInitOptions}
@@ -4684,7 +4752,7 @@ declare class VePlayer {
4684
4752
  /** {en}
4685
4753
  * @hidden
4686
4754
  */
4687
- createPlayer(): Promise<PlayerCore>;
4755
+ createPlayer: () => Promise<PlayerCore>;
4688
4756
  /** {zh}
4689
4757
  * @hidden
4690
4758
  * @brief 设置合并开发者的插件配置,如果开发者从初始化的configs里传了插件配置,则只用开发者的配置,并补齐其他参数
@@ -4732,7 +4800,7 @@ declare class VePlayer {
4732
4800
  lineId?: string | number;
4733
4801
  definition?: string;
4734
4802
  startTime?: number;
4735
- volume?: number;
4803
+ volume?: IVolume;
4736
4804
  DanmuPlugin?: any;
4737
4805
  LiveSubtitlesIconPlugin?: any;
4738
4806
  };
@@ -4762,6 +4830,7 @@ declare class VePlayer {
4762
4830
  * @memberof VePlayer
4763
4831
  */
4764
4832
  afterPlayerCreate(): void;
4833
+ _setVeError(): void;
4765
4834
  /**
4766
4835
  * @hidden
4767
4836
  *
@@ -4775,6 +4844,11 @@ declare class VePlayer {
4775
4844
  * @memberof VePlayer
4776
4845
  */
4777
4846
  private _setPlayerInfo;
4847
+ /**
4848
+ * @hidden
4849
+ * @private
4850
+ */
4851
+ private getVtype;
4778
4852
  /**
4779
4853
  *
4780
4854
  *
@@ -4790,6 +4864,7 @@ declare class VePlayer {
4790
4864
  * @memberof VePlayer
4791
4865
  */
4792
4866
  private _bindPlayerEvents;
4867
+ _proxyError: (veError: any) => void;
4793
4868
  private _onError;
4794
4869
  /** {zh}
4795
4870
  * @private
@@ -4880,6 +4955,7 @@ declare class VePlayer {
4880
4955
  */
4881
4956
  set src(url: Url);
4882
4957
  /** {zh}
4958
+ * @hidden
4883
4959
  * @brief 播放时更换视频 URL,以更换视频源。
4884
4960
  * @notes 更换后,会从更换前的时间点继续播放。
4885
4961
  * @param url 视频播放地址。