在本文中,我們將學習一些常見的指令,用於轉換及操控媒體檔案的特定屬性。雖然我們已嘗試為所有程序顯示等效的操作,但兩個應用程式並非所有操作都能互通。
在許多情況下,我們顯示的指令可能會在單一指令列作業中合併,並在實際使用時合併。舉例來說,您可以同時設定輸出檔案的位元率,以及執行檔案轉換作業。為了方便說明,本文通常會將這些作業顯示為個別指令。
轉換作業會透過下列應用程式完成:
顯示器特性
您可以使用 Shaka Packager 和 FFmpeg 檢查媒體檔案的內容,然後顯示串流的特性。不過,兩者都會為相同的媒體提供不同的輸出內容。
使用 Shaka Packager 的特性
packager input=glocken.mp4 --dump_stream_info
輸出內容如下:
File "glocken.mp4":
Found 2 stream(s).
Stream [0] type: Video
codec_string: avc1.640028
time_scale: 30000
duration: 300300 (10.0 seconds)
is_encrypted: false
codec: H264
width: 1920
height: 1080
pixel_aspect_ratio: 1:1
trick_play_factor: 0
nalu_length_size: 4
Stream [1] type: Audio
codec_string: mp4a.40.2
time_scale: 48000
duration: 481280 (10.0 seconds)
is_encrypted: false
codec: AAC
sample_bits: 16
num_channels: 2
sampling_frequency: 48000
language: eng
seek_preroll_ns: 20833
使用 FFmpeg 的特性
ffmpeg -i glocken.mp4
輸出內容如下:
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'glocken.mp4':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf57.83.100
Duration: 00:00:10.03, start: 0.000000, bitrate: 8063 kb/s
Stream #0:0(eng): Video: h264 (High) (avc1 / 0x31637661), yuvj420p(pc), 1920x1080, 7939 kb/s, 29.97 fps, 29.97 tbr, 30k tbn, 59.94 tbc (default)
Metadata:
handler_name : VideoHandler
Stream #0:1(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 127 kb/s (default)
Metadata:
handler_name : SoundHandler
At least one output file must be specified
將音訊和視訊串流解除多路複合 (分離)
轉換檔案時,Shaka Packager 需要解多工處理。使用媒體架構時,也必須遵守這項規定。
Shaka Packager 解多工
MP4
packager input=myvideo.mp4,stream=video,output=myvideo_video.mp4
packager input=myvideo.mp4,stream=audio,output=myvideo_audio.m4a
或:
packager \
input=myvideo.mp4,stream=video,output=myvideo_video.mp4 \
input=myvideo.mp4,stream=audio,output=myvideo_audio.m4a
WebM
packager \
input=myvideo.webm,stream=video,output=myvideo_video.webm \
input=myvideo.webm,stream=audio,output=myvideo_audio.webm
FFmpeg 解多工
MP4
ffmpeg -i myvideo.mp4 -vcodec copy -an myvideo_video.mp4
ffmpeg -i myvideo.mp4 -acodec copy -vn myvideo_audio.m4a
WebM
ffmpeg -i myvideo.webm -vcodec copy -an myvideo_video.webm
ffmpeg -i myvideo.webm -acodec copy -vn myvideo_audio.webm
重新混合 (結合) 音訊和視訊串流
在某些情況下,您需要將音訊和影片重新合併為單一容器。特別是在未使用媒體架構時。FFmpeg 可以處理這類問題,而 Shaka Packager 目前不支援。
ffmpeg -i myvideo_video.webm -i myvideo_audio.webm -c copy myvideo.webm
變更特性
位元率
對於 FFmpeg,我們可以在轉換為 .mp4
或 .webm
時執行這項操作。
ffmpeg -i myvideo.mov -b:v 350K myvideo.mp4
ffmpeg -i myvideo.mov -vf setsar=1:1 -b:v 350K myvideo.webm
尺寸 (解析度)
ffmpeg -i myvideo.webm -s 1920x1080 myvideo_1920x1080.webm
檔案類型
Shaka Packager 無法處理 .mov
檔案,因此無法用於轉換該格式的檔案。
.mov
到 .mp4
ffmpeg -i myvideo.mov myvideo.mp4
.mov
到 .webm
ffmpeg -i myvideo.mov myvideo.webm
同步音訊和視訊
如要確保音訊和影片在播放期間同步,請插入主影格。
ffmpeg -i myvideo.mp4 -keyint_min 150 -g 150 -f webm -vf setsar=1:1 out.webm
MP4/H.264
ffmpeg -i myvideo.mp4 -c:v libx264 -c:a copy myvideo.mp4
MP4 的音訊
ffmpeg -i myvideo.mp4 -c:v copy -c:a aac myvideo.mp4
WebM/VP9
ffmpeg -i myvideo.webm -v:c libvpx-vp9 -v:a copy myvideo.webm
WebM 音訊
ffmpeg -i myvideo.webm -v:c copy -v:a libvorbis myvideo.webm
ffmpeg -i myvideo.webm -v:c copy -v:a libopus myvideo.webm
隨選影片和直播
我們將在本文中示範兩種串流通訊協定。第一個是基於 HTTP 的動態自動調整串流 (DASH),這是一種可自動調整位元率的串流技術,也是以網路標準為基礎的隨選即播影片呈現方法。第二種是 HTTP 即時串流 (HLS),這是 Apple 的標準,可用於網頁的直播和隨選影片。
DASH/MPD
這個範例會從音訊和視訊串流產生媒體顯示說明 (MPD) 輸出檔案。
packager \
input=myvideo.mp4,stream=audio,output=myvideo_audio.mp4 \
input=myvideo.mp4,stream=video,output=myvideo_video.mp4 \
--mpd_output myvideo_vod.mpd
HLS
這些範例會從音訊和影片串流產生 M3U8
輸出檔案,也就是採用 UTF-8 編碼的多媒體播放清單。
ffmpeg -i myvideo.mp4 -c:a copy -b:v 8M -c:v copy -f hls \
-hls_time 10 -hls_list_size 0 myvideo.m3u8
或:
packager \
'input=myvideo.mp4,stream=video,segment_template=output$Number$.ts,playlist_name=video_playlist.m3u8' \
'input=myvideo.mp4,stream=audio,segment_template=output_audio$Number$.ts,playlist_name=audio_playlist.m3u8,hls_group_id=audio,hls_name=ENGLISH' \
--hls_master_playlist_output="master_playlist.m3u8"
希望您已經掌握如何轉換檔案,接下來我們將根據本文的說明,進一步瞭解媒體加密。