/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ #ifndef INCLUDED_SDEXT_SOURCE_PRESENTER_PRESENTERPANECONTAINER_HXX #define INCLUDED_SDEXT_SOURCE_PRESENTER_PRESENTERPANECONTAINER_HXX #include "PresenterTheme.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace sdext { namespace presenter { class PresenterPaneBase; class PresenterSprite; namespace { typedef ::cppu::WeakComponentImplHelper < css::lang::XEventListener > PresenterPaneContainerInterfaceBase; } /** This class could also be called PresenterPaneAndViewContainer because it stores not only references to all panes that belong to the presenter screen but stores the views displayed in these panes as well. */ class PresenterPaneContainer : private ::cppu::BaseMutex, public PresenterPaneContainerInterfaceBase { public: explicit PresenterPaneContainer ( const css::uno::Reference& rxContext); virtual ~PresenterPaneContainer(); PresenterPaneContainer(const PresenterPaneContainer&) = delete; PresenterPaneContainer& operator=(const PresenterPaneContainer&) = delete; virtual void SAL_CALL disposing() override; typedef ::std::function&)> ViewInitializationFunction; /** Each pane descriptor holds references to one pane and the view displayed in this pane as well as the other information that is used to manage the pane window like an XWindow reference, the title, and the coordinates. A initialization function for the view is stored as well. This function is executed as soon as a view is created. */ class PaneDescriptor { public: typedef ::std::function Activator; typedef ::std::function ()> SpriteProvider; css::uno::Reference mxPaneId; OUString msViewURL; ::rtl::Reference mxPane; css::uno::Reference mxView; css::uno::Reference mxContentWindow; css::uno::Reference mxBorderWindow; OUString msTitleTemplate; OUString msAccessibleTitleTemplate; OUString msTitle; ViewInitializationFunction maViewInitialization; double mnLeft; double mnTop; double mnRight; double mnBottom; SharedBitmapDescriptor mpViewBackground; bool mbIsActive; bool mbNeedsClipping; bool mbIsOpaque; SpriteProvider maSpriteProvider; bool mbIsSprite; Activator maActivator; css::awt::Point maCalloutAnchorLocation; bool mbHasCalloutAnchor; void SetActivationState (const bool bIsActive); }; typedef std::shared_ptr SharedPaneDescriptor; typedef ::std::vector PaneList; PaneList maPanes; void PreparePane ( const css::uno::Reference& rxPaneId, const OUString& rsViewURL, const OUString& rsTitle, const OUString& rsAccessibleTitle, const bool bIsOpaque, const ViewInitializationFunction& rViewIntialization, const double nLeft, const double nTop, const double nRight, const double nBottom); SharedPaneDescriptor StorePane ( const rtl::Reference& rxPane); SharedPaneDescriptor StoreBorderWindow( const css::uno::Reference& rxPaneId, const css::uno::Reference& rxBorderWindow); SharedPaneDescriptor StoreView ( const css::uno::Reference& rxView, const SharedBitmapDescriptor& rpViewBackground); SharedPaneDescriptor RemovePane ( const css::uno::Reference& rxPaneId); SharedPaneDescriptor RemoveView ( const css::uno::Reference& rxView); /** Find the pane whose border window is identical to the given border window. */ SharedPaneDescriptor FindBorderWindow ( const css::uno::Reference& rxBorderWindow); /** Find the pane whose border window is identical to the given content window. */ SharedPaneDescriptor FindContentWindow ( const css::uno::Reference& rxBorderWindow); /** Find the pane whose pane URL is identical to the given URL string. */ SharedPaneDescriptor FindPaneURL (const OUString& rsPaneURL); /** Find the pane whose resource id is identical to the given one. */ SharedPaneDescriptor FindPaneId (const css::uno::Reference< css::drawing::framework::XResourceId>& rxPaneId); SharedPaneDescriptor FindViewURL (const OUString& rsViewURL); OUString GetPaneURLForViewURL (const OUString& rsViewURL); void ToTop (const SharedPaneDescriptor& rpDescriptor); // XEventListener virtual void SAL_CALL disposing ( const css::lang::EventObject& rEvent) throw (css::uno::RuntimeException, std::exception) override; private: css::uno::Reference mxPresenterHelper; }; } } // end of namespace ::sdext::presenter #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */