mirror of
				https://github.com/amiaopensource/ffmprovisr.git
				synced 2025-10-26 06:32:06 +01:00 
			
		
		
		
	Compare commits
	
		
			14 Commits
		
	
	
		
			v2019-11-0
			...
			v2019-12-2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | e4c327bbac | ||
|  | 4359d6dd4a | ||
|  | d184ed2fe9 | ||
|  | 089725a753 | ||
|  | 897f1b1616 | ||
|  | 358a2ec23b | ||
|  | de6c08a58d | ||
|  | 0d1fc1bfe8 | ||
|  | cbca3ac7ad | ||
|  | bcc425a955 | ||
|  | 0353c1761e | ||
|  | e3aa81fb95 | ||
|  | 633374f22d | ||
|  | 1d60060eed | 
							
								
								
									
										43
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								index.html
									
									
									
									
									
								
							| @@ -2,7 +2,8 @@ | |||||||
| <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" content="text/html, width=device-width, initial-scale=1"> | ||||||
|  |   <meta charset="utf-8"> | ||||||
|   <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> | ||||||
| @@ -18,7 +19,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> |     <div id="toggle-expand-collapse-all" class="contents-list">Expand/collapse 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> | ||||||
| @@ -218,6 +219,36 @@ | |||||||
|     </div> |     </div> | ||||||
|     <!-- End Basic rewrap command --> |     <!-- End Basic rewrap command --> | ||||||
|  |  | ||||||
|  |     <!-- BWF --> | ||||||
|  |     <label class="recipe" for="bwf">Convert to (or create) Broadcast WAV</label> | ||||||
|  |     <input type="checkbox" id="bwf"> | ||||||
|  |     <div class="hiding"> | ||||||
|  |       <h5>Generate Broadcast WAV</h5> | ||||||
|  |       <p><code>ffmpeg -i <em>input_file.wav</em> -c copy -write_bext 1 -metadata field_name='Content' <em>output_file.wav</em></code></p> | ||||||
|  |       <p>This command will write a file in the Broadcast Wave Format (BWF) containing a BEXT chunk with related metadata.</p> | ||||||
|  |       <dl> | ||||||
|  |         <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |         <dt>-i <em>input_file.wav</em></dt><dd>path and name of the input file</dd> | ||||||
|  |         <dt>-c copy</dt><dd>this will copy the encoding/sample rate etc from the input. If not using a WAV as the input file you will have to specify codec settings in place of this.</dd> | ||||||
|  |         <dt>-write_bext 1</dt><dd>tells FFmpeg to write a BEXT chunk, the part of the file where BWF metadata is stored.</dd> | ||||||
|  |         <dt>-metadata field_name='Content'</dt><dd>This is where you can specify which BEXT fields to write, and what information to fill them with by replacing <code>field_name</code> and <code>'Content'</code> respectively. See below for additional details.</dd> | ||||||
|  |       </dl> | ||||||
|  |       <p>Notes: You can choose which fields to write by repeating <code>-metadata field_name='Content'</code> for each desired field. Flags for commonly used fields (such as those recommended by the <a href="http://www.digitizationguidelines.gov/audio-visual/documents/Embed_Guideline_20120423.pdf">FADGI guidelines</a>) are as follows:</p> | ||||||
|  |       <ul> | ||||||
|  |         <li>description</li> | ||||||
|  |         <li>originator</li> | ||||||
|  |         <li>originator_reference</li> | ||||||
|  |         <li>origination_date</li> | ||||||
|  |         <li>origination_time</li> | ||||||
|  |         <li>coding_history</li> | ||||||
|  |         <li>IARL</li> | ||||||
|  |       </ul> | ||||||
|  |       <p>Example: <code>-metadata originator='US, UW Libraries'</code></p> | ||||||
|  |       <p>Additionally, users should be aware that BWF metadata fields are limited by characters, with some such as OriginatorReference maxing out at 32. Specific information can be found in the <a href="https://tech.ebu.ch/docs/tech/tech3285.pdf">Broadcast Wave Format specification</a>. Additional examples of BWF metadata usage can be found in the <a href="http://www.dlib.indiana.edu/projects/sounddirections/papersPresent/sd_bp_07.pdf">Sound Directions report</a> by Indiana University and Harvard.</p> | ||||||
|  |       <p class="link"></p> | ||||||
|  |     </div> | ||||||
|  |     <!-- ends BWF --> | ||||||
|  |  | ||||||
|     <!-- Rewrap DV --> |     <!-- Rewrap DV --> | ||||||
|     <label class="recipe" for="rewrap-dv">Rewrap DV video to .dv file</label> |     <label class="recipe" for="rewrap-dv">Rewrap DV video to .dv file</label> | ||||||
|     <input type="checkbox" id="rewrap-dv"> |     <input type="checkbox" id="rewrap-dv"> | ||||||
| @@ -773,13 +804,13 @@ | |||||||
|       <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>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 <em>input_file</em> -vf "crop=<em>width</em>:<em>height</em>[:<em>x_position</em>:<em>y_position</em>]" <em>output_file</em></code></p> |       <p><code>ffmpeg -i <em>input_file</em> -vf "crop=<em>width</em>:<em>height</em>[:<em>x_position</em>:<em>y_position</em>]" <em>output_file</em></code></p> | ||||||
|       <h5>Examples</h5> |       <h5>Examples</h5> | ||||||
|       <p>The original frame, a screenshot of the SMPTE colorbars:</p> |       <p>The original frame, a screenshot of Maggie Cheung in the film <i>Hero</i>:</p> | ||||||
|       <img class="sample-image" src="img/crop_example_orig.png" alt="VLC screenshot of Maggie Cheung"> |       <img class="sample-image" src="img/crop_example_orig.png" alt="VLC screenshot of Maggie Cheung"> | ||||||
|       <p>Result of the command <code>ffmpeg -i <em>smpte_colorsbars.mov</em> -vf "crop=500:500" <em>output_file</em></code>:</p> |       <p>Result of the command <code>ffmpeg -i <em>maggie.mov</em> -vf "crop=500:500" <em>output_file</em></code>:</p> | ||||||
|       <img class="sample-image-small" src="img/crop_example_aftercrop1.png" alt="VLC screenshot of Maggie Cheung, cropped from original"> |       <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 <em>smpte_colorsbars.mov</em> -vf "crop=500:500:0:0" <em>output_file</em></code>, appending <code>:0:0</code> to crop from the top left corner:</p> |       <p>Result of the command <code>ffmpeg -i <em>maggie.mov</em> -vf "crop=500:500:0:0" <em>output_file</em></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"> |       <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 <em>smpte_colousbars.mov</em> -vf "crop=500:300:500:30" <em>output_file</em></code>:</p> |       <p>Result of the command <code>ffmpeg -i <em>maggie.mov</em> -vf "crop=500:300:500:30" <em>output_file</em></code>:</p> | ||||||
|       <img class="sample-image-small" src="img/crop_example_aftercrop3.png" alt="VLC screenshot of Maggie Cheung, cropped from original"> |       <img class="sample-image-small" src="img/crop_example_aftercrop3.png" alt="VLC screenshot of Maggie Cheung, cropped from original"> | ||||||
|       <p class="link"></p> |       <p class="link"></p> | ||||||
|     </div> |     </div> | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								js/js.js
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								js/js.js
									
									
									
									
									
								
							| @@ -32,11 +32,21 @@ $(document).ready(function() { | |||||||
|     } |     } | ||||||
|   }) |   }) | ||||||
|  |  | ||||||
|   // open all windows if button is clicked |   // Collapse all recipes when button is clicked | ||||||
|   $('#open-all').on("click", function(){ |   $('#toggle-expand-collapse-all').on("click", function(){ | ||||||
|     $('input[type=checkbox]').each(function(){ |     var checkboxes = $('input[type=checkbox]'); | ||||||
|       this.checked = !this.checked; |     var anyRecipesOpen = $(checkboxes).is(':checked'); | ||||||
|     }) |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|  |     if (anyRecipesOpen) { | ||||||
|  |       // Collapse all | ||||||
|  |       $('input[type=checkbox]').each(function() { | ||||||
|  |         this.checked = false; | ||||||
|  |       }); | ||||||
|  |     } else new Promise(function(resolve, reject) { | ||||||
|  |       // Expand all | ||||||
|  |       $('input[type=checkbox]').each(function() { | ||||||
|  |         this.checked = true; | ||||||
|  |       }); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										24
									
								
								readme.md
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								readme.md
									
									
									
									
									
								
							| @@ -83,31 +83,36 @@ You can read our contributor code of conduct [here](https://github.com/amiaopens | |||||||
|    |    | ||||||
| *Code Contributors*:   | *Code Contributors*:   | ||||||
| ablwr (Ashley)   | ablwr (Ashley)   | ||||||
|  | alavigne12 (A. Lavigne)   | ||||||
|  | Anushka-codergirl (Anushka Raj)   | ||||||
| bastibeckr (Basti Becker)   | bastibeckr (Basti Becker)   | ||||||
| b00giehead (Joanna White)   |  | ||||||
| bturkus   | bturkus   | ||||||
| dericed (Dave Rice)   | dericed (Dave Rice)   | ||||||
|  | digitensions (Joanna White)   | ||||||
| edsu (Ed Summers)   | edsu (Ed Summers)   | ||||||
| jamessam (Jim Sam)   | jamessam (Jim Sam)   | ||||||
| jfarbowitz (Jonathan Farbowitz)   | jfarbowitz (Jonathan Farbowitz)   | ||||||
| kfrn (Katherine Frances Nagels)   | kfrn (Katherine Frances Nagels)   | ||||||
| kgrons (Kathryn Gronsbell)   | kgrons (Kathryn Gronsbell)   | ||||||
| kieranjol (Kieran O'Leary)   | kieranjol (Kieran O'Leary)   | ||||||
| llogan (Lou)   | llogan (Lou Logan)   | ||||||
|  | macasaurusrex (Maura)   | ||||||
| mgiraldo (Mauricio Giraldo)   | mgiraldo (Mauricio Giraldo)   | ||||||
| pjotrek-b (Peter B.)   | 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)   | ||||||
|  | alavigne12 (A. Lavigne)   | ||||||
|  | Anushka-codergirl (Anushka Raj)   | ||||||
| audiovisualopen   | audiovisualopen   | ||||||
| bastibeckr (Basti Becker)   | bastibeckr (Basti Becker)   | ||||||
| b00giehead (Joanna White)   |  | ||||||
| brainwane (Sumana Harihareswara)   | brainwane (Sumana Harihareswara)   | ||||||
| bturkus   | bturkus   | ||||||
| dericed (Dave Rice)   | dericed (Dave Rice)   | ||||||
|  | digitensions (Joanna White)   | ||||||
| drodz11 (Dave Rodriguez)   | drodz11 (Dave Rodriguez)   | ||||||
| edsu (Ed Summers)   | edsu (Ed Summers)   | ||||||
| EG-tech (Ethan Gates)   | EG-tech (Ethan Gates)   | ||||||
| @@ -122,7 +127,9 @@ kellyhaydon (metacynic) | |||||||
| kfrn (Katherine Frances Nagels)   | kfrn (Katherine Frances Nagels)   | ||||||
| kgrons (Kathryn Gronsbell)   | kgrons (Kathryn Gronsbell)   | ||||||
| kieranjol (Kieran O'Leary)   | kieranjol (Kieran O'Leary)   | ||||||
| llogan (Lou)   | llogan (Lou Logan)   | ||||||
|  | macasaurusrex (Maura)   | ||||||
|  | mercuryswitch   | ||||||
| mgiraldo (Mauricio Giraldo)   | mgiraldo (Mauricio Giraldo)   | ||||||
| mulvya   | mulvya   | ||||||
| nkrabben (Nick Krabbenhoeft)   | nkrabben (Nick Krabbenhoeft)   | ||||||
| @@ -132,12 +139,13 @@ retokromer (Reto Kromer) | |||||||
| rfraimow   | rfraimow   | ||||||
| richardpl (Paul B Mahol)   | richardpl (Paul B Mahol)   | ||||||
| ross-spencer (Ross Spencer)   | ross-spencer (Ross Spencer)   | ||||||
|  | taschenbach (Tommy Aschenbach)   | ||||||
| todrobbins (Tod Robbins)   | todrobbins (Tod Robbins)   | ||||||
|    |    | ||||||
| Repo: amiaopensource/ffmprovisr   | Repo: amiaopensource/ffmprovisr   | ||||||
| Code Contributors: 17   | GitHub Contributors: 20   | ||||||
| All Contributors: 32    | All Contributors: 37   | ||||||
| Last updated: 2019-02-11   | Last updated: 2019-12-11  | ||||||
|  |  | ||||||
| ## AVHack Team | ## AVHack Team | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user