获取视频第一帧兼容ios

js封装:

javascript 复制代码
/**
 * 获取视频第一帧的方法,并将画面转换成 base64 格式
 * @param {String} url 视频的 URL,可以是 base64 格式
 * @return {Promise} 一个 Promise 对象,返回值为视频第一帧的 base64 数据
 */
export function getVideoBase64(url) {
  return new Promise((resolve, reject) => {
    // 创建 video 元素
    const video = document.createElement('video');
    video.crossOrigin = 'anonymous'; // 设置跨域属性
    video.src = url; // 设置视频 URL
    video.preload = 'auto'; // 设置预加载方式为自动加载
    video.muted = true; // 静音,避免播放时发出声音
    video.autoplay = true; // 自动播放

    // 创建 canvas 元素
    const canvas = document.createElement('canvas');
    const ctx = canvas.getContext('2d');

    // 监听视频加载完成
    video.addEventListener('loadedmetadata', () => {
      // 获取视频的宽高
      const videoWidth = video.videoWidth;
      const videoHeight = video.videoHeight;

      // 设置 canvas 尺寸为视频的原始宽高
      canvas.width = videoWidth;
      canvas.height = videoHeight;

      // 确保视频的第一帧已经加载
      video.addEventListener('seeked', () => {
        // 将视频画面绘制到 canvas 中
        ctx.drawImage(video, 0, 0, canvas.width, canvas.height);

        // 将 canvas 转换成 base64 格式的图片数据
        const dataURL = canvas.toDataURL('image/jpeg');
        resolve(dataURL);
      });

      // 手动触发视频跳转到第一帧
      video.currentTime = 0;

      // 在 iOS 上手动触发播放,以避免自动播放被阻止
      if (/iPad|iPhone|iPod/.test(navigator.userAgent)) {
        // 可能需要手动触发播放来确保视频加载
        video.play().catch(err => {
          // 捕获播放失败的情况
          reject(new Error('视频播放失败:' + err.message));
        });
      }
    });

    // 监听错误事件
    video.addEventListener('error', (err) => {
      reject(new Error('视频加载失败:' + err.message));
    });
  });
}

使用:

javascript 复制代码
import { getVideoBase64 } from '@/utils/videoCover.js';

const res = await getVideoBase64('视频地址')
console.log(res);
相关推荐
挣扎与觉醒中的技术人28 分钟前
OpenCV视频解码全流程详解
人工智能·深度学习·opencv·计算机视觉·ffmpeg·音视频
EasyCVR5 小时前
EasyRTC嵌入式音视频通话SDK:基于ICE与STUN/TURN的实时音视频通信解决方案
人工智能·音视频·webrtc·实时音视频·h.265
九丶黎5 小时前
爬虫案例七Python协程爬取视频
爬虫·python·音视频
羑悻的小杀马特6 小时前
通义万相 2.1 + 蓝耘算力,AI 视频生成的梦幻组合
人工智能·音视频·ai大模型·蓝耘
悟纤19 小时前
Luno Api - AI音乐开发「人声伴奏分离 – 自定义音频」「Luno Api系列|AI音乐API」第7篇
人工智能·音视频·suno api·luno api·ai music·luno
水木姚姚20 小时前
图形界面控件编程(iOS)
人工智能·python·macos·ios·xcode
书弋江山1 天前
Flutter 调用原生IOS接口
flutter·ios·cocoa
DogDaoDao1 天前
探秘沃尔什-哈达玛变换(WHT)原理
图像处理·数学·音视频·hadamard·哈达玛变换·wht·视频编码器
挣扎与觉醒中的技术人1 天前
OpenCV视频解码性能优化十连击(实测帧率提升300%)
人工智能·opencv·ffmpeg·音视频·实时音视频·视频编解码·外包转型
声光界1 天前
引领变革!北京爱悦诗科技有限公司荣获“GAS消费电子科创奖-产品创新奖”!
科技·音视频·音频·声学·声学技术