1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_vcl.hxx" 30*cdf0e10cSrcweir 31*cdf0e10cSrcweir #include <vcl/salbtype.hxx> 32*cdf0e10cSrcweir #include <vcl/bitmap.hxx> 33*cdf0e10cSrcweir #include <vcl/bmpacc.hxx> 34*cdf0e10cSrcweir 35*cdf0e10cSrcweir #include <impbmp.hxx> 36*cdf0e10cSrcweir 37*cdf0e10cSrcweir #include <string.h> 38*cdf0e10cSrcweir 39*cdf0e10cSrcweir // -------------------- 40*cdf0e10cSrcweir // - BitmapReadAccess - 41*cdf0e10cSrcweir // -------------------- 42*cdf0e10cSrcweir 43*cdf0e10cSrcweir BitmapReadAccess::BitmapReadAccess( Bitmap& rBitmap, sal_Bool bModify ) : 44*cdf0e10cSrcweir mpBuffer ( NULL ), 45*cdf0e10cSrcweir mpScanBuf ( NULL ), 46*cdf0e10cSrcweir mFncGetPixel ( NULL ), 47*cdf0e10cSrcweir mFncSetPixel ( NULL ), 48*cdf0e10cSrcweir mbModify ( bModify ) 49*cdf0e10cSrcweir { 50*cdf0e10cSrcweir ImplCreate( rBitmap ); 51*cdf0e10cSrcweir } 52*cdf0e10cSrcweir 53*cdf0e10cSrcweir // ------------------------------------------------------------------ 54*cdf0e10cSrcweir 55*cdf0e10cSrcweir BitmapReadAccess::BitmapReadAccess( Bitmap& rBitmap ) : 56*cdf0e10cSrcweir mpBuffer ( NULL ), 57*cdf0e10cSrcweir mpScanBuf ( NULL ), 58*cdf0e10cSrcweir mFncGetPixel ( NULL ), 59*cdf0e10cSrcweir mFncSetPixel ( NULL ), 60*cdf0e10cSrcweir mbModify ( sal_False ) 61*cdf0e10cSrcweir { 62*cdf0e10cSrcweir ImplCreate( rBitmap ); 63*cdf0e10cSrcweir } 64*cdf0e10cSrcweir 65*cdf0e10cSrcweir // ------------------------------------------------------------------ 66*cdf0e10cSrcweir 67*cdf0e10cSrcweir BitmapReadAccess::~BitmapReadAccess() 68*cdf0e10cSrcweir { 69*cdf0e10cSrcweir ImplDestroy(); 70*cdf0e10cSrcweir } 71*cdf0e10cSrcweir 72*cdf0e10cSrcweir // ------------------------------------------------------------------ 73*cdf0e10cSrcweir 74*cdf0e10cSrcweir void BitmapReadAccess::ImplCreate( Bitmap& rBitmap ) 75*cdf0e10cSrcweir { 76*cdf0e10cSrcweir ImpBitmap* pImpBmp = rBitmap.ImplGetImpBitmap(); 77*cdf0e10cSrcweir 78*cdf0e10cSrcweir DBG_ASSERT( pImpBmp, "Forbidden Access to empty bitmap!" ); 79*cdf0e10cSrcweir 80*cdf0e10cSrcweir if( pImpBmp ) 81*cdf0e10cSrcweir { 82*cdf0e10cSrcweir if( mbModify && !maBitmap.ImplGetImpBitmap() ) 83*cdf0e10cSrcweir { 84*cdf0e10cSrcweir rBitmap.ImplMakeUnique(); 85*cdf0e10cSrcweir pImpBmp = rBitmap.ImplGetImpBitmap(); 86*cdf0e10cSrcweir } 87*cdf0e10cSrcweir else 88*cdf0e10cSrcweir { 89*cdf0e10cSrcweir DBG_ASSERT( !mbModify || pImpBmp->ImplGetRefCount() == 2, 90*cdf0e10cSrcweir "Unpredictable results: bitmap is referenced more than once!" ); 91*cdf0e10cSrcweir } 92*cdf0e10cSrcweir 93*cdf0e10cSrcweir mpBuffer = pImpBmp->ImplAcquireBuffer( !mbModify ); 94*cdf0e10cSrcweir 95*cdf0e10cSrcweir if( !mpBuffer ) 96*cdf0e10cSrcweir { 97*cdf0e10cSrcweir ImpBitmap* pNewImpBmp = new ImpBitmap; 98*cdf0e10cSrcweir 99*cdf0e10cSrcweir if( pNewImpBmp->ImplCreate( *pImpBmp, rBitmap.GetBitCount() ) ) 100*cdf0e10cSrcweir { 101*cdf0e10cSrcweir pImpBmp = pNewImpBmp; 102*cdf0e10cSrcweir rBitmap.ImplSetImpBitmap( pImpBmp ); 103*cdf0e10cSrcweir mpBuffer = pImpBmp->ImplAcquireBuffer( !mbModify ); 104*cdf0e10cSrcweir } 105*cdf0e10cSrcweir else 106*cdf0e10cSrcweir delete pNewImpBmp; 107*cdf0e10cSrcweir } 108*cdf0e10cSrcweir 109*cdf0e10cSrcweir if( mpBuffer ) 110*cdf0e10cSrcweir { 111*cdf0e10cSrcweir const long nHeight = mpBuffer->mnHeight; 112*cdf0e10cSrcweir Scanline pTmpLine = mpBuffer->mpBits; 113*cdf0e10cSrcweir 114*cdf0e10cSrcweir mpScanBuf = new Scanline[ nHeight ]; 115*cdf0e10cSrcweir maColorMask = mpBuffer->maColorMask; 116*cdf0e10cSrcweir 117*cdf0e10cSrcweir if( BMP_SCANLINE_ADJUSTMENT( mpBuffer->mnFormat ) == BMP_FORMAT_TOP_DOWN ) 118*cdf0e10cSrcweir { 119*cdf0e10cSrcweir for( long nY = 0L; nY < nHeight; nY++, pTmpLine += mpBuffer->mnScanlineSize ) 120*cdf0e10cSrcweir mpScanBuf[ nY ] = pTmpLine; 121*cdf0e10cSrcweir } 122*cdf0e10cSrcweir else 123*cdf0e10cSrcweir { 124*cdf0e10cSrcweir for( long nY = nHeight - 1; nY >= 0; nY--, pTmpLine += mpBuffer->mnScanlineSize ) 125*cdf0e10cSrcweir mpScanBuf[ nY ] = pTmpLine; 126*cdf0e10cSrcweir } 127*cdf0e10cSrcweir 128*cdf0e10cSrcweir if( !ImplSetAccessPointers( BMP_SCANLINE_FORMAT( mpBuffer->mnFormat ) ) ) 129*cdf0e10cSrcweir { 130*cdf0e10cSrcweir delete[] mpScanBuf; 131*cdf0e10cSrcweir mpScanBuf = NULL; 132*cdf0e10cSrcweir 133*cdf0e10cSrcweir pImpBmp->ImplReleaseBuffer( mpBuffer, !mbModify ); 134*cdf0e10cSrcweir mpBuffer = NULL; 135*cdf0e10cSrcweir } 136*cdf0e10cSrcweir else 137*cdf0e10cSrcweir maBitmap = rBitmap; 138*cdf0e10cSrcweir } 139*cdf0e10cSrcweir } 140*cdf0e10cSrcweir } 141*cdf0e10cSrcweir 142*cdf0e10cSrcweir // ------------------------------------------------------------------ 143*cdf0e10cSrcweir 144*cdf0e10cSrcweir void BitmapReadAccess::ImplDestroy() 145*cdf0e10cSrcweir { 146*cdf0e10cSrcweir ImpBitmap* pImpBmp = maBitmap.ImplGetImpBitmap(); 147*cdf0e10cSrcweir 148*cdf0e10cSrcweir delete[] mpScanBuf; 149*cdf0e10cSrcweir mpScanBuf = NULL; 150*cdf0e10cSrcweir 151*cdf0e10cSrcweir if( mpBuffer && pImpBmp ) 152*cdf0e10cSrcweir { 153*cdf0e10cSrcweir pImpBmp->ImplReleaseBuffer( mpBuffer, !mbModify ); 154*cdf0e10cSrcweir mpBuffer = NULL; 155*cdf0e10cSrcweir } 156*cdf0e10cSrcweir } 157*cdf0e10cSrcweir 158*cdf0e10cSrcweir // ------------------------------------------------------------------ 159*cdf0e10cSrcweir 160*cdf0e10cSrcweir sal_Bool BitmapReadAccess::ImplSetAccessPointers( sal_uLong nFormat ) 161*cdf0e10cSrcweir { 162*cdf0e10cSrcweir sal_Bool bRet = sal_True; 163*cdf0e10cSrcweir 164*cdf0e10cSrcweir switch( nFormat ) 165*cdf0e10cSrcweir { 166*cdf0e10cSrcweir CASE_FORMAT( _1BIT_MSB_PAL ) 167*cdf0e10cSrcweir CASE_FORMAT( _1BIT_LSB_PAL ) 168*cdf0e10cSrcweir CASE_FORMAT( _4BIT_MSN_PAL ) 169*cdf0e10cSrcweir CASE_FORMAT( _4BIT_LSN_PAL ) 170*cdf0e10cSrcweir CASE_FORMAT( _8BIT_PAL ) 171*cdf0e10cSrcweir CASE_FORMAT( _8BIT_TC_MASK ) 172*cdf0e10cSrcweir CASE_FORMAT( _16BIT_TC_MSB_MASK ) 173*cdf0e10cSrcweir CASE_FORMAT( _16BIT_TC_LSB_MASK ) 174*cdf0e10cSrcweir CASE_FORMAT( _24BIT_TC_BGR ) 175*cdf0e10cSrcweir CASE_FORMAT( _24BIT_TC_RGB ) 176*cdf0e10cSrcweir CASE_FORMAT( _24BIT_TC_MASK ) 177*cdf0e10cSrcweir CASE_FORMAT( _32BIT_TC_ABGR ) 178*cdf0e10cSrcweir CASE_FORMAT( _32BIT_TC_ARGB ) 179*cdf0e10cSrcweir CASE_FORMAT( _32BIT_TC_BGRA ) 180*cdf0e10cSrcweir CASE_FORMAT( _32BIT_TC_RGBA ) 181*cdf0e10cSrcweir CASE_FORMAT( _32BIT_TC_MASK ) 182*cdf0e10cSrcweir 183*cdf0e10cSrcweir default: 184*cdf0e10cSrcweir bRet = sal_False; 185*cdf0e10cSrcweir break; 186*cdf0e10cSrcweir } 187*cdf0e10cSrcweir 188*cdf0e10cSrcweir return bRet; 189*cdf0e10cSrcweir } 190*cdf0e10cSrcweir 191*cdf0e10cSrcweir // ------------------------------------------------------------------ 192*cdf0e10cSrcweir 193*cdf0e10cSrcweir void BitmapReadAccess::ImplZeroInitUnusedBits() 194*cdf0e10cSrcweir { 195*cdf0e10cSrcweir const sal_uInt32 nWidth = Width(), nHeight = Height(), nScanSize = GetScanlineSize(); 196*cdf0e10cSrcweir 197*cdf0e10cSrcweir if( nWidth && nHeight && nScanSize && GetBuffer() ) 198*cdf0e10cSrcweir { 199*cdf0e10cSrcweir sal_uInt32 nBits; 200*cdf0e10cSrcweir bool bMsb; 201*cdf0e10cSrcweir 202*cdf0e10cSrcweir const sal_uLong nScanlineFormat = GetScanlineFormat(); 203*cdf0e10cSrcweir switch( nScanlineFormat ) 204*cdf0e10cSrcweir { 205*cdf0e10cSrcweir case( BMP_FORMAT_1BIT_MSB_PAL ): 206*cdf0e10cSrcweir nBits = 1; 207*cdf0e10cSrcweir bMsb = true; 208*cdf0e10cSrcweir break; 209*cdf0e10cSrcweir 210*cdf0e10cSrcweir case( BMP_FORMAT_1BIT_LSB_PAL ): 211*cdf0e10cSrcweir nBits = 1; 212*cdf0e10cSrcweir bMsb = false; 213*cdf0e10cSrcweir break; 214*cdf0e10cSrcweir 215*cdf0e10cSrcweir case( BMP_FORMAT_4BIT_MSN_PAL ): 216*cdf0e10cSrcweir nBits = 4; 217*cdf0e10cSrcweir bMsb = true; 218*cdf0e10cSrcweir break; 219*cdf0e10cSrcweir 220*cdf0e10cSrcweir case( BMP_FORMAT_4BIT_LSN_PAL ): 221*cdf0e10cSrcweir nBits = 4; 222*cdf0e10cSrcweir bMsb = false; 223*cdf0e10cSrcweir break; 224*cdf0e10cSrcweir 225*cdf0e10cSrcweir case( BMP_FORMAT_8BIT_PAL ): 226*cdf0e10cSrcweir case( BMP_FORMAT_8BIT_TC_MASK ): 227*cdf0e10cSrcweir bMsb = true; 228*cdf0e10cSrcweir nBits = 8; 229*cdf0e10cSrcweir break; 230*cdf0e10cSrcweir 231*cdf0e10cSrcweir case( BMP_FORMAT_16BIT_TC_MSB_MASK ): 232*cdf0e10cSrcweir case( BMP_FORMAT_16BIT_TC_LSB_MASK ): 233*cdf0e10cSrcweir bMsb = true; 234*cdf0e10cSrcweir nBits = 16; 235*cdf0e10cSrcweir break; 236*cdf0e10cSrcweir 237*cdf0e10cSrcweir case( BMP_FORMAT_24BIT_TC_BGR ): 238*cdf0e10cSrcweir case( BMP_FORMAT_24BIT_TC_RGB ): 239*cdf0e10cSrcweir case( BMP_FORMAT_24BIT_TC_MASK ): 240*cdf0e10cSrcweir bMsb = true; 241*cdf0e10cSrcweir nBits = 24; 242*cdf0e10cSrcweir break; 243*cdf0e10cSrcweir 244*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_ABGR ): 245*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_ARGB ): 246*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_BGRA ): 247*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_RGBA ): 248*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_MASK ): 249*cdf0e10cSrcweir bMsb = true; 250*cdf0e10cSrcweir nBits = 32; 251*cdf0e10cSrcweir break; 252*cdf0e10cSrcweir 253*cdf0e10cSrcweir default: 254*cdf0e10cSrcweir { 255*cdf0e10cSrcweir DBG_ERROR( "BitmapWriteAccess::ZeroInitUnusedBits: Unsupported pixel format"); 256*cdf0e10cSrcweir nBits = 0; 257*cdf0e10cSrcweir bMsb = true; 258*cdf0e10cSrcweir } 259*cdf0e10cSrcweir break; 260*cdf0e10cSrcweir } 261*cdf0e10cSrcweir 262*cdf0e10cSrcweir nBits *= nWidth; 263*cdf0e10cSrcweir if( nScanSize % 4 || !bMsb ) 264*cdf0e10cSrcweir { 265*cdf0e10cSrcweir DBG_ASSERT( 8*nScanSize >= nBits, 266*cdf0e10cSrcweir "BitmapWriteAccess::ZeroInitUnusedBits: span size smaller than width?!"); 267*cdf0e10cSrcweir const sal_uInt32 nLeftOverBits = 8*sizeof(sal_uInt8)*nScanSize - nBits; 268*cdf0e10cSrcweir if( nLeftOverBits != 0 ) // else there is really nothing to do 269*cdf0e10cSrcweir { 270*cdf0e10cSrcweir const sal_uInt32 nBytes = (nLeftOverBits + 7U) >> 3U; 271*cdf0e10cSrcweir sal_uInt8 nMask; 272*cdf0e10cSrcweir 273*cdf0e10cSrcweir if( bMsb ) 274*cdf0e10cSrcweir nMask = static_cast<sal_uInt8>(0xffU << (nLeftOverBits & 3UL)); 275*cdf0e10cSrcweir else 276*cdf0e10cSrcweir nMask = static_cast<sal_uInt8>(0xffU >> (nLeftOverBits & 3UL)); 277*cdf0e10cSrcweir 278*cdf0e10cSrcweir sal_uInt8* pLastBytes = (sal_uInt8*)GetBuffer() + ( nScanSize - nBytes ); 279*cdf0e10cSrcweir for( sal_uInt32 i = 0; i < nHeight; i++, pLastBytes += nScanSize ) 280*cdf0e10cSrcweir { 281*cdf0e10cSrcweir *pLastBytes &= nMask; 282*cdf0e10cSrcweir for( sal_uInt32 j = 1; j < nBytes; j++ ) 283*cdf0e10cSrcweir pLastBytes[j] = 0; 284*cdf0e10cSrcweir } 285*cdf0e10cSrcweir } 286*cdf0e10cSrcweir } 287*cdf0e10cSrcweir else if( nBits & 0x1f ) 288*cdf0e10cSrcweir { 289*cdf0e10cSrcweir sal_uInt32 nMask = 0xffffffff << ( ( nScanSize << 3 ) - nBits ); 290*cdf0e10cSrcweir sal_uInt8* pLast4Bytes = (sal_uInt8*) GetBuffer() + ( nScanSize - 4 ); 291*cdf0e10cSrcweir 292*cdf0e10cSrcweir #ifdef OSL_LITENDIAN 293*cdf0e10cSrcweir nMask = SWAPLONG( nMask ); 294*cdf0e10cSrcweir #endif 295*cdf0e10cSrcweir for( sal_uInt32 i = 0; i < nHeight; i++, pLast4Bytes += nScanSize ) 296*cdf0e10cSrcweir ( *(sal_uInt32*) pLast4Bytes ) &= nMask; 297*cdf0e10cSrcweir } 298*cdf0e10cSrcweir } 299*cdf0e10cSrcweir } 300*cdf0e10cSrcweir 301*cdf0e10cSrcweir // ------------------------------------------------------------------ 302*cdf0e10cSrcweir 303*cdf0e10cSrcweir void BitmapReadAccess::Flush() 304*cdf0e10cSrcweir { 305*cdf0e10cSrcweir ImplDestroy(); 306*cdf0e10cSrcweir } 307*cdf0e10cSrcweir 308*cdf0e10cSrcweir // ------------------------------------------------------------------ 309*cdf0e10cSrcweir 310*cdf0e10cSrcweir void BitmapReadAccess::ReAccess( sal_Bool bModify ) 311*cdf0e10cSrcweir { 312*cdf0e10cSrcweir const ImpBitmap* pImpBmp = maBitmap.ImplGetImpBitmap(); 313*cdf0e10cSrcweir 314*cdf0e10cSrcweir DBG_ASSERT( !mpBuffer, "No ReAccess possible while bitmap is being accessed!" ); 315*cdf0e10cSrcweir DBG_ASSERT( pImpBmp && ( pImpBmp->ImplGetRefCount() > 1UL ), "Accessed bitmap does not exist anymore!" ); 316*cdf0e10cSrcweir 317*cdf0e10cSrcweir if( !mpBuffer && pImpBmp && ( pImpBmp->ImplGetRefCount() > 1UL ) ) 318*cdf0e10cSrcweir { 319*cdf0e10cSrcweir mbModify = bModify; 320*cdf0e10cSrcweir ImplCreate( maBitmap ); 321*cdf0e10cSrcweir } 322*cdf0e10cSrcweir } 323*cdf0e10cSrcweir 324*cdf0e10cSrcweir // ------------------------------------------------------------------ 325*cdf0e10cSrcweir 326*cdf0e10cSrcweir sal_uInt16 BitmapReadAccess::GetBestPaletteIndex( const BitmapColor& rBitmapColor ) const 327*cdf0e10cSrcweir { 328*cdf0e10cSrcweir return( HasPalette() ? mpBuffer->maPalette.GetBestIndex( rBitmapColor ) : 0 ); 329*cdf0e10cSrcweir } 330*cdf0e10cSrcweir 331*cdf0e10cSrcweir // --------------------- 332*cdf0e10cSrcweir // - BitmapWriteAccess - 333*cdf0e10cSrcweir // --------------------- 334*cdf0e10cSrcweir 335*cdf0e10cSrcweir BitmapWriteAccess::BitmapWriteAccess( Bitmap& rBitmap ) : 336*cdf0e10cSrcweir BitmapReadAccess( rBitmap, sal_True ), 337*cdf0e10cSrcweir mpLineColor ( NULL ), 338*cdf0e10cSrcweir mpFillColor ( NULL ) 339*cdf0e10cSrcweir { 340*cdf0e10cSrcweir } 341*cdf0e10cSrcweir 342*cdf0e10cSrcweir // ------------------------------------------------------------------ 343*cdf0e10cSrcweir 344*cdf0e10cSrcweir BitmapWriteAccess::~BitmapWriteAccess() 345*cdf0e10cSrcweir { 346*cdf0e10cSrcweir delete mpLineColor; 347*cdf0e10cSrcweir delete mpFillColor; 348*cdf0e10cSrcweir } 349*cdf0e10cSrcweir 350*cdf0e10cSrcweir // ------------------------------------------------------------------ 351*cdf0e10cSrcweir 352*cdf0e10cSrcweir void BitmapWriteAccess::CopyScanline( long nY, const BitmapReadAccess& rReadAcc ) 353*cdf0e10cSrcweir { 354*cdf0e10cSrcweir DBG_ASSERT( ( nY >= 0 ) && ( nY < mpBuffer->mnHeight ), "y-coordinate in destination out of range!" ); 355*cdf0e10cSrcweir DBG_ASSERT( nY < rReadAcc.Height(), "y-coordinate in source out of range!" ); 356*cdf0e10cSrcweir DBG_ASSERT( ( HasPalette() && rReadAcc.HasPalette() ) || ( !HasPalette() && !rReadAcc.HasPalette() ), "No copying possible between palette bitmap and TC bitmap!" ); 357*cdf0e10cSrcweir 358*cdf0e10cSrcweir if( ( GetScanlineFormat() == rReadAcc.GetScanlineFormat() ) && 359*cdf0e10cSrcweir ( GetScanlineSize() >= rReadAcc.GetScanlineSize() ) ) 360*cdf0e10cSrcweir { 361*cdf0e10cSrcweir memcpy( mpScanBuf[ nY ], rReadAcc.GetScanline( nY ), rReadAcc.GetScanlineSize() ); 362*cdf0e10cSrcweir } 363*cdf0e10cSrcweir else 364*cdf0e10cSrcweir // TODO: use fastbmp infrastructure 365*cdf0e10cSrcweir for( long nX = 0L, nWidth = Min( mpBuffer->mnWidth, rReadAcc.Width() ); nX < nWidth; nX++ ) 366*cdf0e10cSrcweir SetPixel( nY, nX, rReadAcc.GetPixel( nY, nX ) ); 367*cdf0e10cSrcweir } 368*cdf0e10cSrcweir 369*cdf0e10cSrcweir // ------------------------------------------------------------------ 370*cdf0e10cSrcweir 371*cdf0e10cSrcweir void BitmapWriteAccess::CopyScanline( long nY, ConstScanline aSrcScanline, 372*cdf0e10cSrcweir sal_uLong nSrcScanlineFormat, sal_uLong nSrcScanlineSize ) 373*cdf0e10cSrcweir { 374*cdf0e10cSrcweir const sal_uLong nFormat = BMP_SCANLINE_FORMAT( nSrcScanlineFormat ); 375*cdf0e10cSrcweir 376*cdf0e10cSrcweir DBG_ASSERT( ( nY >= 0 ) && ( nY < mpBuffer->mnHeight ), "y-coordinate in destination out of range!" ); 377*cdf0e10cSrcweir DBG_ASSERT( ( HasPalette() && nFormat <= BMP_FORMAT_8BIT_PAL ) || 378*cdf0e10cSrcweir ( !HasPalette() && nFormat > BMP_FORMAT_8BIT_PAL ), 379*cdf0e10cSrcweir "No copying possible between palette and non palette scanlines!" ); 380*cdf0e10cSrcweir 381*cdf0e10cSrcweir const sal_uLong nCount = Min( GetScanlineSize(), nSrcScanlineSize ); 382*cdf0e10cSrcweir 383*cdf0e10cSrcweir if( nCount ) 384*cdf0e10cSrcweir { 385*cdf0e10cSrcweir if( GetScanlineFormat() == BMP_SCANLINE_FORMAT( nSrcScanlineFormat ) ) 386*cdf0e10cSrcweir memcpy( mpScanBuf[ nY ], aSrcScanline, nCount ); 387*cdf0e10cSrcweir else 388*cdf0e10cSrcweir { 389*cdf0e10cSrcweir DBG_ASSERT( nFormat != BMP_FORMAT_8BIT_TC_MASK && 390*cdf0e10cSrcweir nFormat != BMP_FORMAT_16BIT_TC_MSB_MASK && nFormat != BMP_FORMAT_16BIT_TC_LSB_MASK && 391*cdf0e10cSrcweir nFormat != BMP_FORMAT_24BIT_TC_MASK && nFormat != BMP_FORMAT_32BIT_TC_MASK, 392*cdf0e10cSrcweir "No support for pixel formats with color masks yet!" ); 393*cdf0e10cSrcweir 394*cdf0e10cSrcweir // TODO: use fastbmp infrastructure 395*cdf0e10cSrcweir FncGetPixel pFncGetPixel; 396*cdf0e10cSrcweir 397*cdf0e10cSrcweir switch( nFormat ) 398*cdf0e10cSrcweir { 399*cdf0e10cSrcweir case( BMP_FORMAT_1BIT_MSB_PAL ): pFncGetPixel = GetPixelFor_1BIT_MSB_PAL; break; 400*cdf0e10cSrcweir case( BMP_FORMAT_1BIT_LSB_PAL ): pFncGetPixel = GetPixelFor_1BIT_LSB_PAL; break; 401*cdf0e10cSrcweir case( BMP_FORMAT_4BIT_MSN_PAL ): pFncGetPixel = GetPixelFor_4BIT_MSN_PAL; break; 402*cdf0e10cSrcweir case( BMP_FORMAT_4BIT_LSN_PAL ): pFncGetPixel = GetPixelFor_4BIT_LSN_PAL; break; 403*cdf0e10cSrcweir case( BMP_FORMAT_8BIT_PAL ): pFncGetPixel = GetPixelFor_8BIT_PAL; break; 404*cdf0e10cSrcweir case( BMP_FORMAT_8BIT_TC_MASK ): pFncGetPixel = GetPixelFor_8BIT_TC_MASK; break; 405*cdf0e10cSrcweir case( BMP_FORMAT_16BIT_TC_MSB_MASK ): pFncGetPixel = GetPixelFor_16BIT_TC_MSB_MASK; break; 406*cdf0e10cSrcweir case( BMP_FORMAT_16BIT_TC_LSB_MASK ): pFncGetPixel = GetPixelFor_16BIT_TC_LSB_MASK; break; 407*cdf0e10cSrcweir case( BMP_FORMAT_24BIT_TC_BGR ): pFncGetPixel = GetPixelFor_24BIT_TC_BGR; break; 408*cdf0e10cSrcweir case( BMP_FORMAT_24BIT_TC_RGB ): pFncGetPixel = GetPixelFor_24BIT_TC_RGB; break; 409*cdf0e10cSrcweir case( BMP_FORMAT_24BIT_TC_MASK ): pFncGetPixel = GetPixelFor_24BIT_TC_MASK; break; 410*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_ABGR ): pFncGetPixel = GetPixelFor_32BIT_TC_ABGR; break; 411*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_ARGB ): pFncGetPixel = GetPixelFor_32BIT_TC_ARGB; break; 412*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_BGRA ): pFncGetPixel = GetPixelFor_32BIT_TC_BGRA; break; 413*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_RGBA ): pFncGetPixel = GetPixelFor_32BIT_TC_RGBA; break; 414*cdf0e10cSrcweir case( BMP_FORMAT_32BIT_TC_MASK ): pFncGetPixel = GetPixelFor_32BIT_TC_MASK; break; 415*cdf0e10cSrcweir 416*cdf0e10cSrcweir default: 417*cdf0e10cSrcweir pFncGetPixel = NULL; 418*cdf0e10cSrcweir break; 419*cdf0e10cSrcweir } 420*cdf0e10cSrcweir 421*cdf0e10cSrcweir if( pFncGetPixel ) 422*cdf0e10cSrcweir { 423*cdf0e10cSrcweir const ColorMask aDummyMask; 424*cdf0e10cSrcweir 425*cdf0e10cSrcweir for( long nX = 0L, nWidth = mpBuffer->mnWidth; nX < nWidth; nX++ ) 426*cdf0e10cSrcweir SetPixel( nY, nX, pFncGetPixel( aSrcScanline, nX, aDummyMask ) ); 427*cdf0e10cSrcweir } 428*cdf0e10cSrcweir } 429*cdf0e10cSrcweir } 430*cdf0e10cSrcweir } 431*cdf0e10cSrcweir 432*cdf0e10cSrcweir 433*cdf0e10cSrcweir // ------------------------------------------------------------------ 434*cdf0e10cSrcweir 435*cdf0e10cSrcweir void BitmapWriteAccess::CopyBuffer( const BitmapReadAccess& rReadAcc ) 436*cdf0e10cSrcweir { 437*cdf0e10cSrcweir DBG_ASSERT( ( HasPalette() && rReadAcc.HasPalette() ) || ( !HasPalette() && !rReadAcc.HasPalette() ), "No copying possible between palette bitmap and TC bitmap!" ); 438*cdf0e10cSrcweir 439*cdf0e10cSrcweir if( ( GetScanlineFormat() == rReadAcc.GetScanlineFormat() ) && 440*cdf0e10cSrcweir ( GetScanlineSize() == rReadAcc.GetScanlineSize() ) ) 441*cdf0e10cSrcweir { 442*cdf0e10cSrcweir const long nHeight = Min( mpBuffer->mnHeight, rReadAcc.Height() ); 443*cdf0e10cSrcweir const sal_uLong nCount = nHeight * mpBuffer->mnScanlineSize; 444*cdf0e10cSrcweir 445*cdf0e10cSrcweir memcpy( mpBuffer->mpBits, rReadAcc.GetBuffer(), nCount ); 446*cdf0e10cSrcweir } 447*cdf0e10cSrcweir else 448*cdf0e10cSrcweir for( long nY = 0L, nHeight = Min( mpBuffer->mnHeight, rReadAcc.Height() ); nY < nHeight; nY++ ) 449*cdf0e10cSrcweir CopyScanline( nY, rReadAcc ); 450*cdf0e10cSrcweir } 451