vue中使用@liveqing/liveplayer报错问题踩坑记录

2023-10-18 06:36

本文主要是介绍vue中使用@liveqing/liveplayer报错问题踩坑记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.安装@liveqing/liveplayer

npm i @liveqing/liveplayer

2.引入插件(这里是封装了视频组件)

<template><LivePlayerclass="component-wrapper video-panel":class="{ fullscreen: flag }":videoUrl="options.url":videoTitle="options.title":poster="options.poster":controls="options.controls":autoplay="options.autoplay":live="options.live":hide-snapshot-button="options.hideSnapshot":muted="options.muted":fluent="options.fluent":stretch="options.stretch":aspect="options.aspect":loading="options.loading":hide-big-play-button="options.hideBigPlay"@fullscreen="onFullscreen"><slot></slot></LivePlayer>
</template><script>
import LivePlayer from "@liveqing/liveplayer";export default {name: "VideoPanel",components: {LivePlayer,},props: {params: {type: Object,default: function () {return {url: "",};},},defaultOpts: {type: Object,default: function () {return {// 播放地址url: "",// 视频标题title: "",// 视频封面图片poster: "",// 播放器控制栏controls: true,// 隐藏截图hideSnapshot: true,// 是否直播live: false,// 是否自动播放autoplay: true,// 是否静音muted: true,// 流畅模式fluent: true,// 是否拉伸stretch: true,// 全屏 - 适应divaspect: "fullscreen",// 指示加载状态loading: true,// 隐藏起播状态下的大播放按钮hideBigPlay: true,};},},},data() {return {options: {},flag: false,};},watch: {params: function (newVal) {// if (newVal) {this.options.url= newVal;// }},},created() {this.options = Object.assign({}, this.defaultOpts, this.params);},beforeDestroy() {if (this.options) {this.options.url = "";}this.onExitFullscreen();},methods: {onExitFullscreen() {this.flag = false;},onFullscreen(status) {this.flag = status;if (!status) {this.onExitFullscreen();return;}},},
};
</script><style lang="scss" scoped>
.component-wrapper.video-panel {position: relative;width: 100%;height: 100%;.video-wrapper .video-js {background-color: rgba(32, 46, 71, 0.6);.video-title {top: 4px;right: unset;left: 4px;padding: 4px 6px;max-width: 80%;font-size: 16px;}.video-control {position: absolute;top: 100%;left: 50%;transform: translate(-50%, -140%);margin-top: 0;}}&.fullscreen .video-wrapper .video-js {.video-title {top: 60px;right: unset;left: 20px;padding: 5px 8px 6px;background: rgba(4, 16, 37, 0.6);border-radius: 4px;}}
}
</style>

3.使用

<template><div><div class="video-box"><div class="video"><video-panel :params="videoLeftUrl"></video-panel></div><div class="video"><video-panel :params="videoRightUrl"></video-panel></div><div class="video"><video-panel :params="videoRtspUrl"></video-panel></div></div></div>
</template>
<script>
import VideoPanel from "@/components/video/VideoPanel.vue";
export default {components: { VideoPanel },data() {return {videoLeftUrl:"",videoRightUrl:"",videoRtspUrl:"",}}
}
</script>

正常来说这就可以是吧 但是这里还需要以下几步:
1.安装插件copy-webpack-plugin 请下载这个版本 最开始直接下的最新版 起不来哈

npm  i  copy-webpack-plugin@4.6.0

2.在vue.config.js中如下配置

const CopyWebpackPlugin = require('copy-webpack-plugin')
module.exports = {configureWebpack: config => {// 视频播放config.plugins.push(new CopyWebpackPlugin([{from: 'node_modules/@liveqing/liveplayer/dist/component/crossdomain.xml'},{from: 'node_modules/@liveqing/liveplayer/dist/component/liveplayer.swf'},{from: 'node_modules/@liveqing/liveplayer/dist/component/liveplayer-lib.min.js',to: 'js/'}]))},devServer: {port: 1888,}
}

3.在public/index.html 中引用 liveplayer-lib.min.js

 <head>
<script  type="text/javascript" src="<%= BASE_URL %>js/liveplayer-lib.min.js"></script>
<script  type="text/javascript" src="<%= BASE_URL %>js/liveplayer-component.min.js"></script>
</head>

即可完美启动 但是这个插件不可以直接播放rtsp流 转化视频流过程中可能回出现延迟问题 如需解决请看下篇

这篇关于vue中使用@liveqing/liveplayer报错问题踩坑记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/230829

相关文章

springboot3.x使用@NacosValue无法获取配置信息的解决过程

《springboot3.x使用@NacosValue无法获取配置信息的解决过程》在SpringBoot3.x中升级Nacos依赖后,使用@NacosValue无法动态获取配置,通过引入SpringC... 目录一、python问题描述二、解决方案总结一、问题描述springboot从2android.x

SpringBoot整合AOP及使用案例实战

《SpringBoot整合AOP及使用案例实战》本文详细介绍了SpringAOP中的切入点表达式,重点讲解了execution表达式的语法和用法,通过案例实战,展示了AOP的基本使用、结合自定义注解以... 目录一、 引入依赖二、切入点表达式详解三、案例实战1. AOP基本使用2. AOP结合自定义注解3.

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Linux内核定时器使用及说明

《Linux内核定时器使用及说明》文章详细介绍了Linux内核定时器的特性、核心数据结构、时间相关转换函数以及操作API,通过示例展示了如何编写和使用定时器,包括按键消抖的应用... 目录1.linux内核定时器特征2.Linux内核定时器核心数据结构3.Linux内核时间相关转换函数4.Linux内核定时

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav