mirror of
				https://github.com/amiaopensource/ffmprovisr.git
				synced 2025-10-24 22:50:51 +02:00 
			
		
		
		
	Compare commits
	
		
			22 Commits
		
	
	
		
			v2017-02-2
			...
			v2017-03-0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | bd0ac73d78 | ||
|  | 7e7da29093 | ||
|  | 47acc400ce | ||
|  | c117e18c0c | ||
|  | 0921bd68d5 | ||
|  | d0e13f3eb6 | ||
|  | 82a1cfeb8b | ||
|  | 472fcfe833 | ||
|  | 0907590913 | ||
|  | 0ed5cfff65 | ||
|  | e3deb3af4e | ||
|  | 5869850d4b | ||
|  | a5a49e1f28 | ||
|  | cdd65fd765 | ||
|  | c85d6c5874 | ||
|  | 63879e0e51 | ||
|  | d02633b612 | ||
|  | 0d92454148 | ||
|  | 8ebf23f172 | ||
|  | 43f228c930 | ||
|  | 22958ed956 | ||
|  | 16a4d3241e | 
							
								
								
									
										24
									
								
								css/css.css
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								css/css.css
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| h1,h2,h3,h4,h5,h6 { | h1, h2, h3, h4, h5, h6 { | ||||||
|   font-family: 'Montserrat', sans-serif; |   font-family: 'Montserrat', sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -11,13 +11,14 @@ dd { | |||||||
| } | } | ||||||
|  |  | ||||||
| dt { | dt { | ||||||
|   font-family: Menlo,Monaco,Consolas,"Courier New",monospace; |   font-family: Menlo, Monaco, Consolas, "Courier New", monospace; | ||||||
| } | } | ||||||
|  |  | ||||||
| img { | img { | ||||||
|   display: block; |   display: block; | ||||||
|   margin-left: auto; |   margin-left: auto; | ||||||
|   margin-right: auto; |   margin-right: auto; | ||||||
|  |   width: 100%; | ||||||
| } | } | ||||||
|  |  | ||||||
| .sample-image { | .sample-image { | ||||||
| @@ -37,9 +38,6 @@ div { | |||||||
|  |  | ||||||
| .btn { | .btn { | ||||||
|   margin: 8px; |   margin: 8px; | ||||||
| } |  | ||||||
|  |  | ||||||
| .btn { |  | ||||||
|   display: inline-block; |   display: inline-block; | ||||||
|   vertical-align: middle; |   vertical-align: middle; | ||||||
|   -webkit-transform: translateZ(0); |   -webkit-transform: translateZ(0); | ||||||
| @@ -53,6 +51,7 @@ div { | |||||||
|   -webkit-transition-duration: 0.3s; |   -webkit-transition-duration: 0.3s; | ||||||
|   transition-duration: 0.3s; |   transition-duration: 0.3s; | ||||||
| } | } | ||||||
|  |  | ||||||
| .btn:before { | .btn:before { | ||||||
|   content: "💫"; |   content: "💫"; | ||||||
|   position: absolute; |   position: absolute; | ||||||
| @@ -67,6 +66,7 @@ div { | |||||||
|   -webkit-transition-timing-function: ease-out; |   -webkit-transition-timing-function: ease-out; | ||||||
|   transition-timing-function: ease-out; |   transition-timing-function: ease-out; | ||||||
| } | } | ||||||
|  |  | ||||||
| .btn:hover:before, .btn:focus:before, .btn:active:before { | .btn:hover:before, .btn:focus:before, .btn:active:before { | ||||||
|   -webkit-transform: scale(1.3) translateZ(0); |   -webkit-transform: scale(1.3) translateZ(0); | ||||||
|   transform: scale(1.3) translateZ(0); |   transform: scale(1.3) translateZ(0); | ||||||
| @@ -78,7 +78,7 @@ div { | |||||||
|   font-size: 90%; |   font-size: 90%; | ||||||
|   color: #c7254e; |   color: #c7254e; | ||||||
|   background-color: #f9f2f4; |   background-color: #f9f2f4; | ||||||
|   border-radius: 4px |   border-radius: 4px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .beware { | .beware { | ||||||
| @@ -88,3 +88,15 @@ div { | |||||||
| .footnote { | .footnote { | ||||||
|   font-size: 90%; |   font-size: 90%; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @media only screen and (min-width: 576px) { | ||||||
|  |   img { | ||||||
|  |     max-width: 60%; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @media only screen and (min-width: 992px) { | ||||||
|  |   img { | ||||||
|  |     width: 100%; | ||||||
|  |   } | ||||||
|  | } | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								img/ivtc_originalvideo.gif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								img/ivtc_originalvideo.gif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.4 MiB | 
							
								
								
									
										
											BIN
										
									
								
								img/ivtc_result.gif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								img/ivtc_result.gif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.4 MiB | 
							
								
								
									
										112
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										112
									
								
								index.html
									
									
									
									
									
								
							| @@ -3,11 +3,9 @@ | |||||||
|   <head> |   <head> | ||||||
|     <title>ffmprovisr</title> |     <title>ffmprovisr</title> | ||||||
|     <meta charset="utf-8"> |     <meta charset="utf-8"> | ||||||
|  |     <link href="https://fonts.googleapis.com/css?family=Montserrat|Merriweather" rel="stylesheet" type="text/css"> | ||||||
|     <link href='https://fonts.googleapis.com/css?family=Montserrat|Merriweather' rel='stylesheet' type='text/css'> |  | ||||||
|     <link rel="stylesheet" href="css/bootstrap.min.css"> |     <link rel="stylesheet" href="css/bootstrap.min.css"> | ||||||
|     <link rel="stylesheet" href="css/css.css"> |     <link rel="stylesheet" href="css/css.css"> | ||||||
|  |  | ||||||
|     <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> | ||||||
|     <script src="js/bootstrap.min.js"></script> |     <script src="js/bootstrap.min.js"></script> | ||||||
| @@ -32,7 +30,8 @@ | |||||||
|   <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="http://explainshell.com/" target="_blank">explainshell.com</a>!</p> | ||||||
|   <h5>License</h5> |   <h5>License</h5> | ||||||
|   <p><a target="_blank" href="http://creativecommons.org/licenses/by-sa/4.0/"><img alt="Creative Commons License" src="https://i.creativecommons.org/l/by-sa/4.0/88x31.png"></a><br>This work is licensed under a <a href="http://creativecommons.org/licenses/by-sa/4.0/">Creative Commons Attribution-ShareAlike 4.0 International License</a></p> |   <p><a target="_blank" href="https://creativecommons.org/licenses/by-sa/4.0/"><img alt="Creative Commons License" src="https://i.creativecommons.org/l/by-sa/4.0/88x31.png"></a><br> | ||||||
|  |     This work is licensed under a <a href="https://creativecommons.org/licenses/by-sa/4.0/">Creative Commons Attribution-ShareAlike 4.0 International License</a>.</p> | ||||||
|   <h5>Sister projects</h5> |   <h5>Sister projects</h5> | ||||||
|   <p><a target="_blank" href="http://dd388.github.io/crals/">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p> |   <p><a target="_blank" href="http://dd388.github.io/crals/">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p> | ||||||
|   <p><a target="_blank" href="https://datapraxis.github.io/sourcecaster/">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 target="_blank" href="https://datapraxis.github.io/sourcecaster/">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> | ||||||
| @@ -72,6 +71,31 @@ | |||||||
|   </div> |   </div> | ||||||
|   <!-- ends WAV to MP3 --> |   <!-- ends WAV to MP3 --> | ||||||
|  |  | ||||||
|  |   <!-- WAV to AAC/MP4 --> | ||||||
|  |   <span data-toggle="modal" data-target="#wav_to_mp4"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Convert WAV to AAC/MP4">WAV to AAC/MP4</button></span> | ||||||
|  |   <div id="wav_to_mp4" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|  |     <div class="modal-dialog modal-lg"> | ||||||
|  |       <div class="modal-content"> | ||||||
|  |         <div class="well"> | ||||||
|  |           <h3>WAV to AAC/MP4</h3> | ||||||
|  |           <p><code>ffmpeg -i <i>input_file</i>.wav -c:a aac -b:a 128k -dither_method modified_e_weighted -ar 44100 <i>output_file</i>.mp4</code></p> | ||||||
|  |           <p>This will convert your WAV file to AAC/MP4.</p> | ||||||
|  |           <dl> | ||||||
|  |             <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |             <dt>-i <i>input_file</i></dt><dd>path and name of the input file</dd> | ||||||
|  |             <dt>-c:a aac</dt><dd>sets the audio codec to AAC</dd> | ||||||
|  |             <dt>-b:a 128k</dt><dd>sets the bitrate of the audio to 128k</dd> | ||||||
|  |             <dt>-dither_method modified_e_weighted</dt><dd>Dither makes sure you don’t unnecessarily truncate the dynamic range of your audio.</dd> | ||||||
|  |             <dt>-ar 44100</dt><dd>sets the audio sampling frequency to 44100 Hz, or 44.1 kHz, or “CD quality”</dd> | ||||||
|  |             <dt><i>output_file</i></dt><dd>path and name of the output file</dd> | ||||||
|  |           </dl> | ||||||
|  |           <p class="link"></p> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <!-- ends WAV to AAC/MP4 --> | ||||||
|  |  | ||||||
|   <!-- Transcode to ProRes --> |   <!-- Transcode to ProRes --> | ||||||
|   <span data-toggle="modal" data-target="#to_prores"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Transcode to deinterlaced Apple ProRes LT">Transcode to ProRes</button></span> |   <span data-toggle="modal" data-target="#to_prores"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Transcode to deinterlaced Apple ProRes LT">Transcode to ProRes</button></span> | ||||||
|   <div id="to_prores" class="modal fade" tabindex="-1" role="dialog"> |   <div id="to_prores" class="modal fade" tabindex="-1" role="dialog"> | ||||||
| @@ -246,7 +270,7 @@ | |||||||
|   </div> |   </div> | ||||||
|   <!-- ends SD to HD --> |   <!-- ends SD to HD --> | ||||||
|  |  | ||||||
| <!-- 16:9 to 4:3 --> |   <!-- 16:9 to 4:3 --> | ||||||
|   <span data-toggle="modal" data-target="#HD_SD"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Transform 16:9 aspect ratio video into 4:3 with letterbox">16:9 to 4:3</button></span> |   <span data-toggle="modal" data-target="#HD_SD"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Transform 16:9 aspect ratio video into 4:3 with letterbox">16:9 to 4:3</button></span> | ||||||
|   <div id="HD_SD" class="modal fade" tabindex="-1" role="dialog"> |   <div id="HD_SD" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|     <div class="modal-dialog modal-lg"> |     <div class="modal-dialog modal-lg"> | ||||||
| @@ -258,7 +282,8 @@ | |||||||
|           <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:v "pad=iw:iw*3/4:(ow-iw)/2:(oh-ih)/2"</dt><dd>video padding<br>This resolution independent formula is actually padding any aspect ratio into 4:3 by letterboxing, because the video filter uses relative values for input width (iw), input height (ih), output width (ow) and output height (oh).</dd> |             <dt>-filter:v "pad=iw:iw*3/4:(ow-iw)/2:(oh-ih)/2"</dt><dd>video padding<br> | ||||||
|  |             This resolution independent formula is actually padding any aspect ratio into 4:3 by letterboxing, because the video filter uses relative values for input width (iw), input height (ih), output width (ow) and output height (oh).</dd> | ||||||
|             <dt>-c:a copy</dt><dd>re-encodes using the same audio codec<br> |             <dt>-c:a copy</dt><dd>re-encodes using the same audio codec<br> | ||||||
|             For silent videos you can replace <code>-c:a copy</code> by <code>-an</code>.</dd> |             For silent videos you can replace <code>-c:a copy</code> by <code>-an</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> | ||||||
| @@ -324,7 +349,7 @@ | |||||||
|   </div> |   </div> | ||||||
|   <!-- ends Change display aspect ratio without re-encoding video --> |   <!-- ends Change display aspect ratio without re-encoding video --> | ||||||
|  |  | ||||||
|  <!-- MKV to MP4 --> |   <!-- MKV to MP4 --> | ||||||
|   <span data-toggle="modal" data-target="#mkv_to_mp4"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Convert Matroska (MKV) to MP4">MKV to MP4</button></span> |   <span data-toggle="modal" data-target="#mkv_to_mp4"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Convert Matroska (MKV) to MP4">MKV to MP4</button></span> | ||||||
|   <div id="mkv_to_mp4" class="modal fade" tabindex="-1" role="dialog"> |   <div id="mkv_to_mp4" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|     <div class="modal-dialog modal-lg"> |     <div class="modal-dialog modal-lg"> | ||||||
| @@ -351,7 +376,7 @@ | |||||||
|   </div> |   </div> | ||||||
|   <!-- ends MKV to MP4 --> |   <!-- ends MKV to MP4 --> | ||||||
|  |  | ||||||
|  <!-- Images to GIF --> |   <!-- Images to GIF --> | ||||||
|   <span data-toggle="modal" data-target="#img_to_gif"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Converts images to GIF">Images to GIF</button></span> |   <span data-toggle="modal" data-target="#img_to_gif"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Converts images to GIF">Images to GIF</button></span> | ||||||
|   <div id="img_to_gif" class="modal fade" tabindex="-1" role="dialog"> |   <div id="img_to_gif" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|     <div class="modal-dialog modal-lg"> |     <div class="modal-dialog modal-lg"> | ||||||
| @@ -366,7 +391,7 @@ | |||||||
|             <dt>-framerate 9</dt><dd>sets framerate to 9 frames per second</dd> |             <dt>-framerate 9</dt><dd>sets framerate to 9 frames per second</dd> | ||||||
|             <dt>-pattern_type glob</dt><dd>tells ffmpeg that the following mapping should "interpret like a <a href="https://en.wikipedia.org/wiki/Glob_%28programming%29" target="_blank">glob</a>" (a "global command" function that relies on the * as a wildcard and finds everything that matches)</dd> |             <dt>-pattern_type glob</dt><dd>tells ffmpeg that the following mapping should "interpret like a <a href="https://en.wikipedia.org/wiki/Glob_%28programming%29" target="_blank">glob</a>" (a "global command" function that relies on the * as a wildcard and finds everything that matches)</dd> | ||||||
|             <dt>-i <i>"input_image_*.jpg"</i></dt><dd>maps all files in the directory that start with input_image_, for example input_image_001.jpg, input_image_002.jpg, input_image_003.jpg... etc.<br> |             <dt>-i <i>"input_image_*.jpg"</i></dt><dd>maps all files in the directory that start with input_image_, for example input_image_001.jpg, input_image_002.jpg, input_image_003.jpg... etc.<br> | ||||||
|             (The quotation marks are necessary for the above "glob" pattern!)</dd> |             (The quotation marks are necessary for the above “glob” pattern!)</dd> | ||||||
|             <dt>-vf scale=250x250</dt><dd>filter the video to scale it to 250x250; -vf is an alias for -filter:v</dd> |             <dt>-vf scale=250x250</dt><dd>filter the video to scale it to 250x250; -vf is an alias for -filter:v</dd> | ||||||
|             <dt><i>output_file.gif</i></dt><dd>path and name of the output file</dd> |             <dt><i>output_file.gif</i></dt><dd>path and name of the output file</dd> | ||||||
|           </dl> |           </dl> | ||||||
| @@ -461,13 +486,13 @@ | |||||||
|             <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>-vf</dt><dd>video filtering will be used<dd> |             <dt>-vf</dt><dd>video filtering will be used (<code>-vf</code> is an alias of <code>-filter:v</code>)</dd> | ||||||
|             <dt><i>"</i></dt><dd>start of filtergraph (see below)</dd> |             <dt><i>"</i></dt><dd>start of filtergraph (see below)</dd> | ||||||
|             <dt><i>yadif</i></dt><dd>deinterlacing filter (‘yet another deinterlacing filter’)<br> |             <dt><i>yadif</i></dt><dd>deinterlacing filter (‘yet another deinterlacing filter’)<br> | ||||||
|               By default, <a href="https://ffmpeg.org/ffmpeg-filters.html#yadif-1" target="_blank">yadif</a> will output one frame for each frame. Outputting one frame for each <i>field</i> (thereby doubling the frame rate) with <code>yadif=1</code> may produce visually better results.</dd> |               By default, <a href="https://ffmpeg.org/ffmpeg-filters.html#yadif-1" target="_blank">yadif</a> will output one frame for each frame. Outputting one frame for each <i>field</i> (thereby doubling the frame rate) with <code>yadif=1</code> may produce visually better results.</dd> | ||||||
|             <dt><i>,</i></dt><dd>separates filters</dd> |             <dt><i>,</i></dt><dd>separates filters</dd> | ||||||
|             <dt><i>format=yuv420p</i></dt><dd>chroma subsampling set to 4:2:0<br> |             <dt><i>format=yuv420p</i></dt><dd>chroma subsampling set to 4:2:0<br> | ||||||
|               By default, <code>libx264</code> 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, therefore it's advisable to specify 4:2:0 chroma subsampling.</dd> |               By default, <code>libx264</code> 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, therefore it’s advisable to specify 4:2:0 chroma subsampling.</dd> | ||||||
|             <dt><i>"</i></dt><dd>end of filtergraph</dd> |             <dt><i>"</i></dt><dd>end of filtergraph</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> | ||||||
| @@ -534,10 +559,10 @@ | |||||||
|           <img src="./img/colourspace_metadata_mediainfo.png" alt="MediaInfo screenshots of colourspace metadata"><br> |           <img src="./img/colourspace_metadata_mediainfo.png" alt="MediaInfo screenshots of colourspace metadata"><br> | ||||||
|           <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="./index.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="./index.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> | ||||||
|           <p class="link"></p> |           <p class="link"></p> | ||||||
|         </div> |         </div> | ||||||
| @@ -546,6 +571,42 @@ | |||||||
|   </div> |   </div> | ||||||
|   <!-- ends Convert colourspace --> |   <!-- ends Convert colourspace --> | ||||||
|  |  | ||||||
|  |   <!-- Inverse telecine --> | ||||||
|  |   <span data-toggle="modal" data-target="#inverse-telecine"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Inverse telecine video">Inverse telecine</button></span> | ||||||
|  |   <div id="inverse-telecine" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|  |     <div class="modal-dialog modal-lg"> | ||||||
|  |       <div class="modal-content"> | ||||||
|  |         <div class="well"> | ||||||
|  |           <h3>Inverse telecine a video file</h3> | ||||||
|  |           <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf "fieldmatch,yadif,decimate" <i>output_file</i></code></p> | ||||||
|  |           <p>The inverse telecine procedure reverses the <a href="https://en.wikipedia.org/wiki/Three-two_pull_down">3:2 pull down</a> process, restoring 29.97fps interlaced video to the 24fps frame rate of the original film source.</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>-c:v libx264</dt><dd>encode video as H.264</dd> | ||||||
|  |             <dt>-vf "fieldmatch,yadif,decimate"</dt><dd>applies these three video filters to the input video.<br> | ||||||
|  |             <a href="https://ffmpeg.org/ffmpeg-filters.html#fieldmatch">Fieldmatch</a> is a field matching filter for inverse telecine - it reconstructs the progressive frames from a telecined stream.<br> | ||||||
|  |             <a href="https://ffmpeg.org/ffmpeg-filters.html#yadif-1">Yadif</a> (‘yet another deinterlacing filter’) deinterlaces the video. (Note that ffmpeg also includes several other deinterlacers).<br> | ||||||
|  |             <a href="https://ffmpeg.org/ffmpeg-filters.html#decimate-1">Decimate</a> deletes duplicated frames.</dd> | ||||||
|  |             <dt><i>output file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|  |           </dl> | ||||||
|  |           <p> <code>"fieldmatch,yadif,decimate"</code> is an ffmpeg <a href="https://trac.ffmpeg.org/wiki/FilteringGuide#FiltergraphChainFilterrelationship" target="_blank">filtergraph</a>. Here the filtergraph is made up of one filter chain, which is itself made up of the three filters (separated by commas).<br> | ||||||
|  |           The enclosing quote marks are necessary when you use spaces within the filtergraph, e.g. <code>-vf "fieldmatch, yadif, decimate"</code>, and are included above as an example of good practice.</p> | ||||||
|  |           <p>Note that if applying an inverse telecine procedure to a 29.97i file, the output framerate will actually be 23.976fps.</p> | ||||||
|  |           <p>This command can also be used to restore other framerates.</p> | ||||||
|  |           <div class="sample-image"> | ||||||
|  |             <h4>Example</h4> | ||||||
|  |             <p>Before and after inverse telecine:</p> | ||||||
|  |             <img src="img/ivtc_originalvideo.gif" alt="GIF of original video"> | ||||||
|  |             <img src="img/ivtc_result.gif" alt="GIF of video after inverse telecine"> | ||||||
|  |           </div> | ||||||
|  |           <p class="link"></p> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <!-- ends Inverse telecine --> | ||||||
|  |  | ||||||
|   </div> |   </div> | ||||||
|   <div class="well"> |   <div class="well"> | ||||||
|   <h4>Filters</h4> |   <h4>Filters</h4> | ||||||
| @@ -1233,7 +1294,7 @@ foreach ($file in $inputfiles) { | |||||||
|  |  | ||||||
|   </div> |   </div> | ||||||
|   <div class="well"> |   <div class="well"> | ||||||
|   <h4>Test videos</h4> |   <h4>Test files</h4> | ||||||
|  |  | ||||||
|   <!-- Mandelbrot --> |   <!-- Mandelbrot --> | ||||||
|   <span data-toggle="modal" data-target="#mandelbrot"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Make a mandelbrot test pattern video">Mandelbrot</button></span> |   <span data-toggle="modal" data-target="#mandelbrot"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Make a mandelbrot test pattern video">Mandelbrot</button></span> | ||||||
| @@ -1347,6 +1408,29 @@ foreach ($file in $inputfiles) { | |||||||
|   </div> |   </div> | ||||||
|   <!-- ends Play VGA SMPTE bars --> |   <!-- ends Play VGA SMPTE bars --> | ||||||
|  |  | ||||||
|  |   <!-- Sine wave --> | ||||||
|  |   <span data-toggle="modal" data-target="#sine_wave"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Generate a test audio file playing a sine wave">Sine wave</button></span> | ||||||
|  |   <div id="sine_wave" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|  |     <div class="modal-dialog modal-lg"> | ||||||
|  |       <div class="modal-content"> | ||||||
|  |         <div class="well"> | ||||||
|  |           <h3>Sine wave</h3> | ||||||
|  |           <p>Generate a test audio file playing a sine wave.</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> | ||||||
|  |             <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |             <dt>-f lavfi</dt><dd>tells ffmpeg to use the libavfilter input virtual device <a href="http://ffmpeg.org/ffmpeg-devices.html#lavfi" target="_blank">[more]</a></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). pcm 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> | ||||||
|  |           </dl> | ||||||
|  |           <p class="link"></p> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <!-- ends Sine wave --> | ||||||
|  |  | ||||||
|   </div> |   </div> | ||||||
|   <div class="well"> |   <div class="well"> | ||||||
|   <h4>Other</h4> |   <h4>Other</h4> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user