利用ffmpeg给gif配上文字

复制代码
./ffmpeg -i ./sk.gif -vf "fps=10,scale=400:-1,
drawtext=fontfile='/System/Library/Fonts/STHeiti Medium.ttc':text='嗷~'
:fontcolor=yellow:bordercolor=black:borderw=1:fontsize=100:x=(w-text_w)/2:y=h-text_h-20:enable='between(t,0,1.8)',
drawtext=fontfile='/System/Library/Fonts/STHeiti Medium.ttc':text='哈哈哈'
:fontcolor=yellow:bordercolor=black:borderw=1:fontsize=100:x=(w-text_w)/2:y=h-text_h-20:enable='between(t,1.9,4)'" hahaha.gif

关键参数说明​

  • enable='between(t,开始时间,结束时间)':控制文本显示的时间段(单位:秒)。
  • text='你的文本':要显示的文本内容(需转义特殊字符如 '%)。
  • x, y:文本位置(示例:x=(w-text_w)/2:y=(h-text_h)/2 居中显示)。
  • fontfile=字体路径:自定义字体(如 fontfile=/path/to/font.ttf)。
  • fontsize=数字, fontcolor=颜色:字体大小和颜色(如 fontcolor=white)。
  • 转义字符​ :文本含单引号时需转义(如 text='It\'s a test')。
  • RGBA 格式(推荐):bordercolor=0xRRGGBBAA
  • 例如红色,完全不透明:bordercolor=0xff0000ff
  • 红色,半透明(alpha=128):bordercolor=0xff000080
  • 带透明度的名称格式(可选) :bordercolor=black@0.5 其中@0.5 表示 50% 透明。
  • 移动文字​ :使用 x/y 动态表达式,t表示时间
复制代码
  x='50 + 10*t':y='h - 20*t'
  x与的坐标中,有关键字文本自身的宽高text_w,text_h
  图片的宽高w,h
  #比如居中显示
  x=(w-text_w)/2:y=(h-text_h)/2 

  常用中文字体路径(macOS):
  你可以用这些字体名尝试:

  字体名称	文件路径示例
  苹方 (PingFang)	/System/Library/Fonts/Supplemental/PingFang.ttc
  华文黑体	/System/Library/Fonts/STHeiti Medium.ttc
  华文仿宋	/System/Library/Fonts/STFangsong.ttf
  宋体	/System/Library/Fonts/Supplemental/Songti.ttc

mac系统

  • 字体路径在/System/Library/Fonts

  • 也可在cmd中使用ls /System/Library/Fonts

相关推荐
blog.pytool.com10 小时前
LVGL 驱动地址自动变更为32 位的问题
ffmpeg
知南x11 小时前
【物联网视频监控系统----韦东山老师视频总结】(4)流媒体方案的实现之ffmpeg
ffmpeg·音视频
kkoral12 小时前
FFmpeg 零基础入门教程
ffmpeg
小Tomkk2 天前
⭐️ StarRocks Web 使用介绍与实战指南
前端·ffmpeg
aqi003 天前
FFmpeg开发笔记(九十八)基于FFmpeg的跨平台图形用户界面LosslessCut
android·ffmpeg·kotlin·音视频·直播·流媒体
带土13 天前
2. Linux下FFmpeg C++音视频解码+推流开发
linux·c++·ffmpeg
aqi003 天前
FFmpeg开发笔记(九十七)国产的开源视频剪辑工具AndroidVideoEditor
android·ffmpeg·音视频·直播·流媒体
Sleepless_斑马3 天前
RTMP/RTSP流媒体服务器搭建、ffmpeg推流桌面、vlc拉流
ffmpeg·rtmp·rtsp
炼金术4 天前
SkyPlayer v1.1.0 - 在线视频播放功能更新
android·ffmpeg
喜欢吃豆4 天前
深度解析:FFmpeg 远程流式解复用原理与工程实践
人工智能·架构·ffmpeg·大模型·音视频·多模态