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-26 11:08:02

    多边型无序点排序(地图绘制多边形)

    任务需求要做一个区域高亮的功能,用到地图,想到了高德地图的多边形API,但是多边形顶点的顺序是要有序的,需求是无序,在API查找无果的情况下,只能手动实现点集合排序。

  • 2019-11-26 11:11:59

    正多边形的编程绘制(javascript)

    如何用程序来绘制正多边形? 在一般情况下,会使用 x = radius * Math.cos(angle), y = radius * Math.sin(angle) 来进行绘制,但这是关于x轴对称的,如果遇到正多边形的边数为奇数,而你又希望它是以y轴对称时,可按照下面的方法。

  • 2019-11-26 13:36:28

    Vue组件命名找不到的问题以及如何给vue组件命名

    首先,Vue 会将 template 中的内容插到 DOM 中,以方便解析标签。由于 HTML 标签不区分大小写,所以在生成的标签名都会转换为小写。例如,当你的 template 为 <MyComponent></MyComponent> 时,插入 DOM 后会被转换为 <mycomponent></mycomponent>。 然后,通过标签名寻找对应的自定义组件。匹配的优先顺序从高到低为:原标签名、camelCase化的标签名、PascalCase化的标签名。例如 <my-component>会依次匹配 my-component、myComponent、MyComponent。camelCase 和 PascalCase 的代码

  • 2019-11-28 11:00:35

    Vue子组件调用父组件的方法

    下面有三种方法,我自己重点推荐第一种,毕竟这种简单粗暴好用好理解,不过这个有一个弊端,再组件嵌套组件的时候,尤其是用第三方组件里面调用自己的子组件的时候,其实已经是孙子组件了,这个时候就要parent.parent。。。。,这样就不好了,我们就得考虑其他方法了,具体怎么判断是父组件,还是爷爷组件,我会单独出一篇文章讲述。

  • 2019-11-29 13:04:47

    计算一个多边形的重心点坐标(准确版)

    在之前的 《如何判断一个多边形是否合法》 一文中有提到,用无人机规划飞行路线前,往往需要框选一个多边形的区域。 而在地图控件上显示这个多边形区域时,往往会遇到这样一个需求:需要把所要测绘的多边形区域移动到地图中心。 实现这个需求的基本思路就是:获取到多边形区域的重心点坐标,然后利用地图控件的 setCenter方法,就可以把地图的显示中心移动到多边形区域重心了。那么问题来了,如何求出一个多边形的重心点坐标呢?