欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 养生 > 获取视频第一帧兼容ios

获取视频第一帧兼容ios

2025/7/8 18:40:39 来源:https://blog.csdn.net/m0_58361435/article/details/146064257  浏览:    关键词:获取视频第一帧兼容ios

js封装:

/*** 获取视频第一帧的方法,并将画面转换成 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; // 设置视频 URLvideo.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));});});
}

使用:

import { getVideoBase64 } from '@/utils/videoCover.js';const res = await getVideoBase64('视频地址')
console.log(res);

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com