diff options
Diffstat (limited to 'vcl/inc/bitmap')
-rw-r--r-- | vcl/inc/bitmap/Octree.hxx | 88 | ||||
-rw-r--r-- | vcl/inc/bitmap/impoctree.hxx | 89 |
2 files changed, 86 insertions, 91 deletions
diff --git a/vcl/inc/bitmap/Octree.hxx b/vcl/inc/bitmap/Octree.hxx index cec8e4171494..3e54826a9313 100644 --- a/vcl/inc/bitmap/Octree.hxx +++ b/vcl/inc/bitmap/Octree.hxx @@ -23,20 +23,20 @@ #include <vcl/salbtype.hxx> #include <vcl/dllapi.h> -#define OCTREE_BITS 5 -#define OCTREE_BITS_1 10 +#define OCTREE_BITS 5 +#define OCTREE_BITS_1 10 struct OctreeNode { - sal_uLong nCount; - sal_uLong nRed; - sal_uLong nGreen; - sal_uLong nBlue; - OctreeNode* pChild[ 8 ]; - OctreeNode* pNext; - OctreeNode* pNextInCache; - sal_uInt16 nPalIndex; - bool bLeaf; + sal_uLong nCount; + sal_uLong nRed; + sal_uLong nGreen; + sal_uLong nBlue; + OctreeNode* pChild[8]; + OctreeNode* pNext; + OctreeNode* pNextInCache; + sal_uInt16 nPalIndex; + bool bLeaf; }; class ImpNodeCache; @@ -45,73 +45,69 @@ class BitmapReadAccess; class VCL_PLUGIN_PUBLIC Octree { private: - void CreatePalette( OctreeNode* pNode ); - void GetPalIndex( OctreeNode* pNode ); - - SAL_DLLPRIVATE void ImplDeleteOctree( OctreeNode** ppNode ); - SAL_DLLPRIVATE void ImplAdd( OctreeNode** ppNode ); - SAL_DLLPRIVATE void ImplReduce(); - - - BitmapPalette aPal; - sal_uLong nLeafCount; - sal_uLong nLevel; - OctreeNode* pTree; - OctreeNode* pReduce[ OCTREE_BITS + 1 ]; - BitmapColor const * pColor; + void CreatePalette(OctreeNode* pNode); + void GetPalIndex(OctreeNode* pNode); + + SAL_DLLPRIVATE void ImplDeleteOctree(OctreeNode** ppNode); + SAL_DLLPRIVATE void ImplAdd(OctreeNode** ppNode); + SAL_DLLPRIVATE void ImplReduce(); + + BitmapPalette aPal; + sal_uLong nLeafCount; + sal_uLong nLevel; + OctreeNode* pTree; + OctreeNode* pReduce[OCTREE_BITS + 1]; + BitmapColor const* pColor; std::unique_ptr<ImpNodeCache> pNodeCache; - const BitmapReadAccess* pAcc; - sal_uInt16 nPalIndex; + const BitmapReadAccess* pAcc; + sal_uInt16 nPalIndex; public: - - Octree( const BitmapReadAccess& rReadAcc, sal_uLong nColors ); - ~Octree(); + Octree(const BitmapReadAccess& rReadAcc, sal_uLong nColors); + ~Octree(); inline const BitmapPalette& GetPalette(); - inline sal_uInt16 GetBestPaletteIndex( const BitmapColor& rColor ); + inline sal_uInt16 GetBestPaletteIndex(const BitmapColor& rColor); }; inline const BitmapPalette& Octree::GetPalette() { - aPal.SetEntryCount( static_cast<sal_uInt16>(nLeafCount) ); + aPal.SetEntryCount(static_cast<sal_uInt16>(nLeafCount)); nPalIndex = 0; - CreatePalette( pTree ); + CreatePalette(pTree); return aPal; } -inline sal_uInt16 Octree::GetBestPaletteIndex( const BitmapColor& rColor ) +inline sal_uInt16 Octree::GetBestPaletteIndex(const BitmapColor& rColor) { pColor = &rColor; nPalIndex = 65535; nLevel = 0; - GetPalIndex( pTree ); + GetPalIndex(pTree); return nPalIndex; } class VCL_PLUGIN_PUBLIC InverseColorMap { private: - std::unique_ptr<sal_uInt8[]> pBuffer; std::unique_ptr<sal_uInt8[]> pMap; - static constexpr sal_uLong gnBits = 8 -OCTREE_BITS; + static constexpr sal_uLong gnBits = 8 - OCTREE_BITS; - SAL_DLLPRIVATE void ImplCreateBuffers( const sal_uLong nMax ); + SAL_DLLPRIVATE void ImplCreateBuffers(const sal_uLong nMax); public: + explicit InverseColorMap(const BitmapPalette& rPal); + ~InverseColorMap(); - explicit InverseColorMap( const BitmapPalette& rPal ); - ~InverseColorMap(); - - inline sal_uInt16 GetBestPaletteIndex( const BitmapColor& rColor ); + inline sal_uInt16 GetBestPaletteIndex(const BitmapColor& rColor); }; -inline sal_uInt16 InverseColorMap::GetBestPaletteIndex( const BitmapColor& rColor ) +inline sal_uInt16 InverseColorMap::GetBestPaletteIndex(const BitmapColor& rColor) { - return pMap[ ( ( static_cast<sal_uLong>(rColor.GetRed()) >> gnBits ) << OCTREE_BITS_1 ) | - ( ( static_cast<sal_uLong>(rColor.GetGreen()) >> gnBits ) << OCTREE_BITS ) | - ( static_cast<sal_uLong>(rColor.GetBlue()) >> gnBits ) ]; + return pMap[((static_cast<sal_uLong>(rColor.GetRed()) >> gnBits) << OCTREE_BITS_1) + | ((static_cast<sal_uLong>(rColor.GetGreen()) >> gnBits) << OCTREE_BITS) + | (static_cast<sal_uLong>(rColor.GetBlue()) >> gnBits)]; } #endif // INCLUDED_VCL_INC_OCTREE_HXX diff --git a/vcl/inc/bitmap/impoctree.hxx b/vcl/inc/bitmap/impoctree.hxx index b2f05b351c5a..0ade7b7bcc3b 100644 --- a/vcl/inc/bitmap/impoctree.hxx +++ b/vcl/inc/bitmap/impoctree.hxx @@ -29,7 +29,6 @@ class ImpErrorQuad long nBlue; public: - ImpErrorQuad() : nRed(0) , nGreen(0) @@ -37,93 +36,93 @@ public: { } - ImpErrorQuad( const BitmapColor& rColor ) - : nRed( static_cast<long>(rColor.GetRed()) << 5 ) - , nGreen( static_cast<long>(rColor.GetGreen()) << 5 ) - , nBlue( static_cast<long>(rColor.GetBlue()) << 5 ) + ImpErrorQuad(const BitmapColor& rColor) + : nRed(static_cast<long>(rColor.GetRed()) << 5) + , nGreen(static_cast<long>(rColor.GetGreen()) << 5) + , nBlue(static_cast<long>(rColor.GetBlue()) << 5) { } - inline void operator=( const BitmapColor& rColor ); - inline ImpErrorQuad& operator-=( const BitmapColor& rColor ); + inline void operator=(const BitmapColor& rColor); + inline ImpErrorQuad& operator-=(const BitmapColor& rColor); - inline void ImplAddColorError1( const ImpErrorQuad& rErrQuad ); - inline void ImplAddColorError3( const ImpErrorQuad& rErrQuad ); - inline void ImplAddColorError5( const ImpErrorQuad& rErrQuad ); - inline void ImplAddColorError7( const ImpErrorQuad& rErrQuad ); + inline void ImplAddColorError1(const ImpErrorQuad& rErrQuad); + inline void ImplAddColorError3(const ImpErrorQuad& rErrQuad); + inline void ImplAddColorError5(const ImpErrorQuad& rErrQuad); + inline void ImplAddColorError7(const ImpErrorQuad& rErrQuad); - inline BitmapColor ImplGetColor(); + inline BitmapColor ImplGetColor(); }; -inline void ImpErrorQuad::operator=( const BitmapColor& rColor ) +inline void ImpErrorQuad::operator=(const BitmapColor& rColor) { nRed = static_cast<long>(rColor.GetRed()) << 5; nGreen = static_cast<long>(rColor.GetGreen()) << 5; nBlue = static_cast<long>(rColor.GetBlue()) << 5; } -inline ImpErrorQuad& ImpErrorQuad::operator-=( const BitmapColor& rColor ) +inline ImpErrorQuad& ImpErrorQuad::operator-=(const BitmapColor& rColor) { - nRed -= ( static_cast<long>(rColor.GetRed()) << 5 ); - nGreen -= ( static_cast<long>(rColor.GetGreen()) << 5 ); - nBlue -= ( static_cast<long>(rColor.GetBlue()) << 5 ); + nRed -= (static_cast<long>(rColor.GetRed()) << 5); + nGreen -= (static_cast<long>(rColor.GetGreen()) << 5); + nBlue -= (static_cast<long>(rColor.GetBlue()) << 5); return *this; } -inline void ImpErrorQuad::ImplAddColorError1( const ImpErrorQuad& rErrQuad ) +inline void ImpErrorQuad::ImplAddColorError1(const ImpErrorQuad& rErrQuad) { - nRed += ( rErrQuad.nRed >> 4 ); - nGreen += ( rErrQuad.nGreen >> 4 ); - nBlue += ( rErrQuad.nBlue >> 4 ); + nRed += (rErrQuad.nRed >> 4); + nGreen += (rErrQuad.nGreen >> 4); + nBlue += (rErrQuad.nBlue >> 4); } -inline void ImpErrorQuad::ImplAddColorError3( const ImpErrorQuad& rErrQuad ) +inline void ImpErrorQuad::ImplAddColorError3(const ImpErrorQuad& rErrQuad) { - nRed += ( rErrQuad.nRed * 3L >> 4 ); - nGreen += ( rErrQuad.nGreen * 3L >> 4 ); - nBlue += ( rErrQuad.nBlue * 3L >> 4 ); + nRed += (rErrQuad.nRed * 3L >> 4); + nGreen += (rErrQuad.nGreen * 3L >> 4); + nBlue += (rErrQuad.nBlue * 3L >> 4); } -inline void ImpErrorQuad::ImplAddColorError5( const ImpErrorQuad& rErrQuad ) +inline void ImpErrorQuad::ImplAddColorError5(const ImpErrorQuad& rErrQuad) { - nRed += ( rErrQuad.nRed * 5L >> 4 ); - nGreen += ( rErrQuad.nGreen * 5L >> 4 ); - nBlue += ( rErrQuad.nBlue * 5L >> 4 ); + nRed += (rErrQuad.nRed * 5L >> 4); + nGreen += (rErrQuad.nGreen * 5L >> 4); + nBlue += (rErrQuad.nBlue * 5L >> 4); } -inline void ImpErrorQuad::ImplAddColorError7( const ImpErrorQuad& rErrQuad ) +inline void ImpErrorQuad::ImplAddColorError7(const ImpErrorQuad& rErrQuad) { - nRed += ( rErrQuad.nRed * 7L >> 4 ); - nGreen += ( rErrQuad.nGreen * 7L >> 4 ); - nBlue += ( rErrQuad.nBlue *7L >> 4 ); + nRed += (rErrQuad.nRed * 7L >> 4); + nGreen += (rErrQuad.nGreen * 7L >> 4); + nBlue += (rErrQuad.nBlue * 7L >> 4); } inline BitmapColor ImpErrorQuad::ImplGetColor() { - return BitmapColor( static_cast<sal_uInt8>( ( nRed < 0 ? 0L : nRed > 8160 ? 8160L : nRed ) >> 5 ), - static_cast<sal_uInt8>( ( nGreen < 0 ? 0L : nGreen > 8160 ? 8160L : nGreen ) >> 5 ), - static_cast<sal_uInt8>( ( nBlue < 0 ? 0L : nBlue > 8160 ? 8160L : nBlue ) >> 5 ) ); + return BitmapColor( + static_cast<sal_uInt8>((nRed < 0 ? 0L : nRed > 8160 ? 8160L : nRed) >> 5), + static_cast<sal_uInt8>((nGreen < 0 ? 0L : nGreen > 8160 ? 8160L : nGreen) >> 5), + static_cast<sal_uInt8>((nBlue < 0 ? 0L : nBlue > 8160 ? 8160L : nBlue) >> 5)); } class ImpNodeCache { - OctreeNode* pActNode; + OctreeNode* pActNode; public: + ImpNodeCache(const sal_uLong nInitSize); + ~ImpNodeCache(); - ImpNodeCache( const sal_uLong nInitSize ); - ~ImpNodeCache(); - - inline OctreeNode* ImplGetFreeNode(); - inline void ImplReleaseNode( OctreeNode* pNode ); + inline OctreeNode* ImplGetFreeNode(); + inline void ImplReleaseNode(OctreeNode* pNode); }; inline OctreeNode* ImpNodeCache::ImplGetFreeNode() { OctreeNode* pNode; - if ( !pActNode ) + if (!pActNode) { pActNode = new OctreeNode; pActNode->pNextInCache = nullptr; @@ -131,12 +130,12 @@ inline OctreeNode* ImpNodeCache::ImplGetFreeNode() pNode = pActNode; pActNode = pNode->pNextInCache; - memset( pNode, 0, sizeof( OctreeNode ) ); + memset(pNode, 0, sizeof(OctreeNode)); return pNode; } -inline void ImpNodeCache::ImplReleaseNode( OctreeNode* pNode ) +inline void ImpNodeCache::ImplReleaseNode(OctreeNode* pNode) { pNode->pNextInCache = pActNode; pActNode = pNode; |