FFmpegFreeUI(简称 3FUI)是在 Windows 上的 FFmpeg 的专业交互外壳,使用 .NET 10 框架,使用纯 WinForm 开发,配合 SunnyUI 和自绘制打造专业高效的暗黑风格界面。
设计定位:3FUI 的目标是做一款轻度专业参数调整的转码软件,并非行业深度专业软件;让普通人能够通过图形化界面接触到较为全面的通用参数来轻松压制和转换格式。
广告词:难以忍受格式工厂的烦人捆绑?行业专业软件限制太多?小作坊产品过于业余?来用 3FUI 就对了,专注转码,不干别的,真免费,真自由,真专业,真开源!
3FUI 是一个完全倒贴开发的项目,除了用户自愿赞助以外没有任何收入来源。如果我的设计对你有帮助,请帮助我宣传或者考虑资金支持,点击仓库的赞助按钮来前往赞助页。另:我不会接受任何广告植入合作!
使用时间一长就炸的主要原因是系统息屏和杀毒软件拦截
请检查这些事项:
- 任务进行时关闭杀毒软件,或添加此程序到白名单
- 尽可能不要在任务期间插拔显示器或是更改显示器设置
- 在 0.6 版本之后,使用主页上的性能调度功能空出至少一个核心能有效缓解此问题,ffmpeg 把 CPU 性能吃完后 3FUI 就没有足够的性能去计算了,响应延迟越堆越多就会炸
- explorer 爆炸的时候会一并炸掉 3FUI,这个无解,正常重启 explorer 是没有问题的
-
底层逻辑基于预设
保存到 json 文件中,由用户自行管理,以及与他人分享
注意:不保证跨版本的兼容,因为参数项目和数据类型可能更改 -
专业参数,而非业余表述
低中高是什么玩意,真实参数才是真理
且大多数地方直接标出参数名称,更易于上手 -
智能交互
至少可以在一定程度上阻止炸膛的发生 -
准确显示 ffmpeg 输出的信息
更易于尝试新方案 -
实时计算剩余时间
剩余时间 = Max(总时长 - 已处理时长, 0) / 实时速度比值
你的时间非常值钱
-
预估最终输出大小
最终大小 = 已生成大小 / 进度百分比
当然这肯定是不准的,但有个大概总比没有强
-
可暂停!是的!真正可暂停
虽然 ffmpeg 自身并不支持暂停,但是 ntdll 可不会让着谁
这让你可以先暂停去奖励一下然后再继续烧机,而不是全程被硬控 -
完成后自动开始下一个
你先睡觉,让它自己转 -
干净无垃圾,不保存任何信息
没有用户设置,没有软件缓存,更不会碰注册表
不会在任何地方扔垃圾,也不会收集任何信息
- 首先需要明确,这只能用于 Windows,我没有能力开发其他系统的版本。
- 前往 FFmpeg 官网 下载最新的发行版,gyan.dev 和 BtbN 两者的发行皆可。
- 若选择 gyan.dev 的发行版,应该下载 ffmpeg-release-full.7z
- 若选择 BtbN 的发行版,应该下载 ffmpeg-master-latest-win64-gpl.zip
- 找到压缩包中的 ffmpeg.exe 可执行文件。
- 将 ffmpeg.exe 和我的 FFmpegFreeUI 放在同一个文件夹中。
或者将 ffmpeg.exe 加入环境变量中也可。 - 然后就可以正常使用了。
- 3FUI 没有针对酒吧的炒饭进行预防,非正常操作极易引发报错
- 要反馈任何问题,请到Q群:1050613952
选中一个错误的任务 然后将调试信息完整地截图 然后发给技术人员!
最好带上命令行,如果你不想让别人看到你的文件名,可以手动抹掉或在预设管理中复制!
如果有条件,请提供输入文件的详细参数,很多播放器都可以查看!
新手常见问题:执着于设置解码数据格式,我也是挺理解不了的
- 3FUI 使用 MIT 开源许可,可以自由地使用和分发此软件
- 仅发布于 GitHub,在其他平台看到的源代码都不是本人!
编码器类别 | 提供的编码 | 备注 |
---|---|---|
复制流 | copy | |
H.266/VVC | libx266 libvvenc |
266 还不成熟,需要大量性能,也没几个播放器放得出来 |
AV1 | libaom-av1 av1_nvenc av1_qsv av1_amf libsvtav1 rav1e |
如果没有可用的新显卡进行硬件加速,强烈建议考虑软件编码 libsvtav1 |
H.265/HEVC | libx265 hevc_nvenc hevc_qsv hevc_amf |
|
H.264/AVC | libx264 h264_nvenc h264_qsv h264_amf |
|
ProRes | prores_ks | |
VP9 | libvpx-vp9 | |
禁用 | -vn |
答:lib = CPU,nvenc = NVIDIA,amf = AMD,qsv = INTEL,再问紫砂
复制流、AAC、LAME MP3、FLAC、ALAC、WAV 16bit、WAV 24bit、WAV 32bit Float、Dolby Digital AC3、DTS Coherent Acoustics、Opus、Vorbis、True Audio、禁用
PNG、JPEG\JPG、WEBP、TIFF、AVIF、GIF、BMP、JPEG-LS、DPX、OpenEXR
方式 | 说明 |
---|---|
动态码率 VBR | 存储首选,硬件加速首选 配合 -cq 或 -qp 使用,VBR HQ 同理 |
动态码率 VBR HQ | 硬件加速专用 仅限 NVIDIA、INTEL、AMD 的 AV1、HEVC、H264 硬件加速编码器使用 其他编码器选这个等同于 ABR |
恒定质量 CRF | 存储首选,软件编码首选 -rc 并没有 crf 这个值,而是使用 -crf <?>,你需要在质量控制里填写它 |
恒定量化 CQP | 不推荐,主用于研究和特定场景 仅向 NVIDIA 和 AMD 的 AV1、HEVC、H264 硬件加速编码传递对应的参数 其他编码器选这个等同于 ABR |
平均码率 ABR | 相当于没有 -rc 参数,经典的转码 |
二次编码 TPE | 也不建议,二次编码不见得总会比单次编码好 只对 NVIDIA 的 HEVC 和 H264 硬件加速编码器传递参数 其他编码器选这个等同于 ABR |
恒定速率 CBR | 应该没什么人用这玩意,我知道还有个 CBR HQ,但恒定速率对于普通人来说真没什么意义 |
建议搭配 VBR HQ 使用,通常考虑为原视频的帧率
AMD 的硬件加速编码器不要写这个参数,写了也不会传递,已经预置高质量参数了
质量的默认值是 23,肉眼无损是 16,但仍需根据具体编码器调整
不要设置为 0!除非你知道自己在做什么以及需要什么
答:硬件加速选 VBR 和 HQ 搭配 -cq 使用,软件编码选 CRF;要想同时拥有画质和降低大小就不要想着设置比特率,去设置质量值,让编码器自己算;没有通用的方案也没有最好的方案,编码时间、画面质量、文件体积、解码性能,你总要至少放弃一样,不要想着全都要,都是按照自己的需求慢慢试出来的,只能给参考,没有作业抄。
- 画面缩放维持比例 scale
- 画面裁剪 crop
- 智能抽帧 select='gt(scene,?)',setpts=N/FRAME_RATE/TB
- 色彩管理 zscale
- 降噪 hqdn3d、nlmeans、atadenoise、bm3d、AviSynth(avs)
- 锐化 unsharp
- 转逐行 yadif
- 转隔行 tinterlace
- 响度标准化 loudnorm
画面裁剪滤镜 crop 的四个参数值是:裁剪宽度:裁剪高度:左上角X:左上角Y
在分辨率板块中打开此窗口,此界面独立,仅向主窗口上的那个文本框传递最终值,与已添加的文件无关。首先需要打开一个视频文件用于获取一帧预览图用来裁剪,在此之前可以设定时间戳来或者指定位置的帧,如果不设置默认获取第10秒的第一帧。此功能需要 ffmpeg 才能获取到视频帧。
获取到视频帧后,图片将以原分辨率显示,在图片上使用鼠标左右键来调整红框的尺寸,红框就是要裁剪的目标区域。左键控制左上角坐标,右键控制右下角坐标,如果按错了或者在越界的位置按下并拖动鼠标,则会自动互换功能。可以手动更改参数文本框的值然后按 Enter 键来微调红框,也就是可以反向操作。如果需要让红框保持固定比例或居中,也提供了相应的功能。在窗口右上角还有红框定位的放大镜视图,更方便精确定位。
我都写成这样了,软件里又写一遍,再不会用就去紫砂。
AviSynth 选项在降噪设置里提供,最后一个选项就是。3FUI 只能使用 avs 文件来加载,在开始前必须明确,3FUI 是设计用于批量处理的转码工具,因此这个加载逻辑也必然是这样设计的。当使用此滤镜时,avs 文件将取代输入文件的位置,3FUI 默认您不会在 avs 里处理音频,为了避免新手直接用发现视频声音没了,因此当选择此降噪时自动覆盖填写自定义参数和流控制参数,请注意检查。
首先下载这些 dll 文件:
- AviSynth.dll(在发行版中有个名为 filesonly 的那里面找)
https://github.com/AviSynth/AviSynthPlus/releases - LSMASHSource.dll
https://github.com/HomeOfAviSynthPlusEvolution/L-SMASH-Works/releases
此文件用于读取视频文件 - knlmeanscl.dll
https://github.com/Khanattila/KNLMeansCL/releases
此文件用于降噪 - fmtconv.dll
https://gitlab.com/EleonoreMizo/fmtconv
用于改变视频位深
将这些文件与 ffmpeg 放在一起!
在 3FUI 的目录下创建 AviSynth.avs 文件,此文件作为模板提供给 3FUI,在其中填写以下内容:
LoadPlugin("C:\xxxx\LSMASHSource.dll")
LoadPlugin("C:\xxxx\fmtconv.dll")
LoadPlugin("C:\xxxx\knlmeanscl.dll")
LWLibavVideoSource("<FilePath>")#读取文件中的视频流
fmtc_bitdepth(bits=16,dmode=1)#为KNLMeansCL降噪而提升位深
KNLMeansCL(d=2,a=3,s=4,h=3,channels="Y",wmode=3)#对亮度平面的降噪强度高于色度平面
KNLMeansCL(d=2,a=3,s=4,h=2,channels="UV",wmode=3)#对色度平面的降噪强度低于亮度平面
fmtc_bitdepth(bits=10,dmode=0)#为libsvtav1编码而降低位深
如果需要在avs中读取文件的音视频流可用以下模板
LoadPlugin("C:\xxxx\LSMASHSource.dll")
LoadPlugin("C:\xxxx\fmtconv.dll")
LoadPlugin("C:\xxxx\knlmeanscl.dll")
function LibavSource2(string path, int "atrack",
\ int "fpsnum", int "fpsden",
\ string "format", bool "cache")
{
atrack = Default(atrack, -1)
fpsnum = Default(fpsnum, 0)
fpsden = Default(fpsden, 1)
cache = Default(cache, true)
format = Default(format, "")
video = LWLibavVideoSource(path,
\ fpsnum=fpsnum, fpsden=fpsden, format=format,
\ cache=cache)
return (atrack==-2) ? video: AudioDub(video,
\ LWLibavAudioSource(path, stream_index=atrack, cache=cache))
}
LibavSource2("<FilePath>")#读取文件中的音视频流。atrack - 音频轨道号,默认为自动,如果为 -2,则忽略音频。cache - 如果为 true(默认值),则创建索引文件
fmtc_bitdepth(bits=16,dmode=1)#为KNLMeansCL降噪而提升位深
KNLMeansCL(d=2,a=3,s=4,h=3,channels="Y",wmode=3)#对亮度平面的降噪强度高于色度平面
KNLMeansCL(d=2,a=3,s=4,h=2,channels="UV",wmode=3)#对色度平面的降噪强度低于亮度平面
fmtc_bitdepth(bits=10,dmode=0)#为libsvtav1编码而降低位深
- LoadPlugin 方法用来加载这些 dll,不需要在这里加载 AviSynth.dll
dll 的路径请写绝对路径! - LWLibavVideoSource 加载视频文件,直接把第四行复制过去,3FUI 会自动替换这个文件路径
- fmtc_bitdepth 用于先为 KNLMeansCL 的降噪提升位深,而后为视频编码器的编码降低位深
- KNLMeansCL 就是降噪方法,其参数如下:
原文:https://github.com/Khanattila/KNLMeansCL/wiki/Filter-description
KNLMeansCL(clip, int d, int a, int s, float h, string channels, int wmode, float wref, clip rclip, string device_type, int device_id, bool lsb_inout, bool info)
参数名 | 说明 |
---|---|
clip | 不写 |
d | 前后参考帧数量,d=0 使用 1 帧,d=1 使用 3 帧,n=2*d+1,以此类推,值越大降噪效果越好 |
a | 搜索像素半径,a=1 使用 9 像素,a=2 使用 25 像素,n=(2*a+1)^2,以此类推,值越大降噪效果越好 |
s | 相似半径,默认 = 4,对性能的影响很小,这取决于噪声的性质 |
h | 过滤强度,默认 = 1.2,值越大,去除的杂色越多 |
channels | 设置要去噪的颜色通道。可能的值为 YUV、Y、UV |
wmode | 0 := Welsch weighting function has a faster decay, but still assigns positive weights to dissimilar blocks. Original Non-local means denoising weighting function. 1 := Modified Bisquare weighting function to be less robust. 2 := Bisquare weighting function use a soft threshold to compare neighbourhoods (the weight is 0 as soon as a given threshold is exceeded). 3 := Modified Bisquare weighting function to be even more robust. |
wref | 默认 = 1,相对于找到的最相似像素的权重,影响滤镜输出的原始像素量 |
rclip | 不写 |
device_type | accelerator、cpu、gpu、auto |
device_id | 显卡索引 |
lsb_inout | 没必要 |
info | 输出额外信息 |
3FUI 目前不会自动删除为每个文件生成的 avs 文件,这是为了方便检查有没有正常运行。