/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_canvas.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include "spritecanvas.hxx" #include "windowoutdevholder.hxx" using namespace ::com::sun::star; namespace vclcanvas { SpriteCanvas::SpriteCanvas( const uno::Sequence< uno::Any >& aArguments, const uno::Reference< uno::XComponentContext >& rxContext ) : maArguments(aArguments), mxComponentContext( rxContext ) { } 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 maPropHelper.addProperties( ::canvas::PropertySetHelper::MakeMap ("UnsafeScrolling", boost::bind(&SpriteCanvasHelper::isUnsafeScrolling, boost::ref(maCanvasHelper)), boost::bind(&SpriteCanvasHelper::enableUnsafeScrolling, boost::ref(maCanvasHelper), _1)) ("SpriteBounds", boost::bind(&SpriteCanvasHelper::isSpriteBounds, boost::ref(maCanvasHelper)), boost::bind(&SpriteCanvasHelper::enableSpriteBounds, boost::ref(maCanvasHelper), _1))); VERBOSE_TRACE( "VCLSpriteCanvas::initialize called" ); 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(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() { OSL_TRACE( "SpriteCanvas destroyed" ); } void SAL_CALL SpriteCanvas::disposing() { tools::LocalGuard aGuard; mxComponentContext.clear(); // forward to parent SpriteCanvasBaseT::disposing(); } ::sal_Bool SAL_CALL SpriteCanvas::showBuffer( ::sal_Bool bUpdateAll ) throw (uno::RuntimeException) { return updateScreen( bUpdateAll ); } ::sal_Bool SAL_CALL SpriteCanvas::switchBuffer( ::sal_Bool bUpdateAll ) throw (uno::RuntimeException) { return updateScreen( bUpdateAll ); } sal_Bool SAL_CALL SpriteCanvas::updateScreen( 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 : maCanvasHelper.updateScreen(bUpdateAll, mbSurfaceDirty); } ::rtl::OUString SAL_CALL SpriteCanvas::getServiceName( ) throw (::com::sun::star::uno::RuntimeException) { return ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SPRITECANVAS_SERVICE_NAME ) ); } bool SpriteCanvas::repaint( const GraphicObjectSharedPtr& rGrf, const rendering::ViewState& viewState, const rendering::RenderState& renderState, const ::Point& rPt, const ::Size& rSz, const GraphicAttr& rAttr ) const { tools::LocalGuard aGuard; return maCanvasHelper.repaint( rGrf, viewState, renderState, rPt, rSz, rAttr ); } }