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

【Qt】QImage::Format

QImage::Format 是 Qt 中用于指定图像像素数据格式的枚举类型。它决定了图像如何存储颜色信息和透明度(如果有)。选择合适的 Format 对性能、内存占用以及是否支持某些特性(如透明通道)有重要影响。

常见的 QImage::Format 枚举值及其用途:


1. 无效格式
  • Format_Invalid
    表示无效的图像格式,通常用于错误检测或初始化。

2. 单色/黑白图像
  • Format_Mono
    每个像素用 1 位表示,0 表示黑色,1 表示白色(未预乘透明度)。
  • Format_MonoLSB
    类似于 Format_Mono,但每个字节中最低有效位(LSB)对应第一个像素。

3. 调色板索引图像
  • Format_Indexed8
    每个像素是一个 8 位索引值,指向一个颜色表(colorTable()),最多支持 256 种颜色。

4. RGB 格式(无透明通道)
  • Format_RGB32
    每个像素用 32 位表示,其中 R、G、B 各占 8 位,剩余 8 位未使用(通常为 0 或填充)。
  • Format_RGB16
    每个像素用 16 位表示,通常是 RGB565 格式(R:5, G:6, B:5)。
  • Format_RGB888
    每个像素用 24 位表示,R、G、B 各占 8 位。
  • Format_RGB666Format_RGB555Format_RGB444
    不同精度的 RGB 图像格式,适用于对内存敏感的场景。

5. ARGB 格式(带透明通道)
  • Format_ARGB32
    每个像素用 32 位表示,A(Alpha)、R、G、B 各占 8 位,Alpha 未预乘(即原始 Alpha 值)。

  • Format_ARGB32_Premultiplied
    同样是 32 位,但 Alpha 预乘到颜色分量中,即:

    • R = R_original × A

    • G = G_original × A

    • B = B_original × A

    • A 保持不变

    区别说明:

    • Format_ARGB32:保留原始颜色和透明度,适合编辑和处理。
    • Format_ARGB32_Premultiplied:在渲染时更高效(尤其在合成操作中),因为不需要额外计算预乘 Alpha,常用于 GPU 渲染。
  • Format_ARGB8565_Premultiplied
    使用 24 位,其中 A 占 8 位,RGB 分别为 8:5:6:5(预乘)。

  • Format_ARGB8555_PremultipliedFormat_ARGB4444_Premultiplied
    不同精度的预乘格式,适用于特定硬件或压缩需求。


6. RGBA 格式
  • Format_RGBA8888
    每个像素用 32 位表示,R、G、B、A 各占 8 位,Alpha 未预乘
  • Format_RGBA8888_Premultiplied
    同上,但 Alpha 预乘,适合快速合成。

7. 其他专业格式
  • Format_RGBX8888
    32 位 RGB 格式,最后 8 位未使用(通常为 0)。
  • Format_BGR30Format_RGB30
    每个颜色分量占 10 位,提供更高色彩深度。
  • Format_Alpha8
    仅包含 8 位 Alpha 通道,用于遮罩或透明度图。
  • Format_Grayscale8
    8 位灰度图像,每个像素代表亮度(0 为黑,255 为白)。

如何选择正确的 Format

目标推荐格式
无透明度要求的彩色图像Format_RGB32Format_RGB888
支持透明度的图像Format_ARGB32Format_RGBA8888
快速合成与渲染Format_ARGB32_PremultipliedFormat_RGBA8888_Premultiplied
节省内存Format_RGB16Format_Indexed8
灰度图像Format_Grayscale8
遮罩/透明度图Format_Alpha8

示例代码:转换图像格式

 

cpp

QImage image("input.png"); QImage rgbaImage = image.convertToFormat(QImage::Format_ARGB32); // 明确转成 ARGB32


小结

  • 非预乘格式(如 Format_ARGB32 更适合图像处理与编辑。
  • 预乘格式(如 Format_ARGB32_Premultiplied 更适合高性能渲染(尤其是图形硬件加速)。
  • 如果不需要透明度,使用 Format_RGB32 或 Format_RGB888 更合适。
  • 对资源受限的设备,可考虑使用 Format_RGB16 或 Format_Indexed8 来节省内存。
http://www.xdnf.cn/news/569701.html

相关文章:

  • 目标检测 Sparse DETR(2022)详细解读
  • 线上 Linux 环境 MySQL 磁盘 IO 高负载深度排查与性能优化实战
  • 学编程对数学成绩没帮助?
  • 一、苍穹外卖
  • File文件
  • 大模型下载到本地
  • 深入解析Dify:从架构到应用的全面探索
  • Unity中SRP Batcher使用整理
  • plt.rcParams[“font.family“] = [“SimHei“, “WenQuanYi Micro Hei“, “Heiti TC“]
  • vue3:十三、分类管理-表格--模糊查询搜索框
  • 程序设计基础----排序(2)
  • Temporary failure in name resolution
  • C++ 01.vscode配置c++开发环境
  • 5.21本日总结
  • 两足行走机器人:仿生设计与智能控制的技术革命
  • Zabbix开源监控的全面详解!
  • 论文阅读:Auto-Encoding Variational Bayes
  • 信奥赛-刷题笔记-栈篇-T3-P1901发射站0521
  • 在 Windows 系统部署对冲基金分析工具 ai-hedge-fund 的笔记
  • 科普: 天然气蓝牙卡充值流程
  • CST软件基础四:电场和电导的设置
  • Unity基础学习(五)Mono中的重要内容(1)延时函数
  • Model 是 Agent 的大脑(以camel为例)
  • 补充Depends 和 request: Request 依赖注入用法的注意事项
  • 【C++ Primer 学习札记】智能指针
  • 构建 PyMNN
  • Halcon窗口的基本操作
  • Elasticsearch生产环境性能调优指南
  • Spring Boot + +小程序, 快速开发零工市场小程序
  • 如何使用 Docker Compose 部署 Immich