mirror of
				https://github.com/amiaopensource/ffmprovisr.git
				synced 2025-10-25 23:20:54 +02:00 
			
		
		
		
	Compare commits
	
		
			18 Commits
		
	
	
		
			v2018-04-1
			...
			v2018-04-2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | f2ec08fd59 | ||
|  | 32004553a6 | ||
|  | a67b7cc879 | ||
|  | b9da657b19 | ||
|  | 91e929dab4 | ||
|  | 21e5561dc9 | ||
|  | 36deb1ea62 | ||
|  | 89139311f4 | ||
|  | fb6581a50e | ||
|  | 5bdd6f8d8a | ||
|  | 3b7ce0e79f | ||
|  | b9b7e0fef9 | ||
|  | 95e90bb26b | ||
|  | d70a1de6e1 | ||
|  | 8417883004 | ||
|  | 937b9ae525 | ||
|  | d46138a81b | ||
|  | e6317731c9 | 
| @@ -1,6 +1,7 @@ | |||||||
| html, body { | html, body { | ||||||
|   line-height: 1.5; |   line-height: 1.5; | ||||||
|   font-size: 16px; |   font-size: 18px; | ||||||
|  |   font-family: sans-serif; | ||||||
|   color: #888888; |   color: #888888; | ||||||
|   background-color: #060606; |   background-color: #060606; | ||||||
|   margin: 0; |   margin: 0; | ||||||
| @@ -88,9 +89,6 @@ a:visited { | |||||||
|   display: inline; |   display: inline; | ||||||
| } | } | ||||||
|  |  | ||||||
| h1, h2, h3, h4, h5, h6 { |  | ||||||
|   font-family: 'Montserrat', sans-serif; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| h1 { | h1 { | ||||||
|   letter-spacing: 0.1em; |   letter-spacing: 0.1em; | ||||||
| @@ -116,7 +114,6 @@ h4 { | |||||||
| } | } | ||||||
|  |  | ||||||
| .intro-lead { | .intro-lead { | ||||||
|   font-family: 'Montserrat', sans-serif; |  | ||||||
|   font-size: 1em; |   font-size: 1em; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -165,7 +162,6 @@ img { | |||||||
| } | } | ||||||
|  |  | ||||||
| div { | div { | ||||||
|   font-family: 'Merriweather', serif; |  | ||||||
|   color: white; |   color: white; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -177,7 +173,6 @@ div { | |||||||
|   color: white; |   color: white; | ||||||
|   background-color: #383838; |   background-color: #383838; | ||||||
|   padding: 14px; |   padding: 14px; | ||||||
|   font-family: "Montserrat"; |  | ||||||
|   letter-spacing: 0.05em; |   letter-spacing: 0.05em; | ||||||
|   border: 1px solid black; |   border: 1px solid black; | ||||||
|   cursor: pointer; |   cursor: pointer; | ||||||
|   | |||||||
							
								
								
									
										62
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								index.html
									
									
									
									
									
								
							| @@ -3,7 +3,6 @@ | |||||||
| <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 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> | ||||||
| @@ -19,6 +18,7 @@ | |||||||
|   <nav class="sidebar well"> |   <nav class="sidebar well"> | ||||||
|     <h2 class="heading">Table of Contents</h2> |     <h2 class="heading">Table of Contents</h2> | ||||||
|     <a href="#about"><div class="contents-list">About this resource</div></a> |     <a href="#about"><div class="contents-list">About this resource</div></a> | ||||||
|  |     <div id="open-all" class="contents-list">Show/hide all recipes</div> | ||||||
|     <a href="#basics"><div class="contents-list">FFmpeg basics</div></a> |     <a href="#basics"><div class="contents-list">FFmpeg basics</div></a> | ||||||
|     <a href="#concepts"><div class="contents-list">Advanced FFmpeg concepts</div></a> |     <a href="#concepts"><div class="contents-list">Advanced FFmpeg concepts</div></a> | ||||||
|     <a href="#rewrap"><div class="contents-list">Change container (rewrap)</div></a> |     <a href="#rewrap"><div class="contents-list">Change container (rewrap)</div></a> | ||||||
| @@ -47,6 +47,7 @@ | |||||||
|       <span class="intro-lead">Making FFmpeg Easier</span> |       <span class="intro-lead">Making FFmpeg Easier</span> | ||||||
|       <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> | ||||||
|  |       <p>This page does not have search functionality, but you can open all recipes (second option in the sidebar) and use your browser's search tool (often ctrl+f or cmd+f) to perform a keyword search through all recipes.</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://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> | ||||||
| @@ -221,7 +222,7 @@ | |||||||
|       <p>This script will take a video that is encoded in the <a href="https://en.wikipedia.org/wiki/DV">DV Codec</a> but wrapped in a different container (such as MOV) and rewrap it into a raw DV file (with the .dv extension). Since DV files potentially contain a great deal of provenance metadata within the DV stream, it is necessary to rewrap files in this method to avoid unintentional stripping of this metadata.</p> |       <p>This script will take a video that is encoded in the <a href="https://en.wikipedia.org/wiki/DV">DV Codec</a> but wrapped in a different container (such as MOV) and rewrap it into a raw DV file (with the .dv extension). Since DV files potentially contain a great deal of provenance metadata within the DV stream, it is necessary to rewrap files in this method to avoid unintentional stripping of this metadata.</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 and name of the input file</dd> |         <dt>-i <i>input_file</i></dt><dd>path and name of the input file</dd> | ||||||
|         <dt>-f rawvideo</dt><dd>this tells FFmpeg to pass the video stream as raw video data without remuxing. This step is what ensures the survival of embedded metadata versus a standard rewrap.</dd> |         <dt>-f rawvideo</dt><dd>this tells FFmpeg to pass the video stream as raw video data without remuxing. This step is what ensures the survival of embedded metadata versus a standard rewrap.</dd> | ||||||
|         <dt>-c:v copy</dt><dd>copy the DV stream directly, without re-encoding.</dd> |         <dt>-c:v copy</dt><dd>copy the DV stream directly, without re-encoding.</dd> | ||||||
|         <dt><i>output_file.dv</i></dt><dd>tells FFmpeg to use the DV wrapper for the output.</dd> |         <dt><i>output_file.dv</i></dt><dd>tells FFmpeg to use the DV wrapper for the output.</dd> | ||||||
| @@ -260,7 +261,7 @@ | |||||||
|       <p>FFmpeg comes with more than one ProRes encoder:</p> |       <p>FFmpeg comes with more than one ProRes encoder:</p> | ||||||
|       <ul> |       <ul> | ||||||
|         <li><code>prores</code> is much faster, can be used for progressive video only, and seems to be better for video according to Rec. 601 (Recommendation ITU-R BT.601).</li> |         <li><code>prores</code> is much faster, can be used for progressive video only, and seems to be better for video according to Rec. 601 (Recommendation ITU-R BT.601).</li> | ||||||
|         <li><code>prores_ks</code> generates a better file, can also be used for interlaced video, allows also encoding of ProRes 4444 (<code>-c:v prores_ks -profile:v 4</code>), and seems to be better for video according to Rec. 709 (Recommendation ITU-R BT.709).</li> |         <li><code>prores_ks</code> generates a better file, can also be used for interlaced video, allows also encoding of ProRes 4444 (<code>-c:v prores_ks -profile:v 4</code>) and ProRes 4444 XQ (<code>-c:v prores_ks -profile:v 5</code>), and seems to be better for video according to Rec. 709 (Recommendation ITU-R BT.709).</li> | ||||||
|       </ul> |       </ul> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
| @@ -1709,6 +1710,42 @@ | |||||||
|     </div> |     </div> | ||||||
|     <!-- ends batch processing (Windows) --> |     <!-- ends batch processing (Windows) --> | ||||||
|  |  | ||||||
|  |     <!-- Check decoder errors --> | ||||||
|  |     <label class="recipe" for="check_decoder_errors">Check decoder errors</label> | ||||||
|  |     <input type="checkbox" id="check_decoder_errors"> | ||||||
|  |     <div class="hiding"> | ||||||
|  |       <h3>Check decoder errors</h3> | ||||||
|  |       <p><code>ffmpeg -i <i>input_file</i> -f null -</code></p> | ||||||
|  |       <p>This decodes your video and prints any errors or found issues to the screen.</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>-f null</dt><dd>Video is decoded with the <code>null</code> muxer. This allows video decoding without creating an output file.</dd> | ||||||
|  |         <dt>-</dt><dd>FFmpeg syntax requires a specified output, and <code>-</code> is just a place holder. No file is actually created.</dd> | ||||||
|  |       </dl> | ||||||
|  |       <p class="link"></p> | ||||||
|  |     </div> | ||||||
|  |     <!-- ends Check decoder errors --> | ||||||
|  |  | ||||||
|  |     <!-- Check FFV1 fixity --> | ||||||
|  |     <label class="recipe" for="check_FFV1_fixity">Check FFV1 fixity</label> | ||||||
|  |     <input type="checkbox" id="check_FFV1_fixity"> | ||||||
|  |     <div class="hiding"> | ||||||
|  |       <h3>Check FFV1 Version 3 fixity</h3> | ||||||
|  |       <p><code>ffmpeg -report -i <i>input_file</i> -f null -</code></p> | ||||||
|  |       <p>This decodes your video and displays any CRC checksum mismatches. These errors will display in your terminal like this: <code>[ffv1 @ 0x1b04660] CRC mismatch 350FBD8A!at 0.272000 seconds</code></p> | ||||||
|  |       <p>Frame CRCs are enabled by default in FFV1 Version 3.</p> | ||||||
|  |       <dl> | ||||||
|  |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |         <dt>-report</dt><dd>Dump full command line and console output to a file named <i>ffmpeg-YYYYMMDD-HHMMSS.log</i> in the current directory. It also implies <code>-loglevel verbose</code>.</dd> | ||||||
|  |         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|  |         <dt>-f null</dt><dd>Video is decoded with the <code>null</code> muxer. This allows video decoding without creating an output file.</dd> | ||||||
|  |         <dt>-</dt><dd>FFmpeg syntax requires a specified output, and <code>-</code> is just a place holder. No file is actually created.</dd> | ||||||
|  |       </dl> | ||||||
|  |       <p class="link"></p> | ||||||
|  |     </div> | ||||||
|  |     <!-- ends Check FFV1 Fixity --> | ||||||
|  |  | ||||||
|     <!-- Create frame md5s --> |     <!-- Create frame md5s --> | ||||||
|     <label class="recipe" for="create_frame_md5s_v">Create MD5 checksums (video frames)</label> |     <label class="recipe" for="create_frame_md5s_v">Create MD5 checksums (video frames)</label> | ||||||
|     <input type="checkbox" id="create_frame_md5s_v"> |     <input type="checkbox" id="create_frame_md5s_v"> | ||||||
| @@ -1827,25 +1864,6 @@ | |||||||
|     </div> |     </div> | ||||||
|     <!-- ends QCTools Report (no audio) --> |     <!-- ends QCTools Report (no audio) --> | ||||||
|  |  | ||||||
|     <!-- Check FFV1 fixity --> |  | ||||||
|     <label class="recipe" for="check_FFV1_fixity">Check FFV1 fixity</label> |  | ||||||
|     <input type="checkbox" id="check_FFV1_fixity"> |  | ||||||
|     <div class="hiding"> |  | ||||||
|       <h3>Check FFV1 Version 3 fixity</h3> |  | ||||||
|       <p><code>ffmpeg -report -i <i>input_file</i> -f null -</code></p> |  | ||||||
|       <p>This decodes your video and displays any CRC checksum mismatches. These errors will display in your terminal like this: <code>[ffv1 @ 0x1b04660] CRC mismatch 350FBD8A!at 0.272000 seconds</code></p> |  | ||||||
|       <p>Frame CRCs are enabled by default in FFV1 Version 3.</p> |  | ||||||
|       <dl> |  | ||||||
|         <dt>ffmpeg</dt><dd>starts the command</dd> |  | ||||||
|         <dt>-report</dt><dd>Dump full command line and console output to a file named <i>ffmpeg-YYYYMMDD-HHMMSS.log</i> in the current directory. It also implies <code>-loglevel verbose</code>.</dd> |  | ||||||
|         <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |  | ||||||
|         <dt>-f null</dt><dd>Video is decoded with the <code>null</code> muxer. This allows video decoding without creating an output file.</dd> |  | ||||||
|         <dt>-</dt><dd>FFmpeg syntax requires a specified output, and <code>-</code> is just a place holder. No file is actually created. </dd> |  | ||||||
|       </dl> |  | ||||||
|       <p class="link"></p> |  | ||||||
|     </div> |  | ||||||
|     <!-- 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> | ||||||
|     <input type="checkbox" id="readeia608"> |     <input type="checkbox" id="readeia608"> | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								js/js.js
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								js/js.js
									
									
									
									
									
								
							| @@ -18,4 +18,10 @@ $(document).ready(function() { | |||||||
|     $('#' + 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>"); |     $('#' + 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>"); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   $('#open-all').on("click", function(){ | ||||||
|  |     $('input[type=checkbox]').each(function(){ | ||||||
|  |       this.checked = !this.checked; | ||||||
|  |     }) | ||||||
|  |   }); | ||||||
|  |  | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										25
									
								
								readme.md
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								readme.md
									
									
									
									
									
								
							| @@ -49,10 +49,13 @@ You can read our contributor code of conduct [here](https://github.com/amiaopens | |||||||
| ## Contributors | ## Contributors | ||||||
| * Gathered using [octohatrack](https://github.com/LABHR/octohatrack) | * Gathered using [octohatrack](https://github.com/LABHR/octohatrack) | ||||||
|  |  | ||||||
| *GitHub Contributors*:   | *Code Contributors*: | ||||||
| ablwr (Ashley)   | ablwr (Ashley)   | ||||||
|  | bastibeckr (Basti Becker)   | ||||||
|  | bturkus   | ||||||
| dericed (Dave Rice)   | dericed (Dave Rice)   | ||||||
| edsu (Ed Summers)   | edsu (Ed Summers)   | ||||||
|  | jamessam (Jim Sam)   | ||||||
| jfarbowitz (Jonathan Farbowitz)   | jfarbowitz (Jonathan Farbowitz)   | ||||||
| kfrn (Katherine Frances Nagels)   | kfrn (Katherine Frances Nagels)   | ||||||
| kgrons (Kathryn Gronsbell)   | kgrons (Kathryn Gronsbell)   | ||||||
| @@ -62,17 +65,23 @@ pjotrek-b (Peter B.) | |||||||
| privatezero (Andrew Weaver)   | privatezero (Andrew Weaver)   | ||||||
| retokromer (Reto Kromer)   | retokromer (Reto Kromer)   | ||||||
| rfraimow   | rfraimow   | ||||||
|    |  | ||||||
| *All Contributors*:   | *All Contributors*: | ||||||
| ablwr (Ashley)   | ablwr (Ashley)   | ||||||
| audiovisualopen   | audiovisualopen   | ||||||
|  | bastibeckr (Basti Becker)   | ||||||
| brainwane (Sumana Harihareswara)   | brainwane (Sumana Harihareswara)   | ||||||
| bturkus   | bturkus   | ||||||
| dericed (Dave Rice)   | dericed (Dave Rice)   | ||||||
|  | drodz11 (Dave Rodriguez)   | ||||||
| edsu (Ed Summers)   | edsu (Ed Summers)   | ||||||
|  | EG-tech (Ethan Gates)   | ||||||
|  | federicomenaquintero (Federico Mena Quintero)   | ||||||
| Fizz24   | Fizz24   | ||||||
|  | GregH18   | ||||||
| jamessam (Jim Sam)   | jamessam (Jim Sam)   | ||||||
| jfarbowitz (Jonathan Farbowitz)   | jfarbowitz (Jonathan Farbowitz)   | ||||||
|  | JonnyTech   | ||||||
| jronallo (Jason Ronallo)   | jronallo (Jason Ronallo)   | ||||||
| kellyhaydon (metacynic)   | kellyhaydon (metacynic)   | ||||||
| kfrn (Katherine Frances Nagels)   | kfrn (Katherine Frances Nagels)   | ||||||
| @@ -80,16 +89,19 @@ kgrons (Kathryn Gronsbell) | |||||||
| kieranjol (Kieran O'Leary)   | kieranjol (Kieran O'Leary)   | ||||||
| llogan (Lou)   | llogan (Lou)   | ||||||
| mulvya   | mulvya   | ||||||
|  | nkrabben (Nick Krabbenhoeft)   | ||||||
| pjotrek-b (Peter B.)   | pjotrek-b (Peter B.)   | ||||||
| privatezero (Andrew Weaver)   | privatezero (Andrew Weaver)   | ||||||
| retokromer (Reto Kromer)   | retokromer (Reto Kromer)   | ||||||
| rfraimow   | rfraimow   | ||||||
| richardpl (Paul B Mahol)   | richardpl (Paul B Mahol)   | ||||||
|  | ross-spencer (Ross Spencer)   | ||||||
| todrobbins (Tod Robbins)   | todrobbins (Tod Robbins)   | ||||||
|    |  | ||||||
| Repo: amiaopensource/ffmprovisr   | Repo: amiaopensource/ffmprovisr   | ||||||
| GitHub Contributors: 12   | Code Contributors: 15   | ||||||
| All Contributors: 22   | All Contributors: 30    | ||||||
|  | Last updated: 2018-04-22 (4:2:2 Day)   | ||||||
|  |  | ||||||
| ## AVHack Team | ## AVHack Team | ||||||
|  |  | ||||||
| @@ -99,6 +111,7 @@ All Contributors: 22 | |||||||
|  |  | ||||||
| ## Sister projects | ## Sister projects | ||||||
|  |  | ||||||
|  | [The Cable Bible](https://amiaopensource.github.io/cable-bible/): A Guide to Cables and Connectors Used for Audiovisual Tech   | ||||||
| [Script Ahoy](http://dd388.github.io/crals/): Community Resource for Archivists and Librarians Scripting   | [Script Ahoy](http://dd388.github.io/crals/): Community Resource for Archivists and Librarians Scripting   | ||||||
| [sourcecaster](https://datapraxis.github.io/sourcecaster/): helps you use the command line to work through common challenges that come up when working with digital primary sources. | [sourcecaster](https://datapraxis.github.io/sourcecaster/): helps you use the command line to work through common challenges that come up when working with digital primary sources. | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user