diff --git a/index.html b/index.html index 3648fa5..8f96cf1 100644 --- a/index.html +++ b/index.html @@ -20,26 +20,24 @@
FFmpeg is a powerful tool for manipulating audiovisual files. Unfortunately, it also has a steep learning curve, especially for users unfamiliar with a command line interface. This app helps users through the command generation process so that more people can reap the benefits of FFmpeg.
-Each button displays helpful information about how to perform a wide variety of tasks using FFmpeg. To use this site, click on the task you would like to perform. A new window will open up with a sample command and a description of how that command works. You can copy this command and understand how the command works with a breakdown of each of the flags.
-For FFmpeg basics, check out the program's official website.
-For Bash and command line basics, try the Command Line Crash Course
-FFmpeg is a powerful tool for manipulating audiovisual files. Unfortunately, it also has a steep learning curve, especially for users unfamiliar with a command line interface. This app helps users through the command generation process so that more people can reap the benefits of FFmpeg.
+Each button displays helpful information about how to perform a wide variety of tasks using FFmpeg. To use this site, click on the task you would like to perform. A new window will open up with a sample command and a description of how that command works. You can copy this command and understand how the command works with a breakdown of each of the flags.
+For FFmpeg basics, check out the program's official website.
+For Bash and command line basics, try the Command Line Crash Course.
+Part 1: Create 3 second clip from an existing source file (no audio necessary)
- -
- ffmpeg -ss HH:MM:SS -i input -c:v copy -c:a copy -t 3 output
-
ffmpeg -ss HH:MM:SS -i input -c:v copy -c:a copy -t 3 output
Part 2: Make the gif
- -
- ffmpeg -i input -vf scale=500:-1 -t 10 -r 30 output.gif
-
ffmpeg -i input -vf scale=500:-1 -t 10 -r 30 output.gif
- ffmpeg -i [inputfile.wav] -sample_fmt s16p -ar 44100 [outputfile.mp3]
-
ffmpeg -i [inputfile.wav] -sample_fmt s16p -ar 44100 [outputfile.mp3]
This will convert your wav files to mp3s.
- -ffmpeg -sample_fmts
)ffmpeg -sample_fmts
)
- for f in *.MXF; do ffmpeg -i "$f" -acodec copy -vcodec copy "${f%.MXF}.mov"; done
-
for f in *.MXF; do ffmpeg -i "$f" -c:a copy -c:v copy "${f%.MXF}.mov"; done
Re-wrap .MFX files in a specified directory to .mov files by using this code within a .sh file. The shell script (.sh file) and all MXF files must be contained in the same directory, and the script must be run from the directory itself (cd ~/Desktop/MXF_file_directory). Execute .sh file with the command sh Rewrap-MXF.sh
Modify the ffmpeg script as needed to perform different transcodes :)
- ffmpeg -i [inputfile.extension] -an -f framemd5 [outputfile.framemd5]
-
ffmpeg -i [inputfile.extension] -an -f framemd5 [outputfile.framemd5]
This will create an md5 checksum per frame
- -
- ffmpeg -i input.mov -c:v prores -profile:v 1 -c:a pcm_s16le -vf yadif output.mov
-
ffmpeg -i input.mov -c:v prores -profile:v 1 -c:a pcm_s16le -vf yadif output.mov
This command transcodes an input file (input.mov) into a deinterlaced Apple ProRes LT .mov file with 16-bit linear PCM encoded audio. The file is deinterlaced using the yadif (Yet Another De-Interlacing Filter) command.
- -
- ffmpeg -i [file path] -ss 00:00:20 -f image2 -vframes 1 thumb.png
-
ffmpeg -i [file path] -ss 00:00:20 -f image2 -vframes 1 thumb.png
This command will grab a thumbnail 20 seconds into the video.
-
- ffmpeg -i {path/inputfile.extension} -f image2 -vf fps=fps=1/60 out%d.png
-
-
ffmpeg -i {path/inputfile.extension} -f image2 -vf fps=fps=1/60 out%d.png
This will grab a thumbnail every minute and output sequential png files.
-ffmpeg -i [inputfile] -ss 00:12.235 -i "$f" -vframes 1 [outputfile]
Create one thumbnail in JPEG format from a video file at a specific time. In this example: 0hours:0minutes:12sec.235msec
-ffprobe -i filename.avi -show_format -show_streams -print_format xml
This command extracts technical metadata from a video file and displays it in xml.
ffmpeg documentation on ffprobe (full list of flags, commands, https://www.ffmpeg.org/ffprobe.html)
-ffmpeg -f concat -i mylist.txt -c copy [output]
This command takes two or more files of the same file type and joins them together to make a single file. All that the program needs is a text file with a list specifying the files that should be joined. However, it only works properly if the files to be combined have the exact same codec and technical specifications. Be careful, ffmpeg may appear to have successfully joined two video files with different codecs, but may only bring over the audio from the second file or have other weird behaviors. Don’t use this command for joining files with different codecs and technical specs and always preview your resulting video file! -
+This command takes two or more files of the same file type and joins them together to make a single file. All that the program needs is a text file with a list specifying the files that should be joined. However, it only works properly if the files to be combined have the exact same codec and technical specifications. Be careful, ffmpeg may appear to have successfully joined two video files with different codecs, but may only bring over the audio from the second file or have other weird behaviors. Don’t use this command for joining files with different codecs and technical specs and always preview your resulting video file!
ffmpeg documentation on concatenating files (full list of flags, commands, https://trac.ffmpeg.org/wiki/Concatenate)
-ffmpeg -i [input file] -t 5 -c copy [output]
This command captures a certain portion of a video file, starting from the beginning and continuing for the amount of time (in seconds) specified in the script. This can be used to create a preview file, or to remove unwanted content from the end of the file. To be more specific, use timecode, such as 00:00:05.
-ffmpeg -i [input file] -ss 5 -t 5 -c copy [output]
This command captures a certain portion of a video file, starting from a designated point in the file and taking an excerpt as long as the amount of time (in seconds) specified in the script. This can be used to create a preview or clip out a desired segment. To be more specific, use timecode, such as 00:00:05.
- +This command captures a certain portion of a video file, starting from a designated point in the file and taking an excerpt as long as the amount of time (in seconds) specified in the script. This can be used to create a preview or clip out a desired segment. To be more specific, use timecode, such as 00:00:05.
ffmpeg -i [input file] -ss 5 -c copy [output]
This command copies a video file starting from a specified time, removing the first few seconds from the output. This can be used to create an excerpt, or remove unwanted content from the beginning of a video file.
- -ffmpeg -i [input file] -map 0:0 [video output file] -map 0:1 [audio output file]
This command splits the original input file into a video and audio stream. The -map command identifies which streams are mapped to which file. To ensure that you’re mapping the right streams to the right file, run ffprobe before writing the script to identify which stream is 0:0, which is 0:1, etc.
- +This command splits the original input file into a video and audio stream. The -map command identifies which streams are mapped to which file. To ensure that you’re mapping the right streams to the right file, run ffprobe before writing the script to identify which stream is 0:0, which is 0:1, etc.
ffmpeg -i [input file] -c:v libx264 -c:a copy [output file.mp4]
This command takes an input file and transcodes it to h.264 with an .mp4 wrapper, keeping the audio the same codec as the original. The libx264 codec defaults to a “medium” preset for compression quality and a CRF of 23. CRF stands for constant rate factor and determines the quality and file size of the resulting h.264 video. A low CRF means high quality and large file size; a high CRF means the opposite.
- +This command takes an input file and transcodes it to h.264 with an .mp4 wrapper, keeping the audio the same codec as the original. The libx264 codec defaults to a “medium” preset for compression quality and a CRF of 23. CRF stands for constant rate factor and determines the quality and file size of the resulting h.264 video. A low CRF means high quality and large file size; a high CRF means the opposite.
In order to use the same basic command to make a higher quality file, you can add some of these presets:
ffmpeg -i [input file] -vcodec libx264 -acodec copy -preset veryslow -crf 18 [output file.mp4]
libx264 also defaults to 4:2:2 chroma subsampling. Some versions of Quicktime can't read x264 files in 4:2:2. In order to allow the video to play in all Quicktime players, you can specify 4:2:0 chroma subsampling instead:
ffmpeg -i [input file] -c:v libx264 -pix_fmt yuv420p -c:a copy -preset veryslow -crf 18 [output file.mp4]
ffmpeg -i video.mxf -i audio.mxf -c:v libx264 -pix_fmt yuv420p output.mp4
This will transcode mxf wrapped video and audio files to an h.264 encoded .mp4 file. Please note this only works for non-encrypted DCPs.
-Create an ISO file that can be used to burn a DVD. Please note, you will have to install dvdauthor. To install dvd author using Homebrew run: brew install dvdauthor
ffmpeg -i [inputfile.extension] -aspect 4:3 -target ntsc-dvd [outputfile.mpg]
This command will take any file and create an MPEG file that dvdauthor can use to create an ISO.
-ffmpeg -i [inputfile] -c:v libx264 -pix_fmt yuv420p -filter:v "scale=1440:1080, pad=1920:1080:240:0" -vf yadif [outputfile]
Pad without specifying pad width, just put the input video in the middle of the output: pad=1920:1080:(ow-iw)/2:(oh-ih)/2
-Made with ♥ at AMIA #AVhack15! Contribute to the project via our Github page!
+Made with ♥ at AMIA #AVhack15! Contribute to the project via our Github page!
-