4

因此,我对刚刚运行的快速测试感到非常困惑。我正在用 C# 进行一些图像处理。Get/SetPixel() 被证明太慢了,所以我使用 LockBits 来获取原始数据。

但是,我似乎遇到了我无法弄清楚的情况。在扫描图像时,似乎每个像素都按 Bgra 排列,即按蓝色字节、绿色字节、红色字节和 alpha 的顺序排列。我的印象是它们将以 Argb 顺序排列。这是我正在使用的代码示例。

BitmapData baseData =
    m_baseImage.LockBits(new Rectangle(new Point(0, 0), m_baseImage.Size), 
        ImageLockMode.ReadOnly, PixelFormat.Format32bppArgb);
Bitmap test = new Bitmap(m_baseImage.Width, m_baseImage.Height);           

byte* ptr = (byte*)baseData.Scan0;
for (int y = 0; y < m_baseImage.Height; ++y)
{                              
    for (int x = 0; x < m_baseImage.Width; ++x)
    {
        // this works, image is copied correctly
        Color c1 = Color.FromArgb(*(ptr + 3), *(ptr + 2), *(ptr + 1), *ptr);
        // below does not work!  Bytes are reversed.
        //Color c1 = Color.FromArgb(*ptr, *(ptr + 1), *(ptr + 2), *(ptr + 3));

        test.SetPixel(x, y, c1);
        ptr += 4;
    }             
}

m_baseImage.UnlockBits(baseData);
pictureBox1.Image = m_baseImage;
pictureBox2.Image = test;

获取基本图像颜色的第一行有效,第二行无效。我很确定我在这里遗漏了一些非常明显的东西。

4

2 回答 2

6

ARGB 是指作为字提取的字中的字节顺序。如果您一次获取一个字节,您将收到 em low to hi 因为 IBM PC 是little-endian

于 2009-02-24T06:40:55.927 回答
6

不仅颜色反转 BGRA,而且行也反转 - 图像的底部是内存中的第一个。这就是 Windows 一直以来的工作方式。

little-endian 的解释似乎很明显,但我认为这不是事实。如果您查看Windows API 中 COLORREF的定义,您会注意到 Red 是低位字节,Blue 是高位字节;如果将其存储为单个整数值,则它将是 RGB0。

于 2009-02-24T07:23:50.003 回答