/** * @module cpixelformat_BGR24 * @author Guenther Neuwirth (0626638), Manuel Mausz (0728348) * @brief Implementation of CPixelFormat handling 24bit color Windows Bitmaps. * @date 18.04.2009 */ #include #include "cpixelformat_bgr24.h" using namespace std; /* TODO */ void CPixelFormat_BGR24::getPixel(uint32_t *pixel, uint32_t x, uint32_t y) { /* * pixel[0] ... red * pixel[1] ... green * pixel[2] ... blue */ if (m_bitmap->getPixelData() == NULL) throw PixelFormatError("No pixelbuffer allocated."); /* calc rowsize - boundary is 32 */ uint32_t rowsize = 4 * static_cast( ((getBitCount() * m_bitmap->getWidth()) + 31) / 32 ); /* if the y-coordinates are mirrored */ if (m_bitmap->isMirrored()) y = m_bitmap->getHeight() - y - 1; uint32_t offset = y * rowsize + x * (4 * getBitCount() / 32); /* boundary check */ if (offset + getBitCount()/8 > m_bitmap->getPixelDataSize()) throw PixelFormatError("Pixel position is out of range."); /* get pixel */ try { pixel[0] = boost::numeric_cast(*(m_bitmap->getPixelData() + offset + 2)); pixel[1] = boost::numeric_cast(*(m_bitmap->getPixelData() + offset + 1)); pixel[2] = boost::numeric_cast(*(m_bitmap->getPixelData() + offset)); } catch(boost::numeric::bad_numeric_cast& ex) { throw PixelFormatError("Unable to convert pixelcolor to correct size: " + string(ex.what())); } } void CPixelFormat_BGR24::setPixel(const uint32_t *pixel, uint32_t x, uint32_t y) { /* * pixel[0] ... red * pixel[1] ... green * pixel[2] ... blue */ if (m_bitmap->getPixelData() == NULL) throw PixelFormatError("No pixelbuffer allocated."); /* calc rowsize - boundary is 32 */ uint32_t rowsize = 4 * static_cast( ((getBitCount() * m_bitmap->getWidth()) + 31) / 32 ); /* if the y-coordinates are mirrored */ if (m_bitmap->isMirrored()) y = m_bitmap->getHeight() - y - 1; uint32_t offset = y * rowsize + x * (4 * getBitCount() / 32); /* boundary check */ if (offset + getBitCount()/8 > m_bitmap->getPixelDataSize()) throw PixelFormatError("Pixel position is out of range."); /* convert color values to correct types */ uint8_t data[3]; try { data[0] = boost::numeric_cast(pixel[2]); data[1] = boost::numeric_cast(pixel[1]); data[2] = boost::numeric_cast(pixel[0]); } catch(boost::numeric::bad_numeric_cast& ex) { throw PixelFormatError("Unable to convert pixelcolor to correct size: " + string(ex.what())); } copy(data, data + 3, m_bitmap->getPixelData() + offset); } /* vim: set et sw=2 ts=2: */