NodeJS实现视频转码的示例代码

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

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

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

ffmpeg

FFmpeg是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。采用LGPL或GPL许可证。它提供了录制、转换以及流化音视频的完整解决方案。它包含了非常先进的音频/视频编解码库libavcodec,为了保证高可移植性和编解码质量,libavcodec里很多code都是从头开发的

下面就为大家介绍一下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方法可以设置格式。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 使用node.js对音视频文件加密的实例代码

    废话不多说了,直接给大家贴代码了,具体代码如下所示: fs.readFile('./downsuccess/'+name+'', {flag: 'r+', encoding: ''}, function (err, data) { console.log('读取中') if(err) { return; } let b = new Buffer(data); let c = b.toString('hex'); let cipherBuffer = _this.cipher(data); fs.

  • 详解NODEJS基于FFMPEG视频推流测试

    以ffmpeg为核心,包装一款局域网内接收转码并推送互联网的客户端软件.本文仅使用ffmpeg基础功能,拉流.转码.推流及简单播放设置. 工作流程 拉取远端视频流,视频流格式为 rtsp 转换为常用播放格式 rtmp 推送至播放端口 rtmp://您的推送端地址,用户使用播放软件连接该地址后可以直接进行内容播放 所需工具及软件 1.ffmpeg 命令行工具官网链接,选择它的优势在于: 免费 无需安装,很大的减少用户操作复杂度 命令行启动调用 2.nodejs 版本号为 v6.11.3.(实际项目

  • 解决node-webkit 不支持html5播放mp4视频的方法

    原因: mp4似乎是有专利的影音格式.node-webkit不对其进行支持-- 似乎是.. 解决方法 : 在本地安装chrome浏览器,进行安装目录(例:c:\Google\Chrome\Application\37.0.2062.103),找到ffmpegsumo.dll文件. 复制(ffmpegsumo.dll)并替换node-webkit目录下的ffmpegsumo.dll. 注:由于chromium 版本众多,所以,下载的chrome浏览器的chromium版本要与node-webkit

  • NodeJS实现视频转码的示例代码

    视频转码就是一个先解码,再编码的过程,从而将原来的视频转换成我们需要的视频.这种转换可能包括各式(mp4/avi/flv等).分辨率.码率.帧率等. 传统的视频转码中,很常用的工具是FFmpeg.FFmpeg是一套可以用来记录.转换数字音频.视频,并能将其转化为流的开源计算机程序. 在nodejs中,也有FFmpeg,叫做node-fluent-ffmpeg.node-fluent-ffmpeg是一个node上可用的ffmpeg,使用前必须先安装了ffmpeg. ffmpeg FFmpeg是一套

  • Python实现视频自动打码的示例代码

    目录 序言 准备工作 实现原理 模块 素材工具 代码解析 完整代码 序言 我们在观看视频的时候,有时候会出现一些奇怪的马赛克,影响我们的观影体验,那么这些马赛克是如何精确的加上去的呢? 本次我们就来用Python实现对视频自动打码! 准备工作 环境咱们还是使用 Python3.8 和 pycharm2021 即可 实现原理 将视频分为音频和画面: 画面中出现人脸和目标比对,相应人脸进行打码: 处理后的视频添加声音: 模块 手动安装一下 cv2 模块 ,pip install opencv-pyt

  • Android ZxingPlus精简的二维码框架示例代码

    这个二维码框架不仅使用的代码少,而且可以生成带图片的二维码,而且二维码扫描界面也是先做好的,也比较好看.我们所需要做的就是在扫描二维码后得到的数据对其进行操作. 使用方法 添加依赖 compile 'com.singleshu:ZxingPlus:1.1.4' 代码 public class MainActivity extends AppCompatActivity { TextView test; ImageView imageView; @Override protected void o

  • Java生成中间logo的二维码的示例代码

    最近有负责微信开发,对于微信开发的项目,肯定少不了二维码啦,正好有个这样的需求,这对不同的商品生成一个二维码,扫码即刻下单.博主就弄了一个二维码生成的工具类. 弄出来之后,产品经理又说了,中间放上公司的logo是不是好一点?加上吧, 加上公司logo之后,产品经理想了想,每个商品都有个二维码,销售人员有很多个商品二维码,群发给用户,在qq群上,微信群上,怎么知道哪个二维码对应哪个商品的呢?于是决定要加上商品名称.最后商品二维码就成了下面这个模样了(当然啦,这里面的logo并不是博主现职公司的).

  • three.js 制作动态二维码的示例代码

    今天郭先生说一下用canvas解析图片流,然后制作一个动态二维码的小案例,话不多说先上图,这是郭先生的微信二维码哦! 1. 解析图片流 canvas = document.createElement('canvas');//创建canvas画布 content = canvas.getContext('2d');//获取画布的上下文 canvas.width = 310;//设置尺寸 canvas.height = 310; img = new Image();//创建一张图片 img.src

  • C#/VB.NET 在Word中添加条码、二维码的示例代码

    本文介绍如何通过C# 和VB.NET代码实现在Word文档中添加条码和二维码.代码中将分为在Word正文段落中.页眉页脚中等情况来添加. 使用工具: Free Spire.Office for .NET (免费版) 工具简介: 这是Spire所有.NET平台下免费产品的集合包,包含Spire.Barcode.dll.Spire.DataExport.dll.Spire.Pdf.dll.Spire.Doc.dll.Spire.DocViewer.Forms.dll .Spire.PdfViewer

  • java使用jar包生成二维码的示例代码

    使用java进行二维码的生成与读取使用到了谷歌的zxing.jar 第一步 导入,maven依赖或者下载指定jar包 <!-- https://mvnrepository.com/artifact/com.google.zxing/javase --> <dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version

  • Nodejs实现微信分账的示例代码

    公司的业务的场景需要用到微信分账的功能.对着官网文档调试了一下午才调通.记录下使用Nodejs微信分账的流程. 前提条件 在微信商户平台 产品中心->我的产品,支付扩展工具中 开通分账的功能 添加分账接收方. 这一步不设置的话回报一个*分账接收方关系不存在,请检查参数中每个接收方的关系.*错误 在商户平台获取商户id和secrect 需要将apiclient_cert.pem. apiclient_key传到服务器某个目录下面 具体实现 // @router post -> share -&g

  • js生成二维码的示例代码

    前段时间项目中需要开发扫描二维码查看信息的功能,在网上查了一些资料,把用过的方法进行总结需要导入一个qrcode的js 插件. 插件链接: qrcode.js下载地址,点击即可下载 一.一个简单的示例 如下:(仅供参考) <%-- Created by IntelliJ IDEA. User: ASUS author:xumz Date: 2021/2/27 Time: 10:33 搬运请备注 To change this template use File | Settings | File

  • Python实现视频画质增强的示例代码

    目录 前言 原理 实现步骤 拆分 处理 合成 效果 总结 前言 前面通过文章 几行代码,实现Python捕获.播放和保存摄像头视频!给大家介绍了如何读取.播放和保存视频,后面又通过文章 Python美图技术也就几行代码!给大家介绍了如何对图像的亮度.对比度.色度或者锐度进行调整,从而达到基本的图像处理操作. 其实,那两篇文章都是铺垫,都是为了给大家介绍如何对视频进行画质增强.本文将结合前面两篇文章的内容,来讲讲如何对视频画质进行增强. 想要直接看效果的,可以拉到文末. 原理 不知道大家小时候有没

随机推荐