From 3bc9510996b546242ff3a0bc5875ee1e07b1102a Mon Sep 17 00:00:00 2001 From: Pavel Krajcevski Date: Sat, 20 Oct 2012 21:33:23 -0400 Subject: [PATCH] Make sure that we assume pixels are in block stream order when accessing. --- IO/src/ImageWriter.cpp | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) diff --git a/IO/src/ImageWriter.cpp b/IO/src/ImageWriter.cpp index 18b8172..cb648b6 100644 --- a/IO/src/ImageWriter.cpp +++ b/IO/src/ImageWriter.cpp @@ -1,7 +1,24 @@ #include "ImageWriter.h" uint32 ImageWriter::GetChannelForPixel(uint32 x, uint32 y, uint32 ch) { - uint32 bytesPerRow = GetWidth() * 4; - uint32 byteLocation = y * bytesPerRow + x*4 + ch; - return m_PixelData[byteLocation]; + + // Assume pixels are in block stream order, hence we would need to first find + // the block that contains pixel (x, y) and then find the byte location for it. + + const uint32 blocksPerRow = GetWidth() / 4; + const uint32 blockIdxX = x / 4; + const uint32 blockIdxY = y / 4; + const uint32 blockIdx = blockIdxY * blocksPerRow + blockIdxX; + + // Now we find the offset in the block + const uint32 blockOffsetX = x % 4; + const uint32 blockOffsetY = y % 4; + const uint32 pixelOffset = blockOffsetY * 4 + blockOffsetX; + + // There are 16 pixels per block and bytes per pixel... + uint32 dataOffset = blockIdx * 4 * 16; + dataOffset += 4 * pixelOffset; + dataOffset += ch; + + return m_PixelData[dataOffset]; }