windows下通过nodejs将音频和图片进行批量合并

windows下通过nodejs将音频和图片进行批量合并

月光魔力鸭

2018-09-12 10:24 阅读 646 喜欢 1 图片音频 合并

背景

客户有一批音频需要处理成视频,最好是带有图片,于是就有了下文。

原始目录结构

-- mp3
----01
------01.mp3
------01.jpg
----02
------02.mp3
------02.jpg

将目录全部处理成为同名,实现只是一个很简单的nodejs调用批处理操作,只是不用手动了。

ffmpeg 原始命令

ffmpeg -r 15 -f image2 -loop 1 -i d:/zzs/pp/2/index.jpg -i d:/zzs/pp/2/index.mp3 -s 720x480 -pix_fmt yuvj420p -t 567 -vcodec libx264 -y d:/zzs/pp/2/index.mp4

-loop 1 每帧循环
-s 分辨率
-t 输出视频时长

以上命令应该是能处理大部分的音频、图片吧 ,没有兼容测试,不过肯定会有其他问题,再进行微调就行。

代码

//将mp3 转化为mp4 文件

var ffmpeg = "d:/soft/ffmpeg/bin/";//ffmpeg path
var fs = require('fs');
var async = require('async');
var path = require('path');

//将目标下的文件夹获得,然后把里面的mp3 和 mp4 整合

function TOMP4( opts ){

    this.opts = opts;
    var arr = this.getFolder();
    this.start(arr);

}

//获得文件夹
TOMP4.prototype.getFolder  = function(){
    var thiz = this,opts = thiz.opts,target = opts.target;
    var arr = fs.readdirSync(target);
    return arr;
}
//获得mp3的时长,用于输出
TOMP4.prototype.getDuration = function( path,cb ){
    var exec = require('child_process').exec;
    exec(ffmpeg+'ffmpeg -i '+path,function(error,stdout,stderr){
        var std = error.toString();
        var bb = std.match(/Duration: ([0-9:.]*),/);
        var time = bb[1];
        console.log(time);
        var timeArr = time.split(':');
        var seconds = 0;
        timeArr.forEach(function( a, index ){
            a = Math.round(a);
            seconds += a * (index == 0 ? 3600 : (index == 1 ? 60 : 1));
        });
        cb(seconds);
    });
}
//调用命令转码
TOMP4.prototype.tomp4 = function(picpath,mp3path,topath,duration,cb){
    var exec = require('child_process').exec;
    console.log(mp3path+': 正在转化中,请等待....');
    exec(ffmpeg+'ffmpeg -r 15 -f image2 -loop 1 -i '+picpath+' -i '+mp3path+' -s 720x480 -pix_fmt yuvj420p -t '+duration+' -vcodec libx264 -y '+topath,function(err,stdout,stderr){
        console.log(mp3path+' 转化完成');
        cb(null,null);
    });
}
//启动入口
TOMP4.prototype.start = function( arr ){
    var thiz = this,opts = thiz.opts,target = opts.target,mp3 = opts.mp3,pic = opts.pic;
    async.mapLimit(arr,1,function(item,cb){
        thiz.transform(item,cb);
    },function(){
        console.log('全部转化完毕')
    });
}
//转化-函数
TOMP4.prototype.transform = function( item , cb ){
    var thiz = this,opts = thiz.opts,target = opts.target,mp3 = opts.mp3,pic = opts.pic,to = opts.to;
    var mp3Path = path.join(target,item,mp3);
    var picPath = path.join(target,item,pic);
    var toPath = path.join(target,item,to);
    thiz.getDuration(mp3Path,function(duration){
        thiz.tomp4(picPath,mp3Path,toPath,duration,cb);
    });
}

//调用
var aa = new TOMP4(
    {
        target : 'd:/zzs/pp/',
        mp3 : 'index.mp3',
        pic : 'index.jpg',
        to : 'index.mp4'
    }
);

代码逻辑

截图

处理结果.png

说明

代码比较粗糙,因为是临时性的工作,没有做很多的处理,只是勉强能用。

转载请注明出处: https://chrunlee.cn/article/nodejs-combo-picture-and-radio.html


感谢支持!

赞赏支持
提交评论
评论信息(请文明评论)
暂无评论,快来快来写想法...
推荐
在我们做运维或者小工具的时候,总会有些需要提醒的事情,比如服务器宕机或者天气提醒,但是发email又会不够及时或者可能会忽略,那么短信就是一个不错的选择了
thinkjs框架使用ueditor记录。
今天写文章,突然发现自己常用的素材站换成了webp格式的图片.. 可惜本站还没准备加这个支持,所以准备加个webp转jpg的小功能,继续使用啦。
当我们做爬虫或其他的一些应用的时候,如果需要一些短信验证,但是又没有那么多手机号,又不能放人在那里一直输入的时候?怎么办?
在使用puppeteer 跳转窗口的时候,发现waitForNavigator 并不起作用,最后找到通过browser 获得page 并继续操作。
前几天给朋友帮忙,想要一个一模一样的网站...自告奋勇去帮忙.. 结果发现之前一直没处理过类似的情况,虽然也写过爬虫,不过看了下网站,也不算麻烦。于是简单实现了这个自动抓站的功能,最终整理成为一个自动抓站的工具,能省很多的事情。
最近在折腾的时候又想写less了,但是换框架了,成了thinkjs,考虑到开发阶段一直编译编译less的情况..最终根据middleware的特点实现了一个超级简单的less中间件。
开始入手webpack ,直接看的官方文档和demo,对于自动刷新这部分还是希望通过express 加载插件来控制,但是文档没有提供,经过参考github上其他高玩的套路,最终整理了一个基础的配置版本。