2004-01-20 10:38:14 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: OutlineViewShell.hxx,v $
|
|
|
|
*
|
2004-07-13 12:57:48 +00:00
|
|
|
* $Revision: 1.5 $
|
2004-01-20 10:38:14 +00:00
|
|
|
*
|
2004-07-13 12:57:48 +00:00
|
|
|
* last change: $Author: rt $ $Date: 2004-07-13 13:57:48 $
|
2004-01-20 10:38:14 +00:00
|
|
|
*
|
|
|
|
* 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);
|
|
|
|
|
2004-07-13 12:57:48 +00:00
|
|
|
// The previous macros change access mode. To be sure switch back
|
|
|
|
// to public access.
|
2004-01-20 10:38:14 +00:00
|
|
|
public:
|
|
|
|
/** 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,
|
2004-07-13 12:57:48 +00:00
|
|
|
::Window* pParentWindow,
|
2004-01-20 10:38:14 +00:00
|
|
|
FrameView* pFrameView = NULL);
|
|
|
|
|
2004-07-13 12:57:48 +00:00
|
|
|
OutlineViewShell (
|
|
|
|
SfxViewFrame* pFrame,
|
|
|
|
::Window* pParentWindow,
|
|
|
|
const OutlineViewShell& rShell);
|
|
|
|
|
2004-01-20 10:38:14 +00:00
|
|
|
virtual ~OutlineViewShell (void);
|
|
|
|
|
|
|
|
virtual void Paint(const Rectangle& rRect, ::sd::Window* pWin);
|
|
|
|
|
|
|
|
/** 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);
|
|
|
|
|
2004-07-13 12:57:48 +00:00
|
|
|
virtual DrawController* GetController (void);
|
|
|
|
|
2004-01-20 10:38:14 +00:00
|
|
|
protected:
|
|
|
|
virtual Size GetOptimalSizePixel() const;
|
|
|
|
|
|
|
|
// Methoden, die fuer die Preview gebraucht werden
|
|
|
|
BOOL UpdateTitleObject( SdPage* pPage, Paragraph* pPara );
|
|
|
|
BOOL UpdateLayoutObject( SdPage* pPage, Paragraph* pPara );
|
|
|
|
|
2004-07-13 12:57:48 +00:00
|
|
|
/** Make the given page the new current page. This method
|
|
|
|
notifies the controller and adapts the selection of the
|
|
|
|
model.
|
|
|
|
@param pPage
|
|
|
|
The new current page. Pass NULL when there is no current page.
|
|
|
|
*/
|
|
|
|
void SetCurrentPage (SdPage* pPage);
|
|
|
|
|
2004-01-20 10:38:14 +00:00
|
|
|
private:
|
|
|
|
OutlineView* pOlView;
|
|
|
|
SdPage* pLastPage; // Zur performanten Aufbereitung der Preview
|
|
|
|
TransferableClipboardListener* pClipEvtLstnr;
|
|
|
|
BOOL bPastePossible;
|
|
|
|
|
|
|
|
void Construct (DrawDocShell* pDocSh);
|
|
|
|
DECL_LINK( ClipboardChanged, TransferableDataHelper* );
|
|
|
|
};
|
|
|
|
|
|
|
|
} // end of namespace sd
|
|
|
|
|
|
|
|
#endif
|