【发布时间】:2020-10-13 21:54:28
【问题描述】:
我正在使用 WIC (Windows Imaging Component) 来解码图像文件并访问像素数据。我正在尝试找出像素顺序(即自下而上或自上而下)。
我使用IWICImagingFactory::CreateDecoderFromFileName 创建解码器,从中获取(第一)帧(IWICBitmapFrameDecode)。对于帧,我使用GetPixelFormat 和GetSize 计算缓冲区大小,最后我使用CopyPixels 将解码后的像素数据放入我的缓冲区。
这适用于各种 JPEG 文件,以自上而下的顺序为我提供像素行,并且像素按 BGRX 顺序排列 (GUID_WICPixelFormat32bppBGR)。
但是,当我尝试使用 GIF 文件时,像素行以自下而上的顺序出现。报告的像素格式为 RGBA (GUID_WICPixelFormat32bppRGBA),但基本事实显示通道顺序为 BGRA(每个 32 位像素的低字节为蓝色,就像 JPEG)。
我的主要问题:有没有办法查询像素数据的自上而下/自下而上的方向?
我发现了一个类似的问题,询问使用 JPEG 源时的旋转,答案是查询 EXIF 数据以了解图像是否旋转。但 EXIF 不与 GIF 一起使用。 所以我想知道我是否应该假设像素总是自下而上,除了那些确实有一个 EXIF 方向的像素。 2020 年 6 月 25 日更新 不,JPEG 方向是中性的,GIF 没有方向信息,但 MS Paint 和其他程序可以以正确的方向打开文件。
我的第二个问题:GIF 解码器的通道顺序 (RGB/BGR) 不正确是怎么回事?
不仅如此,WIC 文档还说将GIF decoder should return indexes 转换为颜色表 (GUID_WICPixelFormat8bppIndexed) 而不是实际的像素值。是否有可能我的机器上的某些软件安装了自己的有缺陷的 GIF 解码器,取代了 Windows 10 附带的那个?
【问题讨论】:
-
你应该问两个不同的问题。第一个,你在找这个吗:stackoverflow.com/a/60112084/403671
-
@Simon Mourier:我在这里提出第二个问题只是因为 (1) 它可能与主要问题有关,以及 (2) 包含有关我尝试过的所有相关信息,并且学到为止。将这些信息放在一个单独的问题中似乎会降低对第一个问题做出体面回应的机会。这不是我的第一个 SO 牛仔竞技表演。