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

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

javascript 复制代码
/** 初始化视频播放器 */
    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、图例

点击《截图》,直接下载

截取的画面:

相关推荐
lichenyang453几秒前
打车票根卡片 UI 重构:从 Circle 挖洞到 clipShape PathShape,再到 100% 自适应
前端
luoyayun3612 分钟前
Qt + FFmpeg 实战:音频静音段检测
qt·ffmpeg·音视频·静音段检测
傅科摆 _ py4 分钟前
AI Ping 平台使用教程
java·前端·人工智能
Johnstons4 分钟前
网页加载到一半卡住?视频看到关键处花屏?可能是丢包在作祟
开发语言·php·音视频·弱网测试·网络损伤
lichenyang4538 分钟前
聊天历史从 Preferences 搬到关系型数据库(RDB):为什么换、怎么换、踩了什么坑
前端
七夜zippoe9 分钟前
OpenClaw 节点摄像头:远程拍照与视频录制实
音视频·视频录制·openclaw·节点摄像头·远程拍照
jinglong.zha9 分钟前
AI视频全流程实战:广告/动画/短剧都适用,解决角色一致性+后期合成难题
人工智能·ai·音视频·光照贴图·叙事照片
HjhIron14 分钟前
从栈到队列,再到链表:前端开发者必知的线性数据结构
前端·javascript
PedroQue9914 分钟前
uni-app路由管理神器:vue-router风格体验
前端·uni-app
用户17335980753715 分钟前
花两周用 Vue 3 做了个 PDF 工具站,我在生产环境踩了 8 个坑
前端·vue.js