Jessibuca 插件播放直播流视频

news2024/9/29 21:22:46

jessibuca官网:http://jessibuca.monibuca.com/player.html
git地址:https://gitee.com/huangz2350_admin/jessibuca#https://gitee.com/link?target=http%3A%2F%2Fjessibuca.monibuca.com%2F
项目需要的文件
在这里插入图片描述
在这里插入图片描述

1.播放组件

<template >
    <div id="jessibuca" style="width: auto; height: auto; position: relative" @mouseover="showbtn">
        <div :id="'container' + index" ref="container" :style="'position: relative;width: 100%; height:' +
            height +
            '; background:url(' +  background +
            ') no-repeat;background-size: 100% 100%;background-color: #000;'
            " @dblclick="fullscreenSwich">
            <div :id="'buttonsBox' + index" class="buttons-box" style="position: absolute; left: 0; bottom: 0">
                <div class="buttons-box-left">
                    <i v-if="!playing" class="iconfont icon-play jessibuca-btn" @click="playBtnClick" />
                    <i v-if="playing" class="iconfont icon-pause jessibuca-btn" @click="pause" />
                    <i class="iconfont icon-stop jessibuca-btn" @click="destroy" />
                    <i v-if="isNotMute" class="iconfont icon-audio-high jessibuca-btn" @click="jessibuca.mute()" />
                    <i v-if="!isNotMute" class="iconfont icon-audio-mute jessibuca-btn" @click="jessibuca.cancelMute()" />
                </div>
                <div class="buttons-box-right">
                    <span class="jessibuca-btn">{{ kBps }} kb/s</span>
                    <!--          <i class="iconfont icon-file-record1 jessibuca-btn"></i>-->
                    <!--          <i class="iconfont icon-xiangqing2 jessibuca-btn" ></i>-->
                    <i class="iconfont icon-camera1196054easyiconnet jessibuca-btn"
                        @click="jessibuca.screenshot('截图', 'png', 0.5)" />
                    <i class="iconfont icon-shuaxin11 jessibuca-btn" @click="playBtnClick" />
                    <i v-if="!fullscreen" class="iconfont icon-weibiaoti10 jessibuca-btn" @click="fullscreenSwich" />
                    <i v-if="fullscreen" class="iconfont icon-weibiaoti11 jessibuca-btn" @click="fullscreenSwich" />
                </div>
            </div>
        </div>
        <div v-if="!playing && !autoplay" class="btn-image" :style="'height:' + height">
            <div class="btn-image-center" @click="playBtnClick" :style="'width:' +
                btnimageW +
                ';height: ' +
                btnimageH +
                ';background:url(' +
                btnimage +
                ') no-repeat;background-size: 100% 100%;'
                "></div>
        </div>
    </div>
</template>
  
<script>
/* eslint-disable no-underscore-dangle */
export default {
    name: 'Jessibuca',
    props: {
        index: {
            //index
            type: Number,
            default: 0,
        },
        videoUrl: {
            //播放地址
            type: String,
            default: '',
        },
        error: {
            //报错信息
            type: Function,
            default: null,
        },
        hasAudio: {
            //静音
            type: Boolean,
            default: false,
        },
        height: {
            //播放器高度
            type: String,
            default: '500px',
        },
        isFullResize: {
            //播放面即是否填充满容器
            type: Boolean,
            default: true,
        },
        autoplay: {
            //是否自动播放
            type: Boolean,
            default: false,
        },
        background: {
            //封面图
            type: String,
            default: '',
        },
        btnimage: {
            //播放器按钮图片
            type: String,
            default: '',
        },
        btnimageH: {
            //播放器按钮图片高度
            type: String,
            default: '60px',
        },
        btnimageW: {
            //播放器按钮图片宽度
            type: String,
            default: '60px',
        },
    },
    data() {
        return {
            jessibuca: null,
            playing: false,
            isNotMute: false,
            quieting: false,
            fullscreen: false,
            loaded: false, // mute
            speed: 0,
            performance: '', // 工作情况
            kBps: 0,
            btnDom: null,
            videoInfo: null,
            volume: 1,
            rotate: 0,
            vod: true, // 点播
            forceNoOffscreen: false,
        }
    },
    watch: {
        videoUrl: {
            handler(newData, oldData) {
                if (!this.autoplay && !oldData) return
                this.play(newData)
            },
        },
    },
    mounted() {
        window.onerror = (msg) => {
            // console.error(msg)
        }
        const paramUrl = decodeURIComponent(this.$route.params.url)
        this.$nextTick(() => {
            if (typeof this.videoUrl === 'undefined') {
                this.videoUrl = paramUrl
            }
            this.btnDom = document.getElementById('buttonsBox' + this.index)
            console.log(`初始化时的地址为: ${this.videoUrl}`)
            this.autoplay ? this.play(this.videoUrl) : ''
        })
    },
    destroyed() {
        if (this.jessibuca) {
            this.jessibuca.destroy()
        }
        this.playing = false
        // this.loaded = false
        this.performance = ''
    },
    methods: {
        create() {
            const options = {}
            console.log(this.$refs.container)
            console.log(`hasAudio  ${this.hasAudio}`)

            this.jessibuca = new window.Jessibuca(
                Object.assign(
                    {
                        container: this.$refs.container,
                        videoBuffer: 0.5, // 最大缓冲时长,单位秒
                        isResize: true,
                        isFlv: true,
                        decoder: '/js/jessibuca/index.js',
                        // text: "WVP-PRO",
                        // background: "bg.jpg",
                        loadingText: '加载中',
                        hasAudio:
                            typeof this.hasAudio === 'undefined' ? true : this.hasAudio,
                        debug: false,
                        supportDblclickFullscreen: false, // 是否支持屏幕的双击事件,触发全屏,取消全屏事件。
                        operateBtns: {
                            fullscreen: false,
                            screenshot: false,
                            play: false,
                            audio: false,
                        },
                        record: 'record',
                        isFullResize: this.isFullResize || false,
                        vod: this.vod,
                        forceNoOffscreen: this.forceNoOffscreen,
                        isNotMute: this.isNotMute,
                    },
                    options
                )
            )

            // eslint-disable-next-line no-underscore-dangle
            const _this = this
            this.jessibuca.on('load', () => {
                console.log('on load init')
            })

            this.jessibuca.on('log', (msg) => {
                console.log('on log', msg)
            })
            this.jessibuca.on('record', (msg) => {
                console.log('on record:', msg)
            })
            this.jessibuca.on('pause', () => {
                _this.playing = false
            })
            this.jessibuca.on('play', () => {
                _this.playing = true
            })
            this.jessibuca.on('fullscreen', (msg) => {
                console.log('on fullscreen', msg)
                _this.fullscreen = msg
            })

            this.jessibuca.on('mute', (msg) => {
                console.log('on mute', msg)
                _this.isNotMute = !msg
            })
            this.jessibuca.on('audioInfo', (msg) => {
                // console.log("audioInfo", msg);
            })

            this.jessibuca.on('videoInfo', function (msg) {
                this.videoInfo = msg
                // console.log("videoInfo", msg);
            })

            this.jessibuca.on('bps', (bps) => {
                // console.log('bps', bps);
            })
            // eslint-disable-next-line no-unused-vars
            let _ts = 0
            this.jessibuca.on('timeUpdate', (ts) => {
                // console.log('timeUpdate,old,new,timestamp', _ts, ts, ts - _ts);
                _ts = ts
            })

            this.jessibuca.on('videoInfo', (info) => {
                console.log('videoInfo', info)
            })

            this.jessibuca.on('error', (error) => {
                console.log('error', error)
            })

            this.jessibuca.on('timeout', () => {
                console.log('timeout')
            })

            this.jessibuca.on('start', () => {
                console.log('start')
            })

            this.jessibuca.on('performance', (performance) => {
                let show = '卡顿'
                if (performance === 2) {
                    show = '非常流畅'
                } else if (performance === 1) {
                    show = '流畅'
                }
                _this.performance = show
            })
            this.jessibuca.on('buffer', (buffer) => {
                // console.log('buffer', buffer);
            })

            this.jessibuca.on('stats', (stats) => {
                // console.log('stats', stats);
            })

            this.jessibuca.on('kBps', (kBps) => {
                _this.kBps = Math.round(kBps)
            })

            // 显示时间戳 PTS
            this.jessibuca.on('videoFrame', () => { })

            //
            this.jessibuca.on('metadata', () => { })
        },
        playBtnClick(event) {
            this.play(this.videoUrl)
        },
        play(url) {
            if (!url || url.length == 0) {
                this.$message.warning('当前摄像头出错,请稍后重试')
                this.pause()
                return
            }
            if (this.jessibuca) {
                this.destroy()
            }
            this.create()
            this.jessibuca.on('play', () => {
                this.playing = true
                // this.loaded = true
                // this.quieting = this.jessibuca.quieting
            })
            if (this.jessibuca.hasLoaded()) {
                this.jessibuca.play(url)
            } else {
                this.jessibuca.on('load', () => {
                    console.log('load 播放')
                    this.jessibuca.play(url)
                })
            }
        },
        pause() {
            if (this.jessibuca) {
                this.jessibuca.pause()
            }
            this.playing = false
            this.err = ''
            this.performance = ''
        },
        destroy() {
            if (this.jessibuca) {
                this.jessibuca.destroy()
            }
            if (document.getElementById('buttonsBox' + this.index) == null) {
                document
                    .getElementById('container' + this.index)
                    .appendChild(this.btnDom)
            }
            this.jessibuca = null
            this.playing = false
            this.err = ''
            this.performance = ''
        },
        showbtn() {
            if (document.getElementById('buttonsBox' + this.index) == null) {
                document
                    .getElementById('container' + this.index)
                    .appendChild(this.btnDom)
            }
        },
        eventcallbacK(type, message) {
            // console.log("player 事件回调")
            // console.log(type)
            // console.log(message)
        },
        fullscreenSwich() {
            const isFull = this.isFullscreen()
            this.jessibuca.setFullscreen(!isFull)
            this.fullscreen = !isFull
        },
        isFullscreen() {
            return (
                document.fullscreenElement ||
                document.msFullscreenElement ||
                document.mozFullScreenElement ||
                document.webkitFullscreenElement ||
                false
            )
        },
    },
}
</script>
  
<style>
@font-face {
    font-family: 'iconfont';
    /* Project id 1291092 */
    src: url('iconfont.woff2') format('woff2');
}

.iconfont {
    font-family: 'iconfont' !important;
    font-size: 16px;
    font-style: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.icon-play:before {
    content: '\e603';
}

.icon-pause:before {
    content: '\e6c6';
}

.icon-stop:before {
    content: '\e6a8';
}

.icon-audio-high:before {
    content: '\e793';
}

.icon-audio-mute:before {
    content: '\e792';
}

.icon-shuaxin11:before {
    content: '\e720';
}

.icon-weibiaoti10:before {
    content: '\e78f';
}

.icon-weibiaoti11:before {
    content: '\e790';
}

.icon-camera1196054easyiconnet:before {
    content: '\e791';
}

.buttons-box {
    width: 100%;
    height: 0px;
    transition: 0.4s;
    background-color: rgba(43, 51, 63, 0.7);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    user-select: none;
    z-index: 100;
    display: flex;
    align-items: center;
    overflow: hidden;
}

#jessibuca:hover .buttons-box {
    height: 40px;
}

.buttons-box-left {
    display: flex;
    flex: 1;
    align-items: center;
}

.jessibuca-btn {
    color: rgb(255, 255, 255);
    line-height: 27px;
    margin: 0px 5px;
    padding: 0px 2px;
    cursor: pointer;
    text-align: center;
    font-size: 20px !important;
}

.buttons-box-right {
    height: 100%;
    position: absolute;
    right: 0;
    display: flex;
    flex: 1;
    align-items: center;
    font-size: 20px;
}

.btn-image {
    width: 100%;
    /* height: 100%; */
    position: absolute;
    left: 0;
    top: 0;
    z-index: 99 !important;
}

.btn-image-center {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
}
</style>
  
  
.jessibuca-btn 设置播放控件的间距
decoder: '/js/jessibuca/index.js',地址是服务静态文件的相对地址
 src: url('iconfont.woff2') format('woff2'); 相对地址 iconfont.woff2需要和组件放在同一目录下

2.父组件引用

<template>
  <div class="app-container">
    <player video-url="视频地址" :has-audio="false" height="200px" :isFullResize="false" :autoplay="true"
      :index="getIndex" />
  </div>
</template>
<script>
import player from '@/components/jessibuca/index.vue' // h265播放器

export default {
  name: 'video',
  components: {
    player,
  },
  data() {
    return {
    }
  },
  computed: {
    // 获取时间戳
    getIndex() {
      let time = new Date().getTime()
      return time
    },
  },
}
</script>


3.index.html 需要引入静态js文件

<script src="./public/js/jessibuca/index.js"></script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1472970.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Qt项目:网络1

文章目录 项目&#xff1a;网路项目1&#xff1a;主机信息查询1.1 QHostInfo类和QNetworkInterface类1.2 主机信息查询项目实现 项目2&#xff1a;基于HTTP的网络应用程序2.1 项目中用到的函数详解2.2 主要源码 项目&#xff1a;网路 项目1&#xff1a;主机信息查询 使用QHostI…

浅析ARMv8体系结构:原子操作

文章目录 概述LL/SC机制独占内存访问指令多字节独占内存访问指令 独占监视器经典自旋锁实现 LSE机制原子内存操作指令CAS指令交换指令 相关参考 概述 在编程中&#xff0c;当多个处理器或线程访问共享数据&#xff0c;并且至少有一个正在写入时&#xff0c;操作必须是原子的&a…

JAVA集合进阶(Set、Map集合)

一、Set系列集合 1.1 认识Set集合的特点 Set集合是属于Collection体系下的另一个分支&#xff0c;它的特点如下图所示 下面我们用代码简单演示一下&#xff0c;每一种Set集合的特点。 //Set<Integer> set new HashSet<>(); //无序、无索引、不重复 //Set<…

【kubernetes】关于k8s集群中kubectl的陈述式资源管理

目录 一、k8s集群资源管理方式分类&#xff1a; &#xff08;1&#xff09;陈述式资源管理方式&#xff1a;增删查比较方便&#xff0c;但是改非常不方便 &#xff08;2&#xff09;声明式资源管理方式&#xff1a;yaml文件管理 二、陈述式资源管理方法&#xff1a; 三、ku…

计算机设计大赛 深度学习大数据物流平台 python

文章目录 0 前言1 课题背景2 物流大数据平台的架构与设计3 智能车货匹配推荐算法的实现**1\. 问题陈述****2\. 算法模型**3\. 模型构建总览 **4 司机标签体系的搭建及算法****1\. 冷启动**2\. LSTM多标签模型算法 5 货运价格预测6 总结7 部分核心代码8 最后 0 前言 &#x1f5…

Nodejs 第四十二章(jwt)

什么是jwt? JWT&#xff08;JSON Web Token&#xff09;是一种开放的标准&#xff08;RFC 7519&#xff09;&#xff0c;用于在网络应用间传递信息的一种方式。它是一种基于JSON的安全令牌&#xff0c;用于在客户端和服务器之间传输信息。 https://jwt.io/ JWT由三部分组成&…

FL Studio All Plugins Edition2024中文完整版Win/Mac

FL Studio All Plugins Edition&#xff0c;常被誉为数字音频工作站&#xff08;DAW&#xff09;的佼佼者&#xff0c;是音乐制作人和声音工程师钟爱的工具。它集音频录制、编辑、混音以及MIDI制作为一体&#xff0c;为用户提供了从创作到最终作品输出的完整工作流程。这个版本…

下载huggingface数据集到本地并读取.arrow文件遇到的问题

文章目录 1. 524MB中文维基百科语料&#xff08;需要下载的数据集&#xff09;2. 下载 hugging face 网站上的数据集3. 读取 .arrow 文件报错代码4. 纠正后代码 1. 524MB中文维基百科语料&#xff08;需要下载的数据集&#xff09; 2. 下载 hugging face 网站上的数据集 要将H…

CrossOver24破解版下载安装与激活

在 Mac 上运行Windows 软件&#xff0c;CrossOver Mac 可以轻松地从 Dock 本地启动 Windows 应用程序&#xff0c;并将 Mac 操作系统功能&#xff08;如跨平台复制和粘贴以及共享文件系统&#xff09;集成到您的 Windows 程序中。 CrossOver 产品特性 无需重启 CrossOver 可以…

python Matplotlib Tkinter(pack)-->最大化去掉,仅剩关闭按钮

环境 python:python-3.12.0-amd64 包: matplotlib 3.8.2 pillow 10.1.0 import matplotlib.pyplot as plt from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg, NavigationToolbar2Tk import tkinter as tk import tkinter.messagebox as messagebox import …

C/C++基础语法

C/C基础语法 文章目录 C/C基础语法头文件经典问题秒数转换闰年斐波那契数列打印n阶菱形曼哈顿距离菱形图案的定义大数计算 输入输出格式化输入输出getline()函数解决cin只读入一个单词的问题 运算符赋值运算符 Switch循环处理未知数量输入的几种常见方法for-each 字符串String字…

Dell Vestro 7500 Realtek ALC236 耳机插入无效无声音 解决

查了很多&#xff0c;试了很多。 最终还下是重启设备来得最简单有效。 无效方式&#xff1a; 安装最新驱动&#xff1a;没有236这个芯片&#xff0c;找不到官方驱动使用旧驱动&#xff1a;问题依旧使用驱动程序中的禁用设备&#xff0c;启用后还是没有&#xff08;以前好像也…

Kubernetes部署及运用

Kubernetes 1. Kubernetes介绍 1.1 应用部署方式演变 在部署应用程序的方式上&#xff0c;主要经历了三个时代&#xff1a; 传统部署&#xff1a;互联网早期&#xff0c;会直接将应用程序部署在物理机上 优点&#xff1a;简单&#xff0c;不需要其它技术的参与 缺点&#xf…

2024程序员容器化上云之旅-第4集-Ubuntu-WSL2-Windows11版:夺取宝剑

故事梗概 Java程序员马意浓在互联网公司维护老旧电商后台系统。 渴望学习新技术的他在工作中无缘Docker和K8s。 他开始自学Vue3并使用SpringBoot3完成了一个前后端分离的Web应用系统&#xff0c;并打算将其用Docker容器化后用K8s上云。 6 夺取宝剑 &#x1f525;阅读Nigel…

【Vue3】学习watch监视:深入了解Vue3响应式系统的核心功能(下)

&#x1f497;&#x1f497;&#x1f497;欢迎来到我的博客&#xff0c;你将找到有关如何使用技术解决问题的文章&#xff0c;也会找到某个技术的学习路线。无论你是何种职业&#xff0c;我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章&#xff0c;也欢…

二叉树进阶oj练习

目录 1. 根据二叉树创建字符串 1&#xff09;思路 2&#xff09;代码实现 2. 二叉树前序非递归遍历实现 1&#xff09;思路&#xff1a; 2&#xff09;代码实现 3. 二叉树中序非递归遍历实现 1&#xff09;思路&#xff1a; 2&#xff09;代码实现&#xff1a; 4. 二…

Programming Abstractions in C阅读笔记:p303-p305

《Programming Abstractions in C》学习第74天&#xff0c;p303-p305总结&#xff0c;总计3页。 一、技术总结 1.时间复杂度分类(complexity classes) ClassNotationExampleconstantO(1)Returning the first element in an arraylogarithmicO(logN)Binary search in a sorte…

三菱plc控制双控电磁阀(从接线到程序)

目录 硬件设备 电磁阀的类型&#xff08;下图为例&#xff09; 三菱plc的类型&#xff08;西门子控正COOM接接正极&#xff0c;三菱控负COM接负极&#xff09; 气缸图 三菱plc与双控电磁阀接线 输出接线图&#xff08;COOM输出的公共端&#xff0c;三菱控负COM接负极&#x…

大学生课程|统计基础与python分析6|主流的评估方法:ROC曲线和KS曲线(免费下载所有课程材料)

目录 1 ROC曲线 2.查看混淆矩阵 3.实战评估股票客户流失预警模型 4.阈值的取值方法 5.KS曲线与KS值 6.获取KS值对应的阈值 7.获取KS值 对于二分类模型来说&#xff0c;主流的评估方法有ROC曲线和KS曲线两种方法 1 ROC曲线 之前已经获得了模型的准确度为79.77%&#xf…

【USENIX论文阅读】Day2

Birds of a Feather Flock Together: How Set Bias Helps to Deanonymize You via Revealed Intersection Sizes&#xff08;"物以类聚&#xff1a;集合偏差如何帮助去匿名化——通过揭示交集大小&#xff09; Xiaojie Guo, Ye Han, Zheli Liu, Ding Wang, Yan Jia, Jin L…