hm-ng-video
Version:
(1)引入 npm 包,在==package.json==里面添加:
707 lines • 60.5 kB
JavaScript
/**
* @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