ffmpeg 视频处理有fluent-ffmpeg例子

2019-10-23 10:23:43

这里有简单的ffmpeg-fluent一个例子

参考地址  ffmpeg 视频处理


  • 给 input.mp4 视频,加上 input.png 水印 位置为 x:y

ffmpeg -i input.mp4 -i input.png -filter_complex overlay=x:y -acodec copy output.mp4
  • 拼接两个视频,按照 input.txt 中的顺序 ,两个视频必须同样的尺寸

// input.txt 的内容// file 'input1.mp4'// file 'input2.mp4'ffmpeg -f concat -safe 0 -i input.txt -c copy output.mp4
  • 加文字水印

ffmpeg -i input.flv -vf "drawtext=fontfile=simhei.ttf: text='雷':x=100:y=10:fontsize=24:fontcolor=yellow:shadowy=2" drawtext.mp4
  • 加上node

const ffmpeg = require('fluent-ffmpeg');var fs = require('fs');var path = require('path');var vname = '6619626578831740000';var input = './input';var output = './output';var middle = './middle';// 用 endingH 生成 endingW 视频// ffmpeg(path.join(__dirname, middle, `endingH.mp4`))// .size('960x540').autopad('black')// .on('error', function (err) {//     console.log('生成endingW视频发生错误: ' + err.message);// }).on('end', function () {//     console.log('生成endingW视频成功');// }).save(path.join(__dirname, middle, `endingW.mp4`));new Promise((resolve) => {

    ffmpeg(path.join(__dirname, input, `${vname}.mp4`))
    .ffprobe(0, function(err, metadata) {
        !!err && console.log('无法读取视频大小:' + err.message);
        var endName = metadata.streams[0].height > 600 ? 'endingH' : 'endingW';
        var out = fs.createWriteStream(path.join(__dirname, middle, 'input.txt'), 'utf8');
        out.write(`file '${path.join(__dirname, input, vname)}.mp4'\nfile '${path.join(__dirname, middle, endName)}.mp4'`)
        out.end;
        out.on('ready', function () {
            console.log('创建文本成功');
             resolve();
        });
    });}).then(() => {

    return new Promise((resolve) => {
        ffmpeg(path.join(__dirname, middle,'input.txt'))
        .inputOptions(
            '-f','concat',
            '-safe','0'
        ).on('error', function (err) {
            console.log('合并视频发生错误: ' + err.message);
        }).on('end', function () {
            console.log('合并视频成功');
            resolve();
        }).save(path.join(__dirname, middle, 'first.mp4'));
    });
    }).then(() => {

    return new Promise((resolve) => {
        ffmpeg(path.join(__dirname, middle, 'first.mp4'))
        .input(path.join(__dirname, middle, 'logo.png'))
        .inputOptions(
            '-filter_complex','overlay=10:10'
        ).on('error', function (err) {
            console.log('水印添加错误: ' + err.message);
        }).on('end', function () {
            console.log('水印添加成功');
            resolve();
        }).save(path.join(__dirname, middle, 'second.mp4'));
    });}).then(() => {

    return new Promise((resolve) => {
        ffmpeg(path.join(__dirname, middle, 'second.mp4'))
        .videoFilters("drawtext=fontfile=simhei.ttf:text='tttttTTT':x=100:y=10:fontsize=24:fontcolor=yellow:shadowy=2")
        .on('error', function (err) {
            console.log('文字水印添加错误: ' + err.message);
        }).on('end', function () {
            console.log('文字水印添加成功');
            resolve();
        }).save(path.join(__dirname, output, `${vname}.mp4`));
    });}).then(() => {
    console.log(path.join(__dirname, output, `${vname}.mp4`));})// [https://github.com/Nana-Cti/fluent-ffmpeg-watermark](https://github.com/Nana-Cti/fluent-ffmpeg-watermark)
1人点赞
游戏与3D效果
作者:总有妖孽勾引我_cf18
链接:https://www.jianshu.com/p/25816cc8a6bc
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


  • 2018-12-13 17:17:02

    轻松实现动态获取Android手机CPU架构类型

    .so文件是unix的动态连接库,是二进制文件,作用相当于windows下的.dll文件。 他使用了C/C++代码编写的可以操作硬件比java更高级的 底层代码,执行速度和效率比其他语言要高。 在Android中调用动态库文件(*.so)都是通过jni的方式。

  • 2018-12-13 22:48:48

    Android MultiDex实践:如何绕过那些坑?

    MultiDex, 顾名思义,是指多dex实现,大多数App,解压其apk后,一般只有一个classes.dex文件,采用MultiDex的App解压后可以看到有classes.dex,classes2.dex,… classes(N).dex,这样每个dex都可以最大承载65k个方法,很大限度地缓解了单dex方法数限制。

  • 2018-12-14 13:32:18

    解决chrome调试手机模式没有鼠标问题

    F12后,切换到手机模式,方向没有鼠标,这对于调试前端页面来说无疑是一大难题,看不见只能盲点, 以为是浏览器问题,清理缓存,升级浏览器,清除插件等都不好使。 后来查到资料说是显卡问题。果然还真是显卡问题。

  • 2018-12-14 17:12:51

    Android APP适配全面屏手机的技术要点

    全面屏是手机业界对于超高屏占比手机设计的一个宽泛的定义。从字面上解释就是,手机的正面全部都是屏幕,四个边框位置都是采用无边框设计,追求接近100%的屏占比。但受限于目前的技术,还不能做到手机正面屏占比100%的手机。现在业内所说的全面屏手机是指真实屏占比可以达到80%以上,拥有超窄边框设计的手机。

  • 2018-12-14 17:15:50

    Android适配刘海屏沉浸式状态栏的一些坑

    18年简直是刘海元年,所有手机都在跟风刘海屏,甚至每个厂商还有自己的一套适配规范。我的初始需求很简单,就是做一个全屏显示的页面,一般情况下只需要开启Android规范的全屏模式就好:

  • 2018-12-16 12:12:12

    android:windowSoftInputMode属性具体解释

    android:windowSoftInputMode属性一共同拥有9个取值。各自是: stateUnspecified,stateUnchanged。stateHidden,stateAlwaysHidden。stateVisible,stateAlwaysVisible,adjustUnspecified,adjustResize。adjustPan。

  • 2018-12-16 18:14:23

    Android在代码中设置状态栏半透明/全透明

    顶部是有文字,小图标等,如果直接用透明半透明 状态栏上的东西会与内容重叠(你觉得无所谓也可以直接用上面2部分代码),这样我们就想做成类似支付宝这样的效果: