/* -*- 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_PRESENTERCONTROLLER_HXX #define INCLUDED_SDEXT_SOURCE_PRESENTER_PRESENTERCONTROLLER_HXX #include "PresenterAccessibility.hxx" #include "PresenterPaneContainer.hxx" #include "PresenterTheme.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace sd { class DrawController; } namespace sdext::presenter { class PresenterCanvasHelper; class PresenterPaintManager; class PresenterPaneAnimator; class PresenterPaneContainer; class PresenterPaneBorderPainter; class PresenterScreen; class PresenterTheme; class PresenterWindowManager; typedef ::cppu::WeakComponentImplHelper < css::drawing::framework::XConfigurationChangeListener, css::frame::XFrameActionListener, css::awt::XKeyListener, css::awt::XMouseListener > PresenterControllerInterfaceBase; /// Represents an element in the toolbar that shows the time elapsed since the presentation started. class IPresentationTime { public: virtual void restart() = 0; virtual bool isPaused() = 0; virtual void setPauseStatus(const bool pauseStatus) = 0; virtual ~IPresentationTime(); }; /** The controller of the presenter screen is responsible for telling the individual views which slides to show. Additionally it provides access to frequently used values of the current theme. */ class PresenterController : protected ::cppu::BaseMutex, public PresenterControllerInterfaceBase { public: static ::rtl::Reference Instance ( const css::uno::Reference& rxFrame); PresenterController ( unotools::WeakReference xScreen, const css::uno::Reference& rxContext, const rtl::Reference<::sd::DrawController>& rxController, const css::uno::Reference& rxSlideShowController, rtl::Reference xPaneContainer, const css::uno::Reference& rxMainPaneId); virtual ~PresenterController() override; virtual void SAL_CALL disposing() override; void UpdateCurrentSlide (const sal_Int32 nOffset); SharedBitmapDescriptor GetViewBackground (const OUString& rsViewURL) const; PresenterTheme::SharedFontDescriptor GetViewFont (const OUString& rsViewURL) const; const std::shared_ptr& GetTheme() const; const ::rtl::Reference& GetWindowManager() const; const css::uno::Reference& GetSlideShowController() const; const rtl::Reference& GetPaneContainer() const; const ::rtl::Reference& GetPaneBorderPainter() const; const std::shared_ptr& GetCanvasHelper() const; const css::uno::Reference& GetPresenterHelper() const; const std::shared_ptr& GetPaintManager() const; double GetSlideAspectRatio() const; void ShowView (const OUString& rsViewURL); void HideView (const OUString& rsViewURL); void SwitchMonitors(); void ExitPresenter(); void DispatchUnoCommand (const OUString& rsCommand) const; css::uno::Reference GetDispatch ( const css::util::URL& rURL) const; css::util::URL CreateURLFromString (const OUString& rsURL) const; const css::uno::Reference& GetConfigurationController() const; const css::uno::Reference& GetCurrentSlide() const; static bool HasTransition (css::uno::Reference const & rxPage); static bool HasCustomAnimation (css::uno::Reference const & rxPage); void SetAccessibilityActiveState (const bool bIsActive); bool IsAccessibilityActive() const { return mbIsAccessibilityActive;} void HandleMouseClick (const css::awt::MouseEvent& rEvent); void UpdatePaneTitles(); // check if the 'NextSlide' needs an update when the given // XShape is changed and trigger that update void CheckNextSlideUpdate(const css::uno::Reference& rxShape); /** Request activation or deactivation of (some of) the views according to the given parameters. */ void RequestViews ( const bool bIsSlideSorterActive, const bool bIsNotesViewActive, const bool bIsHelpViewActive); void SetPresentationTime(IPresentationTime* pPresentationTime); IPresentationTime* GetPresentationTime(); // XConfigurationChangeListener virtual void SAL_CALL notifyConfigurationChange ( const css::drawing::framework::ConfigurationChangeEvent& rEvent) override; // XEventListener virtual void SAL_CALL disposing ( const css::lang::EventObject& rEvent) override; // XFrameActionListener virtual void SAL_CALL frameAction ( const css::frame::FrameActionEvent& rEvent) override; // XKeyListener virtual void SAL_CALL keyPressed (const css::awt::KeyEvent& rEvent) override; virtual void SAL_CALL keyReleased (const css::awt::KeyEvent& rEvent) override; // XMouseListener virtual void SAL_CALL mousePressed (const css::awt::MouseEvent& rEvent) override; virtual void SAL_CALL mouseReleased (const css::awt::MouseEvent& rEvent) override; virtual void SAL_CALL mouseEntered (const css::awt::MouseEvent& rEvent) override; virtual void SAL_CALL mouseExited (const css::awt::MouseEvent& rEvent) override; private: typedef ::std::map,rtl::Reference > InstanceContainer; static InstanceContainer maInstances; unotools::WeakReference mxScreen; css::uno::Reference mxComponentContext; css::uno::Reference mxCanvas; rtl::Reference<::sd::DrawController> mxController; css::uno::Reference mxConfigurationController; css::uno::Reference mxSlideShowController; css::uno::Reference mxMainPaneId; rtl::Reference mpPaneContainer; sal_Int32 mnCurrentSlideIndex; css::uno::Reference mxCurrentSlide; css::uno::Reference mxNextSlide; ::rtl::Reference mpWindowManager; std::shared_ptr mpTheme; css::uno::Reference mxMainWindow; ::rtl::Reference mpPaneBorderPainter; std::shared_ptr mpCanvasHelper; css::uno::Reference mxPresenterHelper; std::shared_ptr mpPaintManager; sal_Int32 mnPendingSlideNumber; css::uno::Reference mxUrlTransformer; ::rtl::Reference mpAccessibleObject; bool mbIsAccessibilityActive; IPresentationTime* mpPresentationTime; void GetSlides (const sal_Int32 nOffset); void UpdateViews(); void InitializeMainPane (const css::uno::Reference& rxPane); void LoadTheme (const css::uno::Reference& rxPane); void UpdatePendingSlideNumber (const sal_Int32 nPendingSlideNumber); /** This method is called when the user pressed one of the numerical keys. Depending on the modifier, numeric keys switch to another slide (no modifier), or change to another view (Ctrl modifier). @param nKey Numeric value that is printed on the pressed key. For example pressing the key '4' will result in the value 4, not the ASCII code (0x34?). @param nModifiers The modifier bit field as provided by the key up event. */ void HandleNumericKeyPress (const sal_Int32 nKey, const sal_Int32 nModifiers); }; } // end of namespace ::sdext::presenter #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */