Dans cet article, nous allons découvrir quelques commandes courantes permettant de convertir et de manipuler des caractéristiques spécifiques de fichiers multimédias. Bien que nous ayons essayé d'afficher des opérations équivalentes pour toutes les procédures, toutes les opérations ne sont pas possibles dans les deux applications.
Dans de nombreux cas, les commandes que nous montrons peuvent être combinées en une seule opération de ligne de commande. Le cas échéant, elles le seraient réellement. Par exemple, rien ne vous empêche de définir le débit d'un fichier de sortie lors de la même opération qu'une conversion de fichier. Par souci de clarté, nous présentons souvent ces opérations sous forme de commandes distinctes dans cet article.
La conversion est effectuée avec les applications suivantes:
Caractéristiques d'affichage
Shaka Packager et FFmpeg peuvent tous deux être utilisés pour inspecter le contenu d'un fichier multimédia, puis afficher les caractéristiques d'un flux. Cependant, ils fournissent tous deux une sortie différente pour le même support.
Caractéristiques de Shaka Packager
packager input=glocken.mp4 --dump_stream_info
Le résultat ressemble à ceci:
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
Caractéristiques de FFmpeg
ffmpeg -i glocken.mp4
Le résultat ressemble à ceci:
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
Démux (séparer) les flux audio et vidéo
Shaka Packager nécessite une démuxage lors de la conversion des fichiers. Ceci est également requis pour utiliser les frameworks multimédias.
Démuxage de Shaka Packager
MP4
packager input=myvideo.mp4,stream=video,output=myvideo_video.mp4
packager input=myvideo.mp4,stream=audio,output=myvideo_audio.m4a
soit :
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
Démuxage 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
Remux (combiner) les flux audio et vidéo
Dans certains cas, vous devrez combiner l'audio et la vidéo dans un seul conteneur. Surtout lorsque vous n'utilisez pas de framework multimédia. C'est quelque chose que FFmpeg peut gérer assez bien et qui n'est actuellement pas pris en charge par Shaka Packager.
ffmpeg -i myvideo_video.webm -i myvideo_audio.webm -c copy myvideo.webm
Caractéristiques des modifications
Débit
Pour FFmpeg, nous pouvons le faire lors de la conversion en .mp4
ou .webm
.
ffmpeg -i myvideo.mov -b:v 350K myvideo.mp4
ffmpeg -i myvideo.mov -vf setsar=1:1 -b:v 350K myvideo.webm
Dimensions (résolution)
ffmpeg -i myvideo.webm -s 1920x1080 myvideo_1920x1080.webm
File type
Shaka Packager ne peut pas traiter les fichiers .mov
et ne peut donc pas être utilisé pour convertir des fichiers dans ce format.
De .mov
à .mp4
ffmpeg -i myvideo.mov myvideo.mp4
De .mov
à .webm
ffmpeg -i myvideo.mov myvideo.webm
Synchroniser l'audio et la vidéo
Pour vous assurer que l'audio et la vidéo se synchronisent pendant la lecture, insérez des images clés.
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
Audio pour 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
Audio pour 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
Vidéos à la demande et diffusion en direct
Il existe deux types de protocoles de traitement par flux que nous allons présenter dans cet article. La première est Dynamic Adaptive Streaming over HTTP (DASH), qui est une technique de streaming à débit adaptatif et une méthode de présentation de vidéos à la demande basée sur des normes Web. La seconde est HTTP Live Streaming (HLS), qui est la norme Apple pour la diffusion en direct et la vidéo à la demande pour le Web.
DASH/MPD
Cet exemple génère le fichier de sortie Media Presentation Description (MPD) à partir des flux audio et vidéo.
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
Ces exemples génèrent un fichier de sortie M3U8
à partir des flux audio et vidéo, qui est une playlist multimédia encodée en 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
OU :
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"
Maintenant que nous avons compris comment convertir des fichiers, nous pouvons nous appuyer sur ce que nous avons appris dans cet article pour en apprendre davantage sur le chiffrement multimédia.