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
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


  • 2020-04-17 11:29:23

    TweenMax中文初级教程四

    用于滚动窗口(类似于window.scrollTo(x, y))或DOM元素(如myDiv.scrollTop = y; myDiv.scrollLeft = x;)。滚动窗口时使用window作为动画目标。

  • 2020-04-17 14:06:29

    图片解释EaseIn,EaseOut,EaseInOut

    1.EaseIn:即缓动发生在入口处,也就是刚开始的时候。 2.EaseOut:即缓动发生在出口处,也就是结束之前。 3.EaseInOut:就是两边都有缓动了.

  • 2020-04-21 14:47:13

    Redis危险命令重命名、禁用

    flushdb,清空数据库 flushall,清空所有记录,数据库 config,客户端连接后可配置服务器 keys,客户端连接后可查看所有存在的键

  • 2020-04-21 15:13:15

    redis 简单使用

    Redis和Memcached类似,也属于k-v数据存储 Redis官网 https://redis.io支持更多value类型,除了和string外,还支持hash、lists(链表)、sets(集合)和sorted sets(有序集合) Redis是可以把数据存储在磁盘上的并且使用了两种文件格式:全量数据(RDB)和增量请求(aof)。一般叫做redis持久化 全量数据格式是把内存中的数据写入磁盘,便于下次读取文件进行加载。

  • 2020-04-21 15:14:20

    SpringBoot + Redis:基本配置及使用

    # Redis数据库索引(默认为0) spring.redis.database=0# Redis服务器地址 spring.redis.host=127.0.0.1# Redis服务器连接端口 spring.redis.port=6379# Redis服务器连接密码(默认为空) spring.redis.password=# 连接池最大连接数(使用负值表示没有限制) spring.redis.jedis.pool.max-active=20# 连接池最大阻塞等待时间(使用负值表示没有限制) spring.redis.jedis.pool.max-wait=-1# 连接池中的最大空闲连接 spring.redis.jedis.pool.max-idle=10# 连接池中的最小空闲连接 spring.redis.jedis.pool.min-idle=0# 连接超时时间(毫秒) spring.redis.timeout=1000

  • 2020-04-22 10:49:10

    css按钮特效大全

    打开这个连接,你会发现很多按钮动画脚本,基本这些动画就够大家用的了。