summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTomaž Vajngerl <tomaz.vajngerl@collabora.com>2015-11-23 13:16:26 +0100
committerTomaž Vajngerl <tomaz.vajngerl@collabora.com>2015-11-23 13:59:25 +0100
commit49b0711dade7a926ba03309d376133be3f60bbf0 (patch)
tree557c042d11fcabee0711a10ecbddda5a4105d103
parent15f66df8602b0920266ff2be86873246da4fda31 (diff)
vcl: add colorizeImage to BitmapProcessor
Change-Id: Ic90368e83d7f9a187eb8404d8aaec4380ff5bcb1
-rw-r--r--include/vcl/BitmapProcessor.hxx1
-rw-r--r--vcl/source/bitmap/BitmapProcessor.cxx69
2 files changed, 70 insertions, 0 deletions
diff --git a/include/vcl/BitmapProcessor.hxx b/include/vcl/BitmapProcessor.hxx
index 3d7397fd9a6f..0f0f13869d3f 100644
--- a/include/vcl/BitmapProcessor.hxx
+++ b/include/vcl/BitmapProcessor.hxx
@@ -17,6 +17,7 @@ class BitmapProcessor
public:
static BitmapEx createLightImage(const BitmapEx& rBitmapEx);
static BitmapEx createDisabledImage(const BitmapEx& rBitmapEx);
+ static void colorizeImage(BitmapEx& rBitmapEx, Color aColor);
};
#endif // INCLUDED_VCL_BITMAP_PROCESSOR_HXX
diff --git a/vcl/source/bitmap/BitmapProcessor.cxx b/vcl/source/bitmap/BitmapProcessor.cxx
index 5ac46804e103..20f812167373 100644
--- a/vcl/source/bitmap/BitmapProcessor.cxx
+++ b/vcl/source/bitmap/BitmapProcessor.cxx
@@ -127,4 +127,73 @@ BitmapEx BitmapProcessor::createDisabledImage(const BitmapEx& rBitmapEx)
return aReturnBitmap;
}
+void BitmapProcessor::colorizeImage(BitmapEx& rBitmapEx, Color aColor)
+{
+ Bitmap aBitmap = rBitmapEx.GetBitmap();
+ Bitmap::ScopedWriteAccess pWriteAccess(aBitmap);
+
+ if (pWriteAccess)
+ {
+ BitmapColor aBitmapColor;
+ const long nW = pWriteAccess->Width();
+ const long nH = pWriteAccess->Height();
+ std::vector<sal_uInt8> pMapR(256);
+ std::vector<sal_uInt8> pMapG(256);
+ std::vector<sal_uInt8> pMapB(256);
+ long nX;
+ long nY;
+
+ const sal_uInt8 cR = aColor.GetRed();
+ const sal_uInt8 cG = aColor.GetGreen();
+ const sal_uInt8 cB = aColor.GetBlue();
+
+ for (nX = 0; nX < 256; ++nX)
+ {
+ pMapR[nX] = MinMax((nX + cR) / 2, 0, 255);
+ pMapG[nX] = MinMax((nX + cG) / 2, 0, 255);
+ pMapB[nX] = MinMax((nX + cB) / 2, 0, 255);
+ }
+
+ if (pWriteAccess->HasPalette())
+ {
+ for (sal_uInt16 i = 0, nCount = pWriteAccess->GetPaletteEntryCount(); i < nCount; i++)
+ {
+ const BitmapColor& rCol = pWriteAccess->GetPaletteColor(i);
+ aBitmapColor.SetRed(pMapR[rCol.GetRed()]);
+ aBitmapColor.SetGreen(pMapG[rCol.GetGreen()]);
+ aBitmapColor.SetBlue(pMapB[rCol.GetBlue()]);
+ pWriteAccess->SetPaletteColor(i, aBitmapColor);
+ }
+ }
+ else if (pWriteAccess->GetScanlineFormat() == BMP_FORMAT_24BIT_TC_BGR)
+ {
+ for (nY = 0; nY < nH; ++nY)
+ {
+ Scanline pScan = pWriteAccess->GetScanline(nY);
+
+ for (nX = 0; nX < nW; ++nX)
+ {
+ *pScan = pMapB[*pScan]; pScan++;
+ *pScan = pMapG[*pScan]; pScan++;
+ *pScan = pMapR[*pScan]; pScan++;
+ }
+ }
+ }
+ else
+ {
+ for (nY = 0; nY < nH; ++nY)
+ {
+ for (nX = 0; nX < nW; ++nX)
+ {
+ aBitmapColor = pWriteAccess->GetPixel(nY, nX);
+ aBitmapColor.SetRed(pMapR[aBitmapColor.GetRed()]);
+ aBitmapColor.SetGreen(pMapG[aBitmapColor.GetGreen()]);
+ aBitmapColor.SetBlue(pMapB[aBitmapColor.GetBlue()]);
+ pWriteAccess->SetPixel(nY, nX, aBitmapColor);
+ }
+ }
+ }
+ }
+}
+
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */