当前位置: 首页 > news >正文

vue videojs使用canvas截取视频画面

前言
刚开始做的时候太多坑,导致一直报错:
Uncaught (in promise) TypeError: Failed to execute ‘drawImage’ on ‘CanvasRenderingContext2D’: The provided value is not of type ‘(CSSImageValue or HTMLCanvasElement or HTMLImageElement or HTMLVideoElement or ImageBitmap or OffscreenCanvas or SVGImageElement or VideoFrame)’.

直接上代码!!!

1、html

<el-button class="capture-item" type="primary" @click="captureScreenshot">截图</el-button>

<video id="viewer" class="video-js vjs-default-skin" crossorigin="anonymous" controls>
      <source :src="playVideo.url" type='video/mp4'>
</video>

2、js

/** 初始化视频播放器 */
    const initViewer = async () => {
      await nextTick() // 等待 DOM 更新

      // 初始化 video.js
      player.value = videojs('viewer', {
        controls: true,
        autoplay: true,
        fluid: true,
      });
    }
    
// 截图功能
    const captureScreenshot = () => {
      if (!player.value) return;

      const videoElement = player.value.el().querySelector('video');
      if (!videoElement) return;

      // 创建 Canvas
      const canvas = document.createElement('canvas');
      const ctx = canvas.getContext('2d');
      if (!ctx) return;

      // 设置 Canvas 尺寸(可排除控制条)
      const controlHeight = 30; // 控制条高度
      canvas.width = videoElement.videoWidth;
      canvas.height = videoElement.videoHeight - controlHeight;

      // 绘制当前帧
      ctx.drawImage(
        videoElement,
        0, 0,
        videoElement.videoWidth, videoElement.videoHeight - controlHeight, // 源尺寸
        0, 0,
        canvas.width, canvas.height // 目标尺寸
      );

      // 转换为 DataURL
      const dataUrl = canvas.toDataURL('image/png');

      downloadImage(dataUrl);
    };

    // 下载图片
    const downloadImage = (dataUrl: string) => {
      const link = document.createElement('a');
      link.download = `视频截图_${new Date()}.png`;
      link.href = dataUrl;
      link.click();
    };

我这里是截取完画面下载到浏览器!

3、图例

点击《截图》,直接下载
在这里插入图片描述
截取的画面:
在这里插入图片描述

相关文章:

  • Linux命令常用的有哪些?
  • nlp第十节——LLM相关
  • 013-2 订单支付超时自动取消订单(rocketmq jpa)
  • 迷你世界脚本玩家接口:Player
  • 蓝桥杯2025模拟三(01字符串)
  • Python Tornado 框架面试题及参考答案
  • 【leetcode hot 100 76】最小覆盖子串
  • TypeScript系列01-类型系统全解析
  • 【中值滤波器(Median Filter)详解】
  • go routine 并发和同步
  • 虚拟机的IP配置
  • 网络安全月度报告
  • LLM 对话框组件 | 字节青训营前端开发项目
  • 计算机网络-实验四子网划分
  • 拒绝被假量薅羊毛,游戏渠道反作弊解决方案发布
  • go类型转换
  • Docker 模拟 kubernetes 的 pod
  • 【C++】:STL详解 —— priority_queue类
  • docker关闭mysql端口映射的使用
  • 计算机基础面试(数据结构)
  • 网站解析后怎么解决方法/app投放推广
  • c mvc网站开发实例/sem优化托管公司
  • 惠州网站建设如何/企业网站seo案例
  • 免费下载的网页模板/seo chinaz
  • 常见的手机网站/谷歌google官方下载
  • 南京软月网站建设公司/免费下载b站视频软件