ffmpeg 摄像头 声卡 录屏
使用gdigrab录制屏幕
// gdigrab 录屏
//-s 1920x1080 录制的屏幕宽度、高度
//- offset_x 100 偏移
// - offset_y 200 偏移
// 需要注意宽度、高度分别加上偏移以后不能超出屏幕
//例如 - s 1920x1080 - offset_x 100 - offset_y 200
//会有以下报错
//Capture area(10, 20),(1930, 1100) extends outside window area(0,-1440),(2560, 1080)desktop: I / O error
// - i desktop 录制屏幕
//-thread_queue_size 此选项设置从文件或设备读取时排队数据包的最大数量。低延迟 / 高速率的直播流,如果不及时读取数据包可能会被丢弃;设置此值可以强制 ffmpeg 使用单独的输入线程并在数据包到达时立即读取数据包。默认情况下,ffmpeg 仅在指定了多个输入时才执行此操作。
//-r 帧率
//libx264 使用 libx264 编码所有视频流并复制所有音频流。
//-acodec 设置音频编解码器,copy: 所选流的数据包应从输入文件传送并在输出文件中混合
//- f 强制输入或输出文件格式。通常会自动检测输入文件的格式,并根据输出文件的文件扩展名猜测格式,因此在大多数情况下不需要此选项。
常用操作
- 抓取整个屏幕保存图片
ffmpeg -f gdigrab -i desktop test.png
- 截屏指定区域
//调整截图区域需要在输入-i之前
ffmpeg -f gdigrab -s 500x500 -offset_x 100 -offset_y 100 -i desktop -frames:v 1 test.png
- 截屏指定窗口
//通过title指定窗口标题
//输出为jpg,若为png将存在透明窗口的问题
ffmpeg -f gdigrab -i title="Windows 7sp1 x64_677408 - VMware Workstation" -frames:v 1 test.jpg
- 截屏指定窗口指定区域
ffmpeg -f gdigrab -s 500x500 -offset_x 100 -offset_y 100 -i title="Windows 7sp1 x64_677408 - VMware Workstation" -frames:v 1 test.jpg
- 录制屏幕为视频文件
ffmpeg.exe -r 1 -f gdigrab -i desktop -vcodec libx264 a.mp4
- 录制屏幕指定区域
ffmpeg.exe -r 1 -f gdigrab -s 500x500 -offset_x 100 -offset_y 100 -i desktop -vcodec libx264 a.mp4
- 录制屏幕为直播流
ffmpeg -thread_queue_size 1000 -r 30 -f gdigrab -s 1820x880 -offset_x 100 -offset_y 200 -i desktop -vcodec libx264 -acodec copy -preset:v ultrafast -tune:v zerolatency -max_delay 10 -g 50 -sc_threshold 0 -f flv rtmp://xxxxxx
- 将摄像头的图像和麦克风的音频录制保存成一个文件
ffmpeg -f dshow -i video="USB 2861 Device" -f dshow -i audio="线路 (3- USB Audio Device)" -vcodec libx264 -acodec aac -strict -2 mycamera.mkv
- 录制桌面和电脑播放的声音
需要注意打开立体声混音
右键任务栏声音图标 → 声音设置 → 声音控制面板。
在 录制 选项卡中,右键空白处 → 显示已禁用的设备。
启用 立体声混音(或类似选项)。
ffmpeg -f gdigrab -framerate 30 -i desktop -f dshow -i audio="立体声混音 (Realtek(R) Audio)" output.mp4
- 列出所有的音视频设备
ffmpeg -list_devices true -f dshow -i dummy
- 录制屏幕、声卡、扬声器
[1:a][2:a]:选择第 2 个输入(麦克风)和第 3 个输入(扬声器)的音频流。
amix=inputs=2:合并 2 个音频输入为一个混合流。
[a]:将混合后的音频流命名为 a,供后续 -map 引用。
-map 0:v:选择第一个输入(桌面)的视频流。
-map "[a]":选择合并后的音频流。
ffmpeg -f gdigrab -framerate 30 -i desktop
-f dshow -i audio="麦克风阵列 (适用于数字麦克风的英特尔® 智音技术)"
-f dshow -i audio="立体声混音 (Realtek(R) Audio)"
-filter_complex "[1:a][2:a]amix=inputs=2[a]"
-map 0:v -map "[a]"
-vcodec libx264 -preset ultrafast -crf 23
-acodec aac -b:a 192k
output.mp4
留待后查,同时方便他人
联系我:renhanlinbsl@163.com
联系我:renhanlinbsl@163.com
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具