diff options
-rw-r--r-- | canvas/source/vcl/cachedbitmap.cxx | 73 |
1 files changed, 14 insertions, 59 deletions
diff --git a/canvas/source/vcl/cachedbitmap.cxx b/canvas/source/vcl/cachedbitmap.cxx index 6d42fd3d1e5b..6bd0b8e09e0a 100644 --- a/canvas/source/vcl/cachedbitmap.cxx +++ b/canvas/source/vcl/cachedbitmap.cxx @@ -4,9 +4,9 @@ * * $RCSfile: cachedbitmap.cxx,v $ * - * $Revision: 1.3 $ + * $Revision: 1.4 $ * - * last change: $Author: rt $ $Date: 2005-09-07 23:16:39 $ + * last change: $Author: kz $ $Date: 2005-11-02 12:57:49 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. @@ -38,27 +38,15 @@ #include "cachedbitmap.hxx" #include "repainttarget.hxx" -#ifndef _COM_SUN_STAR_RENDERING_REPAINTRESULT_HPP_ #include <com/sun/star/rendering/RepaintResult.hpp> -#endif -#ifndef _COM_SUN_STAR_RENDERING_XPOLYPOLYGON2D_HPP_ #include <com/sun/star/rendering/XPolyPolygon2D.hpp> -#endif -#ifndef _BGFX_MATRIX_B2DHOMMATRIX_HXX #include <basegfx/matrix/b2dhommatrix.hxx> -#endif -#ifndef _BGFX_TOOLS_CANVASTOOLS_HXX #include <basegfx/tools/canvastools.hxx> -#endif using namespace ::com::sun::star; - -#define IMPLEMENTATION_NAME "VCLCanvas::CachedBitmap" -#define SERVICE_NAME "com.sun.star.rendering.CachedBitmap" - namespace vclcanvas { CachedBitmap::CachedBitmap( const GraphicObjectSharedPtr& rGraphicObject, @@ -67,17 +55,11 @@ namespace vclcanvas const GraphicAttr& rAttr, const rendering::ViewState& rUsedViewState, const uno::Reference< rendering::XCanvas >& rTarget ) : - CachedBitmap_Base( m_aMutex ), + CachedPrimitiveBase( rUsedViewState, rTarget, true ), mpGraphicObject( rGraphicObject ), maPoint( rPoint ), maSize( rSize ), - maAttributes( rAttr ), - maUsedViewState( rUsedViewState ), - mxTarget( rTarget ) - { - } - - CachedBitmap::~CachedBitmap() + maAttributes( rAttr ) { } @@ -85,34 +67,25 @@ namespace vclcanvas { ::osl::MutexGuard aGuard( m_aMutex ); - maUsedViewState.Clip.clear(); mpGraphicObject.reset(); - mxTarget.clear(); + + CachedPrimitiveBase::disposing(); } - sal_Int8 SAL_CALL CachedBitmap::redraw( const rendering::ViewState& aState ) throw (lang::IllegalArgumentException, uno::RuntimeException) + ::sal_Int8 CachedBitmap::doRedraw( const rendering::ViewState& rNewState, + const rendering::ViewState& rOldState, + const uno::Reference< rendering::XCanvas >& rTargetCanvas, + bool bSameViewTransform ) { - ::basegfx::B2DHomMatrix aUsedTransformation; - ::basegfx::B2DHomMatrix aNewTransformation; - - ::basegfx::unotools::homMatrixFromAffineMatrix( aUsedTransformation, - maUsedViewState.AffineTransform ); - ::basegfx::unotools::homMatrixFromAffineMatrix( aNewTransformation, - aState.AffineTransform ); - - if( aUsedTransformation != aNewTransformation ) - { - // differing transformations, don't try to draft the - // output, just plain fail here. - return rendering::RepaintResult::FAILED; - } + ENSURE_AND_THROW( bSameViewTransform, + "CachedBitmap::doRedraw(): base called with changed view transform " + "(told otherwise during construction)" ); - RepaintTarget* pTarget = dynamic_cast< RepaintTarget* >(mxTarget.get()); + RepaintTarget* pTarget = dynamic_cast< RepaintTarget* >(rTargetCanvas.get()); ENSURE_AND_THROW( pTarget, "CachedBitmap::redraw(): cannot cast target to RepaintTarget" ); - if( !pTarget->repaint( mpGraphicObject, maPoint, maSize, @@ -124,22 +97,4 @@ namespace vclcanvas return rendering::RepaintResult::REDRAWN; } - - ::rtl::OUString SAL_CALL CachedBitmap::getImplementationName( ) throw (uno::RuntimeException) - { - return ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( IMPLEMENTATION_NAME ) ); - } - - sal_Bool SAL_CALL CachedBitmap::supportsService( const ::rtl::OUString& ServiceName ) throw (uno::RuntimeException) - { - return ServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( SERVICE_NAME ) ); - } - - uno::Sequence< ::rtl::OUString > SAL_CALL CachedBitmap::getSupportedServiceNames( ) throw (uno::RuntimeException) - { - uno::Sequence< ::rtl::OUString > aRet(1); - aRet[0] = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( SERVICE_NAME ) ); - - return aRet; - } } |