mirror of
				https://github.com/amiaopensource/ffmprovisr.git
				synced 2025-10-24 22:50:51 +02:00 
			
		
		
		
	Compare commits
	
		
			33 Commits
		
	
	
		
			v2017-11-0
			...
			v2018-01-1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 32260c405f | ||
|  | d142564f36 | ||
|  | d41674a267 | ||
|  | 99450e61de | ||
|  | 1fec9b21c8 | ||
|  | 42189e5b94 | ||
|  | 929f92a52a | ||
|  | 02e2f11718 | ||
|  | 10636e24e2 | ||
|  | 61b890d31c | ||
|  | 85a79d2eb5 | ||
|  | b5ec56174a | ||
|  | f0e0cf8ed3 | ||
|  | 5c1c336d77 | ||
|  | d71793583e | ||
|  | 6705bdf41d | ||
|  | 25e779a59f | ||
|  | ba0852a957 | ||
|  | 88024c040f | ||
|  | 3d9b9edf1c | ||
|  | c0326ad7d9 | ||
|  | 0cb6827b39 | ||
|  | 0d68614c04 | ||
|  | 1e86b70ba4 | ||
|  | ced142a215 | ||
|  | bf301daa71 | ||
|  | 278ac2baae | ||
|  | 10b8e4c941 | ||
|  | 1d1b3e4eac | ||
|  | 5a3e437d76 | ||
|  | 75a7aa1299 | ||
|  | cf13529485 | ||
|  | 7c03ae2f80 | 
							
								
								
									
										12
									
								
								css/css.css
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								css/css.css
									
									
									
									
									
								
							| @@ -44,6 +44,9 @@ html, body { | |||||||
|     "content" |     "content" | ||||||
|     "footer"; |     "footer"; | ||||||
|   } |   } | ||||||
|  |   code { | ||||||
|  |     word-break: break-all; | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @media only screen and (min-width: 1000px) { | @media only screen and (min-width: 1000px) { | ||||||
| @@ -118,8 +121,8 @@ code { | |||||||
|   color: #c7254e; |   color: #c7254e; | ||||||
|   background-color: #f9f2f4; |   background-color: #f9f2f4; | ||||||
|   border-radius: 4px; |   border-radius: 4px; | ||||||
|   word-break: break-all; |  | ||||||
|   word-wrap: break-word; |   word-wrap: break-word; | ||||||
|  |   max-width: 800px; | ||||||
|   white-space: normal; |   white-space: normal; | ||||||
|   display: inline-block; |   display: inline-block; | ||||||
| } | } | ||||||
| @@ -150,6 +153,13 @@ img { | |||||||
|   text-align: center; |   text-align: center; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .sample-image-small { | ||||||
|  |   margin: 0 auto; | ||||||
|  |   margin-bottom: 18px; | ||||||
|  |   max-width: 250px; | ||||||
|  |   text-align: center; | ||||||
|  | } | ||||||
|  |  | ||||||
| div { | div { | ||||||
|   font-family: 'Merriweather', serif; |   font-family: 'Merriweather', serif; | ||||||
|   color: white; |   color: white; | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								img/crop_example_aftercrop1.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								img/crop_example_aftercrop1.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 245 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/crop_example_aftercrop2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								img/crop_example_aftercrop2.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 167 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/crop_example_aftercrop3.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								img/crop_example_aftercrop3.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 146 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/crop_example_orig.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								img/crop_example_orig.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 436 KiB | 
							
								
								
									
										
											BIN
										
									
								
								img/life.gif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								img/life.gif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 574 KiB | 
							
								
								
									
										322
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										322
									
								
								index.html
									
									
									
									
									
								
							| @@ -1,14 +1,14 @@ | |||||||
| <!DOCTYPE html> | <!DOCTYPE html> | ||||||
| <html lang="en"> | <html lang="en"> | ||||||
|   <head> | <head> | ||||||
|     <title>ffmprovisr</title> |   <title>ffmprovisr</title> | ||||||
|     <meta name="viewport" charset="utf-8" content="text/html, width=device-width, initial-scale=1"> |   <meta name="viewport" charset="utf-8" content="text/html, width=device-width, initial-scale=1"> | ||||||
|     <link href="https://fonts.googleapis.com/css?family=Montserrat%7CMerriweather" rel="stylesheet" type="text/css"> |   <link href="https://fonts.googleapis.com/css?family=Montserrat%7CMerriweather" rel="stylesheet" type="text/css"> | ||||||
|     <link rel="stylesheet" href="css/css.css"> |   <link rel="stylesheet" href="css/css.css"> | ||||||
|     <link rel="icon" href="img/vhs.ico"> |   <link rel="icon" href="img/vhs.ico"> | ||||||
|     <script src="js/jquery.min.js"></script> |   <script src="js/jquery.min.js"></script> | ||||||
|     <script src="js/js.js"></script> |   <script src="js/js.js"></script> | ||||||
|   </head> | </head> | ||||||
|  |  | ||||||
| <body> | <body> | ||||||
| <div class="grid"> | <div class="grid"> | ||||||
| @@ -46,16 +46,16 @@ | |||||||
|       <p>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.</p> |       <p>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.</p> | ||||||
|       <p>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.</p> |       <p>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.</p> | ||||||
|       <span class="intro-lead">Tutorials</span> |       <span class="intro-lead">Tutorials</span> | ||||||
|       <p>For FFmpeg basics, check out the program’s <a href="https://www.ffmpeg.org/" target="_blank">official website</a>.</p> |       <p>For FFmpeg basics, check out the program’s <a href="https://ffmpeg.org/" target="_blank">official website</a>.</p> | ||||||
|       <p>For instructions on how to install FFmpeg on Mac, Linux, and Windows, refer to Reto Kromer’s <a href="https://avpres.net/FFmpeg/#ch1" target="_blank">installation instructions</a>.</p> |       <p>For instructions on how to install FFmpeg on Mac, Linux, and Windows, refer to Reto Kromer’s <a href="https://avpres.net/FFmpeg/#ch1" target="_blank">installation instructions</a>.</p> | ||||||
|       <p>For Bash and command line basics, try the <a href="https://learnpythonthehardway.org/book/appendixa.html" target="_blank">Command Line Crash Course</a>. For a little more context presented in an ffmprovisr style, try <a href="http://explainshell.com/" target="_blank">explainshell.com</a>!</p> |       <p>For Bash and command line basics, try the <a href="https://learnpythonthehardway.org/book/appendixa.html" target="_blank">Command Line Crash Course</a>. For a little more context presented in an ffmprovisr style, try <a href="https://explainshell.com/" target="_blank">explainshell.com</a>!</p> | ||||||
|       <span class="intro-lead">License</span> |       <span class="intro-lead">License</span> | ||||||
|       <p class="license"> |       <p class="license"> | ||||||
|         <a href="https://creativecommons.org/licenses/by/4.0/" target="_blank"><img alt="Creative Commons License" src="img/cc.png"></a><br> |         <a href="https://creativecommons.org/licenses/by/4.0/" target="_blank"><img alt="Creative Commons License" src="img/cc.png"></a><br> | ||||||
|         This work is licensed under a <a href="https://creativecommons.org/licenses/by/4.0/" target="_blank">Creative Commons Attribution 4.0 International License</a>. |         This work is licensed under a <a href="https://creativecommons.org/licenses/by/4.0/" target="_blank">Creative Commons Attribution 4.0 International License</a>. | ||||||
|       </p> |       </p> | ||||||
|       <span class="intro-lead">Sister projects</span> |       <span class="intro-lead">Sister projects</span> | ||||||
|       <p><a href="http://dd388.github.io/crals/" target="_blank">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p> |       <p><a href="https://dd388.github.io/crals/" target="_blank">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p> | ||||||
|       <p><a href="https://datapraxis.github.io/sourcecaster/" target="_blank">The Sourcecaster</a>: an app that helps you use the command line to work through common challenges that come up when working with digital primary sources.</p> |       <p><a href="https://datapraxis.github.io/sourcecaster/" target="_blank">The Sourcecaster</a>: an app that helps you use the command line to work through common challenges that come up when working with digital primary sources.</p> | ||||||
|       <p><a href="https://amiaopensource.github.io/cable-bible/" target="_blank">Cable Bible</a>: A Guide to Cables and Connectors Used for Audiovisual Tech</p> |       <p><a href="https://amiaopensource.github.io/cable-bible/" target="_blank">Cable Bible</a>: A Guide to Cables and Connectors Used for Audiovisual Tech</p> | ||||||
|     </div> |     </div> | ||||||
| @@ -83,23 +83,37 @@ | |||||||
|       </div> |       </div> | ||||||
|       <!-- End Basic structure of an FFmpeg command --> |       <!-- End Basic structure of an FFmpeg command --> | ||||||
|  |  | ||||||
|  |       <!-- Streaming vs. Saving --> | ||||||
|  |       <label class="recipe" for="streaming-saving">Streaming vs. Saving</label> | ||||||
|  |       <input type="checkbox" id="streaming-saving"> | ||||||
|  |       <div class="hiding"> | ||||||
|  |         <h3>Streaming vs. Saving</h3> | ||||||
|  |         <p>FFplay allows you to stream created video and FFmpeg allows you to save video.</p> | ||||||
|  |         <p>The following command creates and saves a 10-second video of SMPTE bars:</p> | ||||||
|  |         <code>ffmpeg -f lavfi -i smptebars=size=640x480 -t 5 output_file</code> | ||||||
|  |         <p>This command plays and streams SMPTE bars but does not save them on the computer:</p> | ||||||
|  |         <code>ffplay -f lavfi smptebars=size=640x480</code> | ||||||
|  |         <p>The main difference is small but significant: the <code>-i</code> flag is required for FFmpeg but not required for FFplay. Additionally, the FFmpeg script needs to have <code>-t 5</code> and <code>output.mkv</code> added to specify the length of time to record and the place to save the video.</p> | ||||||
|  |         <p class="link"></p> | ||||||
|  |       </div> | ||||||
|  |       <!-- End Streaming vs. Saving --> | ||||||
|     </div> |     </div> | ||||||
|     <div class="well"> |     <div class="well"> | ||||||
|     <h2 id="concepts">Learn about more advanced FFmpeg concepts</h2> |  | ||||||
|  |  | ||||||
|  |     <h2 id="concepts">Learn about more advanced FFmpeg concepts</h2> | ||||||
|     <!-- Filtergraph explanation --> |     <!-- Filtergraph explanation --> | ||||||
|     <label class="recipe" for="filtergraphs">Filtergraphs</label> |     <label class="recipe" for="filtergraphs">Filtergraphs</label> | ||||||
|     <input type="checkbox" id="filtergraphs"> |     <input type="checkbox" id="filtergraphs"> | ||||||
|     <div class="hiding"> |     <div class="hiding"> | ||||||
|       <h3>Filtergraphs</h3> |       <h3>Filtergraphs</h3> | ||||||
|       <p>Many FFmpeg commands use filters that manipulate the video or audio stream in some way: for example, <a href="http://ffmpeg.org/ffmpeg-filters.html#hflip" target="_blank">hflip</a> to horizontally flip a video, or <a href="http://ffmpeg.org/ffmpeg-filters.html#amerge-1" target="_blank">amerge</a> to merge two or more audio tracks into a single stream.</p> |       <p>Many FFmpeg commands use filters that manipulate the video or audio stream in some way: for example, <a href="https://ffmpeg.org/ffmpeg-filters.html#hflip" target="_blank">hflip</a> to horizontally flip a video, or <a href="https://ffmpeg.org/ffmpeg-filters.html#amerge-1" target="_blank">amerge</a> to merge two or more audio tracks into a single stream.</p> | ||||||
|       <p>The use of a filter is signalled by the flag <code>-vf</code> (video filter) or <code>-af</code> (audio filter), followed by the name and options of the filter itself. For example, take the <a href="#convert-colourspace">convert colourspace</a> command:</p> |       <p>The use of a filter is signalled by the flag <code>-vf</code> (video filter) or <code>-af</code> (audio filter), followed by the name and options of the filter itself. For example, take the <a href="#convert-colourspace">convert colourspace</a> command:</p> | ||||||
|       <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf colormatrix=<i>src</i>:<i>dst</i> <i>output_file</i></code> |       <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf colormatrix=<i>src</i>:<i>dst</i> <i>output_file</i></code> | ||||||
|       <p>Here, <a href="http://ffmpeg.org/ffmpeg-filters.html#colormatrix" target="_blank">colormatrix</a> is the filter used, with <i>src</i> and <i>dst</i> representing the source and destination colourspaces. This part following the <code>-vf</code> is a <b>filtergraph</b>.</p> |       <p>Here, <a href="https://ffmpeg.org/ffmpeg-filters.html#colormatrix" target="_blank">colormatrix</a> is the filter used, with <i>src</i> and <i>dst</i> representing the source and destination colourspaces. This part following the <code>-vf</code> is a <b>filtergraph</b>.</p> | ||||||
|       <p>It is also possible to apply multiple filters to an input, which are sequenced together in the filtergraph. A chained set of filters is called a filter chain, and a filtergraph may include multiple filter chains. Filters in a filterchain are separated from each other by commas (<code>,</code>), and filterchains are separated from each other by semicolons (<code>;</code>). For example, take the <a href="#inverse-telecine">inverse telecine</a> command:</p> |       <p>It is also possible to apply multiple filters to an input, which are sequenced together in the filtergraph. A chained set of filters is called a filter chain, and a filtergraph may include multiple filter chains. Filters in a filterchain are separated from each other by commas (<code>,</code>), and filterchains are separated from each other by semicolons (<code>;</code>). For example, take the <a href="#inverse-telecine">inverse telecine</a> command:</p> | ||||||
|       <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf "fieldmatch,yadif,decimate" <i>output_file</i></code></p> |       <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf "fieldmatch,yadif,decimate" <i>output_file</i></code></p> | ||||||
|       <p>Here we have a filtergraph including one filter chain, which is made up of three video filters.</p> |       <p>Here we have a filtergraph including one filter chain, which is made up of three video filters.</p> | ||||||
|       <p>It is often prudent to enclose your filtergraph in quotation marks; this  means that you can use spaces within the filtergraph. Using the inverse telecine example again, the following filter commands are all valid and equivalent: |       <p>It is often prudent to enclose your filtergraph in quotation marks; this means that you can use spaces within the filtergraph. Using the inverse telecine example again, the following filter commands are all valid and equivalent: | ||||||
|         <ul> |         <ul> | ||||||
|           <li><code>-vf fieldmatch,yadif,decimate</code></li> |           <li><code>-vf fieldmatch,yadif,decimate</code></li> | ||||||
|           <li><code>-vf "fieldmatch,yadif,decimate"</code></li> |           <li><code>-vf "fieldmatch,yadif,decimate"</code></li> | ||||||
| @@ -140,7 +154,7 @@ | |||||||
|       </ul> |       </ul> | ||||||
|       <p>To map <i>all</i> streams in the input file to the output file, use <code>-map 0</code>. However, note that not all container formats can include all stream types: for example, .mp4 cannot contain timecode.</p> |       <p>To map <i>all</i> streams in the input file to the output file, use <code>-map 0</code>. However, note that not all container formats can include all stream types: for example, .mp4 cannot contain timecode.</p> | ||||||
|       <p>When no mapping is specified in an ffmpeg command, the default for video files is to take just one video and one audio stream for the output: other stream types, such as timecode or subtitles, will not be copied to the output file by default. If multiple video or audio streams are present, the best quality one is automatically selected by FFmpeg.</p> |       <p>When no mapping is specified in an ffmpeg command, the default for video files is to take just one video and one audio stream for the output: other stream types, such as timecode or subtitles, will not be copied to the output file by default. If multiple video or audio streams are present, the best quality one is automatically selected by FFmpeg.</p> | ||||||
|       <p>For more information, check out the FFmpeg wiki <a href="https://trac.ffmpeg.org/wiki/Map" target="_blank">Map</a> page, and the official FFmpeg <a href="http://ffmpeg.org/ffmpeg.html#Advanced-options" target="_blank">documentation on <code>-map</code></a>.</p> |       <p>For more information, check out the FFmpeg wiki <a href="https://trac.ffmpeg.org/wiki/Map" target="_blank">Map</a> page, and the official FFmpeg <a href="https://ffmpeg.org/ffmpeg.html#Advanced-options" target="_blank">documentation on <code>-map</code></a>.</p> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
|     <!-- End Stream Mapping explanation --> |     <!-- End Stream Mapping explanation --> | ||||||
| @@ -242,7 +256,7 @@ | |||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|         <dt>-c:v libx264</dt><dd>tells FFmpeg to encode the video stream as H.264</dd> |         <dt>-c:v libx264</dt><dd>tells FFmpeg to encode the video stream as H.264</dd> | ||||||
|         <dt>-pix_fmt yuv420p</dt><dd> libx264 will use a chroma subsampling scheme that is the closest match to that of the input. This can result in Y′C<sub>B</sub>C<sub>R</sub> 4:2:0, 4:2:2, or 4:4:4 chroma subsampling. QuickTime and most other non-FFmpeg based players can’t decode H.264 files that are not 4:2:0. In order to allow the video to play in all players, you can specify 4:2:0 chroma subsampling.</dd> |         <dt>-pix_fmt yuv420p</dt><dd>libx264 will use a chroma subsampling scheme that is the closest match to that of the input. This can result in Y′C<sub>B</sub>C<sub>R</sub> 4:2:0, 4:2:2, or 4:4:4 chroma subsampling. QuickTime and most other non-FFmpeg based players can’t decode H.264 files that are not 4:2:0. In order to allow the video to play in all players, you can specify 4:2:0 chroma subsampling.</dd> | ||||||
|         <dt>-c:a copy</dt><dd>tells FFmpeg to copy the audio stream without re-encoding it</dd> |         <dt>-c:a copy</dt><dd>tells FFmpeg to copy the audio stream without re-encoding it</dd> | ||||||
|         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|       </dl> |       </dl> | ||||||
| @@ -305,7 +319,7 @@ | |||||||
|         <dt>-slices 16</dt><dd>Each frame is split into 16 slices. 16 is a good trade-off between filesize and encoding time.</dd> |         <dt>-slices 16</dt><dd>Each frame is split into 16 slices. 16 is a good trade-off between filesize and encoding time.</dd> | ||||||
|         <dt>-c:a copy</dt><dd>copies all mapped audio streams.</dd> |         <dt>-c:a copy</dt><dd>copies all mapped audio streams.</dd> | ||||||
|         <dt><i>output_file</i>.mkv</dt><dd>path and name of the output file. Use the <code>.mkv</code> extension to save your file in a Matroska container. Optionally, choose a different extension if you want a different container, such as <code>.mov</code> or <code>.avi</code>.</dd> |         <dt><i>output_file</i>.mkv</dt><dd>path and name of the output file. Use the <code>.mkv</code> extension to save your file in a Matroska container. Optionally, choose a different extension if you want a different container, such as <code>.mov</code> or <code>.avi</code>.</dd> | ||||||
|         <dt>-f framemd5</dt><dd> Decodes video with the framemd5 muxer in order to generate MD5 checksums for every frame of your input file. This allows you to verify losslessness when compared against the framemd5s of the output file.</dd> |         <dt>-f framemd5</dt><dd>Decodes video with the framemd5 muxer in order to generate MD5 checksums for every frame of your input file. This allows you to verify losslessness when compared against the framemd5s of the output file.</dd> | ||||||
|         <dt>-an</dt><dd>ignores the audio stream when creating framemd5 (audio no)</dd> |         <dt>-an</dt><dd>ignores the audio stream when creating framemd5 (audio no)</dd> | ||||||
|         <dt><i>framemd5_output_file</i></dt><dd>path, name and extension of the framemd5 file.</dd> |         <dt><i>framemd5_output_file</i></dt><dd>path, name and extension of the framemd5 file.</dd> | ||||||
|       </dl> |       </dl> | ||||||
| @@ -568,7 +582,7 @@ | |||||||
|         For example, to convert from Rec.601 to Rec.709, you would use <code>-vf colormatrix=bt601:bt709</code>.</dd> |         For example, to convert from Rec.601 to Rec.709, you would use <code>-vf colormatrix=bt601:bt709</code>.</dd> | ||||||
|         <dt><i>output file</i></dt><dd>path, name and extension of the output file</dd> |         <dt><i>output file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p><b>Note:</b> Converting between colourspaces with FFmpeg can be done via either the <b>colormatrix</b> or <b>colorspace</b> filters, with colorspace allowing finer control (individual setting of colourspace, transfer characteristics, primaries, range, pixel format, etc). See <a href="https://trac.ffmpeg.org/wiki/colorspace" target="_blank">this</a> entry on the FFmpeg wiki, and the FFmpeg documentation for <a href="http://ffmpeg.org/ffmpeg-filters.html#colormatrix" target="_blank">colormatrix</a> and <a href="http://ffmpeg.org/ffmpeg-filters.html#colorspace" target="_blank">colorspace</a>.</p> |       <p><b>Note:</b> Converting between colourspaces with FFmpeg can be done via either the <b>colormatrix</b> or <b>colorspace</b> filters, with colorspace allowing finer control (individual setting of colourspace, transfer characteristics, primaries, range, pixel format, etc). See <a href="https://trac.ffmpeg.org/wiki/colorspace" target="_blank">this</a> entry on the FFmpeg wiki, and the FFmpeg documentation for <a href="https://ffmpeg.org/ffmpeg-filters.html#colormatrix" target="_blank">colormatrix</a> and <a href="https://ffmpeg.org/ffmpeg-filters.html#colorspace" target="_blank">colorspace</a>.</p> | ||||||
|       <hr> |       <hr> | ||||||
|       <h4>Convert colourspace and embed colourspace metadata</h4> |       <h4>Convert colourspace and embed colourspace metadata</h4> | ||||||
|       <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf colormatrix=src:dst -color_primaries <i>val</i> -color_trc <i>val</i> -colorspace <i>val</i> <i>output_file</i></code></p> |       <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf colormatrix=src:dst -color_primaries <i>val</i> -color_trc <i>val</i> -colorspace <i>val</i> <i>output_file</i></code></p> | ||||||
| @@ -597,7 +611,7 @@ | |||||||
|       <p><span class="beware">⚠</span> Using this command it is possible to add Rec.709 tags to a file that is actually Rec.601 (etc), so apply with caution!</p> |       <p><span class="beware">⚠</span> Using this command it is possible to add Rec.709 tags to a file that is actually Rec.601 (etc), so apply with caution!</p> | ||||||
|       <p>These commands are relevant for H.264 and H.265 videos, encoded with <code>libx264</code> and <code>libx265</code> respectively.</p> |       <p>These commands are relevant for H.264 and H.265 videos, encoded with <code>libx264</code> and <code>libx265</code> respectively.</p> | ||||||
|       <p><b>Note:</b> If you wish to embed colourspace metadata <i>without</i> changing to another colourspace, omit <code>-vf colormatrix=src:dst</code>. However, since it is <code>libx264</code>/<code>libx265</code> that writes the metadata, it’s not possible to add these tags without reencoding the video stream.</p> |       <p><b>Note:</b> If you wish to embed colourspace metadata <i>without</i> changing to another colourspace, omit <code>-vf colormatrix=src:dst</code>. However, since it is <code>libx264</code>/<code>libx265</code> that writes the metadata, it’s not possible to add these tags without reencoding the video stream.</p> | ||||||
|       <p>For all possible values for <code>-color_primaries</code>, <code>-color_trc</code>, and <code>-colorspace</code>, see the FFmpeg documentation on <a href="https://www.ffmpeg.org/ffmpeg-codecs.html#Codec-Options" target="_blank">codec options</a>.</p> |       <p>For all possible values for <code>-color_primaries</code>, <code>-color_trc</code>, and <code>-colorspace</code>, see the FFmpeg documentation on <a href="https://ffmpeg.org/ffmpeg-codecs.html#Codec-Options" target="_blank">codec options</a>.</p> | ||||||
|       <hr> |       <hr> | ||||||
|       <p id="fn1" class="footnote">1. Out of step with the regular pattern, <code>-color_trc</code> doesn’t accept <code>bt470bg</code>; it is instead here referred to directly as gamma.<br> |       <p id="fn1" class="footnote">1. Out of step with the regular pattern, <code>-color_trc</code> doesn’t accept <code>bt470bg</code>; it is instead here referred to directly as gamma.<br> | ||||||
|       In the Rec.601 standard, 525-line/NTSC and 625-line/PAL video have assumed gammas of 2.2 and 2.8 respectively. <a href="#ref1" title="Jump back.">↩</a></p> |       In the Rec.601 standard, 525-line/NTSC and 625-line/PAL video have assumed gammas of 2.2 and 2.8 respectively. <a href="#ref1" title="Jump back.">↩</a></p> | ||||||
| @@ -661,11 +675,41 @@ | |||||||
|         <dt>-color_trc <i>VALUE</i> -movflags write_colr</dt><dd>Set a new color_transfer value.</dd> |         <dt>-color_trc <i>VALUE</i> -movflags write_colr</dt><dd>Set a new color_transfer value.</dd> | ||||||
|         <dt>-field_order <i>VALUE</i></dt><dd>Set interlacement values.</dd> |         <dt>-field_order <i>VALUE</i></dt><dd>Set interlacement values.</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p>The possible values for <code>-color_primaries</code>, <code>-color_trc</code>, and <code>-field_order</code> are given in the <a href="http://ffmpeg.org/ffmpeg-all.html#toc-Codec-Options" target="_blank">Codec Options</a> section of the FFmpeg docs - scroll down to near the bottom of the section.</p> |       <p>The possible values for <code>-color_primaries</code>, <code>-color_trc</code>, and <code>-field_order</code> are given in the <a href="https://ffmpeg.org/ffmpeg-all.html#toc-Codec-Options" target="_blank">Codec Options</a> section of the FFmpeg docs - scroll down to near the bottom of the section.</p> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
|     <!-- ends Make stream properties explicate --> |     <!-- ends Make stream properties explicate --> | ||||||
|  |  | ||||||
|  |     <!-- Crop video --> | ||||||
|  |     <label class="recipe" for="crop_video">Crop video</label> | ||||||
|  |     <input type="checkbox" id="crop_video"> | ||||||
|  |     <div class="hiding"> | ||||||
|  |       <h3>Crop video</h3> | ||||||
|  |       <p><code>ffmpeg -i <i>input_file</i> -vf "crop=<i>width</i>:<i>height</i>" <i>output_file</i></code></p> | ||||||
|  |       <p>This command crops the input video to the dimensions defined</p> | ||||||
|  |       <dl> | ||||||
|  |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|  |         <dt>-vf "<i>width</i>:<i>height</i>"</dt><dd>Crops the video to the given width and height (in pixels).<br> | ||||||
|  |           By default, the crop area is centred: that is, the position of the top left of the cropped area is set to x = (<i>input_width</i> - <i>output_width</i>) / 2, y = <i>input_height</i> - <i>output_height</i>) / 2. | ||||||
|  |         </dd> | ||||||
|  |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|  |       </dl> | ||||||
|  |       <p>It's also possible to specify the crop position by adding the x and y coordinates representing the top left of your cropped area to your crop filter, as such:</p> | ||||||
|  |       <p><code>ffmpeg -i <i>input_file</i> -vf "crop=<i>width</i>:<i>height</i>[:<i>x_position</i>:<i>y_position</i>]" <i>output_file</i></code></p> | ||||||
|  |       <h3>Examples</h3> | ||||||
|  |       <p>The original frame, a screenshot of the SMPTE colourbars:</p> | ||||||
|  |       <img class="sample-image" src="img/crop_example_orig.png" alt="VLC screenshot of Maggie Cheung"> | ||||||
|  |       <p>Result of the command <code>ffmpeg -i <i>smpte_coloursbars.mov</i> -vf "crop=500:500" <i>output_file</i></code>:</p> | ||||||
|  |       <img class="sample-image-small" src="img/crop_example_aftercrop1.png" alt="VLC screenshot of Maggie Cheung, cropped from original"> | ||||||
|  |       <p>Result of the command <code>ffmpeg -i <i>smpte_coloursbars.mov</i> -vf "crop=500:500:0:0" <i>output_file</i></code>, appending <code>:0:0</code> to crop from the top left corner:</p> | ||||||
|  |       <img class="sample-image-small" src="img/crop_example_aftercrop2.png" alt="VLC screenshot of Maggie Cheung, cropped from original"> | ||||||
|  |       <p>Result of the command <code>ffmpeg -i <i>smpte_coloursbars.mov</i> -vf "crop=500:300:500:30" <i>output_file</i></code>:</p> | ||||||
|  |       <img class="sample-image-small" src="img/crop_example_aftercrop3.png" alt="VLC screenshot of Maggie Cheung, cropped from original"> | ||||||
|  |       <p class="link"></p> | ||||||
|  |     </div> | ||||||
|  |     <!-- ends Crop video --> | ||||||
|  |  | ||||||
|     </div> |     </div> | ||||||
|     <div class="well"> |     <div class="well"> | ||||||
|     <h2 id="audio-files">Change or view audio properties</h2> |     <h2 id="audio-files">Change or view audio properties</h2> | ||||||
| @@ -698,7 +742,7 @@ | |||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|         <dt>-filter_complex </dt><dd>tells fmpeg that we will be using a complex filter</dd> |         <dt>-filter_complex</dt><dd>tells ffmpeg that we will be using a complex filter</dd> | ||||||
|         <dt>"</dt><dd>quotation mark to start filtergraph</dd> |         <dt>"</dt><dd>quotation mark to start filtergraph</dd> | ||||||
|         <dt>[0:a:0][0:a:1]amerge[out]</dt><dd>combines the two audio tracks into one</dd> |         <dt>[0:a:0][0:a:1]amerge[out]</dt><dd>combines the two audio tracks into one</dd> | ||||||
|         <dt>"</dt><dd>quotation mark to end filtergraph</dd> |         <dt>"</dt><dd>quotation mark to end filtergraph</dd> | ||||||
| @@ -710,7 +754,7 @@ | |||||||
|       </dl> |       </dl> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
|     <!-- ends Combine audio tracks  --> |     <!-- ends Combine audio tracks --> | ||||||
|  |  | ||||||
|     <!-- phase shift --> |     <!-- phase shift --> | ||||||
|     <label class="recipe" for="phase_shift">Inverses the audio phase of the second channel</label> |     <label class="recipe" for="phase_shift">Inverses the audio phase of the second channel</label> | ||||||
| @@ -739,7 +783,7 @@ | |||||||
|       <p><code>ffmpeg -i <i>input_file</i> -af loudnorm=print_format=json -f null -</code></p> |       <p><code>ffmpeg -i <i>input_file</i> -af loudnorm=print_format=json -f null -</code></p> | ||||||
|       <p>This filter calculates and outputs loudness information in json about an input file (labeled input) as well as what the levels would be if loudnorm were applied in its one pass mode (labeled output). The values generated can be used as inputs for a 'second pass' of the loudnorm filter allowing more accurate loudness normalization than if it is used in a single pass.</p> |       <p>This filter calculates and outputs loudness information in json about an input file (labeled input) as well as what the levels would be if loudnorm were applied in its one pass mode (labeled output). The values generated can be used as inputs for a 'second pass' of the loudnorm filter allowing more accurate loudness normalization than if it is used in a single pass.</p> | ||||||
|       <p>These instructions use the loudnorm defaults, which align well with PBS recommendations for target loudness. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> |       <p>These instructions use the loudnorm defaults, which align well with PBS recommendations for target loudness. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> | ||||||
|       <p>Information about PBS loudness standards can be found in the <a href="http://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> |       <p>Information about PBS loudness standards can be found in the <a href="https://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
| @@ -775,7 +819,7 @@ | |||||||
|       <h3>One Pass Loudness Normalization</h3> |       <h3>One Pass Loudness Normalization</h3> | ||||||
|       <p><code>ffmpeg -i <i>input_file</i> -af loudnorm=dual_mono=true -ar 48k <i>output_file</i></code></p> |       <p><code>ffmpeg -i <i>input_file</i> -af loudnorm=dual_mono=true -ar 48k <i>output_file</i></code></p> | ||||||
|       <p>This will normalize the loudness of an input using one pass, which is quicker but less accurate than using two passes. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> |       <p>This will normalize the loudness of an input using one pass, which is quicker but less accurate than using two passes. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> | ||||||
|       <p>Information about PBS loudness standards can be found in the <a href="http://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> |       <p>Information about PBS loudness standards can be found in the <a href="https://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
| @@ -795,7 +839,7 @@ | |||||||
|       <h3>Two Pass Loudness Normalization</h3> |       <h3>Two Pass Loudness Normalization</h3> | ||||||
|       <p><code>ffmpeg -i <i>input_file</i> -af loudnorm=dual_mono=true:measured_I=<i>input_i</i>:measured_TP=<i>input_tp</i>:measured_LRA=<i>input_lra</i>:measured_thresh=<i>input_thresh</i>:offset=<i>target_offset</i>:linear=true -ar 48k <i>output_file</i></code></p> |       <p><code>ffmpeg -i <i>input_file</i> -af loudnorm=dual_mono=true:measured_I=<i>input_i</i>:measured_TP=<i>input_tp</i>:measured_LRA=<i>input_lra</i>:measured_thresh=<i>input_thresh</i>:offset=<i>target_offset</i>:linear=true -ar 48k <i>output_file</i></code></p> | ||||||
|       <p>This command allows using the levels calculated using a <a href="#loudnorm_metadata">first pass of the loudnorm filter</a> to more accurately normalize loudness. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> |       <p>This command allows using the levels calculated using a <a href="#loudnorm_metadata">first pass of the loudnorm filter</a> to more accurately normalize loudness. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> | ||||||
|       <p>Information about PBS loudness standards can be found in the <a href="http://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> |       <p>Information about PBS loudness standards can be found in the <a href="https://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
| @@ -846,7 +890,7 @@ | |||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-f concat</dt><dd>forces ffmpeg to concatenate the files and to keep the same file format</dd> |         <dt>-f concat</dt><dd>forces ffmpeg to concatenate the files and to keep the same file format</dd> | ||||||
|         <dt>-i <i>mylist.txt</i></dt><dd>path, name and extension of the input file. Per the <a href="https://www.ffmpeg.org/ffmpeg-formats.html#Options" target="_blank">FFmpeg documentation</a>, it is preferable to specify relative rather than absolute file paths, as allowing absolute file paths may pose a security risk.<br> |         <dt>-i <i>mylist.txt</i></dt><dd>path, name and extension of the input file. Per the <a href="https://ffmpeg.org/ffmpeg-formats.html#Options" target="_blank">FFmpeg documentation</a>, it is preferable to specify relative rather than absolute file paths, as allowing absolute file paths may pose a security risk.<br> | ||||||
|         This text file contains the list of files to be concatenated and should be formatted as follows: |         This text file contains the list of files to be concatenated and should be formatted as follows: | ||||||
|         <pre>file '<i>./first_file.ext</i>' |         <pre>file '<i>./first_file.ext</i>' | ||||||
|   file '<i>./second_file.ext</i>' |   file '<i>./second_file.ext</i>' | ||||||
| @@ -874,7 +918,7 @@ | |||||||
|         <dt>-i <i>input_file</i></dt><dd>Takes in a normal file.</dd> |         <dt>-i <i>input_file</i></dt><dd>Takes in a normal file.</dd> | ||||||
|         <dt>-c copy</dt><dd>Use stream copy mode to re-mux instead of re-encode.</dd> |         <dt>-c copy</dt><dd>Use stream copy mode to re-mux instead of re-encode.</dd> | ||||||
|         <dt>-map 0</dt><dd>tells FFmpeg to map all streams of the input to the output.</dd> |         <dt>-map 0</dt><dd>tells FFmpeg to map all streams of the input to the output.</dd> | ||||||
|         <dt>-f segment</dt><dd>Use <a href="http://www.ffmpeg.org/ffmpeg-formats.html#toc-segment_002c-stream_005fsegment_002c-ssegment" target="_blank">segment muxer</a> for generating the output.</dd> |         <dt>-f segment</dt><dd>Use <a href="https://ffmpeg.org/ffmpeg-formats.html#toc-segment_002c-stream_005fsegment_002c-ssegment" target="_blank">segment muxer</a> for generating the output.</dd> | ||||||
|         <dt>-segment_time 60</dt><dd>Set duration of each segment (in seconds). This example creates segments with max. duration of 60s each.</dd> |         <dt>-segment_time 60</dt><dd>Set duration of each segment (in seconds). This example creates segments with max. duration of 60s each.</dd> | ||||||
|         <dt>-reset_timestamps 1</dt><dd>Reset timestamps of each segment to 0. Meant to ease the playback of the generated segments.</dd> |         <dt>-reset_timestamps 1</dt><dd>Reset timestamps of each segment to 0. Meant to ease the playback of the generated segments.</dd> | ||||||
|         <dt><i>output_file-%03d.mkv</i></dt> |         <dt><i>output_file-%03d.mkv</i></dt> | ||||||
| @@ -1122,12 +1166,12 @@ | |||||||
|         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|         <dt>-vf drawtext=</dt><dd>This calls the drawtext filter with the following options: |         <dt>-vf drawtext=</dt><dd>This calls the drawtext filter with the following options: | ||||||
|         <dl> |         <dl> | ||||||
|           <dt>fontfile=<i>font_path</i></dt><dd> Set path to font. For example in macOS: <code>fontfile=/Library/Fonts/AppleGothic.ttf</code></dd> |           <dt>fontfile=<i>font_path</i></dt><dd>Set path to font. For example in macOS: <code>fontfile=/Library/Fonts/AppleGothic.ttf</code></dd> | ||||||
|           <dt>fontsize=<i>font_size</i></dt><dd> Set font size. <code>35</code> is a good starting point for SD. Ideally this value is proportional to video size, for example use ffprobe to acquire video height and divide by 14.</dd> |           <dt>fontsize=<i>font_size</i></dt><dd>Set font size. <code>35</code> is a good starting point for SD. Ideally this value is proportional to video size, for example use ffprobe to acquire video height and divide by 14.</dd> | ||||||
|           <dt>text=<i>watermark_text</i> </dt><dd> Set the content of your watermark text. For example: <code>text='FFMPROVISR EXAMPLE TEXT'</code></dd> |           <dt>text=<i>watermark_text</i></dt><dd>Set the content of your watermark text. For example: <code>text='FFMPROVISR EXAMPLE TEXT'</code></dd> | ||||||
|           <dt>fontcolor=<i>font_colour</i> </dt><dd> Set colour of font. Can be a text string such as <code>fontcolor=white</code> or a hexadecimal value such as <code>fontcolor=0xFFFFFF</code></dd> |           <dt>fontcolor=<i>font_colour</i></dt><dd>Set colour of font. Can be a text string such as <code>fontcolor=white</code> or a hexadecimal value such as <code>fontcolor=0xFFFFFF</code></dd> | ||||||
|           <dt>alpha=0.4</dt><dd> Set transparency value.</dd> |           <dt>alpha=0.4</dt><dd>Set transparency value.</dd> | ||||||
|           <dt>x=(w-text_w)/2:y=(h-text_h)/2</dt><dd> Sets <i>x</i> and <i>y</i> coordinates for the watermark. These relative values will centre your watermark regardless of video dimensions.</dd> |           <dt>x=(w-text_w)/2:y=(h-text_h)/2</dt><dd>Sets <i>x</i> and <i>y</i> coordinates for the watermark. These relative values will centre your watermark regardless of video dimensions.</dd> | ||||||
|         </dl> |         </dl> | ||||||
|         Note: <code>-vf</code> is a shortcut for <code>-filter:v</code>.</dd> |         Note: <code>-vf</code> is a shortcut for <code>-filter:v</code>.</dd> | ||||||
|         <dt><i>output_file</i></dt><dd>path, name and extension of the output file.</dd> |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file.</dd> | ||||||
| @@ -1146,7 +1190,7 @@ | |||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-i <i>input_video_file</i></dt><dd>path, name and extension of the input video file</dd> |         <dt>-i <i>input_video_file</i></dt><dd>path, name and extension of the input video file</dd> | ||||||
|         <dt>-i <i>input_image_file</i></dt><dd>path, name and extension of the image file</dd> |         <dt>-i <i>input_image_file</i></dt><dd>path, name and extension of the image file</dd> | ||||||
|         <dt>-filter_complex overlay=main_w-overlay_w-5:5</dt><dd>This calls the overlay filter and sets x and y coordinates for the position of the watermark on the video. Instead of hardcoding specific x and y coordinates, <code>main_w-overlay_w-5:5</code> uses relative coordinates to place the watermark in the upper right hand corner, based on the width of your input files. Please see the <a href="https://www.ffmpeg.org/ffmpeg-all.html#toc-Examples-102" target="_blank">FFmpeg documentation for more examples.</a></dd> |         <dt>-filter_complex overlay=main_w-overlay_w-5:5</dt><dd>This calls the overlay filter and sets x and y coordinates for the position of the watermark on the video. Instead of hardcoding specific x and y coordinates, <code>main_w-overlay_w-5:5</code> uses relative coordinates to place the watermark in the upper right hand corner, based on the width of your input files. Please see the <a href="https://ffmpeg.org/ffmpeg-all.html#toc-Examples-102" target="_blank">FFmpeg documentation for more examples.</a></dd> | ||||||
|         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
| @@ -1164,14 +1208,14 @@ | |||||||
|         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|         <dt>-vf drawtext=</dt><dd>This calls the drawtext filter with the following options: |         <dt>-vf drawtext=</dt><dd>This calls the drawtext filter with the following options: | ||||||
|         <dt>"</dt><dd>quotation mark to start drawtext filter command</dd> |         <dt>"</dt><dd>quotation mark to start drawtext filter command</dd> | ||||||
|         <dt>fontfile=<i>font_path</i></dt><dd> Set path to font. For example in macOS: <code>fontfile=/Library/Fonts/AppleGothic.ttf</code></dd> |         <dt>fontfile=<i>font_path</i></dt><dd>Set path to font. For example in macOS: <code>fontfile=/Library/Fonts/AppleGothic.ttf</code></dd> | ||||||
|         <dt>fontsize=<i>font_size</i></dt><dd> Set font size. <code>35</code> is a good starting point for SD. Ideally this value is proportional to video size, for example use ffprobe to acquire video height and divide by 14.</dd> |         <dt>fontsize=<i>font_size</i></dt><dd>Set font size. <code>35</code> is a good starting point for SD. Ideally this value is proportional to video size, for example use ffprobe to acquire video height and divide by 14.</dd> | ||||||
|         <dt>timecode=<i>starting_timecode</i> </dt><dd> Set the timecode to be displayed for the first frame. Timecode is to be represented as <code>hh:mm:ss[:;.]ff</code>. Colon escaping is determined by O.S, for example in Ubuntu <code>timecode='09\\:50\\:01\\:23'</code>. Ideally, this value would be generated from the file itself using ffprobe.</dd> |         <dt>timecode=<i>starting_timecode</i></dt><dd>Set the timecode to be displayed for the first frame. Timecode is to be represented as <code>hh:mm:ss[:;.]ff</code>. Colon escaping is determined by O.S, for example in Ubuntu <code>timecode='09\\:50\\:01\\:23'</code>. Ideally, this value would be generated from the file itself using ffprobe.</dd> | ||||||
|         <dt>fontcolor=<i>font_colour</i> </dt><dd> Set colour of font. Can be a text string such as <code>fontcolor=white</code> or a hexadecimal value such as <code>fontcolor=0xFFFFFF</code></dd> |         <dt>fontcolor=<i>font_colour</i></dt><dd>Set colour of font. Can be a text string such as <code>fontcolor=white</code> or a hexadecimal value such as <code>fontcolor=0xFFFFFF</code></dd> | ||||||
|         <dt>box=1</dt><dd> Enable box around timecode</dd> |         <dt>box=1</dt><dd>Enable box around timecode</dd> | ||||||
|         <dt>boxcolor=<i>box_colour</i></dt><dd> Set colour of box. Can be a text string such as <code>fontcolor=black</code> or a hexadecimal value such as <code>fontcolor=0x000000</code></dd> |         <dt>boxcolor=<i>box_colour</i></dt><dd>Set colour of box. Can be a text string such as <code>fontcolor=black</code> or a hexadecimal value such as <code>fontcolor=0x000000</code></dd> | ||||||
|         <dt>rate=<i>timecode_rate</i></dt><dd> Framerate of video. For example <code>25/1</code></dd> |         <dt>rate=<i>timecode_rate</i></dt><dd>Framerate of video. For example <code>25/1</code></dd> | ||||||
|         <dt>x=(w-text_w)/2:y=h/1.2</dt><dd> Sets <i>x</i> and <i>y</i> coordinates for the timecode. These relative values will horizontally centre your timecode in the bottom third regardless of video dimensions.</dd> |         <dt>x=(w-text_w)/2:y=h/1.2</dt><dd>Sets <i>x</i> and <i>y</i> coordinates for the timecode. These relative values will horizontally centre your timecode in the bottom third regardless of video dimensions.</dd> | ||||||
|         <dt>"</dt><dd>quotation mark to end drawtext filter command</dd> |         <dt>"</dt><dd>quotation mark to end drawtext filter command</dd> | ||||||
|         <dt><i>output_file</i></dt><dd>path, name and extension of the output file.</dd> |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file.</dd> | ||||||
|       </dl> |       </dl> | ||||||
| @@ -1180,6 +1224,25 @@ | |||||||
|     </div> |     </div> | ||||||
|     <!-- ends Burn in timecode --> |     <!-- ends Burn in timecode --> | ||||||
|  |  | ||||||
|  |     <!-- Embed subtitles--> | ||||||
|  |     <label class="recipe" for="embed_subtitles">Embed subtitles</label> | ||||||
|  |     <input type="checkbox" id="embed_subtitles"> | ||||||
|  |     <div class="hiding"> | ||||||
|  |       <h3>Embed a subtitle file into a movie file </h3> | ||||||
|  |       <p><code>ffmpeg -i <i>input_file</i> -i <i>subtitles_file</i> -c copy -c:s mov_text <i>output_file</i></code></p> | ||||||
|  |       <dl> | ||||||
|  |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|  |         <dt>-i <i>subtitles_file</i></dt><dd>path to subtitles file, e.g. <code>subtitles.srt</code></dd> | ||||||
|  |         <dt>-c copy</dt><dd>enable stream copy (no re-encode)</dd> | ||||||
|  |         <dt>-c:s mov_text</dt><dd>Encode subtitles using the <code>mov_text</code> codec. Note: The <code>mov_text</code> codec works for MP4 and MOV containers. For the MKV container, acceptable formats are <code>ASS</code>, <code>SRT</code>, and <code>SSA</code>.</dd> | ||||||
|  |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|  |       </dl> | ||||||
|  |       <p>Note: <code>-c:s</code> is a shortcut for <code>-scodec</code></p> | ||||||
|  |       <p class="link"></p> | ||||||
|  |     </div> | ||||||
|  |     <!-- ends Embed subtitles --> | ||||||
|  |  | ||||||
|     </div> |     </div> | ||||||
|     <div class="well"> |     <div class="well"> | ||||||
|     <h2 id="create-images">Create thumbnails or GIFs</h2> |     <h2 id="create-images">Create thumbnails or GIFs</h2> | ||||||
| @@ -1354,7 +1417,7 @@ | |||||||
|       <p><code>ffplay -f lavfi "amovie='input.mp3', astats=metadata=1:reset=1, adrawgraph=lavfi.astats.Overall.Peak_level:max=0:min=-30.0:size=700x256:bg=Black[out]"</code></p> |       <p><code>ffplay -f lavfi "amovie='input.mp3', astats=metadata=1:reset=1, adrawgraph=lavfi.astats.Overall.Peak_level:max=0:min=-30.0:size=700x256:bg=Black[out]"</code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffplay</dt><dd>starts the command</dd> |         <dt>ffplay</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a></dd> |         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a></dd> | ||||||
|         <dt>"</dt><dd>quotation mark to start the lavfi filtergraph</dd> |         <dt>"</dt><dd>quotation mark to start the lavfi filtergraph</dd> | ||||||
|         <dt>movie='<i>input.mp3</i>'</dt><dd>declares audio source file on which to apply filter</dd> |         <dt>movie='<i>input.mp3</i>'</dt><dd>declares audio source file on which to apply filter</dd> | ||||||
|         <dt>,</dt><dd>comma signifies the end of audio source section and the beginning of the filter section</dd> |         <dt>,</dt><dd>comma signifies the end of audio source section and the beginning of the filter section</dd> | ||||||
| @@ -1383,11 +1446,11 @@ | |||||||
|       <p><code>ffplay -f lavfi "movie='<i>input.mp4</i>', signalstats=out=brng:color=cyan[out]"</code></p> |       <p><code>ffplay -f lavfi "movie='<i>input.mp4</i>', signalstats=out=brng:color=cyan[out]"</code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffplay</dt><dd>starts the command</dd> |         <dt>ffplay</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a></dd> |         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a></dd> | ||||||
|         <dt>"</dt><dd>quotation mark to start the lavfi filtergraph</dd> |         <dt>"</dt><dd>quotation mark to start the lavfi filtergraph</dd> | ||||||
|         <dt>movie='<i>input.mp4</i>'</dt><dd>declares video file source to apply filter</dd> |         <dt>movie='<i>input.mp4</i>'</dt><dd>declares video file source to apply filter</dd> | ||||||
|         <dt>,</dt><dd>comma signifies closing of video source assertion and ready for filter assertion</dd> |         <dt>,</dt><dd>comma signifies closing of video source assertion and ready for filter assertion</dd> | ||||||
|         <dt>signalstats=out=brng:</dt><dd>tells ffplay to use the signalstats command, output the data, use the brng filter</dd> |         <dt>signalstats=out=brng</dt><dd>tells ffplay to use the signalstats command, output the data, use the brng filter</dd> | ||||||
|         <dt>:</dt><dd>indicates there’s another parameter coming</dd> |         <dt>:</dt><dd>indicates there’s another parameter coming</dd> | ||||||
|         <dt>color=cyan[out]</dt><dd>sets the color of out-of-range pixels to cyan</dd> |         <dt>color=cyan[out]</dt><dd>sets the color of out-of-range pixels to cyan</dd> | ||||||
|         <dt>"</dt><dd>quotation mark to end the lavfi filtergraph</dd> |         <dt>"</dt><dd>quotation mark to end the lavfi filtergraph</dd> | ||||||
| @@ -1438,7 +1501,7 @@ | |||||||
|         <dt>[a][b]hstack[out]</dt><dd>Takes the outputs from the previous steps ([a] and [b] and uses the hstack (horizontal stack) filter on them to create the side by side output. This output is then named [out])</dd> |         <dt>[a][b]hstack[out]</dt><dd>Takes the outputs from the previous steps ([a] and [b] and uses the hstack (horizontal stack) filter on them to create the side by side output. This output is then named [out])</dd> | ||||||
|         <dt>"</dt><dd>quotation mark to end filtergraph</dd> |         <dt>"</dt><dd>quotation mark to end filtergraph</dd> | ||||||
|         <dt>-map [out]</dt><dd>Maps the output of the filter chain</dd> |         <dt>-map [out]</dt><dd>Maps the output of the filter chain</dd> | ||||||
|         <dt>-f nut</dt><dd>Sets the format for the output video stream to <a href="https://www.ffmpeg.org/ffmpeg-formats.html#nut" target="_blank">Nut</a></dd> |         <dt>-f nut</dt><dd>Sets the format for the output video stream to <a href="https://ffmpeg.org/ffmpeg-formats.html#nut" target="_blank">Nut</a></dd> | ||||||
|         <dt>-c:v rawvideo</dt><dd>Sets the video codec of the output video stream to raw video</dd> |         <dt>-c:v rawvideo</dt><dd>Sets the video codec of the output video stream to raw video</dd> | ||||||
|         <dt>-</dt><dd>tells FFmpeg that the output will be piped to a new command (as opposed to a file)</dd> |         <dt>-</dt><dd>tells FFmpeg that the output will be piped to a new command (as opposed to a file)</dd> | ||||||
|         <dt>|</dt><dd>Tells the system you will be piping the output of the previous command into a new command</dd> |         <dt>|</dt><dd>Tells the system you will be piping the output of the previous command into a new command</dd> | ||||||
| @@ -1471,7 +1534,7 @@ | |||||||
|         <dt>-show_data</dt><dd>adds a short “hexdump” to show_streams command output</dd> |         <dt>-show_data</dt><dd>adds a short “hexdump” to show_streams command output</dd> | ||||||
|         <dt>-print_format</dt><dd>Set the output printing format (in this example “xml”; other formats include “json” and “flat”)</dd> |         <dt>-print_format</dt><dd>Set the output printing format (in this example “xml”; other formats include “json” and “flat”)</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p>See also the <a href="www.ffmpeg.org/ffprobe.html" target="_blank"> FFmpeg documentation on ffprobe</a> for a full list of flags, commands, and options.</p> |       <p>See also the <a href="https://ffmpeg.org/ffprobe.html" target="_blank"> FFmpeg documentation on ffprobe</a> for a full list of flags, commands, and options.</p> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
|     <!-- ends Pull specs --> |     <!-- ends Pull specs --> | ||||||
| @@ -1486,10 +1549,11 @@ | |||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|         <dt>-map_metadata -1</dt><dd>sets metadata copying to -1, which copies nothing</dd> |         <dt>-map_metadata -1</dt><dd>sets metadata copying to -1, which copies nothing</dd> | ||||||
|         <dt>-vcodec copy</dt><dd>copies video track</dd> |         <dt>-c:v copy</dt><dd>copies video track</dd> | ||||||
|         <dt>-acodec copy</dt><dd>copies audio track</dd> |         <dt>-c:a copy</dt><dd>copies audio track</dd> | ||||||
|         <dt><i>output_file</i></dt><dd>Makes copy of original file and names output file</dd> |         <dt><i>output_file</i></dt><dd>Makes copy of original file and names output file</dd> | ||||||
|       </dl> |       </dl> | ||||||
|  |       <p>Note: <code>-c:v</code> and <code>-c:a</code> are shortcuts for <code>-vcodec</code> and <code>-acodec</code>.</p> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
|     <!-- ends Strip metadata --> |     <!-- ends Strip metadata --> | ||||||
| @@ -1594,10 +1658,11 @@ | |||||||
|         <li>44.1 kHz: "asetnsamples=n=44100"</li> |         <li>44.1 kHz: "asetnsamples=n=44100"</li> | ||||||
|         <li>96 kHz: "asetnsamples=n=96000"</li> |         <li>96 kHz: "asetnsamples=n=96000"</li> | ||||||
|       </ul> |       </ul> | ||||||
|       <p>Note: This filter trandscodes audio to 16 bit PCM by default. The generated framemd5s will represent this value. Validating these framemd5s will require using the same default settings.</p> |       <p><b>Note:</b> This filter trandscodes audio to 16 bit PCM by default. The generated framemd5s will represent this value. Validating these framemd5s will require using the same default settings. Alternatively, when your file has another quantisation rates (e.g. 24 bit), then you might add the audio codec <code>-c:a pcm_s24le</code> to the command, for compatibility reasons with other tools, like <a href="https://mediaarea.net/BWFMetaEdit" target="_blank">BWF MetaEdit</a>.</p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|  |         <dt>-af "asetnsamples=n=<i>48000</i>"</dt><dd>the audio filter sets the sampling rate</dd> | ||||||
|         <dt>-f framemd5</dt><dd>library used to calculate the MD5 checksums</dd> |         <dt>-f framemd5</dt><dd>library used to calculate the MD5 checksums</dd> | ||||||
|         <dt>-vn</dt><dd>ignores the video stream (video no)</dd> |         <dt>-vn</dt><dd>ignores the video stream (video no)</dd> | ||||||
|         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
| @@ -1607,6 +1672,28 @@ | |||||||
|     </div> |     </div> | ||||||
|     <!-- ends Create frame md5s (audio) --> |     <!-- ends Create frame md5s (audio) --> | ||||||
|  |  | ||||||
|  |     <!-- Create stream md5s --> | ||||||
|  |     <label class="recipe" for="create_stream_md5s">Create MD5 checksum(s) for A/V stream data only</label> | ||||||
|  |     <input type="checkbox" id="create_stream_md5s"> | ||||||
|  |     <div class="hiding"> | ||||||
|  |       <h3>Create stream MD5s</h3> | ||||||
|  |       <p><code>ffmpeg -i <i>input_file</i> -map 0:v:0 -c:v copy -f md5 <i>output_file_1</i> -map 0:a:0 -c:a copy -f md5 <i>output_file_2</i></code></p> | ||||||
|  |       <p>This will create MD5 checksums for the first video and the first audio stream in a file. If only one of these is necessary (for example if used on a WAV file) either part of the command can be excluded to create the desired MD5 only. Use of this kind of checksum enables integrity of the A/V information to be verified independently of any changes to surrounding metadata.</p> | ||||||
|  |       <dl> | ||||||
|  |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|  |         <dt>-map 0:v:0</dt><dd>selects the first video stream from the input</dd> | ||||||
|  |         <dt>-c:v copy</dt><dd>ensures that FFmpeg will not transcode the video to a different codec before generating the MD5</dd> | ||||||
|  |         <dt><i>output_file_1</i></dt><dd>is the output file for the video stream MD5. Example file extensions are <code>.md5</code> and <code>.txt</code></dd> | ||||||
|  |         <dt>-map 0:a:0</dt><dd>selects the first audio stream from the input</dd> | ||||||
|  |         <dt>-c:a copy</dt><dd>ensures that FFmpeg will not transcode the audio to a different codec before generating the MD5 (by default FFmpeg will use 16 bit PCM for audio MD5s).</dd> | ||||||
|  |         <dt><i>output_file_2</i></dt><dd>is the output file for the audio stream MD5.</dd> | ||||||
|  |       </dl> | ||||||
|  |       <p><b>Note:</b>The MD5s generated by running this command on WAV files are compatible with those embedded by the <a href="https://mediaarea.net/BWFMetaEdit" target="_blank">BWF MetaEdit</a> tool and can be compared.</p> | ||||||
|  |       <p class="link"></p> | ||||||
|  |     </div> | ||||||
|  |     <!-- ends Create stream md5s --> | ||||||
|  |  | ||||||
|     <!-- QCTools Report --> |     <!-- QCTools Report --> | ||||||
|     <label class="recipe" for="qctools">QCTools report (with audio)</label> |     <label class="recipe" for="qctools">QCTools report (with audio)</label> | ||||||
|     <input type="checkbox" id="qctools"> |     <input type="checkbox" id="qctools"> | ||||||
| @@ -1616,7 +1703,7 @@ | |||||||
|       <p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and one audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p> |       <p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and one audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffprobe</dt><dd>starts the command</dd> |         <dt>ffprobe</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i</dt><dd>input file and parameters</dd> |         <dt>-i</dt><dd>input file and parameters</dd> | ||||||
|         <dt>"movie=<i>input_file</i>:s=v+a[in0][in1], [in0]signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom, split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim[out0];[in1]ebur128=metadata=1, astats=metadata=1:reset=1:length=0.4[out1]"</dt> |         <dt>"movie=<i>input_file</i>:s=v+a[in0][in1], [in0]signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom, split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim[out0];[in1]ebur128=metadata=1, astats=metadata=1:reset=1:length=0.4[out1]"</dt> | ||||||
|         <dd>This very large lump of commands declares the input file and passes in a request for all potential data signal information for a file with one video and one audio track</dd> |         <dd>This very large lump of commands declares the input file and passes in a request for all potential data signal information for a file with one video and one audio track</dd> | ||||||
| @@ -1641,7 +1728,7 @@ | |||||||
|       <p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and NO audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p> |       <p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and NO audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffprobe</dt><dd>starts the command</dd> |         <dt>ffprobe</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i</dt><dd>input file and parameters</dd> |         <dt>-i</dt><dd>input file and parameters</dd> | ||||||
|         <dt>"movie=<i>input_file</i>,signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom,split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim"</dt> |         <dt>"movie=<i>input_file</i>,signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom,split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim"</dt> | ||||||
|         <dd>This very large lump of commands declares the input file and passes in a request for all potential data signal information for a file with one video and one audio track</dd> |         <dd>This very large lump of commands declares the input file and passes in a request for all potential data signal information for a file with one video and one audio track</dd> | ||||||
| @@ -1674,7 +1761,7 @@ | |||||||
|       </dl> |       </dl> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
|     <!-- ends Check FFV1 Fixity  --> |     <!-- ends Check FFV1 Fixity --> | ||||||
|  |  | ||||||
|     <!-- Read/Extract EIA-608 Closed Captions --> |     <!-- Read/Extract EIA-608 Closed Captions --> | ||||||
|     <label class="recipe" for="readeia608">Read/Extract EIA-608 Closed Captioning</label> |     <label class="recipe" for="readeia608">Read/Extract EIA-608 Closed Captioning</label> | ||||||
| @@ -1686,7 +1773,7 @@ | |||||||
|       <p>If hex isn't your thing, closed captioning <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CHARS.HTML" target="_blank">character</a> and <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CODES.HTML" target="_blank">code</a> sets can be found in the documentation for SCTools.</p> |       <p>If hex isn't your thing, closed captioning <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CHARS.HTML" target="_blank">character</a> and <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CODES.HTML" target="_blank">code</a> sets can be found in the documentation for SCTools.</p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffprobe</dt><dd>starts the command</dd> |         <dt>ffprobe</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i <i>input_file</i></dt><dd>input file and parameters</dd> |         <dt>-i <i>input_file</i></dt><dd>input file and parameters</dd> | ||||||
|         <dt>readeia608 -show_entries frame=pkt_pts_time:frame_tags=lavfi.readeia608.0.line,lavfi.readeia608.0.cc,lavfi.readeia608.1.line,lavfi.readeia608.1.cc -of csv</dt><dd>specifies the first two lines of video in which EIA-608 data (hexadecimal byte pairs) are identifiable by ffprobe, outputting comma separated values (CSV)</dd> |         <dt>readeia608 -show_entries frame=pkt_pts_time:frame_tags=lavfi.readeia608.0.line,lavfi.readeia608.0.cc,lavfi.readeia608.1.line,lavfi.readeia608.1.cc -of csv</dt><dd>specifies the first two lines of video in which EIA-608 data (hexadecimal byte pairs) are identifiable by ffprobe, outputting comma separated values (CSV)</dd> | ||||||
|         <dt>></dt><dd>redirects the standard output (the data created by ffprobe about the video)</dd> |         <dt>></dt><dd>redirects the standard output (the data created by ffprobe about the video)</dd> | ||||||
| @@ -1713,7 +1800,7 @@ | |||||||
|       <p><code>ffmpeg -f lavfi -i mandelbrot=size=1280x720:rate=25 -c:v libx264 -t 10 <i>output_file</i></code></p> |       <p><code>ffmpeg -f lavfi -i mandelbrot=size=1280x720:rate=25 -c:v libx264 -t 10 <i>output_file</i></code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i mandelbrot=size=1280x720:rate=25</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#mandelbrot" target="_blank">mandelbrot test filter</a> as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate.</dd> |         <dt>-i mandelbrot=size=1280x720:rate=25</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#mandelbrot" target="_blank">mandelbrot test filter</a> as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate.</dd> | ||||||
|         <dt>-c:v libx264</dt><dd>transcodes video from rawvideo to H.264. Set <code>-pix_fmt</code> to <code>yuv420p</code> for greater H.264 compatibility with media players.</dd> |         <dt>-c:v libx264</dt><dd>transcodes video from rawvideo to H.264. Set <code>-pix_fmt</code> to <code>yuv420p</code> for greater H.264 compatibility with media players.</dd> | ||||||
|         <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> |         <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> | ||||||
| @@ -1731,7 +1818,7 @@ | |||||||
|       <p><code>ffmpeg -f lavfi -i smptebars=size=720x576:rate=25 -c:v prores -t 10 <i>output_file</i></code></p> |       <p><code>ffmpeg -f lavfi -i smptebars=size=720x576:rate=25 -c:v prores -t 10 <i>output_file</i></code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i smptebars=size=720x576:rate=25</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptebars test filter</a> as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate.</dd> |         <dt>-i smptebars=size=720x576:rate=25</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptebars test filter</a> as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate.</dd> | ||||||
|         <dt>-c:v prores</dt><dd>transcodes video from rawvideo to Apple ProRes 4:2:2.</dd> |         <dt>-c:v prores</dt><dd>transcodes video from rawvideo to Apple ProRes 4:2:2.</dd> | ||||||
|         <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> |         <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> | ||||||
| @@ -1749,7 +1836,7 @@ | |||||||
|       <p><code>ffmpeg -f lavfi -i testsrc=size=720x576:rate=25 -c:v v210 -t 10 <i>output_file</i></code></p> |       <p><code>ffmpeg -f lavfi -i testsrc=size=720x576:rate=25 -c:v v210 -t 10 <i>output_file</i></code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i testsrc=size=720x576:rate=25</dt><dd>asks for the testsrc filter pattern as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate. <br> |         <dt>-i testsrc=size=720x576:rate=25</dt><dd>asks for the testsrc filter pattern as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate. <br> | ||||||
|           The different test patterns that can be generated are listed <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">here</a>.</dd> |           The different test patterns that can be generated are listed <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">here</a>.</dd> | ||||||
|         <dt>-c:v v210</dt><dd>transcodes video from rawvideo to 10-bit Uncompressed Y′C<sub>B</sub>C<sub>R</sub> 4:2:2. Alter this setting to set your desired codec.</dd> |         <dt>-c:v v210</dt><dd>transcodes video from rawvideo to 10-bit Uncompressed Y′C<sub>B</sub>C<sub>R</sub> 4:2:2. Alter this setting to set your desired codec.</dd> | ||||||
| @@ -1769,7 +1856,7 @@ | |||||||
|       <p><code>ffplay -f lavfi -i smptehdbars=size=1920x1080</code></p> |       <p><code>ffplay -f lavfi -i smptehdbars=size=1920x1080</code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffplay</dt><dd>starts the command</dd> |         <dt>ffplay</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i smptehdbars=size=1920x1080</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptehdbars filter pattern</a> as input and sets the HD resolution. This generates a colour bars pattern, based on the SMPTE RP 219–2002.</dd> |         <dt>-i smptehdbars=size=1920x1080</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptehdbars filter pattern</a> as input and sets the HD resolution. This generates a colour bars pattern, based on the SMPTE RP 219–2002.</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
| @@ -1785,7 +1872,7 @@ | |||||||
|       <p><code>ffplay -f lavfi -i smptebars=size=640x480</code></p> |       <p><code>ffplay -f lavfi -i smptebars=size=640x480</code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffplay</dt><dd>starts the command</dd> |         <dt>ffplay</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i smptebars=size=640x480</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptebars filter pattern</a> as input and sets the VGA (SD) resolution. This generates a colour bars pattern, based on the SMPTE Engineering Guideline EG 1–1990.</dd> |         <dt>-i smptebars=size=640x480</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptebars filter pattern</a> as input and sets the VGA (SD) resolution. This generates a colour bars pattern, based on the SMPTE Engineering Guideline EG 1–1990.</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
| @@ -1801,7 +1888,7 @@ | |||||||
|       <p><code>ffmpeg -f lavfi -i "sine=frequency=1000:sample_rate=48000:duration=5" -c:a pcm_s16le <i>output_file</i>.wav</code></p> |       <p><code>ffmpeg -f lavfi -i "sine=frequency=1000:sample_rate=48000:duration=5" -c:a pcm_s16le <i>output_file</i>.wav</code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i "sine=frequency=1000:sample_rate=48000:duration=5"</dt><dd>Sets the signal to 1000 Hz, sampling at 48 kHz, and for 5 seconds</dd> |         <dt>-i "sine=frequency=1000:sample_rate=48000:duration=5"</dt><dd>Sets the signal to 1000 Hz, sampling at 48 kHz, and for 5 seconds</dd> | ||||||
|         <dt>-c:a pcm_s16le</dt><dd>encodes the audio codec in <code>pcm_s16le</code> (the default encoding for wav files). <code>pcm</code> represents pulse-code modulation format (raw bytes), <code>16</code> means 16 bits per sample, and <code>le</code> means "little endian"</dd> |         <dt>-c:a pcm_s16le</dt><dd>encodes the audio codec in <code>pcm_s16le</code> (the default encoding for wav files). <code>pcm</code> represents pulse-code modulation format (raw bytes), <code>16</code> means 16 bits per sample, and <code>le</code> means "little endian"</dd> | ||||||
|         <dt><i>output_file</i>.wav</dt><dd>path, name and extension of the output file</dd> |         <dt><i>output_file</i>.wav</dt><dd>path, name and extension of the output file</dd> | ||||||
| @@ -1819,14 +1906,14 @@ | |||||||
|       <p><code>ffmpeg -f lavfi -i smptebars=size=720x576:rate=25 -f lavfi -i "sine=frequency=1000:sample_rate=48000" -c:a pcm_s16le -t 10 -c:v ffv1 <i>output_file</i></code></p> |       <p><code>ffmpeg -f lavfi -i smptebars=size=720x576:rate=25 -f lavfi -i "sine=frequency=1000:sample_rate=48000" -c:a pcm_s16le -t 10 -c:v ffv1 <i>output_file</i></code></p> | ||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">libavfilter</a> input virtual device</dd> |         <dt>-f lavfi</dt><dd>tells FFmpeg to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">libavfilter</a> input virtual device</dd> | ||||||
|         <dt>-i smptebars=size=720x576:rate=25</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptebars test filter</a> as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate.</dd> |         <dt>-i smptebars=size=720x576:rate=25</dt><dd>asks for the <a href="https://ffmpeg.org/ffmpeg-filters.html#allrgb_002c-allyuv_002c-color_002c-haldclutsrc_002c-nullsrc_002c-rgbtestsrc_002c-smptebars_002c-smptehdbars_002c-testsrc_002c-testsrc2_002c-yuvtestsrc" target="_blank">smptebars test filter</a> as input. Adjusting the <code>size</code> and <code>rate</code> options allows you to choose a specific frame size and framerate.</dd> | ||||||
|         <dt>-f lavfi</dt><dd>use libavfilter again, but now for audio</dd> |         <dt>-f lavfi</dt><dd>use libavfilter again, but now for audio</dd> | ||||||
|         <dt>-i "sine=frequency=1000:sample_rate=48000"</dt><dd>Sets the signal to 1000 Hz, sampling at 48 kHz.</dd> |         <dt>-i "sine=frequency=1000:sample_rate=48000"</dt><dd>Sets the signal to 1000 Hz, sampling at 48 kHz.</dd> | ||||||
|         <dt>-c:a pcm_s16le</dt><dd>encodes the audio codec in <code>pcm_s16le</code> (the default encoding for wav files). <code>pcm</code> represents pulse-code modulation format (raw bytes), <code>16</code> means 16 bits per sample, and <code>le</code> means "little endian"</dd> |         <dt>-c:a pcm_s16le</dt><dd>encodes the audio codec in <code>pcm_s16le</code> (the default encoding for wav files). <code>pcm</code> represents pulse-code modulation format (raw bytes), <code>16</code> means 16 bits per sample, and <code>le</code> means "little endian"</dd> | ||||||
|         <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> |         <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> | ||||||
|         <dt>-c:v ffv1</dt><dd>Encodes to <a href="https://en.wikipedia.org/wiki/FFV1" target="_blank">FFV1</a>. Alter this setting to set your desired codec.</dd> |         <dt>-c:v ffv1</dt><dd>Encodes to <a href="https://en.wikipedia.org/wiki/FFV1" target="_blank">FFV1</a>. Alter this setting to set your desired codec.</dd> | ||||||
|         <dt><i>output_file</i>.wav</dt><dd>path, name and extension of the output file</dd> |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
| @@ -1842,7 +1929,7 @@ | |||||||
|       <dl> |       <dl> | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|         <dt>-i <i>input_file</i></dt><dd>takes in a normal file</dd> |         <dt>-i <i>input_file</i></dt><dd>takes in a normal file</dd> | ||||||
|         <dt>-bsf noise=1</dt><dd>sets bitstream filters for all to 'noise'. Filters can be set on specific filters using syntax such as <code>-bsf:v</code> for video, <code>-bsf:a</code> for audio, etc. The <a href="https://www.ffmpeg.org/ffmpeg-bitstream-filters.html#noise" target="_blank">noise filter</a> intentionally damages the contents of packets without damaging the container. This sets the noise level to 1 but it could be left blank or any number above 0.</dd> |         <dt>-bsf noise=1</dt><dd>sets bitstream filters for all to 'noise'. Filters can be set on specific filters using syntax such as <code>-bsf:v</code> for video, <code>-bsf:a</code> for audio, etc. The <a href="https://ffmpeg.org/ffmpeg-bitstream-filters.html#noise" target="_blank">noise filter</a> intentionally damages the contents of packets without damaging the container. This sets the noise level to 1 but it could be left blank or any number above 0.</dd> | ||||||
|         <dt>-c copy</dt><dd>use stream copy mode to re-mux instead of re-encode</dd> |         <dt>-c copy</dt><dd>use stream copy mode to re-mux instead of re-encode</dd> | ||||||
|         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> |         <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|       </dl> |       </dl> | ||||||
| @@ -1850,6 +1937,31 @@ | |||||||
|     </div> |     </div> | ||||||
|     <!-- ends Broken File --> |     <!-- ends Broken File --> | ||||||
|  |  | ||||||
|  |     <!-- Game of Life --> | ||||||
|  |     <label class="recipe" for="game_of_life">Conway's Game of Life</label> | ||||||
|  |     <input type="checkbox" id="game_of_life"> | ||||||
|  |     <div class="hiding"> | ||||||
|  |       <h3>Conway's Game of Life</h3> | ||||||
|  |       <p>Simulates <a href="https://en.wikipedia.org/wiki/Conway%27s_Game_of_Life">Conway's Game of Life</a></p> | ||||||
|  |       <p><code>ffplay -f lavfi life=s=300x200:mold=10:r=60:ratio=0.1:death_color=#C83232:life_color=#00ff00,scale=1200:800</code></p> | ||||||
|  |       <dl> | ||||||
|  |         <dt>ffplay</dt><dd>starts the command</dd> | ||||||
|  |         <dt>-f lavfi</dt><dd>tells ffplay to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter</a> input virtual device</dd> | ||||||
|  |         <dt>life=s=300x200</dt><dd>use the life filter and set the size of the video to 300x200</dd> | ||||||
|  |         <dt>:</dt><dd>indicates there’s another parameter coming</dd> | ||||||
|  |         <dt>mold=10:r=60:ratio=0.1</dt><dd>sets up the rules of the game: cell mold speed, video rate, and random fill ratio</dd> | ||||||
|  |         <dt>:</dt><dd>indicates there’s another parameter coming</dd> | ||||||
|  |         <dt>death_color=#C83232:life_color=#00ff00</dt><dd>specifies color for cell death and cell life; mold_color can also be set</dd> | ||||||
|  |         <dt>,</dt><dd>comma signifies closing of video source assertion and ready for filter assertion</dd> | ||||||
|  |         <dt>scale=1200:800</dt><dd>scale to 1280 width and 800 height</dd> | ||||||
|  |       </dl> | ||||||
|  |       <img src="img/life.gif" alt="GIF of above command"> | ||||||
|  |       <p>To save a portion of the stream instead of playing it back infinitely, use the following command:</p> | ||||||
|  |       <p><code>ffmpeg -f lavfi -i life=s=300x200:mold=10:r=60:ratio=0.1:death_color=#C83232:life_color=#00ff00,scale=1200:800 -t 5 <i>output_file</i></code></p> | ||||||
|  |       <p class="link"></p> | ||||||
|  |     </div> | ||||||
|  |     <!-- ends Game of Life --> | ||||||
|  |  | ||||||
|     </div> |     </div> | ||||||
|     <div class="well"> |     <div class="well"> | ||||||
|     <h2 id="ocr">Use OCR</h2> |     <h2 id="ocr">Use OCR</h2> | ||||||
| @@ -1889,7 +2001,7 @@ | |||||||
|         <dt>ffprobe</dt><dd>starts the command</dd> |         <dt>ffprobe</dt><dd>starts the command</dd> | ||||||
|         <dt>-show_entries</dt><dd>sets a list of entries to show</dd> |         <dt>-show_entries</dt><dd>sets a list of entries to show</dd> | ||||||
|         <dt>frame_tags=lavfi.ocr.text</dt><dd>shows the <i>lavfi.ocr.text</i> tag in the frame section of the video</dd> |         <dt>frame_tags=lavfi.ocr.text</dt><dd>shows the <i>lavfi.ocr.text</i> tag in the frame section of the video</dd> | ||||||
|         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a></dd> |         <dt>-f lavfi</dt><dd>tells ffprobe to use the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a></dd> | ||||||
|         <dt>-i "movie=<i>input_file</i>,ocr"</dt><dd>declares 'movie' as <i>input_file</i> and passes in the 'ocr' command</dd> |         <dt>-i "movie=<i>input_file</i>,ocr"</dt><dd>declares 'movie' as <i>input_file</i> and passes in the 'ocr' command</dd> | ||||||
|       </dl> |       </dl> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
| @@ -1966,20 +2078,44 @@ | |||||||
|       <input type="checkbox" id="split_audio_video"> |       <input type="checkbox" id="split_audio_video"> | ||||||
|       <div class="hiding"> |       <div class="hiding"> | ||||||
|         <h3>Split audio and video tracks</h3> |         <h3>Split audio and video tracks</h3> | ||||||
|         <p><code>ffmpeg -i <i>input_file</i> -map <i>0:v:0 video_output_file</i> -map <i>0:a:0 audio_output_file</i></code></p> |         <p><code>ffmpeg -i <i>input_file</i> -map 0:v:0 <i>video_output_file</i> -map 0:a:0 <i>audio_output_file</i></code></p> | ||||||
|         <p>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 streams are desired.</p> |         <p>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 streams are desired.</p> | ||||||
|         <dl> |         <dl> | ||||||
|           <dt>ffmpeg</dt><dd>starts the command</dd> |           <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|           <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |           <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|           <dt>-map <i>0:v:0</i></dt><dd>grabs the first video stream and maps it into:</dd> |           <dt>-map 0:v:0</dt><dd>grabs the first video stream and maps it into:</dd> | ||||||
|           <dt><i>video_output_file</i></dt><dd>path, name and extension of the video output file</dd> |           <dt><i>video_output_file</i></dt><dd>path, name and extension of the video output file</dd> | ||||||
|           <dt>-map <i>0:a:0</i></dt><dd>grabs the first audio stream and maps it into:</dd> |           <dt>-map 0:a:0</dt><dd>grabs the first audio stream and maps it into:</dd> | ||||||
|           <dt><i>audio_output_file</i></dt><dd>path, name and extension of the audio output file</dd> |           <dt><i>audio_output_file</i></dt><dd>path, name and extension of the audio output file</dd> | ||||||
|         </dl> |         </dl> | ||||||
|         <p class="link"></p> |         <p class="link"></p> | ||||||
|       </div> |       </div> | ||||||
|       <!-- ends Split audio and video tracks --> |       <!-- ends Split audio and video tracks --> | ||||||
|  |  | ||||||
|  |       <!-- Merge audio and video tracks --> | ||||||
|  |       <label class="recipe" for="merge_audio_video">Merge audio and video tracks</label> | ||||||
|  |       <input type="checkbox" id="merge_audio_video"> | ||||||
|  |       <div class="hiding"> | ||||||
|  |         <h3>Merge audio and video tracks</h3> | ||||||
|  |         <p><code>ffmpeg -i <i>video_file</i> -i <i>audio_file</i> -map 0:v -map 1:a -c copy <i>output_file</i></code></p> | ||||||
|  |         <p>This command takes a video file and an audio file as inputs, and creates an output file that combines the video stream in the first file with the audio stream in the second file.</p> | ||||||
|  |         <dl> | ||||||
|  |           <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |           <dt>-i <i>video_file</i></dt><dd>path, name and extension of the first input file (the video file)</dd> | ||||||
|  |           <dt>-i <i>audio_file</i></dt><dd>path, name and extension of the second input file (the audio file)</dd> | ||||||
|  |           <dt>-map <i>0:v</i></dt><dd>selects the video streams from the first input file</dd> | ||||||
|  |           <dt>-map <i>1:a</i></dt><dd>selects the audio streams from the second input file</dd> | ||||||
|  |           <dt>-c copy</dt><dd>copies streams without re-encoding</dd> | ||||||
|  |           <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|  |         </dl> | ||||||
|  |         <p><b>Note:</b> in the example above, the video input file is given prior to the audio input file. However, input files can be added any order, as long as they are indexed correctly when stream mapping with <code>-map</code>. See the entry on <a href="#stream-mapping">stream mapping</a>.</p> | ||||||
|  |         <h4>Variation:</h4> | ||||||
|  |         <p>Include the audio tracks from both input files with the following command:</p> | ||||||
|  |         <p><code>ffmpeg -i <i>video_file</i> -i <i>audio_file</i> -map 0:v -map 0:a -map 1:a -c copy <i>output_file</i></code></p> | ||||||
|  |         <p class="link"></p> | ||||||
|  |       </div> | ||||||
|  |       <!-- ends Merge audio and video tracks --> | ||||||
|  |  | ||||||
|       <!-- Create ISO --> |       <!-- Create ISO --> | ||||||
|       <label class="recipe" for="create_iso">Create ISO files for DVD access</label> |       <label class="recipe" for="create_iso">Create ISO files for DVD access</label> | ||||||
|       <input type="checkbox" id="create_iso"> |       <input type="checkbox" id="create_iso"> | ||||||
| @@ -2008,7 +2144,7 @@ | |||||||
|         <p>This ffprobe command prints a CSV correlating timestamps and their YDIF values, useful for determining cuts.</p> |         <p>This ffprobe command prints a CSV correlating timestamps and their YDIF values, useful for determining cuts.</p> | ||||||
|         <dl> |         <dl> | ||||||
|           <dt>ffprobe</dt><dd>starts the command</dd> |           <dt>ffprobe</dt><dd>starts the command</dd> | ||||||
|           <dt>-f lavfi</dt><dd>uses the <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a> as chosen format</dd> |           <dt>-f lavfi</dt><dd>uses the <a href="https://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">Libavfilter input virtual device</a> as chosen format</dd> | ||||||
|           <dt>-i movie=<i>input file</i></dt><dd>path, name and extension of the input video file</dd> |           <dt>-i movie=<i>input file</i></dt><dd>path, name and extension of the input video file</dd> | ||||||
|           <dt>,</dt><dd>comma signifies closing of video source assertion and ready for filter assertion</dd> |           <dt>,</dt><dd>comma signifies closing of video source assertion and ready for filter assertion</dd> | ||||||
|           <dt>signalstats</dt><dd>tells ffprobe to use the signalstats command</dd> |           <dt>signalstats</dt><dd>tells ffprobe to use the signalstats command</dd> | ||||||
| @@ -2060,26 +2196,26 @@ | |||||||
|           <li>This is in daily use to live-stream a real-world TV show. No errors for nearly 4 years. Some parameters were found by trial-and-error or empiric testing. So suggestions/questions are welcome.</li> |           <li>This is in daily use to live-stream a real-world TV show. No errors for nearly 4 years. Some parameters were found by trial-and-error or empiric testing. So suggestions/questions are welcome.</li> | ||||||
|         </ol> |         </ol> | ||||||
|         <dl> |         <dl> | ||||||
|            <dt>ffmpeg </dt><dd>starts the command</dd> |            <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|            <dt>-re </dt><dd>Read input at native framerate</dd> |            <dt>-re</dt><dd>Read input at native framerate</dd> | ||||||
|            <dt>-i input.mov </dt><dd>The input file. Can also be a <code>-</code> to use STDIN if you pipe in from webcam or SDI.</dd> |            <dt>-i input.mov</dt><dd>The input file. Can also be a <code>-</code> to use STDIN if you pipe in from webcam or SDI.</dd> | ||||||
|            <dt>-map 0 </dt><dd>map ALL streams from input file to output</dd> |            <dt>-map 0</dt><dd>map ALL streams from input file to output</dd> | ||||||
|            <dt>-flags +global_header </dt><dd>Don't place extra data in every keyframe</dd> |            <dt>-flags +global_header</dt><dd>Don't place extra data in every keyframe</dd> | ||||||
|            <dt>-vf scale="1280:-1" </dt><dd>Scale to 1280 width, maintain aspect ratio.</dd> |            <dt>-vf scale="1280:-1"</dt><dd>Scale to 1280 width, maintain aspect ratio.</dd> | ||||||
|            <dt>-pix_fmt yuv420p </dt><dd>convert to 4:2:0 chroma subsampling scheme</dd> |            <dt>-pix_fmt yuv420p</dt><dd>convert to 4:2:0 chroma subsampling scheme</dd> | ||||||
|            <dt>-level 3.1 </dt><dd>H264 Level (defines some thresholds for bitrate)</dd> |            <dt>-level 3.1</dt><dd>H264 Level (defines some thresholds for bitrate)</dd> | ||||||
|            <dt>-vsync passthrough </dt><dd>Each frame is passed with its timestamp from the demuxer to the muxer.</dd> |            <dt>-vsync passthrough</dt><dd>Each frame is passed with its timestamp from the demuxer to the muxer.</dd> | ||||||
|            <dt>-crf 26 </dt><dd>Constant rate factor - basically the quality</dd> |            <dt>-crf 26</dt><dd>Constant rate factor - basically the quality</dd> | ||||||
|            <dt>-g 50 </dt><dd>GOP size.</dd> |            <dt>-g 50</dt><dd>GOP size.</dd> | ||||||
|            <dt>-bufsize 3500k </dt><dd>Ratecontrol buffer size (~ maxrate x2)</dd> |            <dt>-bufsize 3500k</dt><dd>Ratecontrol buffer size (~ maxrate x2)</dd> | ||||||
|            <dt>-maxrate 1800k </dt><dd>Maximum bit rate</dd> |            <dt>-maxrate 1800k</dt><dd>Maximum bit rate</dd> | ||||||
|            <dt>-c:v libx264 </dt><dd>encode output video stream as H.264</dd> |            <dt>-c:v libx264</dt><dd>encode output video stream as H.264</dd> | ||||||
|            <dt>-c:a aac </dt><dd>encode output audio stream as AAC</dd> |            <dt>-c:a aac</dt><dd>encode output audio stream as AAC</dd> | ||||||
|            <dt>-b:a 128000 </dt><dd>The audio bitrate</dd> |            <dt>-b:a 128000</dt><dd>The audio bitrate</dd> | ||||||
|            <dt>-r:a 44100 </dt><dd>The audio samplerate</dd> |            <dt>-r:a 44100</dt><dd>The audio samplerate</dd> | ||||||
|            <dt>-ac 2 </dt><dd>Two audio channels</dd> |            <dt>-ac 2</dt><dd>Two audio channels</dd> | ||||||
|            <dt>-t ${STREAMDURATION} </dt><dd>Time (in seconds) after which the stream should automatically end.</dd> |            <dt>-t ${STREAMDURATION}</dt><dd>Time (in seconds) after which the stream should automatically end.</dd> | ||||||
|            <dt>-f tee </dt><dd>Use multiple outputs. Outputs defined below.</dd> |            <dt>-f tee</dt><dd>Use multiple outputs. Outputs defined below.</dd> | ||||||
|            <dt>"[movflags=+faststart]target-file.mp4|[f=flv]rtmp://stream-url/stream-id"</dt><dd>The outputs, separated by a pipe (|). The first is the local file, the second is the live stream. Options for each target are given in square brackets before the target.</dd> |            <dt>"[movflags=+faststart]target-file.mp4|[f=flv]rtmp://stream-url/stream-id"</dt><dd>The outputs, separated by a pipe (|). The first is the local file, the second is the live stream. Options for each target are given in square brackets before the target.</dd> | ||||||
|         </dl> |         </dl> | ||||||
|         <p class="link"></p> |         <p class="link"></p> | ||||||
| @@ -2129,9 +2265,9 @@ Change the above data-target field, the hover-over description, the button text, | |||||||
| </div> --> | </div> --> | ||||||
| <!-- ends sample example --> | <!-- ends sample example --> | ||||||
|  |  | ||||||
|   <footer class="footer"> | <footer class="footer"> | ||||||
|     <p>Made with ♥ at <a href="http://wiki.curatecamp.org/index.php/Association_of_Moving_Image_Archivists_%26_Digital_Library_Federation_Hack_Day_2015" target="_blank">AMIA #AVhack15</a>! Contribute to the project via <a href="https://github.com/amiaopensource/ffmprovisr">our GitHub page</a>!</p> |   <p>Made with ♥ at <a href="https://wiki.curatecamp.org/index.php/Association_of_Moving_Image_Archivists_%26_Digital_Library_Federation_Hack_Day_2015" target="_blank">AMIA #AVhack15</a>! Contribute to the project via <a href="https://github.com/amiaopensource/ffmprovisr">our GitHub page</a>!</p> | ||||||
|   </footer> | </footer> | ||||||
| </div><!-- ends "grid" --> | </div><!-- ends "grid" --> | ||||||
| </body> | </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								js/js.js
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								js/js.js
									
									
									
									
									
								
							| @@ -3,10 +3,11 @@ $(document).ready(function() { | |||||||
|   // open recipe window if a hash is found in URL |   // open recipe window if a hash is found in URL | ||||||
|   if(window.location.hash) { |   if(window.location.hash) { | ||||||
|     id = window.location.hash |     id = window.location.hash | ||||||
|  |     console.log(id.substring(1)) | ||||||
|     document.getElementById(id.substring(1)).checked = true; |     document.getElementById(id.substring(1)).checked = true; | ||||||
|     $('html, body').animate({ scrollTop: $(id).offset().top}, 1000); |     $('html, body').animate({ scrollTop: $(id).offset().top}, 1000); | ||||||
|     $(id).closest('div').find('.link').empty(); |     $(id).closest('div').find('.link').empty(); | ||||||
|     $(id).closest('div').find('.link').append("<small>Link to this command: <a href="+window.location.href+">"+window.location.href+"</a></small>"); |     $(id).closest('div').find('.link').append("<small>Link to this command: <a href='https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"'>https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"</a></small>"); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // add hash URL when recipe is opened |   // add hash URL when recipe is opened | ||||||
| @@ -14,7 +15,7 @@ $(document).ready(function() { | |||||||
|     id = $(this).attr("for"); |     id = $(this).attr("for"); | ||||||
|     window.location.hash = ('#' + id) |     window.location.hash = ('#' + id) | ||||||
|     $('#' + id).closest('div').find('.link').empty(); |     $('#' + id).closest('div').find('.link').empty(); | ||||||
|     $('#' + id).closest('div').find('.link').append("<small>Link to this command: <a href="+window.location.href+">"+window.location.href+"</a></small>"); |     $('#' + id).closest('div').find('.link').append("<small>Link to this command: <a href='https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"'>https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"</a></small>"); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -44,7 +44,7 @@ You can read our contributor code of conduct [here](https://github.com/amiaopens | |||||||
|  |  | ||||||
| ## Maintainers | ## Maintainers | ||||||
|  |  | ||||||
| [Ashley Blewer](https://github.com/ablwr), [Katherine Frances Nagels](https://github.com/kfrn), [Kieran O'Leary](https://github.com/kieranjol) and [Reto Kromer](https://github.com/retokromer) | [Ashley Blewer](https://github.com/ablwr), [Katherine Frances Nagels](https://github.com/kfrn), [Kieran O'Leary](https://github.com/kieranjol), [Reto Kromer](https://github.com/retokromer) and [Andrew Weaver](https://github.com/privatezero) | ||||||
|  |  | ||||||
| ## Contributors | ## Contributors | ||||||
| * Gathered using [octohatrack](https://github.com/LABHR/octohatrack) | * Gathered using [octohatrack](https://github.com/LABHR/octohatrack) | ||||||
| @@ -104,4 +104,6 @@ All Contributors: 22 | |||||||
|  |  | ||||||
| ## License | ## License | ||||||
|  |  | ||||||
| <a rel="license" href="http://creativecommons.org/licenses/by/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by/4.0/80x15.png" /></a><br />This <span xmlns:dct="http://purl.org/dc/terms/" href="http://purl.org/dc/dcmitype/InteractiveResource" rel="dct:type">work</span> by <a xmlns:cc="http://creativecommons.org/ns#" href="http://amiaopensource.github.io/ffmprovisr/" property="cc:attributionName" rel="cc:attributionURL">ffmprovisr</a> is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by/4.0/">Creative Commons Attribution 4.0 International License</a>.<br />Based on a work at <a xmlns:dct="http://purl.org/dc/terms/" href="https://github.com/amiaopensource/ffmprovisr" rel="dct:source">https://github.com/amiaopensource/ffmprovisr</a>. | <a rel="license" href="http://creativecommons.org/licenses/by/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by/4.0/80x15.png"></a><br> | ||||||
|  | This <span xmlns:dct="http://purl.org/dc/terms/" href="http://purl.org/dc/dcmitype/InteractiveResource" rel="dct:type">work</span> by <a xmlns:cc="http://creativecommons.org/ns#" href="http://amiaopensource.github.io/ffmprovisr/" property="cc:attributionName" rel="cc:attributionURL">ffmprovisr</a> is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by/4.0/">Creative Commons Attribution 4.0 International License</a>.<br> | ||||||
|  | Based on a work at <a xmlns:dct="http://purl.org/dc/terms/" href="https://github.com/amiaopensource/ffmprovisr" rel="dct:source">https://github.com/amiaopensource/ffmprovisr</a>. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user