使用ffmpeg播放视频并添加当前时间水印

FFmpeg 是一个可以处理音视频的软件,功能非常强大,主要包括,编解码转换,封装格式转换,滤镜特效。同时也支持 各种网络协议,支持 RTMP ,RTSP,HLS 等高层协议的推拉流,也支持更底层一点的TCP/UDP 协议推拉流。

在多平台系统方面,FFmpeg 的兼容性也优势显著,FFmpeg 可以在 windows,Linux,Mac,ios,android 等等操作系统上运行。

因此,可以说 FFmpeg 是音视频领域的瑞士军刀。在多个公司都有使用,例如 Google 的 chrome 里面就使用了 FFmpeg 的库。还有 Youtube,Facebook,以及国内的各种做音视频产品的公司,只要他做音视频,95% 都会用到 FFmpeg。

ffplay是FFmpeg用于视频播放的一个程序,在播放视频时可以用drawtext滤镜来添加字幕,字幕中可以使用表达式来显示当前时间。时间的格式是用C语言的格式化模板。

示例如下:

ffplay.exe -vf "drawtext='fontfile=simhei.ttf:text=当前时间\\\:%{localtime\:%a %b %d %Y-%m-%d %H\\\:%M\\\:%S}': x=w-tw-10: y=10: fontcolor=white: fontsize=24: shadowcolor=black: shadowx=2: shadowy=2" 你的视频全路径.mp4

其中%{localtime\:%a %b %d %Y-%m-%d %H\\\:%M\\\:%S}部分就是用于显示当前时间字幕的,后面的参数用于设置字幕的位置、字体大小以及阴影等参数。基本能够根据参数名称看明白。

需要说明的是参数中的转义,滤镜描述内的转义需要三个\:

转义规则

  • 三级转义
    1. 滤镜选项值:转义:\'(如text=this is a \'string\'\: ...)。
    2. 滤镜描述:转义\'[],;(如drawtext=text=this is a \\\'string\\\'\\: ...)。
    3. shell 命令行:根据 shell 规则转义(如 Bash 中\需再转义为\\)。
  • 简化方式 :使用文件传递参数,如drawtext=/text=/tmp/some_text(从文件加载文本)。

更加详细的滤镜使用说明请参阅官方文档:

https://ffmpeg.org/ffmpeg-filters.html

相关推荐
REDcker2 天前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
gihigo19982 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
山河君2 天前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
音视频牛哥2 天前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器
qq_416276422 天前
通用音频表征的对比学习
学习·音视频
美狐美颜sdk2 天前
Android全局美颜sdk实现方案详解
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
EasyDSS2 天前
私有化部署EasyDSS视频点播能力:全链路视频技术赋能,打造企业级视听新体验
音视频·hls·m3u8·点播技术·智能转码
qq_416276422 天前
DeLoRes——一种通用的音频表征学习新方法(DeLoRes(基于 Barlow Twins 的冗余最小化方法)
学习·音视频
Q_4582838683 天前
从定位到视频:808 + 1078 在各行业的落地实践
音视频
山顶望月川3 天前
实测MiniMax-Hailuo-02:当“开工大吉“变成“无字天书“,国产AI视频模型的能与之不能
人工智能·音视频