diff options
Diffstat (limited to 'sd/source/ui/inc/SdUnoDrawView.hxx')
-rwxr-xr-x | sd/source/ui/inc/SdUnoDrawView.hxx | 153 |
1 files changed, 153 insertions, 0 deletions
diff --git a/sd/source/ui/inc/SdUnoDrawView.hxx b/sd/source/ui/inc/SdUnoDrawView.hxx new file mode 100755 index 000000000000..d29ca3b09d32 --- /dev/null +++ b/sd/source/ui/inc/SdUnoDrawView.hxx @@ -0,0 +1,153 @@ +/************************************************************************* + * + * 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 + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +#ifndef SD_UNO_DRAW_VIEW_HXX +#define SD_UNO_DRAW_VIEW_HXX + +#include "DrawSubController.hxx" +#include "DrawController.hxx" +#include "DrawViewShell.hxx" +#include <cppuhelper/basemutex.hxx> + +class SdXImpressDocument; +class SdPage; + +namespace css = ::com::sun::star; + +namespace com { namespace sun { namespace star { namespace drawing { +class XLayer; +} } } } + +namespace sd { + +class DrawController; +class DrawViewShell; + +/** This class implements the DrawViewShell specific part of the controller. +*/ +class SdUnoDrawView + : private cppu::BaseMutex, + public DrawSubControllerInterfaceBase +{ +public: + SdUnoDrawView ( + DrawController& rController, + DrawViewShell& rViewShell, + View& rView) throw(); + virtual ~SdUnoDrawView (void) throw(); + + // XSelectionSupplier + + virtual sal_Bool SAL_CALL select ( + const css::uno::Any& aSelection) + throw(css::lang::IllegalArgumentException, + css::uno::RuntimeException); + + virtual css::uno::Any SAL_CALL getSelection (void) + throw(css::uno::RuntimeException); + + virtual void SAL_CALL addSelectionChangeListener ( + const css::uno::Reference<css::view::XSelectionChangeListener>& rxListener) + throw(css::uno::RuntimeException); + + virtual void SAL_CALL removeSelectionChangeListener ( + const css::uno::Reference<css::view::XSelectionChangeListener>& rxListener) + throw(css::uno::RuntimeException); + + + // XDrawView + + virtual void SAL_CALL setCurrentPage ( + const css::uno::Reference<css::drawing::XDrawPage >& xPage) + throw(css::uno::RuntimeException); + + virtual css::uno::Reference<css::drawing::XDrawPage> SAL_CALL getCurrentPage (void) + throw(css::uno::RuntimeException); + + + // XFastPropertySet + + virtual void SAL_CALL setFastPropertyValue ( + sal_Int32 nHandle, + const css::uno::Any& rValue) + throw(css::beans::UnknownPropertyException, + css::beans::PropertyVetoException, + css::lang::IllegalArgumentException, + css::lang::WrappedTargetException, + css::uno::RuntimeException); + + virtual css::uno::Any SAL_CALL getFastPropertyValue ( + sal_Int32 nHandle) + throw(css::beans::UnknownPropertyException, + css::lang::WrappedTargetException, + css::uno::RuntimeException); + + // XServiceInfo + virtual ::rtl::OUString SAL_CALL getImplementationName( ) throw (::com::sun::star::uno::RuntimeException); + virtual ::sal_Bool SAL_CALL supportsService( const ::rtl::OUString& ServiceName ) throw (::com::sun::star::uno::RuntimeException); + virtual ::com::sun::star::uno::Sequence< ::rtl::OUString > SAL_CALL getSupportedServiceNames( ) throw (::com::sun::star::uno::RuntimeException); + +protected: + sal_Bool getMasterPageMode(void) const throw(); + void setMasterPageMode(sal_Bool MasterPageMode_) throw(); + sal_Bool getLayerMode(void) const throw(); + void setLayerMode(sal_Bool LayerMode_) throw(); + + /** Return a reference to the active layer object. + @return + The returned value may be empty when the internal state of this + view is not valid (like during destruction.) + */ + ::com::sun::star::uno::Reference< ::com::sun::star::drawing::XLayer> getActiveLayer (void) throw (); + + /** Make the specified object the active layer. + @param rxLayer + The new layer object. + */ + void setActiveLayer (const ::com::sun::star::uno::Reference< ::com::sun::star::drawing::XLayer>& rxLayer) throw (); + + void SetZoom( sal_Int16 nZoom ); + sal_Int16 GetZoom(void) const; + + void SetViewOffset(const com::sun::star::awt::Point& rWinPos ); + com::sun::star::awt::Point GetViewOffset() const; + + void SetZoomType( sal_Int16 nType ); + + ::com::sun::star::uno::Any getDrawViewMode() const; + +private: + DrawController& mrController; + DrawViewShell& mrDrawViewShell; + sd::View& mrView; + + SdXImpressDocument* GetModel (void) const throw(); +}; + +} // end of namespace sd + +#endif |