nodeJs 实现视频的转换(超详细教程)

这篇具有很好参考价值的文章主要介绍了nodeJs 实现视频的转换(超详细教程)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前段时间拿到一个视频是4k的,没法播放,于是通过 node.js  和 ffmpeg 实现了视频的转换。在win10 系统下实现。

所需工具


node 16.19 直接安装

ffmpeg-5.1.1-essentials_build 解压后重名 ffmpeg 放到C盘 然后配置下环境变量
js视频流格式转换,音视频

Git-2.42.0.2-64-bit 直接安装

js视频流格式转换,音视频

安装完

建一个demo 的文件夹,

demo文件下建一个node-server

node-server文件下建一个server.js

// 服务器端代码(Node.js)

const express = require('express');
const path = require('path');


const app = express();
const { exec } = require('child_process');
const port = 3020;


// 配置静态资源文件夹
// app.use(express.static('./video'));




const assetsDir = path.join(__dirname, '../video');
// 将视频转换为1080p 函数
/**
 * 
 * @param {*} inputPath  原视频路径
 * @param {*} outputPath 转换后存放路径
 * ffmpeg: FFmpeg 是一个开源的音视频处理工具,可以用于录制、转换以及流式传输音视频内容。该命令表示要执行FFmpeg程序。
 *-i ${inputPath}: 这是一个选项参数,用于指定输入文件。${inputPath}是一个变量,用于指定输入文件的路径。这里将输入文件的路径作为变量传递给 -i 选项。
 *-s 1920x1080: 这是一个选项参数,用于设置输出视频的分辨率。1920x1080指定了输出视频的宽度和高度为1920像素和1080像素,即高清视频。
 *-c:v libx264: 这是一个选项参数,用于指定视频编解码器。libx264是一个开源的H.264视频编码器,用于压缩视频。
 *-crf 24: 这是一个选项参数,用于设置视频的质量。CRF代表“Constant Rate Factor”,值越低,视频的质量越高,但文件大小也越大。这里的24表示相对较高的质量。
 * ${outputPath}: 这是输出文件的路径,${outputPath}是一个变量,用于指定输出文件的路径。
 */

function convertVideoTo1080p(inputPath, outputPath) {
  const command = `ffmpeg -i ${inputPath} -s 1920x1080 -c:v libx264 -crf 24 ${outputPath}`;
  exec(command, (error, stdout, stderr) => {

    if (error) {
      console.error(`执行出错: ${error}`);
      return;
    }
    console.log('转换成功');
  });
}
 
//执行转换
convertVideoTo1080p(assetsDir  + '\\demo_4K.mp4',assetsDir  + '\\demo_1080p.mp4');



// 截取的时间点(第41秒)截取一张图片当封面用
const timePoint = 41;

/**
 * 截取视频一帧拿到图片
 * @param {*} videoFilePath  原视频路径
 * @param {*} outputImagePath  图片存放
 */
 function extractImageFromVideo(videoFilePath, outputImagePath) {
    // FFmpeg命令
    const ffmpegCommand = `ffmpeg -i ${videoFilePath} -ss ${timePoint} -vframes 1 ${outputImagePath}`;

    // 执行FFmpeg命令
    exec(ffmpegCommand, (error, stdout, stderr) => {
      if (error) {
        console.error('执行命令时出错:', error);
        return;
      }
      console.log('截取完成,已保存为 ' + outputImagePath);
    });

}

extractImageFromVideo(assetsDir  + '\\demo_4K.mp4',assetsDir  + '\\demo_cover.png');



app.listen(port, () => {
    console.log(`Server is running on http://localhost:${port}`);
});

再建一个package.json文件 

{
  "dependencies": {
    "child_process": "^1.0.2",
    "express": "^4.18.2",
    "qrcode": "^1.5.3"
  }
}

demo 文件夹下再建一个video文件夹 里面放一个视频 命名为demo_4k.mp4。

再demo 文件下打开git  执行

npm install
node  node-server/server.js

然后等待结果

js视频流格式转换,音视频

我的视频有300m,大概10分钟转换成功

js视频流格式转换,音视频

完活

如果图省事 就下载我的资源吧,https://download.csdn.net/download/weixin_37742709/89071492文章来源地址https://www.toymoban.com/news/detail-861289.html

到了这里,关于nodeJs 实现视频的转换(超详细教程)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • nodeJs 实现视频的转换(超详细教程)

    前段时间拿到一个视频是4k的,没法播放,于是通过 node.js  和 ffmpeg 实现了视频的转换。在win10 系统下实现。 所需工具 node 16.19 直接安装 ffmpeg-5.1.1-essentials_build 解压后重名 ffmpeg 放到C盘 然后配置下环境变量 Git-2.42.0.2-64-bit 直接安装 安装完 建一个demo 的文件夹, demo文件下

    2024年04月28日
    浏览(36)
  • Monibucav4(开源流媒体服务器)在Windows上搭建rtmp服务器并实现拉取rtsp视频流以及转换flv播放

    开源流媒体服务器ZLMediaKit在Windows上运行、配置、按需拉流拉取摄像头rtsp视频流)并使用http-flv网页播放: 开源流媒体服务器ZLMediaKit在Windows上运行、配置、按需拉流拉取摄像头rtsp视频流)并使用http-flv网页播放_srs按需拉流_霸道流氓气质的博客-CSDN博客 上面讲了ZLMediaKit的使用流

    2024年02月11日
    浏览(66)
  • 【精选】基于OpenCV的实时视频流车牌识别(源码&教程)

    近年来,智能交通系统(ITS)在我国应用日益广泛。作为ITS重要组成部分的自动车牌识别系统在交通流量检测、交通诱导控制、违章车辆监控等方面有着广泛的应用,是确保道路安全畅通的重要手段,也为统计有关资料,为管理者决策提供有效数字依据的重要途径。由于一般的识别系

    2024年01月23日
    浏览(63)
  • Android MediaCodec将h264实时视频流数据解码为yuv,并转换yuv的颜色格式为nv21

    初始化mediacodec 处理数据,解码h264数据为yuv格式 这里传入的是h264格式的实时视频流数据。 处理获取到的nv21颜色格式的yuv数据  yuv视频数据颜色格式转换 h264实时视频流的数据来源 写入h264视频流到sdcard中 rtsp获取h264实时视频流数据  编写C代码加载ffmpeg库 源码地址 https://gi

    2024年01月17日
    浏览(61)
  • web端播放rtsp视频流(摄像头监控视频)教程及window下开机自启动部署

    像海康大华一些摄像头或者直播源 为rtsp视频流,想在web上播放必须进行协议转换。已知一些方案例如rtsp转rtmp需要flash,现在浏览器基本不支持flash。还有转hls或者flv这些延迟都比较高。经过实践对比比较理想方案是 经转码后视频流通过websocket传送给客户端在将视频流解码成

    2024年04月10日
    浏览(72)
  • java实现video标签视频流播放

    问题: 在遇到video标签播放后端视频源时问题。直接返回文件流的话 video需要将文件整个下载一次才会播放。这样如果小文件没有问题。如果文件大的话就比较恶心了。 解决方案:通过模拟video标签默认的range bytes规范方法分段获取视频信息。 video标签是通过请求头带上 Ran

    2024年02月14日
    浏览(57)
  • QT实现OpenCV播放rtsp视频流

    使用OpenCV(图像处理)、FastDeploy(飞桨部署)库; 监控相机传输数据用的是码流,高清网络摄像机产品编码器都会产生两个编码格式,称为 主码流 和 子码流 。这就叫双码流技术。 目的是用于解决监控录像的本地存储和网络传输的图像的质量问题。双码流能实现本地和远程

    2024年02月03日
    浏览(69)
  • 安防监控项目---mjpeg-streamer视频图像显示(实时视频流实现)

    书接上期,我们已经实现了许多功能了,但是对于视频流的实时上传还未实现,本期主要分享的就是如何具体实现网页实时显示摄像头采集到的视频,从而实现安防中监控的功能,这个功能完成后呢,就只剩下一个功能需求了,那就是GPRS模块,能够实现危险报警的功能,也能

    2024年02月06日
    浏览(48)
  • Java后端接口返回视频流,使用video组件播放视频,实现分段下载

    视频文件保存在不为人知的地方,总之前端不能直接访问的位置,需要通过后端接口取出来再返回给前端。 前端这样子播放 src=后端接口 如果后端直接这样子写 小视频问题不大,视频大的话会卡顿很久,查看请求发现会先请求下载完整视频后开始播放。而且不能拖动进度条

    2024年02月12日
    浏览(45)
  • Windows上使用FFmpeg实现本地视频推送模拟海康协议rtsp视频流

    Nginx搭建RTMP服务器+FFmpeg实现海康威视摄像头预览: Nginx搭建RTMP服务器+FFmpeg实现海康威视摄像头预览_nginx rtmp 海康摄像头_霸道流氓气质的博客-CSDN博客 上面记录的是使用FFmpeg拉取海康协议摄像头的rtsp流并推流到流媒体服务器。 如果在其它业务场景下需要本地的视频文件模拟

    2024年02月12日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包