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

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

月光魔力鸭

2018-09-12 10:24 阅读 2061 喜欢 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


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
前几天给朋友帮忙,想要一个一模一样的网站...自告奋勇去帮忙.. 结果发现之前一直没处理过类似的情况,虽然也写过爬虫,不过看了下网站,也不算麻烦。于是简单实现了这个自动抓站的功能,最终整理成为一个自动抓站的工具,能省很多的事情。
最近在折腾的时候又想写less了,但是换框架了,成了thinkjs,考虑到开发阶段一直编译编译less的情况..最终根据middleware的特点实现了一个超级简单的less中间件。
开始入手webpack ,直接看的官方文档和demo,对于自动刷新这部分还是希望通过express 加载插件来控制,但是文档没有提供,经过参考github上其他高玩的套路,最终整理了一个基础的配置版本。
互联网应用经常需要存储用户上传的图片,比如facebook相册。 facebook目前存储了2600亿张照片,总大小为20PB,每张照片约为80KB。用户每周新增照片数量为10亿。(总大小60TB),平均每秒新增3500张照片(3500次写请求),读操作峰值可以达到每秒百万次
对于开发来说,看到别人家的小程序都这么靓,这么顺畅,这么好用,用户又多... 自然是眼馋的..用户馋不来,可以先馋他的身子..啊不,代码啊。
今天想在服务器上跑下自己自动签到的程序,需要安装puppeteer ,结果出错。 permission denied, mkdir '/root/.nvm/versions/node/v9.11.1/lib/node_modules/
通过imap 来接收邮箱新邮件,类似客户端系列,不过比较简单的,目前只有新邮件,后续也可以通过这个来做一个自己的邮件客户端。
使用nodejs连接ftp,进行ftp的操作,包括列表、上传、下载以及速率等。