Node.js下载视频第一帧并将其保存为图片

1、需求

        由于在微信浏览器里,h5页面的video组件无法自动渲染视频第一帧作为封面,所以想着把视频第一帧的图片下载下来放到cdn里作为封面。

2、准备工作
2.1、安装FFmpeg程序

        FFmpeg官网:FFmpeg

2.2、安装fluent-ffmpeg依赖
npm install fluent-ffmpeg

        fluent-ffmpeg:一个基于FFmpeg的流畅的音视频处理库,提供了一种简单而强大的方式来处理音频和视频文件

3、代码实现
// 功能:下载视频第一帧作为封面
const ffmpeg = require('fluent-ffmpeg');
const path = require('path');

// 设置ffmpeg程序路径
ffmpeg.setFfmpegPath("./ffmpeg/bin/ffmpeg.exe")

// 数据源
let dataList= [{
	"id": "1",
	"url": "https://xxxxx1.mp4"
}, {
	"id": "2",
	"url": "https://xxxxx2.mp4"
}]

dataList.forEach(item=>{
  const outputPath = `./img/${item.id}.png` // 图片输出路径
  ffmpeg(item.url)
  // .format('png') // 指定输入格式 
  .on('error', (err)=>{ console.log('An error occurred: ' + err.message) })
  .on('end', ()=>{ console.log('Processing finished !') })
  .screenshot({
    timemarks: ["00:00:01"], // 指定截取的时间点,单位为秒, 设置为1秒,因为精确到0秒可能会因为编解码延迟而错过第一帧
    filename: path.basename(outputPath), // 输出文件名
    folder: path.dirname(outputPath), // 输出文件夹
    size: '360x640' // 输出图片尺寸
  })
})

// 注意:如果视频非常短,可能需要调整timemarks的时间戳

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值