Flutter:如何使用flutter_ffmpeg为视频添加水印和文字等叠加层?
Posted
技术标签:
【中文标题】Flutter:如何使用flutter_ffmpeg为视频添加水印和文字等叠加层?【英文标题】:Flutter: How to use flutter_ffmpeg to add overlays like watermarks and texts to a video? 【发布时间】:2021-09-29 04:30:15 【问题描述】:我尝试在我的应用中实现video_editing
功能,我尝试了Tapioca Package 和Video_Manipulation package,但发现它们都不符合我的标准,所以我把最后的希望寄托在@ 987654323@.
但是当我在 pub.dev 上阅读它的官方文档时,我脑海中的并不是什么,而是 “WHAT THE HECK”,我无法理解这些命令的用途,尽管我找不到与向视频添加小部件叠加层相关的任何内容。而且网上几乎没有教程解释如何使用它。
因此,如果您使用 ffmpeg 包成功地将 watermarks/texts 添加到视频中,请告诉我如何操作。 谢谢!~
【问题讨论】:
【参考方案1】:ffmpeg -i video.mp4 -i logo.png -filter_complex "[0:v][1:v]overlay=5:5,drawtext=text=:x=(w-0)/8:y=(h-4)/10:fontsize=64:fontcolor=white:ryanwangTV" -c:a copy -movflags +faststart output.mp4
ffmpeg -i video.mp4 -i logo.png
有需要工作的视频和我们想要应用水印的 png 图像
video.mp4 有两个“部分”一个视频和一个音频文件,记住它
logo.png 是一个单一的图像,但它是一个持续时间为毫秒的“视频”。
video.mp4 和 logo.png 的部分如何命名?
使用映射,对于文件 1),您将调用 [0],对于文件 2 (logo.png),您将使用 [1]
如果你想使用video.mp4的视频你会调用[0:v],而png的视频是[1:v]
对于水印,使用过滤器复合物,以“混合”视频上的图像
"[0:v][1:v]overlay=5:5,drawtext=text=:x=(w-0)/8:y=(h-4)/10:fontsize=64:fontcolor =white:ryanwangTV
[0:v][1:v] 是 video.mp4 的视频和 logo.png 的图像 overlay=5:5 前5个是主视频,后5个是视频要放在的图像。
x=(w-0)/8 : 是坐标 x y=(h-4)/10 : 坐标 y
fontsize=64 fontcolor=white,最终的词是你的文字
想在视频中画画
-c:a copy 它的意思:复制文件1的音频
-movflags +faststart : 是在浏览器上为互联网用户快速启动
output.mp4 是最终名称
【讨论】:
谢谢@stevejobs,但对此有何解释?我不明白[0:v][1:v]
部分。
我试了很多次,但是Flutter_VideoPlayer无法播放处理后的视频,你能帮我看看我哪里错了吗?这是我的new question link。以上是关于Flutter:如何使用flutter_ffmpeg为视频添加水印和文字等叠加层?的主要内容,如果未能解决你的问题,请参考以下文章
如何在flutter中使用flutter_webview_plugin和AndroidX
如何使用 flutter_webview 插件在 Flutter 中启用位置?
如何通过 FlutterView 或 Flutter.createFragment 使用平台通道
Flutter 和 Amplify/Cognito:如何使用 Flutter 更新 Amplify/cognito 中的电话号码
如何在 Flutter 的原生 C++ 中使用 OpenCV 4(2021 年)(支持 Flutter 2.0)? [关闭]