/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_canvas.hxx" #include // don't ask. msdev breaks otherwise... #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "dx_winstuff.hxx" #include "dx_spritecanvas.hxx" #if DIRECTX_VERSION < 0x0900 # define CANVAS_TECH "DX5" #else # define CANVAS_TECH "DX9" #endif #define SPRITECANVAS_SERVICE_NAME "com.sun.star.rendering.SpriteCanvas." CANVAS_TECH #define SPRITECANVAS_IMPLEMENTATION_NAME "com.sun.star.comp.rendering.SpriteCanvas." CANVAS_TECH using namespace ::com::sun::star; namespace dxcanvas { SpriteCanvas::SpriteCanvas( const uno::Sequence< uno::Any >& aArguments, const uno::Reference< uno::XComponentContext >& rxContext ) : maArguments(aArguments), mxComponentContext( rxContext ) { } void SpriteCanvas::initialize() { // #i64742# Only call initialize when not in probe mode if( maArguments.getLength() == 0 ) return; VERBOSE_TRACE( "SpriteCanvas::initialize called" ); /* aArguments: 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() >= 5 && maArguments[4].getValueTypeClass() == uno::TypeClass_INTERFACE, "VCLSpriteCanvas::initialize: wrong number of arguments, or wrong types" ); uno::Reference< awt::XWindow > xParentWindow; maArguments[4] >>= xParentWindow; Window* pParentWindow = VCLUnoHelper::GetWindow(xParentWindow); if( !pParentWindow ) throw lang::NoSupportException( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Parent window not VCL window, or canvas out-of-process!")), NULL); awt::Rectangle aRect; maArguments[2] >>= aRect; sal_Bool bIsFullscreen( sal_False ); maArguments[3] >>= bIsFullscreen; // setup helper maDeviceHelper.init( *pParentWindow, *this, aRect, bIsFullscreen ); maCanvasHelper.init( *this, maRedrawManager, maDeviceHelper.getRenderModule(), maDeviceHelper.getSurfaceProxy(), maDeviceHelper.getBackBuffer(), ::basegfx::B2ISize() ); maArguments.realloc(0); } void SAL_CALL SpriteCanvas::disposing() { ::osl::MutexGuard aGuard( m_aMutex ); mxComponentContext.clear(); // forward to parent SpriteCanvasBaseT::disposing(); } ::sal_Bool SAL_CALL SpriteCanvas::showBuffer( ::sal_Bool bUpdateAll ) throw (uno::RuntimeException) { ::osl::MutexGuard aGuard( m_aMutex ); // 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 ); } ::sal_Bool SAL_CALL SpriteCanvas::switchBuffer( ::sal_Bool bUpdateAll ) throw (uno::RuntimeException) { ::osl::MutexGuard aGuard( m_aMutex ); // 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 ); } sal_Bool SAL_CALL SpriteCanvas::updateScreen( sal_Bool bUpdateAll ) throw (uno::RuntimeException) { ::osl::MutexGuard aGuard( m_aMutex ); // 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 : maCanvasHelper.updateScreen( ::basegfx::unotools::b2IRectangleFromAwtRectangle(maBounds), bUpdateAll, mbSurfaceDirty ); } ::rtl::OUString SAL_CALL SpriteCanvas::getServiceName( ) throw (uno::RuntimeException) { return ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SPRITECANVAS_SERVICE_NAME ) ); } const IDXRenderModuleSharedPtr& SpriteCanvas::getRenderModule() const { ::osl::MutexGuard aGuard( m_aMutex ); return maDeviceHelper.getRenderModule(); } const DXSurfaceBitmapSharedPtr& SpriteCanvas::getBackBuffer() const { ::osl::MutexGuard aGuard( m_aMutex ); return maDeviceHelper.getBackBuffer(); } IBitmapSharedPtr SpriteCanvas::getBitmap() const { return maDeviceHelper.getBackBuffer(); } static uno::Reference initCanvas( SpriteCanvas* pCanvas ) { uno::Reference xRet(static_cast(pCanvas)); pCanvas->initialize(); return xRet; } namespace sdecl = comphelper::service_decl; sdecl::class_ > serviceImpl(&initCanvas); const sdecl::ServiceDecl dxSpriteCanvasDecl( serviceImpl, SPRITECANVAS_IMPLEMENTATION_NAME, SPRITECANVAS_SERVICE_NAME ); } // The C shared lib entry points COMPHELPER_SERVICEDECL_EXPORTS1(dxcanvas::dxSpriteCanvasDecl);