ffmpeg-on-progress

1.0.0 • Public • Published

ffmpeg-on-progress

Utility for robustly reporting ffmpeg command progress with fluent-ffmpeg.

NPM Build Status JavaScript Style Guide

Some ffmpeg commands aren't capable fo producing progress events, such as when the input is a stream or when using multiple inputs. This simple utility allows you to accurately report progress in these cases by looking at the number of frames ffmpeg has processed with the caveat that you need to know the expected output's duration ahead of time.

In cases where fluent-ffmpeg produces a valid progress event, this module is a noop.

Install

npm install --save ffmpeg-on-progress
# or 
yarn add ffmpeg-on-progress

Usage

const ffmpeg = require('fluent-ffmpeg')
const ffmpegOnProgress = require('ffmpeg-on-progress')
 
const logProgress = (progress, event) => {
  // progress is a floating point number from 0 to 1
  console.log('progress', (progress * 100).toFixed())
}
 
// estimated duration of output in milliseconds
const durationEstimate = 4000
 
const cmd = ffmpeg('input.avi')
  .output('output.mp4')
  .on('progress', ffmpegOnProgress(logProgress, durationEstimate))
  .run()

Related

License

MIT © Travis Fischer

/ffmpeg-on-progress/

    Package Sidebar

    Install

    npm i ffmpeg-on-progress

    Weekly Downloads

    294

    Version

    1.0.0

    License

    MIT

    Unpacked Size

    4.53 kB

    Total Files

    7

    Last publish

    Collaborators

    • fisch0920