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

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

月光魔力鸭

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

背景

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

原始目录结构

-- 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


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
尝试下使用nodejs下开源图像识别库来识别图像状态。
互联网应用经常需要存储用户上传的图片,比如facebook相册。 facebook目前存储了2600亿张照片,总大小为20PB,每张照片约为80KB。用户每周新增照片数量为10亿。(总大小60TB),平均每秒新增3500张照片(3500次写请求),读操作峰值可以达到每秒百万次
最近家里正在装修,实在是不知道怎么做,之前看好好住APP上有不少设计的图,部分还挺好看。。就去看了下有没有WEB端,结果还真有,就有了下文,我抓了几万张图片,然后根据关键字进行分类,从里面找心仪的设计。
前段时间做了个微信小程序反编译的小东西,不过因为功能不全,没加分包处理,正好处理下加上,又考虑到后续可能的更新情况,准备上手增加下更新功能。
由于国家的行政区划每年都有变化,所以经常需要更新最新的数据,这里提供一个nodejs版本mysql数据存储的抓取示例。
因为自己的记录笔记的应用是有道云,又想着把有道云跟自己的小网站联通起来,所以查找了有道云的,然后实现了nodejs版本的sdk.
在开发的时候,经常会有css js 文件的变更,然后部署后发现没有起到作用,最终发现是缓存的问题,如何来方便的解决