获取视频第一帧,以及后续上传

javascript 复制代码
// 获取视频基本信息
const getVideoBasicInfo = (videoSrc) => {
    return new Promise((resolve, reject) => {
        const video = document.createElement("video");
        video.src = videoSrc;
        // 视频一定要添加预加载
        video.preload = "auto";
        // 视频一定要同源或者必须允许跨域
        video.crossOrigin = "Anonymous";
        // 监听:异常
        video.addEventListener("error", (error) => {
            reject(error);
        });
        // 监听:加载完成基本信息,设置要播放的时常
        video.addEventListener("loadedmetadata", () => {
            const videoInfo = {
                video,
                width: video.videoWidth,
                height: video.videoHeight,
                duration: video.duration,
            };
            resolve(videoInfo);
        });
    });
};
javascript 复制代码
// 将获取到的视频信息,转化为图片地址
const getVideoPosterInfo = (videoInfo) => {
    return new Promise((resolve) => {
        const { video, width, height } = videoInfo;
        video.addEventListener("canplay", () => {
            const canvas = document.createElement("canvas");
            canvas.width = width;
            canvas.height = height;
            const ctx = canvas.getContext("2d");
            ctx.drawImage(video, 0, 0, width, height);
            const posterUrl = canvas.toDataURL("image/jpg");
            resolve({ posterUrl });
        });
    });
};

此函数就是最终可以拿到图片地址的函数了。

javascript 复制代码
//获取处理后的图片地址
const getImgUrl = async (videoSrc) => {
    let videoInfo = await getVideoBasicInfo(videoSrc);
    let {posterUrl} = await getVideoPosterInfo(videoInfo);
    return posterUrl
};

拓展:

如果还需要将拿到的图片进行上传到远程服务器的处理 例如阿里云或者OSS服务器中则看下面代码继续处理

javascript 复制代码
//base64转file 文件
const base64ToFile = (data) => {
  // 将base64 的图片转换成file对象上传 atob将ascii码解析成binary数据
  let binary = atob(data.split(",")[1]);
  let mime = data.split(",")[0].match(/:(.*?);/)[1];
  let array = [];
  for (let i = 0; i < binary.length; i++) {
    array.push(binary.charCodeAt(i));
  }
  let fileData = new Blob([new Uint8Array(array)], {
    type: mime,
  });
  let file = new File([fileData], `${new Date().getTime()}.png`, {
    type: mime,
  });
  return file;
}

最终上传工具就写完了。 实际调用 只需要传递 视频地址即可。

javascript 复制代码
//获取OSS地址
const uploadImgUrl = async(videoSrc)=>{
  let imgUrl = await getImgUrl(videoSrc)
  let fileList= base64ToFile(imgUrl)
  var formData = new FormData()
  formData.set('filename', fileList)
  formData.set('merchantId', localStorage.getItem('MerchantId'))
  formData.set('Directory', 'Image')
  return new Promise((resolve, reject) => {
    axios.post(`${configs.host.test}/api/FileUpload/Upload`, formData)
      .then(res => {
        resolve(res.data);
      })
  });
}

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