实际上,我不明白在 PNG 文件中使用 sBIT 块。
我正在存储来自 11 位/通道 RGB 源的 PNG 文件,因此我尽职尽责地在 (c) 代码中设置了 sBIT 块:
...
png_color_8 sig_bit;
sig_bit.gray = 0;
sig_bit.alpha = 0;
sig_bit.red = 11;
sig_bit.green = 11;
sig_bit.blue = 11;
png_set_sBIT(png_ptr, info_ptr, &sig_bit);
...
/* save the png */
当使用 windows 查看器(原生 Vista 图片查看器/Paint.net)查看图像时,低 8 位被截断,所以我只能看到高 3 位。我原以为该sBIT
块会自动指示读者将像素左移 5 位,以使 MSB 证明数据显示的合理性。似乎并非如此。
当我在代码中打开具有或不具有 sBIT 块的 png 文件时,请执行以下操作:
png_color_8p sig_bit;
if (png_get_valid(png_ptr, info_ptr, PNG_INFO_sBIT)) {
png_get_sBIT(png_ptr, info_ptr, &sig_bit);
png_set_shift(png_ptr, sig_bit);
}
像素数据相同。
sBIT块的使用模型是什么?我可以以某种方式使用该sBIT
块来证明像素数据的正确性以供查看,但查看“原始”数据进行数值分析吗?