使用西瓜视频官网来创造一个上一集,下一集的按钮,进行视频的切换操作

需求:

仿照西瓜视频写一个视频播放和上一集下一集的按钮功能

回答:

先访问官网:

西瓜播放器

这是西瓜视频的官网,

点击官网的示例按钮,可以看到相关的视频示例以及相关的代码,

我们复制下来代码,然后添加按钮和切换视频的方法,

完整代码:

javascript 复制代码
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <meta
      name="viewport"
      content="width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no,minimal-ui"
    />
    <meta name="referrer" content="no-referrer" />
    <title>播放器</title>
    <style type="text/css">
      html,
      body {
        width: 100%;
        height: 100%;
        margin: auto;
        overflow: hidden;
      }
      body {
        /* display: flex; */
      }
      #mse {
        flex: auto;
        width: 889px !important;
        height: 500px !important;
        margin-bottom: 20px !important;
      }
    </style>
    <script type="text/javascript">
      window.addEventListener("resize", function () {
        document.getElementById("mse").style.height = window.innerHeight + "px";
      });
    </script>
  </head>
  <body>
    <div id="mse"></div>
    <button onclick="playBack()">上一集</button>
    <button onclick="playNext()">下一集</button>
    <script
      src="https://unpkg.byted-static.com/xgplayer/2.31.2/browser/index.js"
      charset="utf-8"
    ></script>
    <script type="text/javascript">
      // 设置视频数组
      let videoArr = [
        "https://sf1-cdn-tos.huoshanstatic.com/obj/media-fe/xgplayer_doc_video/mp4/xgplayer-demo-360p.mp4",
        "https://player.caixin.com/video/2021/2/7/2021271612673141018_116_4222.mp4",
        "https://vd2.bdstatic.com/mda-pkveyt87ccdibcj6/sc/cae_h264/1701483084537162496/mda-pkveyt87ccdibcj6.mp4?v_from_s=hkapp-haokan-hbf&auth_key=1704261123-0-0-6e2f86b0c57691e183c7501e2cf89640&bcevod_channel=searchbox_feed&cr=2&cd=0&pd=1&pt=3&logid=3123035774&vid=10328216808716942050&klogid=3123035774&abtest=",
        "https://vd4.bdstatic.com/mda-qa1mniexb3f7r1dj/720p/h264/1704208673349687591/mda-qa1mniexb3f7r1dj.mp4?v_from_s=hkapp-haokan-hbf&auth_key=1704261202-0-0-1df311398200508f9b181ab9b343b5dd&bcevod_channel=searchbox_feed&pd=1&cr=2&cd=0&pt=3&logid=3202891224&vid=1343133119504452132&klogid=3202891224&abtest=",
      ];
      let player = new Player({
        id: "mse",
        autoplay: true,
        volume: 0.3,
        url: "https://sf1-cdn-tos.huoshanstatic.com/obj/media-fe/xgplayer_doc_video/mp4/xgplayer-demo-360p.mp4",
        poster:
          "https://lf9-cdn-tos.bytecdntp.com/cdn/expire-1-M/byted-player-videos/1.0.0/poster.jpg",
        playsinline: true,
        thumbnail: {
          pic_num: 44,
          width: 160,
          height: 90,
          col: 10,
          row: 10,
          urls: [
            "https://lf9-cdn-tos.bytecdntp.com/cdn/expire-1-M/byted-player-videos/1.0.0/xgplayer-demo-thumbnail.jpg",
          ],
        },
        danmu: {
          comments: [
            {
              duration: 15000,
              id: "1",
              start: 3000,
              txt: "长弹幕长弹幕长弹幕长弹幕长弹幕",
              style: {
                //弹幕自定义样式
                color: "#ff9500",
                fontSize: "20px",
                border: "solid 1px #ff9500",
                borderRadius: "50px",
                padding: "5px 11px",
                backgroundColor: "rgba(255, 255, 255, 0.1)",
              },
            },
          ],
          area: {
            start: 0,
            end: 1,
          },
        },
        height: window.innerHeight,
        width: window.innerWidth,
        whitelist: [""],
      });
      player.emit("resourceReady", [
        {
          name: "超清",
          url: "https://sf1-cdn-tos.huoshanstatic.com/obj/media-fe/xgplayer_doc_video/mp4/xgplayer-demo-720p.mp4",
        },
        {
          name: "高清",
          url: "https://sf1-cdn-tos.huoshanstatic.com/obj/media-fe/xgplayer_doc_video/mp4/xgplayer-demo-480p.mp4",
        },
        {
          name: "标清",
          url: "https://sf1-cdn-tos.huoshanstatic.com/obj/media-fe/xgplayer_doc_video/mp4/xgplayer-demo-360p.mp4",
        },
      ]);
      let currentIndex = 0;
      function playNext() {
        currentIndex++;
        if (currentIndex >= videoArr.length) {
          currentIndex = 0; // 如果已经是最后一个视频,则切换到第一个视频
        }
        let nextVideoUrl = videoArr[currentIndex];
        player.src = nextVideoUrl;
        // player.src = "https://player.caixin.com/video/2021/2/7/2021271612673141018_116_4222.mp4";
        player.play();
      }

      
      function playBack() {
        currentIndex--;
        if (currentIndex < 0) {
          currentIndex = videoArr.length - 1; // 如果已经是第一个视频,切换到最后一个视频
        }
        let backVideoUrl = videoArr[currentIndex];
        player.src = backVideoUrl;
        // player.src = "https://player.caixin.com/video/2021/2/7/2021271612673141018_116_4222.mp4";
        player.play();
      }
      player.on("ended", function () {
        playNext();
      });
    </script>
  </body>
</html>

这样就实现了一个简单的视频切换功能

相关推荐
REDcker12 天前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
gihigo199812 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
山河君12 天前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
音视频牛哥12 天前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器
qq_4162764212 天前
通用音频表征的对比学习
学习·音视频
美狐美颜sdk12 天前
Android全局美颜sdk实现方案详解
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
EasyDSS12 天前
私有化部署EasyDSS视频点播能力:全链路视频技术赋能,打造企业级视听新体验
音视频·hls·m3u8·点播技术·智能转码
qq_4162764212 天前
DeLoRes——一种通用的音频表征学习新方法(DeLoRes(基于 Barlow Twins 的冗余最小化方法)
学习·音视频
Q_45828386812 天前
从定位到视频:808 + 1078 在各行业的落地实践
音视频
山顶望月川12 天前
实测MiniMax-Hailuo-02:当“开工大吉“变成“无字天书“,国产AI视频模型的能与之不能
人工智能·音视频