mirror of
				https://github.com/amiaopensource/ffmprovisr.git
				synced 2025-10-26 06:32:06 +01:00 
			
		
		
		
	Compare commits
	
		
			8 Commits
		
	
	
		
			v2017-12-0
			...
			v2017-12-1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 1fec9b21c8 | ||
|  | 42189e5b94 | ||
|  | 929f92a52a | ||
|  | 02e2f11718 | ||
|  | 10636e24e2 | ||
|  | 61b890d31c | ||
|  | 85a79d2eb5 | ||
|  | b5ec56174a | 
							
								
								
									
										104
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										104
									
								
								index.html
									
									
									
									
									
								
							| @@ -113,7 +113,7 @@ | ||||
|       <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>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> | ||||
|           <li><code>-vf fieldmatch,yadif,decimate</code></li> | ||||
|           <li><code>-vf "fieldmatch,yadif,decimate"</code></li> | ||||
| @@ -256,7 +256,7 @@ | ||||
|         <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>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><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||
|       </dl> | ||||
| @@ -319,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>-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>-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><i>framemd5_output_file</i></dt><dd>path, name and extension of the framemd5 file.</dd> | ||||
|       </dl> | ||||
| @@ -742,7 +742,7 @@ | ||||
|       <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>-filter_complex </dt><dd>tells fmpeg that we will be using a complex filter</dd> | ||||
|         <dt>-filter_complex</dt><dd>tells fmpeg that we will be using a complex filter</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>"</dt><dd>quotation mark to end filtergraph</dd> | ||||
| @@ -754,7 +754,7 @@ | ||||
|       </dl> | ||||
|       <p class="link"></p> | ||||
|     </div> | ||||
|     <!-- ends Combine audio tracks  --> | ||||
|     <!-- ends Combine audio tracks --> | ||||
|  | ||||
|     <!-- phase shift --> | ||||
|     <label class="recipe" for="phase_shift">Inverses the audio phase of the second channel</label> | ||||
| @@ -1166,12 +1166,12 @@ | ||||
|         <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: | ||||
|         <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>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>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>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>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>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>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> | ||||
|         </dl> | ||||
|         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> | ||||
| @@ -1208,14 +1208,14 @@ | ||||
|         <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>"</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>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>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>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>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>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>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>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>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>"</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> | ||||
|       </dl> | ||||
| @@ -1224,6 +1224,25 @@ | ||||
|     </div> | ||||
|     <!-- 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 class="well"> | ||||
|     <h2 id="create-images">Create thumbnails or GIFs</h2> | ||||
| @@ -1530,10 +1549,11 @@ | ||||
|         <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_metadata -1</dt><dd>sets metadata copying to -1, which copies nothing</dd> | ||||
|         <dt>-vcodec copy</dt><dd>copies video track</dd> | ||||
|         <dt>-acodec copy</dt><dd>copies audio track</dd> | ||||
|         <dt>-c:v copy</dt><dd>copies video 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> | ||||
|       </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> | ||||
|     </div> | ||||
|     <!-- ends Strip metadata --> | ||||
| @@ -1718,7 +1738,7 @@ | ||||
|       </dl> | ||||
|       <p class="link"></p> | ||||
|     </div> | ||||
|     <!-- ends Check FFV1 Fixity  --> | ||||
|     <!-- ends Check FFV1 Fixity --> | ||||
|  | ||||
|     <!-- Read/Extract EIA-608 Closed Captions --> | ||||
|     <label class="recipe" for="readeia608">Read/Extract EIA-608 Closed Captioning</label> | ||||
| @@ -2153,26 +2173,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> | ||||
|         </ol> | ||||
|         <dl> | ||||
|            <dt>ffmpeg </dt><dd>starts the command</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>-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>-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>-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>-crf 26 </dt><dd>Constant rate factor - basically the quality</dd> | ||||
|            <dt>-g 50 </dt><dd>GOP size.</dd> | ||||
|            <dt>-bufsize 3500k </dt><dd>Ratecontrol buffer size (~ maxrate x2)</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:a aac </dt><dd>encode output audio stream as AAC</dd> | ||||
|            <dt>-b:a 128000 </dt><dd>The audio bitrate</dd> | ||||
|            <dt>-r:a 44100 </dt><dd>The audio samplerate</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>-f tee </dt><dd>Use multiple outputs. Outputs defined below.</dd> | ||||
|            <dt>ffmpeg</dt><dd>starts the command</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>-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>-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>-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>-crf 26</dt><dd>Constant rate factor - basically the quality</dd> | ||||
|            <dt>-g 50</dt><dd>GOP size.</dd> | ||||
|            <dt>-bufsize 3500k</dt><dd>Ratecontrol buffer size (~ maxrate x2)</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:a aac</dt><dd>encode output audio stream as AAC</dd> | ||||
|            <dt>-b:a 128000</dt><dd>The audio bitrate</dd> | ||||
|            <dt>-r:a 44100</dt><dd>The audio samplerate</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>-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> | ||||
|         </dl> | ||||
|         <p class="link"></p> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user