This tool allows you to create and distribute easy to use video encoding presets for ffmpeg.
This tool will install the ffmpeg binary using ffbinaries
. You do not need to manually download/install ffmpeg.
npx ffpreset [options] <presetRef> <videoFile...>
options
-r, --respawn
: restart the ffmpeg process when it exits. If more than one file is specified then each will be processed before starting over from the first.
presetRef is a reference to a preset file. It can be in one of these forms:
- Shorthand form: a reference to a file in a git repo, it has three parts: username, repo, filename.
- Example:
joeflateau/ffpresets/my-preset.json
gets translated tohttps://raw.githubusercontent.com/joeflateau/ffpresets/master/my-preset.json
. - You can omit the repo name, in which case the default of
ffpresets
will be used. You can also omit the file extension in which case the default of.json
will be used. - Example:
joeflateau/ffpresets/simple-example.json
andjoeflateau/simple-example
are equivalent.
- Example:
- File reference form:
- Reference a file on your computer (relative to cwd).
- Example:
file:../ffpresets/simple-example.json
- Url reference form:
- Reference a file by a full url
- Example:
https://joeflateau.net/ffpresets/simple-example.json
{
"args": [
["-i", "$input"],
["-c:v", "libx264"],
["-c:a", "aac"],
["-profile:v", "main"],
["-b:v", "1200k"],
["-b:a", "64k"],
["-vf", "scale=1280:-1"],
["-f", "mp4", "$inputFilename-compressed.mp4"],
["-y"]
]
}
These args have replacements substituted and are passed to the ffmpeg binary. There are currently 3 replacements you can use in your preset: $input
, which is the fill path to the video file; $inputFilename
which is just the name of the video file without the directory or extension; and $inputBasename
which is the filename with the extension but without the directory.
npx ffpreset joeflateau/ffpresets/my-preset.json ~/Downloads/my-video-file.mp4