logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
doc:media:ffmpeg [19/08/2018 11:26]
kao [Encoder la vidéo] ajout du h265
doc:media:ffmpeg [13/02/2020 20:06]
Jean-Pierre Pinson [Introduction]
Ligne 9: Ligne 9:
     * Mis à jour le 29-04-2012     * Mis à jour le 29-04-2012
   * Commentaires sur le forum : [[http://​debian-facile.org/​viewtopic.php?​id=2504 | Lien vers le forum concernant ce tuto]]((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !))   * Commentaires sur le forum : [[http://​debian-facile.org/​viewtopic.php?​id=2504 | Lien vers le forum concernant ce tuto]]((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !))
- 
  
  
Ligne 18: Ligne 17:
 Aujourd'​hui,​ il est préférable d'​utiliser avconv à la place de ffmpeg tout en conservant les mêmes options. \\ Aujourd'​hui,​ il est préférable d'​utiliser avconv à la place de ffmpeg tout en conservant les mêmes options. \\
 Pour ce faire, si ce n'est déjà fait, installer : Pour ce faire, si ce n'est déjà fait, installer :
-<code root>apt-get update && apt-get install libav-tools</​code>​+<code root>apt update && apt install libav-tools</​code> ​ 
 +le paquet libav-tools n'​existe pas dans Buster
  
 Et lancez vos commandes en remplaçant //ffmpeg// par **avconv**, tout simplement. Et lancez vos commandes en remplaçant //ffmpeg// par **avconv**, tout simplement.
Ligne 32: Ligne 32:
  
 Ou directement en ligne de commande comme on va le détailler ci-dessous. Ou directement en ligne de commande comme on va le détailler ci-dessous.
 +
 +Une documentation est disponible directement dans l'​application,​ ou sur le site officiel : https://​ffmpeg.org/​
 +<code user>​ffmpeg -h</​code>​
  
 ===== Préambule ===== ===== Préambule =====
Ligne 58: Ligne 61:
 </​file>​ </​file>​
 Le D signifie la capacité à le lire, et E la possibilité d'​encapsuler dans le format. Le D signifie la capacité à le lire, et E la possibilité d'​encapsuler dans le format.
 +
 +Il est possible de voir les options du muxer ou demuxer disponibles pour un format spécifique comme par exemple avec //matroka// (.mkv) :
 +<code user>​ffmpeg -h muxer=matroska</​code>​
  
 ==== Les codecs ==== ==== Les codecs ====
Ligne 64: Ligne 70:
 De la même manière que pour les formats, ffmpeg liste les codecs qu'il est capable de gérer: De la même manière que pour les formats, ffmpeg liste les codecs qu'il est capable de gérer:
 <code user>​ffmpeg -codecs</​code>​ <code user>​ffmpeg -codecs</​code>​
 +
 +Il est possible de voir les options disponibles d'un encoder ou décoder pour un codec spécifique comme par exemple //vp9//:
 +<code user>​ffmpeg -h encoder=vp9</​code>​
  
 ==== Les filtres ==== ==== Les filtres ====
Ligne 69: Ligne 78:
 ffmpeg dispose aussi d'une base importante de filtres qui permettent de modifier le contenu de chaque flux, comme changer la résolution,​ modifier le volume d'une piste, incruster un logo etc.... ffmpeg dispose aussi d'une base importante de filtres qui permettent de modifier le contenu de chaque flux, comme changer la résolution,​ modifier le volume d'une piste, incruster un logo etc....
 <code user>​ffmpeg -filters</​code>​ <code user>​ffmpeg -filters</​code>​
 +Il est possible de voir les options disponibles d'un filtre spécifique comme par exemple avec //scale// :
 +<code user>​ffmpeg -h filter=scale</​code>​
 +
 +
  
 ==== Formats + Codecs + filtres ==== ==== Formats + Codecs + filtres ====
Ligne 84: Ligne 97:
 Heureusement le libre fournit plusieurs formats ainsi que plusieurs codecs libre de droit : Heureusement le libre fournit plusieurs formats ainsi que plusieurs codecs libre de droit :
   * Dans les formats citons: mkv, webm, ogv, ogg...   * Dans les formats citons: mkv, webm, ogv, ogg...
-  * Dans les codecs vidéos citons: vp9, vp8, theora(vp3),​ dirac...+  * Dans les codecs vidéos citons: ​AV1,vp9, vp8, theora(vp3),​ dirac...
   * Dans les codecs audio citons: flac, opus, vorbis et bien d'​autres...   * Dans les codecs audio citons: flac, opus, vorbis et bien d'​autres...
  
Ligne 219: Ligne 232:
  
 ===== Encoder la vidéo ===== ===== Encoder la vidéo =====
 + La liste des options ffmpeg pour le traitement Video est disponible ici: http://​ffmpeg.org/​ffmpeg.html#​Video-Options
  
 +En voici les principales: ​
 ^ option ​   ^  explication de l'​option ​ | ^ option ​   ^  explication de l'​option ​ |
-|-configuration du débit binaire ​par défaut 200 kbps | +|-définit le nombre d'​images ​par seconde ​|
-|-sameq | copie à l'​identique le débit binaire ​|+
 |-s | configuration de la taille du cadre d'​affichage | |-s | configuration de la taille du cadre d'​affichage |
 |-aspect | configuration du format d'​affichage (4:3, 16:9 ou 1.3333, 1.7777) | |-aspect | configuration du format d'​affichage (4:3, 16:9 ou 1.3333, 1.7777) |
 |-vcodec ou -c:v | décision du choix du codec | |-vcodec ou -c:v | décision du choix du codec |
 |-pass | nombre de passage à l'​encodage,​ une passe (-pass 1) ou deux passes (-pass 2) | |-pass | nombre de passage à l'​encodage,​ une passe (-pass 1) ou deux passes (-pass 2) |
-|-qmin détermine le seuil minimum du débit binaire variable ​(VBR+|-crf permet de définir un niveau de qualité entre 0 et 63 (petit nombre = meilleure qualité mais plus de temps de calcul) (défaut 23)|
-|-qmax | détermine le seuil maximum du débit binaire variable ​(VBR) | +
-|-f | sélectionne le nom du conteneur | +
-|-r | définit le nombre d'​images par seconde | +
- +
-==== Encoder en mkv ==== +
- +
-Se placer dans le répertoire VIDEO_TS contenant les fichiers.VOB avec [[doc:​programmation:​shell:​cd|la commande cd]], puis, en utilisant [[doc:​systeme:​cat|la commande cat]], faire la convertion ainsi : +
-<code user>cat *.VOB |  ffmpeg -i - video.mkv</​code>​+
  
-== Note : ==+=== CRF (Constant Rate Factor) ​=
 + Il faut utiliser le CRF pour définir une qualité d'​image constante. L'​objectif est d'​obtenir une qualité d'​image stable entre plusieurs vidéos. À durée égale, la taille du fichier peut varier suivant si la vidéo est facilement compressible ou pas. Un dessin animé avec des aplats prendra moins de place qu'un match de foot avec des panoramiques sur 80000 spectateurs. L'​échelle crf est logarithmique entre 0 et 63, une différence de 6 points double ou divise par 2 environ la taille du fichier final. 
 +Un petit nombre égal une meilleure qualité mais plus de temps de calcul, la valeur est souvent par défaut 23.
  
-Il suffit ​de changer en sortie ​l'extension vidéo mkv en mp2mp4, etc... pour que la convertion se fasse dans le format vidéo indiqué;-)+Le choix du CRF dépends du type d'​image à encoder, de la résolution ​de l'imagede qualité souhaité ou encore de la taille du fichier désiré. Vous pouvez faire des tests sur des segments avant de procéder à l'​encodage total.
  
 ==== Encoder la vidéo en VP8 ==== ==== Encoder la vidéo en VP8 ====
Ligne 274: Ligne 282:
   * **-crf** ​ permet de définir un niveau de qualité entre 0 et 51 (petit nombre = meilleure qualité mais plus de temps de calcul)   * **-crf** ​ permet de définir un niveau de qualité entre 0 et 51 (petit nombre = meilleure qualité mais plus de temps de calcul)
  
-Une documentation plus détaillé en anglais est disponible ici: [[https://​trac.ffmpeg.org/​wiki/​x264EncodingGuide | trac.ffmpeg.org]]+Une documentation plus détaillé en anglais est disponible ici: [[https://​trac.ffmpeg.org/​wiki/​Encode/H.264]]
  
 ==== Encoder la vidéo en H.265/HEVC ==== ==== Encoder la vidéo en H.265/HEVC ====
Ligne 284: Ligne 292:
 Une documentation plus détaillée en anglais est disponible ici : https://​trac.ffmpeg.org/​wiki/​Encode/​H.265 et ici http://​x265.readthedocs.org/​en/​default/​ Une documentation plus détaillée en anglais est disponible ici : https://​trac.ffmpeg.org/​wiki/​Encode/​H.265 et ici http://​x265.readthedocs.org/​en/​default/​
  
-==== Regrouper plusieurs vidéos mp4 en 1 seule ====+==== Encoder VOB en MKV ====
  
-Il y a une fonction ​**concat** qui concatène des fichiers en entrée. C’est ce que l’on va utiliser… sauf que cela ne fonctionne pas avec des fichiers MP4 (container MOV, h264 en codec vidéo, et aac en codec audio). +  ​https://debian-facile.org/viewtopic.php?id=24453
- +
-=== Préparation === +
- +
-On va d’abord changer de container pour nos flux source, puis les assembler, car on ne va pas refaire de transcodage,​ juste de la copie de flux. \\ +
-La fonction **concat** accepte bien le MPEG Transport Stream, allons y : +
-<code user>​ffmpeg -y -i "​source1.mp4"​ -c copy -bsf:v h264_mp4toannexb -f mpegts "​source1.ts"<​/code> +
-Le -bsf:v h264_mp4toannexb restructure le flux h264 pour qu’il puisse rentrer dans le TS. Il le demande, et ça marche. +
- +
-=== Assemblage === +
- +
-Une fois que tous les fichiers à assembler sont passés en TS, on les regroupe et les converti en mp4 ainsi : +
-<code user>​ffmpeg -y -i concat:"​source1.ts|source2.ts"​ -c copy -f mov "​destination.mp4"<​/code> +
- +
-<note important>​Si cela ne fonctionne pas, vérifiez que vos fichiers ont bien le même format, codec, résolution… \\ +
-À la moindre différence,​ l’assemblage est impossible.</​note>​ +
- +
-Source : +
-  * http://​hd3g.tv/​b/​2012/​08/​coller-des-fichiers-mp4-entre-eux-avec-ffmpeg/​ +
- +
-=== Utiliser une boucle for === +
- +
-Si les fichiers à assembler sont nombreux, on peut utiliser une boucle. +
- +
-Rassembler les vidéos afin qu'​elle portent un numéro progressif pour la vidéo finale. \\ +
-Créer le répertoire accueillant les MPG, par exemple : +
-<code user>​mkdir ~./​video-mpg</​code>​ +
-Y déposer les videos MPG à assembler : +
-<code user>mv /​répertoire_acquis/​*.mpg ~./​video-mpg</​code>​ +
-Les numéroter dans l'​ordre où nous souhaitons les assembler. \\ +
-Perso, j'​utilise [[doc:​systeme:​gprename|GPRENAME]] qui me rend la vie facile... ;-) +
- +
-Lister le contenu obtenu : +
-<code user>ls ~./video/</​code>​ +
-<code config retour de la commande ls>0001.mpg 0002.mpg 0003.mpg 0004.mpg 0005.mpg</​code>​  +
- +
-Nous allons d'​abord les convertir chacune en mp4 en utilisant une première fois la boucle for : +
-<code user>cd /​repertoire/​video-mpg</​code>​ +
-<code user>for i in {0001..0005};​ do $i -c:v:0 libx264 -preset slow -crf 15 -s 1024x768 -threads 0 -c:a $i.mp4; done</​code>​ +
- +
-**Explication :** \\ +
-''​for i in {0001..0005};''​ +
- +
-Se traduit : la variable ''​i''​ prendra respectivement les chiffres ''​0001''​ ''​0002''​ ''​0003''​ ''​0004''​ ''​0005''​ comme valeur. \\ +
-Le point virgule '';''​ indique la fin de cette indication. +
- +
-Ensuite vient : +
-''​do $i -c:v:0 libx264 -preset slow -crf 15 -s 1024x768 -threads 0 -c:a $i.mp4;​done''​ +
- +
-**Explication :** +
- +
-Au début : ''​do $i''​ indique qu'il faut considérer chacun des numéros attribués à la variable ''​i''​ précédemment définie. \\ +
-Le : '';​done''​ indique la fin de la commande qui est à répéter pour chaque variable ''​$i''​ trouvée. +
- +
-[[doc:​programmation:​shell:​cd|Se placer dans le dossier]] rassemblant les vidéos MPG numérotées : +
-<code user>cd /​repertoire/​video-mpg</​code>​ +
- +
-On exécute la commande de conversion en TS : +
-<code user>for i in {0001..0005};​ do ffmpeg -y -i "​$i.mp4"​ -c copy -bsf:v h264_mp4toannexb -f mpegts "​$i.ts";​ done</​code>​ +
- +
-Et pour assembler le tout directement en MP4 : +
-<code user>​ffmpeg -y -i concat:"​0001.ts|0002.ts|0003.ts|0004.ts|0005.ts"​ -c copy -f mov "​1.mp4"</​code>​ +
- +
-Où la vidéo 1.mp4 est la vidéo finale assemblée. +
- +
-**Alternative :** +
- +
-En utilisant la boucle de nouveau : +
-<code user>​toto="";​ for i in {0001..0005};​ do toto="​$toto$i.ts|";​ done; ffmpeg -y -i concat:"​$toto"​ -c copy -f mov "​1.mp4"</​code>​ +
-Merci **kyodev** pour cette astuce ! :-D +
- +
-Source de la boucle : +
-  * [[utilisateurs:​smolski:​tutos:​copies-incrementees]]+
  
 ==== Aspect 16:9 ==== ==== Aspect 16:9 ====
Ligne 365: Ligne 301:
 <code user>​ffmpeg -i film.mkv -aspect 16:9 -c copy film2.mkv</​code>​ <code user>​ffmpeg -i film.mkv -aspect 16:9 -c copy film2.mkv</​code>​
  
-On peut en profiter pour changer le codage par la même occasion, par exemple : 
-<code user>​ffmpeg -i film.avi -aspect 16:9 -c copy film2.mkv</​code>​ 
- 
-==== CRF (Constant Rate Factor) ==== 
- 
-Il faut utiliser le CRF pour définir une qualité d'​image constante. L'​objectif est d'​obtenir une qualité d'​image stable entre plusieurs vidéos. À durée égale, la taille du fichier peut varier suivant si la vidéo est facilement compressible ou pas.\\ 
-<note tip>Une vidéo de 30mn avec beaucoup de scènes fixes, typiquement une conférence,​ sera beaucoup moins lourde qu'une vidéo de 30mn avec des explosions et effets stroboscopiques tout du long. L'​encodeur fait varier le bitrate pour s'​adapter à différentes scènes, en gardant comme objectif une certaine qualité d'​image.</​note>​ 
- 
-L'​encodage en 1 ou 2 passes en spécifiant un bitrate était utile à une certaine époque pour utiliser le maximum de place disponibles sur des supports comme le CD ou le DVD, typiquement obtenir la meilleure qualité de vidéo sur 700Mo exactement. En définissant un bitrate de 1000kb/s (vidéo+audio) pour une vidéo de 30mn00s, on obtient un fichier de 219,72 Mio exactement (ajouter quelques Mio pour le conteneur mkv). \\ 
-Si tu ne comptes pas utiliser ces formats de stockage, je te conseille vivement d'​utiliser le CRF. Pour info, un encodage en 2 passes ne fait que définir précisément un CRF lors de la première passe, et fait un encodage tout à fait normal en 2ème passe avec le CRF défini précédemment. 
- 
-Voir discussion avec un des devs du x264 : 
-  * https://​forum.doom9.org/​showthread.php?​t=143904 
-Par défaut le CRF est fixé à 23, ce qui donne une très bonne qualité. 
-  * Réduire ce facteur accroit la qualité de l'​image,​ 
-  * l'​augmenter abaisse la qualité de l'​image. 
-L'​échelle est logarithmique,​ une différence de 6 points double ou divise par 2 environ la taille du fichier final 
-  * Un CRF de 18-20 donne une qualité très proche des disques commerciaux,​ 
-  * un CRF de 26-28 est suffisant pour une conférence. 
-<note important>​Attention toutefois, la définition de la vidéo est importante. \\ 
-Une vidéo en 1080p à CRF 23 sera excellente, alors qu'une vidéo en 240p à CRF 23 pourrait faire apparaître des artefacts.</​note>​ 
- 
-=== Pense-bête à ska === 
- 
-^ Commentaire ​ ^ Option | 
-|On peut séparer plusieurs filtres avec une virgule, l'​ordre est important |-vf filtre1,​filtre2,​etc | 
-|Rogner l'​image,​ origine = en haut à gauche |-vf crop=largeurX:​hauteurY:​decalageX:​decalageY | 
-|Mettre à l'​échelle |-1 conserve le ratio et flag peut être '​bicubic'​ : -vf scale=-1:​480:​flags='​lanczos'​ | 
-|Débruitage de vidéo|défaut = 4. Utiliser 2 pour les vidéos faiblement bruitées : -vf hqdn3d=2 | 
-|Désentralaçage (mcdeint et kerndeint sont moins efficaces) |-vf yadif | 
-|Ajustement des couleurs |([mini/​maxi%%|%%défaut]) : -vf mp=eq2=gamma:​contraste:​luminosite:​saturation |[0.1/​10%%|%%1:​-2/​2%%|%%1:​-1/​1%%|%%0:​0/​3%%|%%1] | 
-|Modifie le ratio, le lecteur affichera la vidéo en 16/9 peut importe la définition |-aspect 16:9 | 
-|Change le départ, la fin ou la durée |-ss départ en secondes\\ -t durée en secondes\\ -to fin en secondes | 
-|Désactive les flux audios ou vidéos |-an sans audio\\ -vn sans vidéo | 
-|Audio Opus | bitrate -c:a libopus -b:a 64k | 
-|Audio Vorbis, qualité | -c:a libvorbis | -q:a 0 (~64 kbps)\\ -q:a 2 (~96 kbps\\ -q:a 3 (~112 kbps standard)\\ -q:a 4 (~128 kbps)\\ -q:a 5 (~160 kbps) | 
-|Conversion audio multi-canaux vers stéréo |-ac 2 | 
  
-Et le lien vers la doc complète de ffmpeg avec toutes les options disponibles pour faire des trucs vraiment spéciaux : 
-  * https://​ffmpeg.org/​ffmpeg-all.html 
-Les conseils pour du x264 sur le wiki ffmpeg : 
-  * https://​trac.ffmpeg.org/​wiki/​Encode/​H.264 
- 
-Pompé du forum df là : 
-  * https://​forum.doom9.org/​showthread.php?​t=143904 
-Merci **ska** ! //Que ton chemin se couvre de pétales de rose...// :-D 
 ===== Encoder le son ===== ===== Encoder le son =====
  
Ligne 530: Ligne 421:
  
 <note important>​FFmpeg ne semble pas respecter le nombre d'​image par seconde. Si les capacités de la machine le permettent, il pourra aller au delà, la vidéo sera donc ralentie.</​note>​ <note important>​FFmpeg ne semble pas respecter le nombre d'​image par seconde. Si les capacités de la machine le permettent, il pourra aller au delà, la vidéo sera donc ralentie.</​note>​
 +
 +===== cat - Regrouper plusieurs vidéos VOB en mp4 =====
 +
 +  * [[doc:​media:​libdvdcss2 | cat-convertion-en-mp4]]
 +
 +===== Regrouper plusieurs vidéos mp4 en 1 seule =====
 +
 +Il y a une fonction **concat** qui concatène des fichiers en entrée. C’est ce que l’on va utiliser… sauf que cela ne fonctionne pas avec des fichiers MP4 (container MOV, h264 en codec vidéo, et aac en codec audio).
 +
 +=== Préparation ===
 +
 +On va d’abord changer de container pour nos flux source, puis les assembler, car on ne va pas refaire de transcodage,​ juste de la copie de flux. \\
 +La fonction **concat** accepte bien le MPEG Transport Stream, allons y :
 +<code user>​ffmpeg -y -i "​source1.mp4"​ -c copy -bsf:v h264_mp4toannexb -f mpegts "​source1.ts"</​code>​
 +Le -bsf:v h264_mp4toannexb restructure le flux h264 pour qu’il puisse rentrer dans le TS. Il le demande, et ça marche.
 +
 +=== Assemblage ===
 +
 +Une fois que tous les fichiers à assembler sont passés en TS, on les regroupe et les converti en mp4 ainsi :
 +<code user>​ffmpeg -y -i concat:"​source1.ts|source2.ts"​ -c copy -f mov "​destination.mp4"</​code>​
 +
 +<note important>​Si cela ne fonctionne pas, vérifiez que vos fichiers ont bien le même format, codec, résolution… \\
 +À la moindre différence,​ l’assemblage est impossible.</​note>​
 +
 +Source :
 +  * http://​hd3g.tv/​b/​2012/​08/​coller-des-fichiers-mp4-entre-eux-avec-ffmpeg/​
 +
 +=== Utiliser une boucle for ===
 +
 +Si les fichiers à assembler sont nombreux, on peut utiliser une boucle.
 +
 +Rassembler les vidéos afin qu'​elle portent un numéro progressif pour la vidéo finale. \\
 +Créer le répertoire accueillant les MPG, par exemple :
 +<code user>​mkdir ~./​video-mpg</​code>​
 +Y déposer les videos MPG à assembler :
 +<code user>mv /​répertoire_acquis/​*.mpg ~./​video-mpg</​code>​
 +Les numéroter dans l'​ordre où nous souhaitons les assembler. \\
 +Perso, j'​utilise [[doc:​systeme:​gprename|GPRENAME]] qui me rend la vie facile... ;-)
 +
 +Lister le contenu obtenu :
 +<code user>ls ~./​video/</​code>​
 +<code config retour de la commande ls>​0001.mpg 0002.mpg 0003.mpg 0004.mpg 0005.mpg</​code> ​
 +
 +Nous allons d'​abord les convertir chacune en mp4 en utilisant une première fois la boucle for :
 +<code user>cd /​repertoire/​video-mpg</​code>​
 +<code user>for i in {0001..0005};​ do $i -c:v:0 libx264 -preset slow -crf 15 -s 1024x768 -threads 0 -c:a $i.mp4; done</​code>​
 +
 +**Explication :** \\
 +''​for i in {0001..0005};''​
 +
 +Se traduit : la variable ''​i''​ prendra respectivement les chiffres ''​0001''​ ''​0002''​ ''​0003''​ ''​0004''​ ''​0005''​ comme valeur. \\
 +Le point virgule '';''​ indique la fin de cette indication.
 +
 +Ensuite vient :
 +''​do $i -c:v:0 libx264 -preset slow -crf 15 -s 1024x768 -threads 0 -c:a $i.mp4;​done''​
 +
 +**Explication :**
 +
 +Au début : ''​do $i''​ indique qu'il faut considérer chacun des numéros attribués à la variable ''​i''​ précédemment définie. \\
 +Le : '';​done''​ indique la fin de la commande qui est à répéter pour chaque variable ''​$i''​ trouvée.
 +
 +[[doc:​programmation:​shell:​cd|Se placer dans le dossier]] rassemblant les vidéos MPG numérotées :
 +<code user>cd /​repertoire/​video-mpg</​code>​
 +
 +On exécute la commande de conversion en TS :
 +<code user>for i in {0001..0005};​ do ffmpeg -y -i "​$i.mp4"​ -c copy -bsf:v h264_mp4toannexb -f mpegts "​$i.ts";​ done</​code>​
 +
 +Et pour assembler le tout directement en MP4 :
 +<code user>​ffmpeg -y -i concat:"​0001.ts|0002.ts|0003.ts|0004.ts|0005.ts"​ -c copy -f mov "​1.mp4"</​code>​
 +
 +Où la vidéo 1.mp4 est la vidéo finale assemblée.
 +
 +**Alternative :**
 +
 +En utilisant la boucle de nouveau :
 +<code user>​toto="";​ for i in {0001..0005};​ do toto="​$toto$i.ts|";​ done; ffmpeg -y -i concat:"​$toto"​ -c copy -f mov "​1.mp4"</​code>​
 +Merci **kyodev** pour cette astuce ! :-D
 +
 +Source de la boucle :
 +  * [[utilisateurs:​smolski:​tutos:​copies-incrementees]]
 +
 +=== Pense-bête à ska ===
 +
 +^ Commentaire ​ ^ Option |
 +|On peut séparer plusieurs filtres avec une virgule, l'​ordre est important |-vf filtre1,​filtre2,​etc |
 +|Rogner l'​image,​ origine = en haut à gauche |-vf crop=largeurX:​hauteurY:​decalageX:​decalageY |
 +|Mettre à l'​échelle |-1 conserve le ratio et flag peut être '​bicubic'​ : -vf scale=-1:​480:​flags='​lanczos'​ |
 +|Débruitage de vidéo|défaut = 4. Utiliser 2 pour les vidéos faiblement bruitées : -vf hqdn3d=2 |
 +|Désentralaçage (mcdeint et kerndeint sont moins efficaces) |-vf yadif |
 +|Ajustement des couleurs |([mini/​maxi%%|%%défaut]) : -vf mp=eq2=gamma:​contraste:​luminosite:​saturation |[0.1/​10%%|%%1:​-2/​2%%|%%1:​-1/​1%%|%%0:​0/​3%%|%%1] |
 +|Modifie le ratio, le lecteur affichera la vidéo en 16/9 peut importe la définition |-aspect 16:9 |
 +|Change le départ, la fin ou la durée |-ss départ en secondes\\ -t durée en secondes\\ -to fin en secondes |
 +|Désactive les flux audios ou vidéos |-an sans audio\\ -vn sans vidéo |
 +|Audio Opus | bitrate -c:a libopus -b:a 64k |
 +|Audio Vorbis, qualité | -c:a libvorbis | -q:a 0 (~64 kbps)\\ -q:a 2 (~96 kbps\\ -q:a 3 (~112 kbps standard)\\ -q:a 4 (~128 kbps)\\ -q:a 5 (~160 kbps) |
 +|Conversion audio multi-canaux vers stéréo |-ac 2 |
 +
 +===== Crop - découpe et recadrage vidéo =====
 +
 +<note important>​Tuto en cours - Commandes en tests à suivre... ;​)</​note>​
 +
 +Les options
 +  * out_w est la largeur du rectangle de sortie
 +  * out_h est la hauteur du rectangle de sortie
 +  * x et y indiquent le coin supérieur gauche du rectangle de sortie
 +
 +=== Exemples ===
 +
 +<code user>​ffmpeg -i in.mp4 -vf "​crop=out_w:​out_h:​x:​y"​ out.mp4</​code>​
 +
 +=== Recadrer en 80x60 ===
 +
 +Original en 320x240
 +
 +Faire un crop de 80×60, depuis la position (200, 100) :
 +<code user>​ffmpeg -i in.mp4 -vf "​crop=80:​60:​200:​100"​ -c:a copy out.mp4</​code>​
 +
 +=== Recadrer le quart inférieur droit ===
 +
 +<code user>​ffmpeg -i in.mp4 -vf "​crop=in_w/​2:​in_h/​2:​in_w/​2:​in_h/​2"​ -c:a copy out.mp4</​code>​
 +Ou bien :
 +<code user>​ffmpeg -i in.mp4 -vf "​crop=240:​120:​240:​120"​ -c:a copy out.mp4</​code>​
 +
 +=== Découpez 20 pixels par le haut et 20 par le bas ===
 +
 +<code user>​ffmpeg -i in.mp4 -vf "​crop=in_w:​in_h-40"​ -c:a copy out.mp4</​code>​
 +<note tip>Le filtre centrera automatiquement le rognage si x et y sont omis.</​note>​
 +
 +=== Prévisualisation ===
 +
 +Vous pouvez réaliser un recadrage (//heh heh heh//) et le prévisualiser en direct avec ffplay :
 +<code user>​ffplay -i input -vf "​crop=in_w:​in_h-40"</​code>​
 +
 +De cette façon, vous pouvez expérimenter et ajuster votre recadrage sans avoir besoin d'​encoder,​ de visualiser ni de recommencer.
 +
 +=====Réparer un fichier mp4=====
 +
 +Il peut arriver qu'un pompage sur le net ne soit pas correctement recodé (par ex. on aura un fichier vidéo et un fichier audio non fusionnés).
 +youtube-dl annonce dans ce cas que la «conversion» n'a pas abouti; à mon avis il s'agit d'une fusion et non d'une conversion.
 +
 +ffmpeg est capable de faire cette fusion:
 +
 +<code user>​ffmpeg -i <fichier vidéo> -i <fichier audio> <fichier final>​.mp4</​code>​
 +
  
  
doc/media/ffmpeg.txt · Dernière modification: 03/12/2023 17:28 par Croutons

Pied de page des forums

Propulsé par FluxBB