0

0

C# AVIF图片格式转换 C#如何将图片编码为高效的AVIF格式

幻夢星雲

幻夢星雲

发布时间:2026-03-02 08:26:03

|

560人浏览过

|

来源于php中文网

原创

c#中avif编码需依赖imagesharp 4.x(配formats.avif包)或windows wic编解码器;imagesharp需显式注册格式、传avifencoder参数并确保libavif(linux/macos)或兼容包(windows)已安装。

c# avif图片格式转换 c#如何将图片编码为高效的avif格式

AVIF在C#中没有原生支持,得靠外部库

System.Drawing 和 ImageSharp 3.x 及更早版本都不支持 AVIF 编码;.NET 6+ 的 System.Drawing.Common 依然不支持。真正能用的路径只有两个:调用系统级编解码器(如 Windows 11 自带的 AVIF WIC 编解码器),或引入支持 AVIF 的第三方图像库。

目前最稳定、跨平台、可直接编码 AVIF 的选择是 ImageSharp 4.x(需搭配 ImageSharp.DrawingImageSharp.Formats.AVIF 扩展包)。

  • 必须安装 ImageSharp ≥ 4.0.0,旧版不识别 AvifEncoder
  • ImageSharp.Formats.AVIF 包不是可选依赖,漏装会报 NotSupportedException: No encoder found for format 'avif'
  • Linux/macOS 需确保系统有 libavif(例如 apt install libavif-dev),否则运行时报 DllNotFoundException

ImageSharp 4.x 编码 AVIF 的最小可行代码

核心是注册 AVIF 格式支持、配置 AvifEncoder 参数,并注意输出流必须可写且未被释放。

using SixLabors.ImageSharp;
using SixLabors.ImageSharp.Formats.Avif;
using SixLabors.ImageSharp.Processing;

// 必须显式注册格式(Image.Load 默认不启用 AVIF)
var image = Image.Load("input.jpg");
image.Mutate(x => x.Resize(800, 600)); // 可选缩放

using var stream = new MemoryStream();
var encoder = new AvifEncoder
{
    Quality = 65,           // 0–100,建议 50–80;低于 40 易出现块效应
    Speed = AvifEncodingSpeed.Balanced, // Fast / Balanced / Slow;Slow 压缩率高但耗时翻倍
    BitDepth = AvifBitDepth.Bit8      // Bit10 不兼容多数浏览器,慎用
};
image.Save(stream, encoder); // 不要省略 encoder 参数!默认 Save() 不走 AVIF
  • Quality = 65 是视觉与体积较优的起点;设为 100 不等于无损,AVIF 本身是损压缩
  • 若输出文件为空或损坏,大概率是忘了传 encoder,或没引用 ImageSharp.Formats.AVIF
  • 编码后记得 stream.Position = 0 才能读取,否则保存到磁盘时可能写入空内容

Windows 平台可用 WIC 直接编码(无需 libavif)

Windows 10 1903+ / Windows 11 内置 AVIF WIC 编解码器,可通过 System.Windows.Media.Imaging 调用,不依赖 libavif,适合纯 Windows 服务场景。

妙刷AI
妙刷AI

美团推出的一款新奇、好玩、荒诞的AI视觉体验工具

下载

缺点是仅支持 .NET Framework 或 .NET Core/6+ 启用 Windows Compatibility Pack(Microsoft.Windows.Compatibility 包)。

  • 必须添加 <packagereference include="Microsoft.Windows.Compatibility" version="8.0.0"></packagereference>
  • 编码前检查是否可用:BitmapEncoder.GetEncoderInfo("image/avif") 返回 null 表示系统不支持
  • WIC 的 AvifBitmapEncoder 不支持自定义 Quality,只提供 BitmapEncoderOptions 中的 QualityLevel(0.0–1.0),且实际压缩行为不可控
  • 生成的 AVIF 兼容性略好于 libavif(尤其对老 Edge),但体积通常大 10%–20%

常见错误:生成的 AVIF 浏览器打不开或报错

不是编码失败,而是元数据或色彩空间不匹配。AVIF 对容器规范比 JPEG 严格得多。

  • 浏览器提示 Failed to load resource: net::ERR_INVALID_RESPONSE → 检查响应头是否设了 Content-Type: image/avif,且文件扩展名是 .avif
  • Chrome 报 Failed to decode image → 输入图像是 CMYK 或带非标准 ICC 配置文件,ImageSharp 默认转成 sRGB,但某些旧版 libavif 会拒绝处理含特定 profile 的 AVIF
  • 图片显示偏色 → 确保原始图像已转换为 PixelFormat.Rgba32Bgra32,AVIF 编码器对像素格式敏感,Rgb24 可能触发内部降级或异常
  • 文件体积比 WebP 还大 → 关闭 Speed = AvifEncodingSpeed.Slow 并调低 Quality 到 50–60;AVIF 在低质量档位优势不明显

AVIF 的真正价值出现在中高画质(Quality ≥ 60)、复杂纹理图(如照片、截图)上;简单图标或文字图用 PNG/WebP 更合适。别为了“用新技术”硬套场景。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1011

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

813

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1637

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

394

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

1015

2025.04.24

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

249

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

967

2024.03.01

resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

174

2023.12.20

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

24

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Rust 教程
Rust 教程

共28课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号