diff options
author | Oliver Bolte <obo@openoffice.org> | 2004-01-20 10:38:14 +0000 |
---|---|---|
committer | Oliver Bolte <obo@openoffice.org> | 2004-01-20 10:38:14 +0000 |
commit | 84a6228f21b7c333b91f6780d5b18eb747eb936c (patch) | |
tree | 47e3c212cc4b2f03eb49838791eefb29124ff2f5 /sd/source/ui/inc/OutlineViewShell.hxx | |
parent | INTEGRATION: CWS impress1 (1.1.2); FILE ADDED (diff) | |
download | core-84a6228f21b7c333b91f6780d5b18eb747eb936c.tar.gz core-84a6228f21b7c333b91f6780d5b18eb747eb936c.zip |
INTEGRATION: CWS impress1 (1.1.2); FILE ADDED
2004/01/09 15:57:23 af 1.1.2.4: #111996# Using the FrameView directly in the constructors of the view shells.
2003/12/04 08:59:59 af 1.1.2.3: #111996# Re-inserted the pOldShell argument into the constructor.
2003/10/23 13:14:10 af 1.1.2.2: #111996# Added a little documentation.
2003/09/16 15:52:05 af 1.1.2.1: #1119996# Renamed from outlnvsh.hxx.
Diffstat (limited to 'sd/source/ui/inc/OutlineViewShell.hxx')
-rw-r--r-- | sd/source/ui/inc/OutlineViewShell.hxx | 234 |
1 files changed, 234 insertions, 0 deletions
diff --git a/sd/source/ui/inc/OutlineViewShell.hxx b/sd/source/ui/inc/OutlineViewShell.hxx new file mode 100644 index 000000000000..426f7f87aa44 --- /dev/null +++ b/sd/source/ui/inc/OutlineViewShell.hxx @@ -0,0 +1,234 @@ +/************************************************************************* + * + * $RCSfile: OutlineViewShell.hxx,v $ + * + * $Revision: 1.2 $ + * + * last change: $Author: obo $ $Date: 2004-01-20 11:38:14 $ + * + * The Contents of this file are made available subject to the terms of + * either of the following licenses + * + * - GNU Lesser General Public License Version 2.1 + * - Sun Industry Standards Source License Version 1.1 + * + * Sun Microsystems Inc., October, 2000 + * + * GNU Lesser General Public License Version 2.1 + * ============================================= + * Copyright 2000 by Sun Microsystems, Inc. + * 901 San Antonio Road, Palo Alto, CA 94303, USA + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License version 2.1, as published by the Free Software Foundation. + * + * This library 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 for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + * + * Sun Industry Standards Source License Version 1.1 + * ================================================= + * The contents of this file are subject to the Sun Industry Standards + * Source License Version 1.1 (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.openoffice.org/license.html. + * + * Software provided under this License is provided on an "AS IS" basis, + * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, + * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, + * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. + * See the License for the specific provisions governing your rights and + * obligations concerning the Software. + * + * The Initial Developer of the Original Code is: Sun Microsystems, Inc. + * + * Copyright: 2000 by Sun Microsystems, Inc. + * + * All Rights Reserved. + * + * Contributor(s): _______________________________________ + * + * + ************************************************************************/ + +#ifndef SD_OUTLINE_VIEW_SHELL_HXX +#define SD_OUTLINE_VIEW_SHELL_HXX + +#ifndef SD_DRAW_DOC_SHELL_HXX +#include "DrawDocShell.hxx" +#endif +#ifndef SD_VIEW_SHELL_HXX +#include "ViewShell.hxx" +#endif +#ifndef SD_OUTLINE_VIEW_HXX +#include "OutlineView.hxx" +#endif + +class SdPage; +class TransferableDataHelper; +class TransferableClipboardListener; + +namespace sd { + +class SdUnoOutlineView; + +/** Show a textual overview of the text contents of all slides. +*/ +class OutlineViewShell + : public ViewShell +{ +public: + TYPEINFO(); + + SFX_DECL_VIEWFACTORY(OutlineViewShell); + SFX_DECL_INTERFACE(SD_IF_SDOUTLINEVIEWSHELL); + +// The previous macros change access mode. Thus we have to switch back to +// public access. +public: + OutlineViewShell(SfxViewFrame *pFrame, const OutlineViewShell& rShell); + + /** Create a new view shell for the outline mode. + @param rViewShellBase + The new object will be stacked on this view shell base. + @param pFrameView + The frame view that makes it possible to pass information from + one view shell to the next. + */ + OutlineViewShell ( + SfxViewFrame* pFrame, + ViewShellBase& rViewShellBase, + FrameView* pFrameView = NULL); + + virtual ~OutlineViewShell (void); + + virtual void Paint(const Rectangle& rRect, ::sd::Window* pWin); + + /** Set the position and size of the area which contains the GUI + elements like rulers, sliders, and buttons as well as the document + view. Both size and position are expected to be in pixel + coordinates. The positions and sizes of the mentioned GUI elements + are updated as well. + + <p> This method is implemented by first setting copying the given + values to internal variables and then calling the + <type>ArrangeGUIElements</type> method which performs the actual + work of sizeing and arranging the UI elements accordingly.</p> + @param rPos + The position of the enclosing window relative to the document + window. This is only interesting if a Draw/Impress document + view is embedded as OLE object into another document view. For + normal documents this position is (0,0). + @param rSize + The new size in pixel. + */ + virtual void AdjustPosSizePixel(const Point &rPos, const Size &rSize); + + /** Arrange and resize the GUI elements like rulers, sliders, and + buttons as well as the actual document view according to the size of + the enclosing window and current sizes of buttons, rulers, and + sliders. + */ + virtual void ArrangeGUIElements (void); + + virtual USHORT PrepareClose( BOOL bUI = TRUE, BOOL bForBrowsing = FALSE ); + + virtual long VirtHScrollHdl(ScrollBar* pHScroll); + virtual long VirtVScrollHdl(ScrollBar* pVHScroll); + + virtual void AddWindow(::sd::Window* pWin); + virtual void RemoveWindow(::sd::Window* pWin); + + virtual void Activate( BOOL IsMDIActivate ); + virtual void Deactivate( BOOL IsMDIActivate ); + + virtual SdPage* GetActualPage(); + /** Return a string that describes the currently selected pages. + */ + String GetPageRangeString (void); + + void ExecCtrl(SfxRequest &rReq); + void GetCtrlState(SfxItemSet &rSet); + void GetMenuState(SfxItemSet &rSet); + void GetAttrState(SfxItemSet &rSet); + void GetState (SfxItemSet& rSet); + + void ExecStatusBar(SfxRequest& rReq); + void GetStatusBarState(SfxItemSet& rSet); + + void FuTemporary(SfxRequest &rReq); + void FuPermanent(SfxRequest &rReq); + void FuSupport(SfxRequest &rReq); + + virtual void SetZoom(long nZoom); + virtual void SetZoomRect(const Rectangle& rZoomRect); + virtual String GetSelectionText( BOOL bCompleteWords = FALSE ); + virtual BOOL HasSelection( BOOL bText = TRUE ) const; + + void Execute(SfxRequest& rReq); + + virtual void ReadFrameViewData(FrameView* pView); + virtual void WriteFrameViewData(); + + virtual void Command( const CommandEvent& rCEvt, ::sd::Window* pWin ); + virtual BOOL KeyInput(const KeyEvent& rKEvt, ::sd::Window* pWin); + virtual void MouseButtonUp(const MouseEvent& rMEvt, ::sd::Window* pWin); + + ULONG Read(SvStream& rInput, USHORT eFormat); + + virtual void WriteUserDataSequence ( ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >&, sal_Bool bBrowse = sal_False ); + virtual void ReadUserDataSequence ( const ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >&, sal_Bool bBrowse = sal_False ); + + /** this method is called when the visible area of the view from this viewshell is changed */ + virtual void VisAreaChanged(const Rectangle& rRect); + + /** Create an accessible object representing the specified window. + @param pWindow + The returned object makes the document displayed in this window + accessible. + @return + Returns an <type>AccessibleDrawDocumentView</type> object. + */ + virtual ::com::sun::star::uno::Reference< + ::com::sun::star::accessibility::XAccessible> + CreateAccessibleDocumentView (::sd::Window* pWindow); + + /** Update the preview to show the specified page. + */ + virtual void UpdatePreview (SdPage* pPage, BOOL bInit = FALSE); + +protected: + virtual SvxRuler* CreateHRuler(::sd::Window* pWin, BOOL bIsFirst); + virtual void UpdateHRuler(); + + virtual void InnerResizePixel(const Point &rPos, const Size &rSize); + virtual void OuterResizePixel(const Point &rPos, const Size &rSize); + virtual Size GetOptimalSizePixel() const; + + // Methoden, die fuer die Preview gebraucht werden + BOOL UpdateTitleObject( SdPage* pPage, Paragraph* pPara ); + BOOL UpdateLayoutObject( SdPage* pPage, Paragraph* pPara ); + +private: + OutlineView* pOlView; + SdPage* pLastPage; // Zur performanten Aufbereitung der Preview + TransferableClipboardListener* pClipEvtLstnr; + BOOL bPastePossible; + + void Construct (DrawDocShell* pDocSh); + DECL_LINK( ClipboardChanged, TransferableDataHelper* ); + + SdUnoOutlineView* pController; +}; + +} // end of namespace sd + +#endif |