当前位置: 首页 > news >正文

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文件下建一个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

然后等待结果

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

完活

如果图省事 就下载我的资源吧,https://download.csdn.net/download/weixin_37742709/89071492

http://www.lryc.cn/news/330606.html

相关文章:

  • Transformer - model architecture
  • Zookeeper学习一
  • SAR教程系列7——在cadence中用Spectrum工具FFT仿真ADC的ENOB、SNR等动态性能指标
  • 攻防世界:mfw[WriteUP]
  • mysq性能优化-my.cnf配置文件参数调整
  • ddres( ) 组站星双差方程和设计矩阵
  • 【OpenCV】图像像素的遍历
  • (超简单)构建高可用网络应用:使用Nginx进行负载均衡与健康检查
  • 华为OD面试手撕算法-合并排序数组
  • 云智慧发布对象关系型数据库CloudPanguDB,打破传统技术壁垒
  • 6.8物联网RK3399项目开发实录-驱动开发之RTC实时时钟的使用(wulianjishu666)
  • VUE——概述
  • 合宙4G模块Air724UG调试过程(短信发送、上传数据到华为云IOT)
  • 【项目新功能开发篇】需求分析和开发设计
  • CentOS 7 下离线安装RabbitMQ教程
  • 【Servlet】session保存作用域
  • 企业周年庆3d云展厅促进了客企间交流与互动
  • Android Studio学习5——布局layout与视图view
  • 设计模式(15):迭代器模式
  • 前端内部技术分享---前端组件之表格组件的封装与使用(Vue3)
  • 【一】Mac 本地部署大模型
  • vue实现相机拍摄,可录视频、拍照片、前置后置切换(简单小demo)
  • 【项目】牛马点评 问题汇总
  • 使用 Docker Compose 部署邮件服务器
  • FastAPI+React全栈开发21 探索React路由器和其他好东西
  • Java pdfbox 给 PDF 添加文字和图片水印 并旋转45度
  • 微信小程序中路由跳转方式
  • Flutter应用发布前的关键iOS设备测试策略
  • 深入理解Linux环境配置文件:.bashrc、.bash_profile和.profile
  • 数据库设计规范(三大范式)