diff options
author | Kurt Zenker <kz@openoffice.org> | 2008-06-24 10:02:18 +0000 |
---|---|---|
committer | Kurt Zenker <kz@openoffice.org> | 2008-06-24 10:02:18 +0000 |
commit | b6a7c4da52acf45a7b69d1e81cf9548f8552752e (patch) | |
tree | 7e2fcaf7a77b0ca9c5e712b5d7399febbc3055c3 /canvas | |
parent | af5a4120dc54fdd1dc7fc477b2d44f090a9e49df (diff) |
INTEGRATION: CWS canvas05 (1.13.56); FILE MERGED
2008/06/09 12:51:48 thb 1.13.56.7: #i88081# Join from CWS impress144 (fixing the dxcanvas crash), extended for the other canvas impls
2008/04/21 07:28:29 thb 1.13.56.6: RESYNC: (1.14-1.15); FILE MERGED
2008/04/09 14:33:12 thb 1.13.56.5: Gave back vclcanvas the window surface; made cairocanvas consistent with rest (regarding setWindow)
2008/04/09 09:35:12 thb 1.13.56.4: Improved log output, fixed wrong arg check for vclcanvas
2007/12/20 22:19:00 thb 1.13.56.3: #i81092# #i78888# #i78925# #i79258# #i79437# #i84784# Large canvas rework, completing various areas such as color spaces, bitmap data access, true sprite and non-sprite implementations, and upstreaming the canvas parts of rodos emf+ rendering
2007/11/06 12:37:01 thb 1.13.56.2: RESYNC: (1.13-1.14); FILE MERGED
2007/10/01 13:02:04 thb 1.13.56.1: #i78888# #i78925# #i79258# #i79437# Merge from CWS picom
Diffstat (limited to 'canvas')
-rw-r--r-- | canvas/source/vcl/spritecanvas.cxx | 185 |
1 files changed, 43 insertions, 142 deletions
diff --git a/canvas/source/vcl/spritecanvas.cxx b/canvas/source/vcl/spritecanvas.cxx index ebda4496dd99..69bd4786b4c8 100644 --- a/canvas/source/vcl/spritecanvas.cxx +++ b/canvas/source/vcl/spritecanvas.cxx @@ -7,7 +7,7 @@ * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: spritecanvas.cxx,v $ - * $Revision: 1.15 $ + * $Revision: 1.16 $ * * This file is part of OpenOffice.org. * @@ -32,6 +32,7 @@ #include "precompiled_canvas.hxx" #include <canvas/debug.hxx> +#include <tools/diagnose_ex.h> #include <canvas/verbosetrace.hxx> #include <canvas/canvastools.hxx> @@ -39,10 +40,6 @@ #include <com/sun/star/lang/XSingleServiceFactory.hpp> #include <com/sun/star/uno/XComponentContext.hpp> -#include <cppuhelper/factory.hxx> -#include <cppuhelper/implementationentry.hxx> -#include <comphelper/servicedecl.hxx> - #include <vcl/canvastools.hxx> #include <vcl/outdev.hxx> #include <vcl/window.hxx> @@ -53,27 +50,28 @@ #include <algorithm> #include "spritecanvas.hxx" +#include "windowoutdevholder.hxx" using namespace ::com::sun::star; -#define SERVICE_NAME "com.sun.star.rendering.VCLCanvas" - namespace vclcanvas { SpriteCanvas::SpriteCanvas( const uno::Sequence< uno::Any >& aArguments, const uno::Reference< uno::XComponentContext >& rxContext ) : + maArguments(aArguments), mxComponentContext( rxContext ) { - // #i64742# Only call initialize when not in probe mode - if( aArguments.getLength() != 0 ) - initialize( aArguments ); } - void SpriteCanvas::initialize( const uno::Sequence< uno::Any >& aArguments ) + void SpriteCanvas::initialize() { tools::LocalGuard aGuard; + // #i64742# Only call initialize when not in probe mode + if( maArguments.getLength() == 0 ) + return; + OSL_TRACE( "SpriteCanvas created" ); // add our own property to GraphicDevice @@ -94,30 +92,37 @@ namespace vclcanvas VERBOSE_TRACE( "VCLSpriteCanvas::initialize called" ); - CHECK_AND_THROW( aArguments.getLength() >= 1, - "SpriteCanvas::initialize: wrong number of arguments" ); - - // We expect a single Any here, containing a pointer to a valid - // VCL window, on which to output - if( aArguments.getLength() >= 1 && - aArguments[0].getValueTypeClass() == uno::TypeClass_HYPER ) - { - sal_Int64 nWindowPtr = 0; - aArguments[0] >>= nWindowPtr; - Window* pOutputWindow = reinterpret_cast<Window*>(nWindowPtr); - - CHECK_AND_THROW( pOutputWindow != NULL, - "SpriteCanvas::initialize: invalid Window pointer" ); - - // setup helper - maDeviceHelper.init( *pOutputWindow, - *this ); - maCanvasHelper.init( *this, - maDeviceHelper.getBackBuffer(), - false, // no OutDev state preservation - false ); // no alpha on surface - maCanvasHelper.setRedrawManager( maRedrawManager ); - } + ENSURE_ARG_OR_THROW( maArguments.getLength() >= 1, + "VCLSpriteCanvas::initialize: wrong number of arguments" ); + + /* maArguments: + 0: ptr to creating instance (Window or VirtualDevice) + 1: SystemEnvData as a streamed Any (or empty for VirtualDevice) + 2: current bounds of creating instance + 3: bool, denoting always on top state for Window (always false for VirtualDevice) + 4: XWindow for creating Window (or empty for VirtualDevice) + 5: SystemGraphicsData as a streamed Any + */ + ENSURE_ARG_OR_THROW( maArguments.getLength() >= 4 && + maArguments[0].getValueTypeClass() == uno::TypeClass_HYPER && + maArguments[4].getValueTypeClass() == uno::TypeClass_INTERFACE, + "VCLSpriteCanvas::initialize: wrong number of arguments, or wrong types" ); + + uno::Reference< awt::XWindow > xParentWindow; + maArguments[4] >>= xParentWindow; + + OutDevProviderSharedPtr pOutDev( new WindowOutDevHolder(xParentWindow) ); + + // setup helper + maDeviceHelper.init( pOutDev ); + setWindow(uno::Reference<awt::XWindow2>(xParentWindow, uno::UNO_QUERY_THROW)); + maCanvasHelper.init( maDeviceHelper.getBackBuffer(), + *this, + maRedrawManager, + false, // no OutDev state preservation + false ); // no alpha on surface + + maArguments.realloc(0); } SpriteCanvas::~SpriteCanvas() @@ -138,22 +143,12 @@ namespace vclcanvas ::sal_Bool SAL_CALL SpriteCanvas::showBuffer( ::sal_Bool bUpdateAll ) throw (uno::RuntimeException) { - tools::LocalGuard aGuard; - - // avoid repaints on hidden window (hidden: not mapped to - // screen). Return failure, since the screen really has _not_ - // been updated (caller should try again later) - return !mbIsVisible ? false : SpriteCanvasBaseT::showBuffer( bUpdateAll ); + return updateScreen( bUpdateAll ); } ::sal_Bool SAL_CALL SpriteCanvas::switchBuffer( ::sal_Bool bUpdateAll ) throw (uno::RuntimeException) { - tools::LocalGuard aGuard; - - // avoid repaints on hidden window (hidden: not mapped to - // screen). Return failure, since the screen really has _not_ - // been updated (caller should try again later) - return !mbIsVisible ? false : SpriteCanvasBaseT::switchBuffer( bUpdateAll ); + return updateScreen( bUpdateAll ); } sal_Bool SAL_CALL SpriteCanvas::updateScreen( sal_Bool bUpdateAll ) throw (uno::RuntimeException) @@ -169,7 +164,7 @@ namespace vclcanvas ::rtl::OUString SAL_CALL SpriteCanvas::getServiceName( ) throw (::com::sun::star::uno::RuntimeException) { - return ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICE_NAME ) ); + return ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SPRITECANVAS_SERVICE_NAME ) ); } bool SpriteCanvas::repaint( const GraphicObjectSharedPtr& rGrf, @@ -183,98 +178,4 @@ namespace vclcanvas return maCanvasHelper.repaint( rGrf, viewState, renderState, rPt, rSz, rAttr ); } - - OutputDevice* SpriteCanvas::getOutDev() const - { - tools::LocalGuard aGuard; - - return maDeviceHelper.getOutDev(); - } - - BackBufferSharedPtr SpriteCanvas::getBackBuffer() const - { - tools::LocalGuard aGuard; - - return maDeviceHelper.getBackBuffer(); - } - - uno::Reference< beans::XPropertySetInfo > SAL_CALL SpriteCanvas::getPropertySetInfo() throw (uno::RuntimeException) - { - tools::LocalGuard aGuard; - return maPropHelper.getPropertySetInfo(); - } - - void SAL_CALL SpriteCanvas::setPropertyValue( const ::rtl::OUString& aPropertyName, - const uno::Any& aValue ) throw (beans::UnknownPropertyException, - beans::PropertyVetoException, - lang::IllegalArgumentException, - lang::WrappedTargetException, - uno::RuntimeException) - { - tools::LocalGuard aGuard; - maPropHelper.setPropertyValue( aPropertyName, aValue ); - } - - uno::Any SAL_CALL SpriteCanvas::getPropertyValue( const ::rtl::OUString& aPropertyName ) throw (beans::UnknownPropertyException, - lang::WrappedTargetException, - uno::RuntimeException) - { - tools::LocalGuard aGuard; - return maPropHelper.getPropertyValue( aPropertyName ); - } - - void SAL_CALL SpriteCanvas::addPropertyChangeListener( const ::rtl::OUString& aPropertyName, - const uno::Reference< beans::XPropertyChangeListener >& xListener ) throw (beans::UnknownPropertyException, - lang::WrappedTargetException, - uno::RuntimeException) - { - tools::LocalGuard aGuard; - maPropHelper.addPropertyChangeListener( aPropertyName, - xListener ); - } - - void SAL_CALL SpriteCanvas::removePropertyChangeListener( const ::rtl::OUString& aPropertyName, - const uno::Reference< beans::XPropertyChangeListener >& xListener ) throw (beans::UnknownPropertyException, - lang::WrappedTargetException, - uno::RuntimeException) - { - tools::LocalGuard aGuard; - maPropHelper.removePropertyChangeListener( aPropertyName, - xListener ); - } - - void SAL_CALL SpriteCanvas::addVetoableChangeListener( const ::rtl::OUString& aPropertyName, - const uno::Reference< beans::XVetoableChangeListener >& xListener ) throw (beans::UnknownPropertyException, - lang::WrappedTargetException, - uno::RuntimeException) - { - tools::LocalGuard aGuard; - maPropHelper.addVetoableChangeListener( aPropertyName, - xListener ); - } - - void SAL_CALL SpriteCanvas::removeVetoableChangeListener( const ::rtl::OUString& aPropertyName, - const uno::Reference< beans::XVetoableChangeListener >& xListener ) throw (beans::UnknownPropertyException, - lang::WrappedTargetException, - uno::RuntimeException) - { - tools::LocalGuard aGuard; - maPropHelper.removeVetoableChangeListener( aPropertyName, - xListener ); - } - - namespace sdecl = comphelper::service_decl; -#if defined (__GNUC__) && (__GNUC__ == 3 && __GNUC_MINOR__ <= 3) - sdecl::class_<SpriteCanvas, sdecl::with_args<true> > serviceImpl; - const sdecl::ServiceDecl vclCanvasDecl( - serviceImpl, -#else - const sdecl::ServiceDecl vclCanvasDecl( - sdecl::class_<SpriteCanvas, sdecl::with_args<true> >(), -#endif - "com.sun.star.comp.rendering.VCLCanvas", - SERVICE_NAME ); } - -// The C shared lib entry points -COMPHELPER_SERVICEDECL_EXPORTS1(vclcanvas::vclCanvasDecl) |