FFMPEG 实现混音,加水印,加文字,模糊水印任意滤镜组合

2019-01-12 22:53:30

一共15种组合一下搞定;先伪代码没逻辑错误,然后就撸正式代码,后面测试就有点小顺利了

伪代码:

根据参数构造ffmpeg参数命令
构造元素视频方面有水印,文字,去水印;音频方面有混音一个
构造顺序: 先音频后视频 1:音频 2:水印 3:文字 4:去水印
伪代码
audioExist = false
videoExist = false
var filterPara string
var tailPara string
cmd += ffmpeg -loglevel verbose -i a.mp4
if(音频||水印||文字||去水印)
    filterPara += -filter_complex 
if(音频)
    cmd += -i b.mp3
    filterPara += "[0:a][1:a]amix=inputs=2:duration=shortest:dropout_transition=2[a]"
    tailPara += '-map 0:v:0 -map "[a]"'
    audioExist = true
if(水印)
    cmd += -i c.jpg
    if(audioExist)
        filterPara += ;[2:v]scale=94:167[vv];[0:v][vv]overlay=102:102
    else
        filterPara += [1:v]scale=94:167[vv];[0:v][vv]overlay=102:102
    videoExist = true
if(文字)
    if(!audioExist&&!videoExist)
        filterPara += ""
    else if(videoExist)
        filterPara += ","
    else 
        filterPara += ";"
    filterPara += ...
    videoExist = true
if(去水印)
    if(!audioExist&&!videoExist)
        filterPara += ""
    else if(videoExist)
        filterPara += ","
    else 
        filterPara += ";"
    filterPara += ...
tailPara += -f mp4 -movflags faststart fileName.mp4 -y
 
cmd += filterPara + tailPara



测试

4个滤镜全组合: 4+6+4+1 = 15种情况

四个全选

//音频+水印+文本+去水印  

curl -i -d '{"audiourl":"http://zxw-ybktest.chinacloudapp.cn/otvcloud_y1cc0ca0-f176-44d3-9d6c-d0634e71c5f6.mp3","cpid":"yz","mp4url":"http://183.131.106/lzy2214test.mp4","returl":"http://180.11.29.170:8880/backend-web/content/recReEditUrl.do","taskid":"1","imagelayers":{"height":"167","offsetX":"102","offsetY":"102","src":"http://13.131.159.21:1006/lzy/1522458959462-1522458959386_24_u=657178443,1345964771&fm=27&gp=0.jpg","width":"94"},"delogo":{"height":"20","offsetX":"10","offsetY":"10","width":"100"},"txtlayers":[{"fontColor":"#000000","fontSize":"14","offsetX":"305","offsetY":"277","text":"world"},{"fontColor":"#000000","fontSize":"14","offsetX":"100","offsetY":"100","text":"hello"}]}' http://183.11.19.27:8080/editvod



  • 2019-11-21 18:13:08

    如何在vue单页应用中使用百度地图

    百度开发者平台已经封装了基于vue的地图组件,详细使用,请参考官网: https://dafrok.github.io/vue-baidu-map/#/zh/start/installation 网上有一些是直接在index.html页面全部引用的,本人强烈反对此种使用方式,因为我们项目是组件化的单页应用,强行引入多页应用的开发方式,会破坏整个项目的框架,严重影响性能。有些甚至还在vue单页应用中引入jquery,感觉这都是一些反人类的骚操作,不到万不得已,不建议使用。

  • 2019-11-25 17:04:10

    Throttle 和 Debounce 的本质及一个简单的实现

    Throttle,Debounce 就不把这两个词翻译成中文了,直接解释他们的概念。实际上这两个东西本质上是一样的,作用都是「为了避免某个『事件』在『一个较短的时间段内』内连续被触发从而引起的其对应的『事件处理函数』不必要的连续执行」。那么区别在哪呢?

  • 2019-11-25 17:05:44

    js实现 throttle 和 debounce,节流,防抖详解

    throttle 节流:drag改变浏览器大小,触发onresize函数,实现拖动每过1秒输出一次,不足1秒,1秒后输出一次。多用于高频操作,如抢票、抢购等,无论点击多少次,只固定间隔执行一次,以减轻压力。debounce防抖:drag改变浏览器大小,触发onresize函数,实现拖动停顿1秒输出。多用于输入框,当某一次输入后停顿满n秒才会去触发远程搜索。

  • 2019-11-25 17:37:01

    百度地图GeoUtils示例

    百度地图JavaScript开源库,是一套基于百度地图API二次开发的开源的代码库。目前提供多个lib库,帮助开发者快速实现在地图上添加Marker、自定义信息窗口、标注相关开发、区域限制设置、几何运算、实时交通、检索与公交驾车查询、鼠标绘制工具等功能。