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 [02/09/2017 10:05]
smolski [Images Fixes]
doc:media:ffmpeg [15/12/2019 18:25]
ottr
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>​
  
 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 24: Ligne 23:
 ===== Installation ===== ===== Installation =====
  
-ffmpeg est dans [[doc:​systeme:​apt:​sources.list#​les-depots-deb-multimedia|les fichiers sources.list - deb-multimedia]] : +<code root>apt install ffmpeg</​code>​
-<code root>apt-get install ffmpeg</​code>​+
 ===== Utilisation ===== ===== Utilisation =====
  
Ligne 33: Ligne 31:
  
 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 59: Ligne 60:
 </​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 65: Ligne 69:
 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 70: Ligne 77:
 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 85: Ligne 96:
 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 220: Ligne 231:
  
 ===== 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 ====+=== 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.
  
-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 : +Le choix du CRF dépends du type d'​image à encoderde 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.
-<code user>cat *.VOB |  ffmpeg -i - video.mkv</​code>​ +
- +
-== Note : == +
- +
-Il suffit ​de changer en sortie ​l'extension vidéo mkv en mp2, mp4, etc... pour que la convertion se fasse dans le format vidéo indiqué;-)+
  
 ==== Encoder la vidéo en VP8 ==== ==== Encoder la vidéo en VP8 ====
 +<​note>​Le VP8 est souvent déprécié au profit du VP9 plus souple et plus performant</​note>​
 VP8 est un codec vidéo libre promu par Google, un bon équivalent au h264/mp4 : VP8 est un codec vidéo libre promu par Google, un bon équivalent au h264/mp4 :
 <code user>​ffmpeg -i tears_of_steel_720p.mkv -c:v:0 libvpx -crf 10 -vb 4M -c:a copy   ​tears_of_steel_vp8.mkv</​code>​ <code user>​ffmpeg -i tears_of_steel_720p.mkv -c:v:0 libvpx -crf 10 -vb 4M -c:a copy   ​tears_of_steel_vp8.mkv</​code>​
Ligne 251: Ligne 257:
   *-vb 4M permet de donner un objectif de débit à 4 Megabit/s   *-vb 4M permet de donner un objectif de débit à 4 Megabit/s
  
-Une liste des options possibles pour encoder en vp8 est disponible ici: +Une liste des options possibles pour encoder en vp8 est disponible ici: [[http://​wiki.webmproject.org/​ffmpeg]]
-  * [[http://​wiki.webmproject.org/​ffmpeg]]+
  
 +==== Encoder la vidéo en VP9 ====
 +
 +VP9 est un codec vidéo libre promu par Google pour concurrencer le h265/HEVC :
 +
 +<code user>​ffmpeg -i tears_of_steel_720p.mkv -c:v:0 libvpx-vp9 -threads 8 -crf 10 -vb 4M -c:a copy   ​tears_of_steel_vp9.mkv</​code>​
 +
 +Ici on utilise la librairie libvpx-vp9 avec trois options :
 +
 +    -crf permet de définir un niveau de qualité entre 0 et 63 (petit nombre = meilleure qualité mais plus de temps de calcul)
 +    -vb 4M permet de donner un objectif de débit à 4 Megabit/s
 +    -threads reste nécessaire pour forcer le nombre de core, libvpx-vp9 ne les detecte pas encore automatiquement. ​
 +
 +Une liste des options possibles pour encoder en vp9 est disponible ici: [[http://​wiki.webmproject.org/​ffmpeg/​vp9-encoding-guide]]
  
 ==== Encoder la vidéo en H264/Mpeg4 ==== ==== Encoder la vidéo en H264/Mpeg4 ====
Ligne 263: Ligne 281:
   * **-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: +Une documentation plus détaillé en anglais est disponible ici: [[https://​trac.ffmpeg.org/​wiki/​Encode/H.264]]
-  * [[https://​trac.ffmpeg.org/​wiki/​x264EncodingGuide | trac.ffmpeg.org]]+
  
-==== Regrouper plusieurs vidéos mp4 en 1 seule ====+==== Encoder la vidéo ​en H.265/​HEVC ​====
  
-Il y a une fonction **concat** qui concatène des fichiers en entréeC’est ce que l’on va utiliser… sauf que cela ne fonctionne pas avec des fichiers MP4 (container MOV, h264 en codec vidéoet aac en codec audio).+Le H.265/​HEVC ​est un nouveau ​codec propriétairesuccesseur du H264/Mpeg4La syntaxe suit celle du H264
  
-=== Préparation ===+<code user>​ffmpeg -i tears_of_steel_720p.mkv -c:v:0 libx265 -preset slow -crf 22 -c:a copy tears_of_steel_h265.mkv</​code>​
  
-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. \\ +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/​
-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 TSIl le demande, ​et ça marche.+
  
-=== Assemblage ​===+==== Encoder VOB en MKV ====
  
-Une fois que tous les fichiers à assembler sont passés en TS, on les regroupe et les converti en mp4 ainsi : +  ​https://debian-facile.org/viewtopic.php?id=24453
-<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 347: Ligne 300:
 <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>​ 
  
 ===== Encoder le son ===== ===== Encoder le son =====
Ligne 469: Ligne 420:
  
 <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>​
 +
  
  
 =====Liens===== =====Liens=====
  
 +  * Forum df - Améliorer la qualité des vidéos : [[https://​debian-facile.org/​viewtopic.php?​pid=244397#​p244397]]
   * Site officiel: (en)[[http://​ffmpeg.org/​]]   * Site officiel: (en)[[http://​ffmpeg.org/​]]
   * Documentation ffmpeg: (en)[[http://​trac.ffmpeg.org/​wiki]]   * Documentation ffmpeg: (en)[[http://​trac.ffmpeg.org/​wiki]]
doc/media/ffmpeg.txt · Dernière modification: 03/12/2023 17:28 par Croutons

Pied de page des forums

Propulsé par FluxBB