NodeJS实现视频转码

2019-01-21 09:41:54

视频转码就是一个先解码,再编码的过程,从而将原来的视频转换成我们需要的视频。这种转换可能包括各式(mp4/avi/flv等)、分辨率、码率、帧率等。


传统的视频转码中,很常用的工具是FFmpeg。FFmpeg是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。


在nodejs中,也有FFmpeg,叫做node-fluent-ffmpeg。node-fluent-ffmpeg是一个node上可用的ffmpeg,使用前必须先安装了ffmpeg。


下面就为大家介绍一下NodeJS实现视频转码的方法。




一、安装FFmpeg(MAC下)


在MAC下,可以直接使用brew命令进行安装:brew install ffmpeg。


安装成功后,我们就可以在命令行进行,利用ffmpeg的命令进行视频转码了。比如将input.avi转码成output.ts并设置视频码率640kbps,需要执行的命令如下:


ffmpeg -i input.avi -b:v 640k output.ts




二、node-fluent-ffmpeg模块基本使用方法


node-fluent-ffmpeg其实本质上就是通过nodejs在终端中执行FFmpeg的命令。node-fluent-ffmpeg的安装和基本引入和其他npm模块相同。通过npm安装后(npm install fluent-ffmpeg),使用require在js文件中引用即可。基本使用如下:


var ffmpeg = require(‘fluent-ffmpeg’);

var command = new ffmpeg(这里可以传入视频文件路径,或者流);

这样就实例化了一个命令行,需要传入要转码的视频文件,也支持数据流的形式。



三、使用实例


下面是使用node-fluent-ffmpeg进行视频转码的一个实例:


var ffmpeg = require('../index');

var command = ffmpeg('testvideo-5m.mpg')

  // set video bitrate

  .videoBitrate(1024)

  // set aspect ratio

  .aspect('16:9')

  // set size in percent

  .size('50%')

  // set fps

  .fps(24)

  // set audio bitrate

  .audioBitrate('128k')

  // set audio codec

  .audioCodec('libmp3lame')

  // set number of audio channels

  .audioChannels(2)

  // set custom option

  .addOption('-vtag', 'DIVX')

  // set output format to force

  .format('avi')

  // setup event handlers

  .on('end', function() {

    console.log('file has been converted succesfully');

  })

  .on('error', function(err) {

    console.log('an error happened: ' + err.message);

  })

  // save to file

  .save('outtest.avi');

node-fluent-ffmpeg可以进行链式调用,上面就在实例化后,链式设置了一系列的视频属性,最后监听end事件,表示视频已经转码完成。完成后可调用save()方法将视频文件存储到相应的目录。



四、node-fluent-ffmpeg可以做什么


node-fluent-ffmpeg可以做ffmpeg能做的任何事情,对视频进行任何的处理。此外,配合nodejs,node-fluent-ffmpeg还可以做许多其他事情,比如读取并动态返回视频长度、按照需求将视频转码成任意格式等。具体的各种方法可以到github上查看,上面有对方法的使用介绍。在使用时只要自取所需就可以很轻松的完成视频转码了。




五、视频转码的一些要素


上面的各个函数设定了视频的各个属性,下面简单为大家介绍一下视频转码中比较重要的一些属性,以及它们对应的node-fluent-ffmpeg中的方法。


1.fps:即视频的帧率,表示1s中画面刷新多少次。玩游戏的时候都清楚如果fps低的话游戏会很卡,这就是fps的作用。fps在一定范围内越高,则视频1s刷新的次数就越高,在人眼中展现的就越流畅。这个属性对应的方法是fps(),传入想设定的帧率值即可。


2.分辨率:用于设定视频的大小,对应的方法是size(),传入宽度x高度。


3.码率:在视频领域中,一般而言码率指的就是比特率。他表示数据传输时单位时间传送的数据位数,单位kbps。这个值影响的就是视频质量了,该值越大,视频的质量越高,但与此同时视频文件的大小就会越大。因此我们在转码时要合理设置码率,保证文件大小不超过限制的情况下质量尽可能高。


4.格式:这个就不用多说了,通过format方法可以设置格式。


  • 2017-04-15 13:34:08

    Android官方技术文档翻译——清单合并

    一般情况下,有三种类型的清单文件需要合并成一个最终的应用程序清单,这里按照优先级顺序列出: Product flavors 和构建类型所指定的清单文件。 应用程序的主清单文件。 类库的清单文件。

  • 2017-04-15 21:47:44

    Android开发笔记——圆角和边框们

    在做Android界面开发时,我们往往希望它尽可能优美,尽可能显得专业。于是你看了看其他应用,哇,好多边框和圆角啊。你是不是也想给自己的应用加上边框和圆角效果?呃……那怎么做呢?如果你是从web前端跑到Android来的,那么我想你一定想到了不下三种解决方案。如用图片替代,用CSS3定义,用JS画。在Android中,其实也有类似的用法,本文将简单介绍两种Android圆角和边框的实现。

  • 2017-04-15 21:49:06

    Android样式的开发:Style篇

    前面铺垫了那么多,终于要讲到本系列的终篇,整合所有资源,定义成统一的样式。 哪些该定义成统一的样式呢?举几个例子吧:

  • 2017-04-15 23:54:49

    ViewPager+Fragment取消预加载以及禁止滑动

    取消预加载 网上了解了很多取消预加载的方法,里面提到了使用一个viewpager的public方法setOffscreenPageLimit 经过查看源码以及验证发现该方法是管理Viewpager预加载的页数,最低也是默认为一页(例如ViewPager一共有4页,当前手机屏幕显示第一页

  • 2017-04-15 23:56:30

    onInterceptTouchEvent和onTouchEvent调用关系详解

    如果没有onInterceptTouchEvent,只考虑onTouchEvent的话,比较容易分析和理解。假如有三层布局结构,linearLayout1,linearLayout2,textView,从前到后是包含的关系。那么下面分情况说明。

  • 2017-04-16 19:36:32

    ViewPager预加载问题和onCreateView多次调用问题的解决

    1,在使用ViewPager嵌套Fragment的时候,由于VIewPager的几个Adapter的设置来说,都会有一定的预加载(默认是左右各一个Frament)。通过设置setOffscreenPageLimit(int number) 来设置预加载的熟练,在V4包中,默认的预加载是1,即使你设置为0,也是不起作用的,设置的只能是大于1才会有效果的。我们需要通过更改V4包中的默认属性才可以