ffmpeg 视频到图像转换。指定图像大小时,过滤文本不清楚

ffmpeg 视频到图像转换。指定图像大小时,过滤文本不清楚

如果我提取分辨率为 320x240 的视频文件,上面的文本看起来不错,而且可读性好。如果我输入分辨率为 1280x720 或更高的视频,上面的文本就不可读了。它可以调整大小或缩放,但文本看起来很糟糕。

图像转换后是否可以应用文本过滤器或任何可用的方法。
您可以找到图像(问题底部)和下面的 ffmpeg 输出。

$ ffmpeg.exe -ss 30 -i 1.mp4 -f image2 -vframes 1 -s 320x240 -vf \
  "drawtext=fontfile=/WINDOWS/Fonts/arial.ttf: timecode='00\:00\:00\:00': \
  r=25: x=(w-tw)/2: y=h-(2*lh): fontcolor=white: box=1: boxcolor=0x00000000@1" \
  ram.jpg

ffmpeg version 2.0.1 Copyright (c) 2000-2013 the FFmpeg developers
  built on Sep 26 2013 01:50:16 with gcc 4.8.1 (GCC)
  configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-avisynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libcaca --enable-libfreetype --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libx264 --enable-libxavs --enable-libxvid --enable-zlib
  libavutil      52. 38.100 / 52. 38.100
  libavcodec     55. 18.102 / 55. 18.102
  libavformat    55. 12.100 / 55. 12.100
  libavdevice    55.  3.100 / 55.  3.100
  libavfilter     3. 79.101 /  3. 79.101
  libswscale      2.  3.100 /  2.  3.100
  libswresample   0. 17.102 /  0. 17.102
  libpostproc    52.  3.100 / 52.  3.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '1.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf55.12.100
  Duration: 00:19:57.82, start: 2.242000, bitrate: 1345 kb/s
    Stream #0:0(und): Video: h264 (Main) (avc1 / 0x31637661), yuv420p, 1280x544, 1343 kb/s, 23.98 fps, 23.98 tbr, 24k tbn, 47.95 tbc
    Metadata:
      handler_name    : VideoHandler
Output #0, image2, to 'ram.jpg':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf55.12.100
    Stream #0:0(und): Video: mjpeg, yuvj420p, 320x240, q=2-31, 200 kb/s, 90k tbn, 23.98 tbc
    Metadata:
      handler_name    : VideoHandler
Stream mapping:
  Stream #0:0 -> #0:0 (h264 -> mjpeg)
Press [q] to stop, [?] for help
frame=    1 fps=0.0 q=0.0 Lsize=N/A time=00:00:00.04 bitrate=N/A dup=0 drop=21    
video:9kB audio:0kB subtitle:0 global headers:0kB muxing overhead -100.244499%

有尺寸和无尺寸的图片 未指定大小的 RAM
指定大小后的 RAM

答案1

您应该使用scale视频滤镜使用前drawtext

$ ffmpeg.exe -ss 30 -i 1.mp4 -vframes 1 -q:v 2 -vf "scale=320:-1, \
  drawtext=fontfile=/WINDOWS/Fonts/arial.ttf: timecode='00\:00\:00\:00': \
  r=25: x=(w-tw)/2: y=h-(2*lh): fontcolor=white: box=1: boxcolor=0x00000000@1" \
  ram.jpg
  • 使用比例视频过滤器,而不是-s因为您可以控制比例发生的时间:在任何其他过滤器之前或之后。

  • 仅声明一个维度,然后-1在另一个维度上使用将允许 ffmpeg 自动选择正确的值来保留方面。

  • 我添加了-q:v 2输出质量,因为我认为在这种情况下默认值不够。如果您希望压缩程度更高,请使用更高的值。jpg 的有效范围是 2-31。

  • 我删除了它-f image2,因为这里不需要它。

另请参阅:

相关内容