前端vue+xgVIdeo集成rstp流播放

注意:rstp流需要对应的西瓜视频插件

项目:

petition-manager

代码概览:

1. video-player 子  组件

<template>
    <div id="video-player" class="video-player"></div>
</template>
<script>

import Player from 'xgplayer'
import FlvPlugin from 'xgplayer-flv'
import "xgplayer/dist/index.min.css"
export default {
    props: {
        url: {
            // 父组件传过来的视频链接
            type: String,
            default: '',
        },
    },
    data() {
        return {
            player: null, //实例
        };
    },
    mounted() {
        console.log('传过来的url:', this.url);
        // 初始化播放器
        this.initPlayer();
    },
    created() { },
    // 监听播放路径的变化
    watch: {
        url: {
            handler(newValue, oldValue) {
                if (!this.player) {
                    this.initPlayer();
                    return;
                }
                this.player.src = this.url;
            },
        },
    },
    methods: {
        // =========================1,设置播放器必要参数===================
        initPlayer() {
            if (!this.url) return console.warn('url is not esist');
            const config = {
                id: 'video-player',
                url: this.url,
                // fluid: true,
              isLive: true,
              plugins: [FlvPlugin],
                /**倍速播放 */
                // playbackRate: [0.5, 0.75, 1, 1.5, 2],
                // defaultPlaybackRate: 1,

                playsinline: this.isAppleDevice(), // IOS设备设置,防止被浏览器劫持
                'x5-video-player-type': 'h5', // 微信内置浏览器设置,防止被浏览器劫持
                'x5-video-orientation': 'portraint',
                /**画中画 */
                pip: true,
                pipConfig: {
                    bottom: 100,
                    right: 100,
                    width: 320,
                    height: 180,
                },
                // download: true,
                /**初始化首帧 */
                // videoInit: true,
                // autoplay: true,
            };
            //========================== 2,开始实例化======================
            const player = new Player(config);

            if (player) {
                this.player = player;
                /* 这里注册监听 */
                // 监听视频开始播放 播放传给父组件的是true
                this.player.on('play', () => {
                    this.$emit('triggerEvent', true);
                });
                // 监听视频已经暂停 暂停传给父组件的是true
                this.player.on('pause', () => {
                    this.$emit('triggerEvent', false);
                });
                // 监听 视频退出全屏
                // this.player.on('exitFullscreen', () => {
                //   window.scrollTo(0, 0);
                //   console.log('已经退出全屏了');
                // });
            }
        },
        // IOS设备设置,防止被浏览器劫持
        isAppleDevice() {
            const ua = navigator.userAgent.toLowerCase();
            return /iphone|ipad|phone|Mac/i.test(ua);
        },
    },
};
</script>

<style></style>

2.父组件中引用:

<el-dialog :title="title" :visible.sync="openLive" width="700px" height="500px">
      <video-player-vue :url="url" @triggerEvent="triggerEvent">
      </video-player-vue>
    </el-dialog>

data  中需要加入  url 属性

方法中需要加入:

 clickLive() {
      this.openLive = true
      this.url = 'xxxxxxx'
    },

    // 监听到子组件传过来的播放状态 true是播放 false是暂停
    triggerEvent(value) {
      console.log("是否播放:", value);
    },

父组件样式:

<style lang="scss" scoped>
.videoPlayer {
  height: 300px;
  width: 500px;
  margin: 0 auto;
}



</style>

相关推荐

  1. 前端vue+xgVIdeo集成rstp播放

    2024-04-25 09:44:02       30 阅读
  2. 原子Linux开发板拉rtsp播放

    2024-04-25 09:44:02       45 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-25 09:44:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-25 09:44:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-25 09:44:02       87 阅读
  4. Python语言-面向对象

    2024-04-25 09:44:02       96 阅读

热门阅读

  1. 【spring mvc】配置默认Servlet处理器

    2024-04-25 09:44:02       33 阅读
  2. 分析和比较深度学习框架 PyTorch 和 Tensorflow

    2024-04-25 09:44:02       37 阅读
  3. 【代码】jetson+OLED屏幕+显示mp4视频

    2024-04-25 09:44:02       36 阅读
  4. uniapp h5文件流下载pdf文件

    2024-04-25 09:44:02       35 阅读
  5. 正则表达式(Regular Expression)详解

    2024-04-25 09:44:02       33 阅读
  6. centos7.9下安装SVN服务

    2024-04-25 09:44:02       29 阅读
  7. Redis之缓存穿透、缓存击穿、缓存雪崩、无底洞

    2024-04-25 09:44:02       35 阅读
  8. 如何查看连接的Linux服务器是ubuntu还是centos

    2024-04-25 09:44:02       32 阅读
  9. uni-app条件编译

    2024-04-25 09:44:02       39 阅读
  10. 前端中的promise.all()的使用

    2024-04-25 09:44:02       34 阅读