UNPKG

hm-ng-video

Version:

(1)引入 npm 包,在==package.json==里面添加:

707 lines 60.5 kB
/** * @fileoverview added by tsickle * Generated from: lib/hm-ng-video.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ViewChild, Input, ElementRef, ViewEncapsulation, EventEmitter, Output, Renderer2, } from "@angular/core"; // import videojs from "hm-videojs"; import videojs from "video.js"; var HmNgVideoComponent = /** @class */ (function () { function HmNgVideoComponent(el, renderer) { this.el = el; this.renderer = renderer; this.PauseEventListener = new EventEmitter(); // 暂停回调 // 暂停回调 this.PlayingEventListener = new EventEmitter(); // 开始播放回调 // 开始播放回调 this.WaitingEventListener = new EventEmitter(); // 缓冲回调 // 缓冲回调 this.ErrorEventListener = new EventEmitter(); // 错误回调 // 错误回调 this.DataLoadedEventListener = new EventEmitter(); // 数据加载完成回调 // 数据加载完成回调 this.CanPlayEventListener = new EventEmitter(); // 可以播放回调 // 可以播放回调 this.ReLoadVideoEventListener = new EventEmitter(); // 重新加载 // 重新加载 this.FullScreenToggeleEventListener = new EventEmitter(); // 切换全屏 // 切换全屏 this.liveLoaded = false; } /** * @param {?} type * @return {?} */ HmNgVideoComponent.prototype.createDom = /** * @param {?} type * @return {?} */ function (type) { var _this = this; if (type === "file") { this.fileVideo.nativeElement.innerHTML = "<video id='" + this.className + "-fileVideo' class='video-js vjs-big-play-centered' controls muted preload='none' x-webkit-airplay='true' webkit-playsinline='isiPhoneShowPlaysinline' playsinline='isiPhoneShowPlaysinline' x5-playsinline='true' x5-video-player-type='h5'></video>"; } else { /** @type {?} */ var guide = "<div class='loading " + this.className + "-loading'><img src='" + (this.loadingSrc || "") + "' alt='' ></div>"; /** @type {?} */ var error = "<div class='error " + this.className + "-error'><span>" + (this.errorContent || "") + "</span></div>"; this.liveVideo.nativeElement.innerHTML = "<video id='" + this.className + "-liveVideo' class='video-js vjs-big-play-centered' controls muted preload='none' x-webkit-airplay='true' webkit-playsinline='isiPhoneShowPlaysinline' playsinline='isiPhoneShowPlaysinline' x5-playsinline='true' x5-video-player-type='h5'></video>" + guide + error; this.el.nativeElement .querySelector("." + this.className + "-error") .addEventListener("click", (/** * @return {?} */ function () { _this.setBgVisible("error", false); _this.createLivePlayer(true); })); } }; /** * @return {?} */ HmNgVideoComponent.prototype.init = /** * @return {?} */ function () { var _this = this; this.liveLoaded = false; // 只播放其中一种就传一种类型的option if (this.fileOptions) { this.createDom("file"); /** @type {?} */ var fileVideoEl = this.el.nativeElement.querySelector("#" + this.className + "-fileVideo"); this.filePlayer = videojs(fileVideoEl, Object.assign(this.fileOptions, { autoplay: this.autoplay, errorDisplay: false, controlBar: { playToggle: true, volumePanel: false, // 不需要静音按钮 pictureInPictureToggle: false, // 不需要画中画 fullscreenToggle: false, }, })); this.setDefaultProperty(this.filePlayer); this.filePlayer.on("error", (/** * @param {?} $event * @return {?} */ function ($event) { _this.ErrorEventListener.emit($event); console.log("文件流出错了!"); _this.dispose(_this.filePlayer); _this.fileOptions = null; _this.createLivePlayer(true, true); })); this.filePlayer.on("playing", (/** * @param {?} $event * @return {?} */ function ($event) { _this.PlayingEventListener.emit($event); if (!_this.livePlayer) { _this.createLivePlayer(true); // 文件流和直播流都存在的情况下,如果不是自动播放,则强行创造自动播放的直播流 } })); this.filePlayer.on("pause", (/** * @param {?} $event * @return {?} */ function ($event) { _this.PauseEventListener.emit($event); })); } else { this.createLivePlayer(); // 如果没有文件流,则按照设置的是否自动播放执行 } }; // 创建直播流 ,内部传就按照内部传的,不传则根据调用的决定 // 创建直播流 ,内部传就按照内部传的,不传则根据调用的决定 /** * @param {?=} isAutoPlay * @param {?=} isLoading * @return {?} */ HmNgVideoComponent.prototype.createLivePlayer = // 创建直播流 ,内部传就按照内部传的,不传则根据调用的决定 /** * @param {?=} isAutoPlay * @param {?=} isLoading * @return {?} */ function (isAutoPlay, isLoading) { var _this = this; if (!this.liveOptions) { return; } this.createDom("live"); if (isLoading) { this.setBgVisible("loading", true); } /** @type {?} */ var liveVideoEl = this.el.nativeElement.querySelector("#" + this.className + "-liveVideo"); /** @type {?} */ var startTime = 0; /** @type {?} */ var endTime = 0; this.livePlayer = videojs(liveVideoEl, Object.assign(this.liveOptions, { autoplay: isAutoPlay ? isAutoPlay : this.autoplay, errorDisplay: false, liveui: true, controlBar: { playToggle: true, volumePanel: false, // 不需要静音按钮 pictureInPictureToggle: false, // 不需要画中画 fullscreenToggle: false, }, })); this.addFullScreen(); this.setDefaultProperty(this.livePlayer); this.livePlayer.on("loadstart", (/** * @param {?} $event * @return {?} */ function ($event) { console.log("直播流开始load"); startTime = new Date().getTime(); // this.setBgVisible("loading", true); if (!_this.isVideoLoadingTimeout) { _this.isVideoLoadingTimeout = setTimeout((/** * @return {?} */ function () { if (_this.livePlayer && _this.livePlayer.readyState() !== 3 && _this.livePlayer.readyState() !== 4) { _this.openModal(); _this.ErrorEventListener.emit("overtime"); console.log("加载超时!"); } }), _this.maxLoadTime || 15000); } })); this.livePlayer.on("loadedmetadata", (/** * @param {?} $event * @return {?} */ function ($event) { endTime = new Date().getTime(); console.log("直播流加载成功"); _this.setBgVisible("loading", false); _this.DataLoadedEventListener.emit(Object.assign($event, { bufferTime: endTime - startTime })); })); this.livePlayer.on("canplaythrough", (/** * @param {?} $event * @return {?} */ function ($event) { if (_this.livePlayer.readyState() === 3 || _this.livePlayer.readyState() === 4) { setTimeout((/** * @return {?} */ function () { if (_this.filePlayer) { _this.dispose(_this.filePlayer); } _this.liveLoaded = true; _this.setBgVisible("loading", false); }), 1000); _this.CanPlayEventListener.emit($event); } console.log(_this.livePlayer.readyState(), "canplaythrough"); })); this.livePlayer.on("playing", (/** * @param {?} $event * @return {?} */ function ($event) { console.log("直播流正在播放!"); _this.destroyTimeout(); _this.setBgVisible("loading", false); _this.PlayingEventListener.emit($event); })); this.livePlayer.on("error", (/** * @param {?} $event * @return {?} */ function ($event) { _this.ErrorEventListener.emit($event); console.log("直播流出错了!"); _this.openModal(); })); this.livePlayer.on("pause", (/** * @param {?} $event * @return {?} */ function ($event) { _this.PauseEventListener.emit($event); })); this.livePlayer.on("timeupdate", (/** * @param {?} $event * @return {?} */ function ($event) { if (!_this.isVideoBreak) { if (_this.livePlayer.readyState() !== 3 && _this.livePlayer.readyState() !== 4) { _this.WaitingEventListener.emit($event); _this.isVideoBreak = setTimeout((/** * @return {?} */ function () { if (_this.livePlayer && _this.livePlayer.readyState() !== 3 && _this.livePlayer.readyState() !== 4) { _this.openModal(); _this.ErrorEventListener.emit("overtime"); console.log("缓冲超时!"); } }), _this.maxLoadTime || 15000); } } })); }; // 获取player实例 // 获取player实例 /** * @return {?} */ HmNgVideoComponent.prototype.getFilePlayer = // 获取player实例 /** * @return {?} */ function () { return this.filePlayer || undefined; }; /** * @return {?} */ HmNgVideoComponent.prototype.getLivePlayer = /** * @return {?} */ function () { return this.livePlayer || undefined; }; // 默认配置 // 默认配置 /** * @param {?} player * @return {?} */ HmNgVideoComponent.prototype.setDefaultProperty = // 默认配置 /** * @param {?} player * @return {?} */ function (player) { player.playsinline(true); //player.crossOrigin("anonymous"); }; // 销毁 // 销毁 /** * @param {?} player * @return {?} */ HmNgVideoComponent.prototype.dispose = // 销毁 /** * @param {?} player * @return {?} */ function (player) { if (!player) { return; } if (!player.isDisposed()) { player.dispose(); player = undefined; } }; // 销毁定时器 // 销毁定时器 /** * @return {?} */ HmNgVideoComponent.prototype.destroyTimeout = // 销毁定时器 /** * @return {?} */ function () { clearTimeout(this.isVideoBreak); clearTimeout(this.isVideoLoadingTimeout); clearInterval(this.fullScreenTimer); this.isVideoBreak = undefined; this.isVideoLoadingTimeout = undefined; this.fullScreenTimer = undefined; }; // 全部销毁 // 全部销毁 /** * @return {?} */ HmNgVideoComponent.prototype.destroy = // 全部销毁 /** * @return {?} */ function () { this.destroyTimeout(); this.dispose(this.filePlayer); this.dispose(this.livePlayer); }; // 绑定错误事件 // 自定义错误显示方式 // 0,1,2,3,4,5 // MEDIA_ERR_CUSTOM、 // MEDIA_ERR_ABORTED、取回过程被用户中止 // MEDIA_ERR_NETWORK、当下载时发生错误 // MEDIA_ERR_DECODE、当解码时发生错误 // MEDIA_ERR_SRC_NOT_SUPPORTED、不支持音频/视频 // MEDIA_ERR_ENCRYPTED // 被加密 // 错误弹窗 // 绑定错误事件 // 自定义错误显示方式 // 0,1,2,3,4,5 // MEDIA_ERR_CUSTOM、 // MEDIA_ERR_ABORTED、取回过程被用户中止 // MEDIA_ERR_NETWORK、当下载时发生错误 // MEDIA_ERR_DECODE、当解码时发生错误 // MEDIA_ERR_SRC_NOT_SUPPORTED、不支持音频/视频 // MEDIA_ERR_ENCRYPTED // 被加密 // 错误弹窗 /** * @return {?} */ HmNgVideoComponent.prototype.openModal = // 绑定错误事件 // 自定义错误显示方式 // 0,1,2,3,4,5 // MEDIA_ERR_CUSTOM、 // MEDIA_ERR_ABORTED、取回过程被用户中止 // MEDIA_ERR_NETWORK、当下载时发生错误 // MEDIA_ERR_DECODE、当解码时发生错误 // MEDIA_ERR_SRC_NOT_SUPPORTED、不支持音频/视频 // MEDIA_ERR_ENCRYPTED // 被加密 // 错误弹窗 /** * @return {?} */ function () { this.fileOptions = null; this.destroy(); this.setBgVisible("loading", false); this.setBgVisible("error", true); }; // 设置加载背景/错误背景显示隐藏 // 设置加载背景/错误背景显示隐藏 /** * @param {?} type * @param {?} isShow * @return {?} */ HmNgVideoComponent.prototype.setBgVisible = // 设置加载背景/错误背景显示隐藏 /** * @param {?} type * @param {?} isShow * @return {?} */ function (type, isShow) { /** @type {?} */ var el = type === "loading" ? this.el.nativeElement.querySelector("." + this.className + "-loading") : this.el.nativeElement.querySelector("." + this.className + "-error"); this.renderer.setStyle(el, "display", isShow ? "block" : "none"); }; // 判断是ios设备 // 判断是ios设备 /** * @return {?} */ HmNgVideoComponent.prototype.isIOS = // 判断是ios设备 /** * @return {?} */ function () { /** @type {?} */ var u = navigator.userAgent; /** @type {?} */ var isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); console.log("ios", isIOS); return isIOS; }; // 添加自定义全屏和播放按钮 // 添加自定义全屏和播放按钮 /** * @return {?} */ HmNgVideoComponent.prototype.addFullScreen = // 添加自定义全屏和播放按钮 /** * @return {?} */ function () { var _this = this; /** @type {?} */ var vjsButtonComponent = videojs.getComponent("Button"); videojs.registerComponent("FullScreenButton", videojs.extend(vjsButtonComponent, { handleClick: (/** * @return {?} */ function () { if (!_this.livePlayer.isFullscreen()) { try { _this.toFullScreen(); if (_this.isIOS()) { _this.fullScreenTimer = setInterval((/** * @return {?} */ function () { if (!_this.livePlayer.isFullscreen()) { // 退出了全屏 _this.FullScreenToggeleEventListener.emit(false); _this.destroy(); _this.createLivePlayer(true); // clearInterval(this.fullScreenTimer); // setTimeout(() => { // this.livePlayer.play(); // }, 1000); } }), 1000); } } catch (error) { console.warn(error); } } else { _this.FullScreenToggeleEventListener.emit(false); _this.livePlayer.exitFullscreen(); } }), buildCSSClass: (/** * @return {?} */ function () { return "my_fullscreen"; }), })); this.livePlayer.getChild("controlBar").addChild("FullScreenButton", {}); }; // 自定义全屏 // 自定义全屏 /** * @return {?} */ HmNgVideoComponent.prototype.toFullScreen = // 自定义全屏 /** * @return {?} */ function () { this.FullScreenToggeleEventListener.emit(true); if (this.livePlayer.requestFullscreen) { return this.livePlayer.requestFullscreen(); } else if (this.livePlayer.webkitRequestFullScreen) { return this.livePlayer.webkitRequestFullScreen(); } else if (this.livePlayer.mozRequestFullScreen) { return this.livePlayer.mozRequestFullScreen(); } else { return this.livePlayer.msRequestFullscreen(); } }; /** * @return {?} */ HmNgVideoComponent.prototype.ngOnInit = /** * @return {?} */ function () { console.log("hm-ng-video 1.5.6"); }; /** * @param {?} changes * @return {?} */ HmNgVideoComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { var _this = this; if (this.exitFullScreen) { console.log("按返回键退出全屏"); this.FullScreenToggeleEventListener.emit(false); this.livePlayer.exitFullscreen(); } if ((changes.fileOptions && changes.fileOptions.firstChange && changes.fileOptions.currentValue) || (changes.liveOptions && changes.liveOptions.firstChange && changes.liveOptions.currentValue)) { this.init(); } if ((changes.fileOptions && changes.fileOptions.currentValue && !changes.fileOptions.firstChange) || (changes.liveOptions && changes.liveOptions.currentValue && !changes.liveOptions.firstChange)) { this.destroy(); setTimeout((/** * @return {?} */ function () { _this.init(); }), 1000); } }; /** * @return {?} */ HmNgVideoComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy(); }; HmNgVideoComponent.decorators = [ { type: Component, args: [{ selector: "hm-ng-video", template: "<!--\r\n * @Descripttion:\r\n * @version:\r\n * @Author: yding\r\n * @Date: 2020-05-08 19:05:06\r\n * @LastEditors: yding\r\n * @LastEditTime: 2020-06-19 10:44:58\r\n-->\r\n<!-- <button\r\n class=\"button\"\r\n style=\"background: red;\"\r\n (click)=\"fullScreen()\"\r\n value=\"\u5168\u5C4F\"\r\n>\r\n \u5168\u5C4F\r\n</button> -->\r\n<div\r\n class=\"vjs-video\"\r\n #fileVideoEl\r\n [ngStyle]=\"{\r\n height: videoHeight + 'px',\r\n width: videoWidth + 'px',\r\n position: 'relative'\r\n }\"\r\n [hidden]=\"(liveLoaded && liveOptions && fileOptions) || !fileOptions\"\r\n></div>\r\n<div\r\n class=\"vjs-video\"\r\n #liveVideoEl\r\n [ngStyle]=\"{\r\n height: videoHeight + 'px',\r\n width: videoWidth + 'px',\r\n position: 'relative'\r\n }\"\r\n [hidden]=\"(!liveLoaded && liveOptions && fileOptions) || !liveOptions\"\r\n></div>\r\n", encapsulation: ViewEncapsulation.None, styles: [".video-js{width:100%;height:100%}.retry:focus,.vjs-big-play-button:focus,video:focus{outline:0}.vjs-paused .vjs-big-play-button,.vjs-paused.vjs-has-started .vjs-big-play-button{display:none}.video-js .vjs-big-play-button{font-size:2.5em;line-height:2.3em;height:2.5em;width:2.5em;border-radius:2.5em;background-color:rgba(115,133,159,.5);border-width:.15em;margin-top:-1.25em;margin-left:-1.75em}.vjs-big-play-button .vjs-icon-placeholder{font-size:1.63em}.vjs-progress-control.vjs-control,.vjs-remaining-time.vjs-time-control.vjs-control{display:none}.vjs-loading-spinner{border:none;visibility:visible;border-radius:0}.vjs-waiting .vjs-loading-spinner{-webkit-animation:none!important;animation:none!important}.video-js .vjs-control.vjs-close-button{display:none}.loading{width:100%;height:100%;top:0;left:0;position:absolute;pointer-events:none;z-index:71;background:#000;display:none}.loading img{width:35px;height:35px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.error{width:100%;height:100%;top:0;left:0;position:absolute;background:#000;cursor:pointer;z-index:70;display:none}.error span{display:block;text-align:center;padding-top:30%;color:#fff}.vjs-control-bar>button.my_fullscreen::before{display:block!important;content:\"\u5168\u5C4F/\u9000\u51FA\";cursor:pointer}"] }] } ]; /** @nocollapse */ HmNgVideoComponent.ctorParameters = function () { return [ { type: ElementRef }, { type: Renderer2 } ]; }; HmNgVideoComponent.propDecorators = { fileVideo: [{ type: ViewChild, args: ["fileVideoEl",] }], liveVideo: [{ type: ViewChild, args: ["liveVideoEl",] }], fileOptions: [{ type: Input }], liveOptions: [{ type: Input }], autoplay: [{ type: Input }], videoHeight: [{ type: Input }], videoWidth: [{ type: Input }], className: [{ type: Input }], loadingSrc: [{ type: Input }], maxReloadTimes: [{ type: Input }], errorContent: [{ type: Input }], maxLoadTime: [{ type: Input }], exitFullScreen: [{ type: Input }], PauseEventListener: [{ type: Output }], PlayingEventListener: [{ type: Output }], WaitingEventListener: [{ type: Output }], ErrorEventListener: [{ type: Output }], DataLoadedEventListener: [{ type: Output }], CanPlayEventListener: [{ type: Output }], ReLoadVideoEventListener: [{ type: Output }], FullScreenToggeleEventListener: [{ type: Output }] }; return HmNgVideoComponent; }()); export { HmNgVideoComponent }; if (false) { /** @type {?} */ HmNgVideoComponent.prototype.fileVideo; /** @type {?} */ HmNgVideoComponent.prototype.liveVideo; /** @type {?} */ HmNgVideoComponent.prototype.fileOptions; /** @type {?} */ HmNgVideoComponent.prototype.liveOptions; /** @type {?} */ HmNgVideoComponent.prototype.autoplay; /** @type {?} */ HmNgVideoComponent.prototype.videoHeight; /** @type {?} */ HmNgVideoComponent.prototype.videoWidth; /** @type {?} */ HmNgVideoComponent.prototype.className; /** @type {?} */ HmNgVideoComponent.prototype.loadingSrc; /** @type {?} */ HmNgVideoComponent.prototype.maxReloadTimes; /** @type {?} */ HmNgVideoComponent.prototype.errorContent; /** @type {?} */ HmNgVideoComponent.prototype.maxLoadTime; /** @type {?} */ HmNgVideoComponent.prototype.exitFullScreen; /** @type {?} */ HmNgVideoComponent.prototype.PauseEventListener; /** @type {?} */ HmNgVideoComponent.prototype.PlayingEventListener; /** @type {?} */ HmNgVideoComponent.prototype.WaitingEventListener; /** @type {?} */ HmNgVideoComponent.prototype.ErrorEventListener; /** @type {?} */ HmNgVideoComponent.prototype.DataLoadedEventListener; /** @type {?} */ HmNgVideoComponent.prototype.CanPlayEventListener; /** @type {?} */ HmNgVideoComponent.prototype.ReLoadVideoEventListener; /** @type {?} */ HmNgVideoComponent.prototype.FullScreenToggeleEventListener; /** @type {?} */ HmNgVideoComponent.prototype.liveLoaded; /** * @type {?} * @private */ HmNgVideoComponent.prototype.filePlayer; /** * @type {?} * @private */ HmNgVideoComponent.prototype.livePlayer; /** * @type {?} * @private */ HmNgVideoComponent.prototype.isVideoBreak; /** * @type {?} * @private */ HmNgVideoComponent.prototype.isVideoLoadingTimeout; /** * @type {?} * @private */ HmNgVideoComponent.prototype.fullScreenTimer; /** * @type {?} * @private */ HmNgVideoComponent.prototype.el; /** @type {?} */ HmNgVideoComponent.prototype.renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hm-ng-video.component.js","sourceRoot":"ng://hm-ng-video/","sources":["lib/hm-ng-video.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  ViewChild,\n  Input,\n  ElementRef,\n  ViewEncapsulation,\n  OnDestroy,\n  EventEmitter,\n  Output,\n  OnChanges,\n  SimpleChanges,\n  Renderer2,\n} from \"@angular/core\";\n// import videojs from \"hm-videojs\";\nimport videojs from \"video.js\";\n@Component({\n  selector: \"hm-ng-video\",\n  templateUrl: \"./hm-ng-video.component.html\",\n  styleUrls: [\"./hm-ng-video.component.css\"],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class HmNgVideoComponent implements OnInit, OnDestroy, OnChanges {\n  @ViewChild(\"fileVideoEl\") fileVideo: ElementRef;\n  @ViewChild(\"liveVideoEl\") liveVideo: ElementRef;\n  @Input() fileOptions?: {\n    loop: boolean;\n    controls: boolean;\n    poster: string;\n    preload: \"auto\" | \"metadata\" | \"none\";\n    sources: {\n      src: string;\n      type: string;\n    }[];\n  };\n  @Input() liveOptions?: {\n    controls: boolean;\n    poster: string;\n    preload: \"auto\" | \"metadata\" | \"none\";\n    sources: {\n      src: string;\n      type: string;\n    }[];\n  };\n  @Input() autoplay: boolean;\n  @Input() videoHeight: number;\n  @Input() videoWidth: number;\n  @Input() className: string;\n  @Input() loadingSrc: string;\n  @Input() maxReloadTimes?: number;\n  @Input() errorContent?: string;\n  @Input() maxLoadTime?: number;\n\n  @Input() exitFullScreen?: boolean;\n\n  @Output() PauseEventListener = new EventEmitter<string>(); // 暂停回调\n  @Output() PlayingEventListener = new EventEmitter<string>(); // 开始播放回调\n  @Output() WaitingEventListener = new EventEmitter<string>(); // 缓冲回调\n  @Output() ErrorEventListener = new EventEmitter<string>(); // 错误回调\n  @Output() DataLoadedEventListener = new EventEmitter<string>(); // 数据加载完成回调\n  @Output() CanPlayEventListener = new EventEmitter<string>(); // 可以播放回调\n  @Output() ReLoadVideoEventListener = new EventEmitter<string>(); // 重新加载\n\n  @Output() FullScreenToggeleEventListener = new EventEmitter<boolean>(); // 切换全屏\n\n  public liveLoaded = false;\n  private filePlayer: videojs.Player;\n  private livePlayer: videojs.Player;\n  private isVideoBreak: any;\n  private isVideoLoadingTimeout: any;\n\n  private fullScreenTimer: any; // 监听全屏\n\n  constructor(private el: ElementRef, public renderer: Renderer2) {}\n\n  public createDom(type: \"file\" | \"live\") {\n    if (type === \"file\") {\n      this.fileVideo.nativeElement.innerHTML = `<video id='${this.className}-fileVideo' class='video-js vjs-big-play-centered'  controls muted preload='none' x-webkit-airplay='true' webkit-playsinline='isiPhoneShowPlaysinline' playsinline='isiPhoneShowPlaysinline' x5-playsinline='true' x5-video-player-type='h5'></video>`;\n    } else {\n      const guide =\n        `<div class='loading ${this.className}-loading'><img src='` +\n        (this.loadingSrc || \"\") +\n        `' alt='' ></div>`;\n      const error =\n        `<div class='error ${this.className}-error'><span>` +\n        (this.errorContent || \"\") +\n        `</span></div>`;\n      this.liveVideo.nativeElement.innerHTML =\n        `<video id='${this.className}-liveVideo' class='video-js vjs-big-play-centered'  controls muted preload='none' x-webkit-airplay='true' webkit-playsinline='isiPhoneShowPlaysinline' playsinline='isiPhoneShowPlaysinline' x5-playsinline='true' x5-video-player-type='h5'></video>` +\n        guide +\n        error;\n      this.el.nativeElement\n        .querySelector(`.${this.className}-error`)\n        .addEventListener(\"click\", () => {\n          this.setBgVisible(\"error\", false);\n          this.createLivePlayer(true);\n        });\n    }\n  }\n  public init() {\n    this.liveLoaded = false;\n    // 只播放其中一种就传一种类型的option\n    if (this.fileOptions) {\n      this.createDom(\"file\");\n      const fileVideoEl = this.el.nativeElement.querySelector(\n        `#${this.className}-fileVideo`\n      );\n      this.filePlayer = videojs(\n        fileVideoEl,\n        Object.assign(this.fileOptions, {\n          autoplay: this.autoplay,\n          errorDisplay: false,\n          controlBar: {\n            playToggle: true,\n            volumePanel: false, // 不需要静音按钮\n            pictureInPictureToggle: false, // 不需要画中画\n            fullscreenToggle: false,\n          },\n        })\n      );\n\n      this.setDefaultProperty(this.filePlayer);\n      this.filePlayer.on(\"error\", ($event) => {\n        this.ErrorEventListener.emit($event);\n        console.log(\"文件流出错了！\");\n        this.dispose(this.filePlayer);\n        this.fileOptions = null;\n        this.createLivePlayer(true, true);\n      });\n\n      this.filePlayer.on(\"playing\", ($event) => {\n        this.PlayingEventListener.emit($event);\n        if (!this.livePlayer) {\n          this.createLivePlayer(true); // 文件流和直播流都存在的情况下，如果不是自动播放，则强行创造自动播放的直播流\n        }\n      });\n      this.filePlayer.on(\"pause\", ($event) => {\n        this.PauseEventListener.emit($event);\n      });\n    } else {\n      this.createLivePlayer(); // 如果没有文件流，则按照设置的是否自动播放执行\n    }\n  }\n\n  // 创建直播流 ,内部传就按照内部传的，不传则根据调用的决定\n  public createLivePlayer(isAutoPlay?, isLoading?) {\n    if (!this.liveOptions) {\n      return;\n    }\n    this.createDom(\"live\");\n    if (isLoading) {\n      this.setBgVisible(\"loading\", true);\n    }\n    const liveVideoEl = this.el.nativeElement.querySelector(\n      `#${this.className}-liveVideo`\n    );\n    let startTime = 0,\n      endTime = 0;\n    this.livePlayer = videojs(\n      liveVideoEl,\n      Object.assign(this.liveOptions, {\n        autoplay: isAutoPlay ? isAutoPlay : this.autoplay,\n        errorDisplay: false,\n        liveui: true,\n        controlBar: {\n          playToggle: true,\n          volumePanel: false, // 不需要静音按钮\n          pictureInPictureToggle: false, // 不需要画中画\n          fullscreenToggle: false,\n        },\n      })\n    );\n    this.addFullScreen();\n    this.setDefaultProperty(this.livePlayer);\n    this.livePlayer.on(\"loadstart\", ($event) => {\n      console.log(\"直播流开始load\");\n      startTime = new Date().getTime();\n      // this.setBgVisible(\"loading\", true);\n      if (!this.isVideoLoadingTimeout) {\n        this.isVideoLoadingTimeout = setTimeout(() => {\n          if (\n            this.livePlayer &&\n            this.livePlayer.readyState() !== 3 &&\n            this.livePlayer.readyState() !== 4\n          ) {\n            this.openModal();\n            this.ErrorEventListener.emit(\"overtime\");\n            console.log(\"加载超时！\");\n          }\n        }, this.maxLoadTime || 15000);\n      }\n    });\n    this.livePlayer.on(\"loadedmetadata\", ($event) => {\n      endTime = new Date().getTime();\n      console.log(\"直播流加载成功\");\n      this.setBgVisible(\"loading\", false);\n      t