mirror of
https://github.com/amiaopensource/ffmprovisr.git
synced 2025-01-26 18:05:24 +01:00
Move 'Record and Live-Stream simultaneously' to 'Other' section
It's not an ideal home for it, but I think it doesn't really belong in the 'Advanced concepts' section, being a command rather than a concept. I've also made a few small edits to the text of the command.
This commit is contained in:
parent
3555a692dc
commit
f427a05c89
81
index.html
81
index.html
@ -125,47 +125,6 @@
|
|||||||
</div>
|
</div>
|
||||||
<!-- End Filtergraph explanation -->
|
<!-- End Filtergraph explanation -->
|
||||||
|
|
||||||
<!-- Record and Live-Stream simultaneously -->
|
|
||||||
<span data-toggle="collapse" data-target="#record-and-stream"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Record and Live-Stream simultaneously">Record and Live-Stream simultaneously</button></span>
|
|
||||||
<div id="record-and-stream" class="collapse">
|
|
||||||
<h3>Record and Live-Stream simultaneously</h3>
|
|
||||||
<p class="link"></p>
|
|
||||||
<p><code>ffmpeg -re -i <i>${INPUTFILE}</i> -map 0 -flags +global_header -vf scale="1280:-1,format=yuv420p" -pix_fmt yuv420p -level 3.1 -vsync passthrough -crf 26 -g 50 -bufsize 3500k -maxrate 1800k -c:v libx264 -c:a aac -b:a 128000 -r:a 44100 -ac 2 -t ${STREAMDURATION} -f tee <i>"[movflags=+faststart]${TARGETFILE}|[f=flv]${STREAMTARGET}"</i></code></p>
|
|
||||||
<p>I use this script to stream to a RTMP target and record the stream locally as .mp4 with only one ffmpeg-instance.</p>
|
|
||||||
<p>As input, I use <code>bmdcapture</code> which is piped to ffmpeg. But it can also be used with a static videofile as input.</p>
|
|
||||||
<p>The input will be scaled to 1280px width, maintaining height. Also the stream will stop after a given time (see <code>-t</code> option.)</p>
|
|
||||||
<h4>Notes</h4>
|
|
||||||
<ol>
|
|
||||||
<li>I recommend to use this inside a shell script. then you can define the variables <code>${INPUTFILE}</code>, <code>${STREAMDURATION}</code>, <code>${TARGETFILE}</code>, <code>${STREAMTARGET}</code>.</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>
|
|
||||||
<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 420p 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 using H.264</dd>
|
|
||||||
<dt>-c:a aac </dt><dd>encode output audio stream using 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 output divided by pipe (|). First is local file. Second is Live Stream. Options for each target in square brackets before the target.</dd>
|
|
||||||
</dl>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
<!-- END Record and Live-Stream at the same time -->
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="well">
|
<div class="well">
|
||||||
<h2 id="rewrap">Change container (rewrap)</h2>
|
<h2 id="rewrap">Change container (rewrap)</h2>
|
||||||
@ -1992,6 +1951,46 @@ ffmpeg -i $file -map 0 -c copy $output
|
|||||||
</div>
|
</div>
|
||||||
<!-- ends Cover head switching noise -->
|
<!-- ends Cover head switching noise -->
|
||||||
|
|
||||||
|
<!-- Record and live-stream simultaneously -->
|
||||||
|
<span data-toggle="collapse" data-target="#record-and-stream"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Record and live-stream simultaneously">Record and live-stream simultaneously</button></span>
|
||||||
|
<div id="record-and-stream" class="collapse">
|
||||||
|
<h3>Record and live-stream simultaneously</h3>
|
||||||
|
<p class="link"></p>
|
||||||
|
<p><code>ffmpeg -re -i <i>${INPUTFILE}</i> -map 0 -flags +global_header -vf scale="1280:-1,format=yuv420p" -pix_fmt yuv420p -level 3.1 -vsync passthrough -crf 26 -g 50 -bufsize 3500k -maxrate 1800k -c:v libx264 -c:a aac -b:a 128000 -r:a 44100 -ac 2 -t ${STREAMDURATION} -f tee <i>"[movflags=+faststart]${TARGETFILE}|[f=flv]${STREAMTARGET}"</i></code></p>
|
||||||
|
<p>I use this script to stream to a RTMP target and record the stream locally as .mp4 with only one ffmpeg-instance.</p>
|
||||||
|
<p>As input, I use <code>bmdcapture</code> which is piped to ffmpeg. But it can also be used with a static videofile as input.</p>
|
||||||
|
<p>The input will be scaled to 1280px width, maintaining height. Also the stream will stop after a given time (see <code>-t</code> option.)</p>
|
||||||
|
<h4>Notes</h4>
|
||||||
|
<ol>
|
||||||
|
<li>I recommend to use this inside a shell script - then you can define the variables <code>${INPUTFILE}</code>, <code>${STREAMDURATION}</code>, <code>${TARGETFILE}</code>, and <code>${STREAMTARGET}</code>.</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>
|
||||||
|
<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>"[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>
|
||||||
|
</div>
|
||||||
|
<!-- END Record and live-stream at the same time -->
|
||||||
|
|
||||||
<!-- View Subprogram Info -->
|
<!-- View Subprogram Info -->
|
||||||
<span data-toggle="collapse" data-target="#view_subprogram_info"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="View FFmpeg subprogram information">View FFmpeg subprogram information</button></span>
|
<span data-toggle="collapse" data-target="#view_subprogram_info"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="View FFmpeg subprogram information">View FFmpeg subprogram information</button></span>
|
||||||
<div id="view_subprogram_info" class="collapse">
|
<div id="view_subprogram_info" class="collapse">
|
||||||
|
Loading…
x
Reference in New Issue
Block a user