2000-09-18 11:07:07 -05:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: drawdoc.hxx,v $
|
|
|
|
*
|
2004-01-20 03:14:57 -06:00
|
|
|
* $Revision: 1.30 $
|
2000-09-18 11:07:07 -05:00
|
|
|
*
|
2004-01-20 03:14:57 -06:00
|
|
|
* last change: $Author: obo $ $Date: 2004-01-20 10:14:57 $
|
2000-09-18 11:07:07 -05: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 _DRAWDOC_HXX
|
|
|
|
#define _DRAWDOC_HXX
|
|
|
|
|
2001-03-19 02:53:25 -06:00
|
|
|
#ifndef _COM_SUN_STAR_FRAME_XMODEL_HDL_
|
|
|
|
#include <com/sun/star/frame/XModel.hdl>
|
|
|
|
#endif
|
2000-09-18 11:07:07 -05:00
|
|
|
#ifndef _SV_PRINT_HXX
|
|
|
|
#include <vcl/print.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FM_FMMODEL_HXX
|
|
|
|
#include <svx/fmmodel.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _PRESENTATION_HXX
|
|
|
|
#include "pres.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_PAGEITEM_HXX //autogen
|
|
|
|
#include <svx/pageitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _UNOTOOLS_CHARCLASS_HXX
|
|
|
|
#include <unotools/charclass.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TOOLS_INTN_HXX
|
|
|
|
#include <tools/intn.hxx>
|
|
|
|
#endif
|
2001-04-26 11:11:09 -05:00
|
|
|
#ifndef _SOT_STORAGE_HXX
|
|
|
|
#include <sot/storage.hxx>
|
|
|
|
#endif
|
2000-09-18 11:07:07 -05:00
|
|
|
#ifndef _RSCSFX_HXX
|
|
|
|
#include <rsc/rscsfx.hxx>
|
|
|
|
#endif
|
2002-08-01 05:30:12 -05:00
|
|
|
#ifndef _COM_SUN_STAR_LANG_LOCALE_HPP_
|
|
|
|
#include <com/sun/star/lang/Locale.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_TEXT_WRITINGMODE_HPP_
|
|
|
|
#include <com/sun/star/text/WritingMode.hpp>
|
|
|
|
#endif
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2003-04-24 08:35:29 -05:00
|
|
|
// #107844#
|
|
|
|
#ifndef _SVDUNDO_HXX
|
|
|
|
#include <svx/svdundo.hxx>
|
|
|
|
#endif
|
2004-01-20 03:14:57 -06:00
|
|
|
#include <memory>
|
2003-04-24 08:35:29 -05:00
|
|
|
|
2004-01-20 03:14:57 -06:00
|
|
|
namespace sd {
|
|
|
|
class FrameView;
|
|
|
|
class Outliner;
|
|
|
|
}
|
2000-09-18 11:07:07 -05:00
|
|
|
class Timer;
|
|
|
|
class SfxObjectShell;
|
|
|
|
class SdPage;
|
|
|
|
class SdAnimationInfo;
|
|
|
|
class SdIMapInfo;
|
|
|
|
class IMapObject;
|
|
|
|
class SdStyleSheetPool;
|
|
|
|
class SfxMedium;
|
|
|
|
class SvxSearchItem;
|
|
|
|
class SdrOle2Obj;
|
|
|
|
class EditStatus;
|
|
|
|
class Graphic;
|
|
|
|
class Point;
|
|
|
|
class Window;
|
2001-11-23 07:04:20 -06:00
|
|
|
class SdTransferable;
|
2000-09-18 11:07:07 -05:00
|
|
|
struct SpellCallbackInfo;
|
|
|
|
struct StyleRequestData;
|
2003-10-27 06:29:14 -06:00
|
|
|
class SdDrawDocument;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2004-01-20 03:14:57 -06:00
|
|
|
namespace sd {
|
|
|
|
#ifndef SV_DECL_DRAW_DOC_SHELL_DEFINED
|
|
|
|
#define SV_DECL_DRAW_DOC_SHELL_DEFINED
|
|
|
|
SV_DECL_REF(DrawDocShell)
|
2000-09-18 11:07:07 -05:00
|
|
|
#endif
|
2004-01-20 03:14:57 -06:00
|
|
|
class DrawDocShell;
|
|
|
|
}
|
|
|
|
|
|
|
|
class ImpDrawPageListWatcher;
|
|
|
|
class ImpMasterPageListWatcher;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
|
|
|
struct StyleReplaceData
|
|
|
|
{
|
|
|
|
SfxStyleFamily nFamily;
|
|
|
|
SfxStyleFamily nNewFamily;
|
|
|
|
String aName;
|
|
|
|
String aNewName;
|
|
|
|
};
|
|
|
|
|
|
|
|
enum DocCreationMode
|
|
|
|
{
|
|
|
|
NEW_DOC,
|
|
|
|
DOC_LOADED
|
|
|
|
};
|
|
|
|
|
2003-04-24 08:35:29 -05:00
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
// #107844#
|
|
|
|
// An undo class which is able to set/unset user calls is needed to handle
|
|
|
|
// the undo/redo of PresObjs correctly. It can also add/remove the object
|
|
|
|
// from the PresObjList of that page.
|
|
|
|
|
|
|
|
class SdrUndoUserCallObj : public SdrUndoObj
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
SdPage* mpOld;
|
|
|
|
SdPage* mpNew;
|
|
|
|
|
|
|
|
public:
|
|
|
|
SdrUndoUserCallObj(SdrObject& rNewObj, SdPage* pNew);
|
|
|
|
|
|
|
|
virtual void Undo();
|
|
|
|
virtual void Redo();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
// ------------------
|
|
|
|
// - SdDrawDocument -
|
|
|
|
// ------------------
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2004-01-20 03:14:57 -06:00
|
|
|
class SdDrawDocument
|
|
|
|
: public FmFormModel
|
2000-09-18 11:07:07 -05:00
|
|
|
{
|
2002-08-01 05:30:12 -05:00
|
|
|
private:
|
|
|
|
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::Outliner* pOutliner; // local outliner for outline mode
|
|
|
|
::sd::Outliner* pInternalOutliner; // internal outliner for creation of text objects
|
2002-08-01 05:30:12 -05:00
|
|
|
Timer* pWorkStartupTimer;
|
|
|
|
Timer* pOnlineSpellingTimer;
|
|
|
|
List* pOnlineSpellingList;
|
|
|
|
List* pDeletedPresObjList;
|
|
|
|
SvxSearchItem* pOnlineSearchItem;
|
|
|
|
List* pFrameViewList;
|
|
|
|
List* pCustomShowList;
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::DrawDocShell* pDocSh;
|
2002-08-01 05:30:12 -05:00
|
|
|
SdTransferable * pCreatingTransferable;
|
|
|
|
BOOL bHasOnlineSpellErrors;
|
|
|
|
BOOL bInitialOnlineSpellingEnabled;
|
|
|
|
String aBookmarkFile;
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::DrawDocShellRef xBookmarkDocShRef;
|
2002-08-01 05:30:12 -05:00
|
|
|
String aPresPage;
|
|
|
|
BOOL bNewOrLoadCompleted;
|
|
|
|
BOOL bPresAll;
|
|
|
|
BOOL bPresEndless;
|
|
|
|
BOOL bPresManual;
|
|
|
|
BOOL bPresMouseVisible;
|
|
|
|
BOOL bPresMouseAsPen;
|
|
|
|
BOOL bStartPresWithNavigator;
|
|
|
|
BOOL bAnimationAllowed;
|
|
|
|
BOOL bPresLockedPages;
|
|
|
|
BOOL bPresAlwaysOnTop;
|
|
|
|
BOOL bPresFullScreen;
|
|
|
|
ULONG nPresPause;
|
|
|
|
BOOL bPresShowLogo;
|
|
|
|
BOOL bOnlineSpell;
|
|
|
|
BOOL bHideSpell;
|
|
|
|
BOOL bCustomShow;
|
|
|
|
BOOL bSummationOfParagraphs;
|
2003-05-16 08:16:20 -05:00
|
|
|
bool mbStartWithPresentation; // is set to true when starting with command line parameter -start
|
2002-08-01 05:30:12 -05:00
|
|
|
|
|
|
|
ULONG nPresFirstPage;
|
|
|
|
LanguageType eLanguage;
|
|
|
|
LanguageType eLanguageCJK;
|
|
|
|
LanguageType eLanguageCTL;
|
|
|
|
SvxNumType ePageNumType;
|
|
|
|
Link aOldNotifyUndoActionHdl;
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::DrawDocShellRef xAllocedDocShRef; // => AllocModel()
|
2002-08-01 05:30:12 -05:00
|
|
|
BOOL bAllocDocSh; // => AllocModel()
|
|
|
|
DocumentType eDocType;
|
|
|
|
UINT16 nFileFormatVersion;
|
|
|
|
SotStorage* pDocStor;
|
|
|
|
SotStorageRef xPictureStorage;
|
|
|
|
SotStorageStreamRef xDocStream;
|
|
|
|
International* mpInternational;
|
|
|
|
CharClass* mpCharClass;
|
|
|
|
::com::sun::star::lang::Locale* mpLocale;
|
|
|
|
|
2003-10-27 06:29:14 -06:00
|
|
|
// #109538#
|
2004-01-20 03:14:57 -06:00
|
|
|
::std::auto_ptr<ImpDrawPageListWatcher> mpDrawPageListWatcher;
|
|
|
|
::std::auto_ptr<ImpMasterPageListWatcher> mpMasterPageListWatcher;
|
2003-10-27 06:29:14 -06:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void UpdatePageObjectsInNotes(USHORT nStartPos);
|
|
|
|
void FillOnlineSpellingList(SdPage* pPage);
|
|
|
|
void SpellObject(SdrTextObj* pObj);
|
|
|
|
|
|
|
|
DECL_LINK(NotifyUndoActionHdl, SfxUndoAction*);
|
|
|
|
DECL_LINK(WorkStartupHdl, Timer*);
|
|
|
|
DECL_LINK(OnlineSpellingHdl, Timer*);
|
|
|
|
DECL_LINK(OnlineSpellEventHdl, EditStatus*);
|
|
|
|
|
2000-11-26 12:11:00 -06:00
|
|
|
protected:
|
2002-08-01 05:30:12 -05:00
|
|
|
|
2000-11-26 12:11:00 -06:00
|
|
|
virtual ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > createUnoModel();
|
|
|
|
|
2000-09-18 11:07:07 -05:00
|
|
|
public:
|
|
|
|
|
2002-11-19 11:02:28 -06:00
|
|
|
class InsertBookmarkAsPage_PageFunctorBase;
|
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
TYPEINFO();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
SdDrawDocument(DocumentType eType, SfxObjectShell* pDocSh);
|
|
|
|
~SdDrawDocument();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
virtual SdrModel* AllocModel() const;
|
|
|
|
virtual SdrPage* AllocPage(FASTBOOL bMasterPage);
|
2000-09-18 11:07:07 -05:00
|
|
|
virtual const SdrModel* LoadModel(const String& rFileName);
|
2002-08-01 05:30:12 -05:00
|
|
|
virtual void DisposeLoadedModels();
|
|
|
|
virtual FASTBOOL IsReadOnly() const;
|
2003-11-24 10:07:24 -06:00
|
|
|
virtual void SetChanged(sal_Bool bFlag = sal_True);
|
2002-08-01 05:30:12 -05:00
|
|
|
virtual SvStream* GetDocumentStream(SdrDocumentStreamInfo& rStreamInfo) const;
|
|
|
|
virtual void HandsOff();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
SfxItemPool& GetPool() { return( *pItemPool ); }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::Outliner* GetOutliner(BOOL bCreateOutliner=TRUE);
|
|
|
|
::sd::Outliner* GetInternalOutliner(BOOL bCreateOutliner=TRUE);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::DrawDocShell* GetDocSh() const { return(pDocSh) ; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
LanguageType GetLanguage( const USHORT nId ) const;
|
|
|
|
void SetLanguage( const LanguageType eLang, const USHORT nId );
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-12-11 09:23:04 -06:00
|
|
|
SvxNumType GetPageNumType() const;
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPageNumType(SvxNumType eType) { ePageNumType = eType; }
|
|
|
|
String CreatePageNumValue(USHORT nNum) const;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
DocumentType GetDocumentType() const { return eDocType; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetAllocDocSh(BOOL bAlloc);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void CreatingDataObj( SdTransferable* pTransferable ) { pCreatingTransferable = pTransferable; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void CreateFirstPages();
|
|
|
|
BOOL CreateMissingNotesAndHandoutPages();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void MovePage(USHORT nPgNum, USHORT nNewPos);
|
|
|
|
void InsertPage(SdrPage* pPage, USHORT nPos=0xFFFF);
|
|
|
|
void DeletePage(USHORT nPgNum);
|
|
|
|
SdrPage* RemovePage(USHORT nPgNum);
|
|
|
|
void RemoveUnnessesaryMasterPages( SdPage* pMaster=NULL, BOOL bOnlyDuplicatePages=FALSE, BOOL bUndo=TRUE );
|
|
|
|
void SetMasterPage(USHORT nSdPageNum, const String& rLayoutName,
|
|
|
|
SdDrawDocument* pSourceDoc, BOOL bMaster, BOOL bCheckMasters);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
SdDrawDocument* OpenBookmarkDoc(const String& rBookmarkFile);
|
|
|
|
SdDrawDocument* OpenBookmarkDoc(SfxMedium& rMedium);
|
|
|
|
BOOL InsertBookmark(List* pBookmarkList, List* pExchangeList, BOOL bLink,
|
|
|
|
BOOL bReplace, USHORT nPgPos, BOOL bNoDialogs,
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::DrawDocShell* pBookmarkDocSh, BOOL bCopy,
|
2002-08-01 05:30:12 -05:00
|
|
|
Point* pObjPos);
|
2003-05-16 08:16:20 -05:00
|
|
|
|
|
|
|
bool IsStartWithPresentation() const;
|
|
|
|
void SetStartWithPresentation( bool bStartWithPresentation );
|
|
|
|
|
2002-11-19 11:02:28 -06:00
|
|
|
/** Insert pages into this document
|
|
|
|
|
|
|
|
This method inserts whole pages into this document, either
|
|
|
|
selected ones (specified via pBookmarkList/pExchangeList), or
|
|
|
|
all from the source document.
|
|
|
|
|
|
|
|
@attention Beware! This method in it's current state does not
|
|
|
|
handle all combinations of their input parameters
|
|
|
|
correctly. For example, for pBookmarkList=NULL, bReplace=TRUE
|
|
|
|
is ignored (no replace happens).
|
|
|
|
|
|
|
|
@param pBookmarkList
|
|
|
|
A list of strings, denoting the names of the pages to be copied
|
|
|
|
|
|
|
|
@param pExchangeList
|
|
|
|
A list of strings, denoting the names of the pages to be renamed
|
|
|
|
|
|
|
|
@param bLink
|
|
|
|
Whether the inserted pages should be links to the bookmark document
|
|
|
|
|
|
|
|
@param bReplace
|
|
|
|
Whether the pages should not be inserted, but replace the pages in
|
|
|
|
the destination document
|
|
|
|
|
|
|
|
@param nPgPos
|
|
|
|
Insertion point/start of replacement
|
|
|
|
|
|
|
|
@param bNoDialogs
|
|
|
|
Whether query dialogs are allowed (e.g. for page scaling)
|
|
|
|
|
|
|
|
@param pBookmarkDocSh
|
|
|
|
DocShell of the source document (used e.g. to extract the filename
|
|
|
|
for linked pages)
|
|
|
|
|
|
|
|
@param bCopy
|
|
|
|
Whether the source document should be treated as immutable (i.e.
|
|
|
|
inserted pages are not removed from it, but cloned)
|
|
|
|
|
|
|
|
@param bMergeMasterPages
|
|
|
|
Whether the source document's master pages should be copied, too.
|
|
|
|
|
|
|
|
@param bPreservePageNames
|
|
|
|
Whether the replace operation should take the name from the new
|
|
|
|
page, or preserve the old name
|
|
|
|
*/
|
2002-08-01 05:30:12 -05:00
|
|
|
BOOL InsertBookmarkAsPage(List* pBookmarkList, List* pExchangeList,
|
|
|
|
BOOL bLink, BOOL bReplace, USHORT nPgPos,
|
2004-01-20 03:14:57 -06:00
|
|
|
BOOL bNoDialogs, ::sd::DrawDocShell* pBookmarkDocSh,
|
2002-11-19 11:02:28 -06:00
|
|
|
BOOL bCopy, BOOL bMergeMasterPages,
|
|
|
|
BOOL bPreservePageNames);
|
2002-08-01 05:30:12 -05:00
|
|
|
BOOL InsertBookmarkAsObject(List* pBookmarkList, List* pExchangeListL,
|
2004-01-20 03:14:57 -06:00
|
|
|
BOOL bLink, ::sd::DrawDocShell* pBookmarkDocSh,
|
2002-08-01 05:30:12 -05:00
|
|
|
Point* pObjPos);
|
2002-11-19 11:02:28 -06:00
|
|
|
void IterateBookmarkPages( SdDrawDocument* pBookmarkDoc, List* pBookmarkList,
|
|
|
|
USHORT nBMSdPageCount,
|
|
|
|
InsertBookmarkAsPage_PageFunctorBase& rPageIterator );
|
2002-08-01 05:30:12 -05:00
|
|
|
void CloseBookmarkDoc();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
SdrObject* GetObj(const String& rObjName) const;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
USHORT GetPageByName(const String& rPgName, BOOL& rbIsMasterPage ) const;
|
|
|
|
SdPage* GetSdPage(USHORT nPgNum, PageKind ePgKind) const;
|
|
|
|
USHORT GetSdPageCount(PageKind ePgKind) const;
|
|
|
|
void SetSelected(SdPage* pPage, BOOL bSelect);
|
|
|
|
BOOL MovePages(USHORT nTargetPage);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
SdPage* GetMasterSdPage(USHORT nPgNum, PageKind ePgKind);
|
|
|
|
USHORT GetMasterSdPageCount(PageKind ePgKind) const;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
USHORT GetMasterPageUserCount(SdrPage* pMaster) const;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresPage( const String& rPresPage ) { aPresPage = rPresPage; }
|
|
|
|
const String& GetPresPage() const { return aPresPage; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresAll(BOOL bNewPresAll);
|
|
|
|
BOOL GetPresAll() const { return bPresAll; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresEndless(BOOL bNewPresEndless);
|
|
|
|
BOOL GetPresEndless() const { return bPresEndless; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresManual(BOOL bNewPresManual);
|
|
|
|
BOOL GetPresManual() const { return bPresManual; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresMouseVisible(BOOL bNewPresMouseVisible);
|
|
|
|
BOOL GetPresMouseVisible() const { return bPresMouseVisible; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresMouseAsPen(BOOL bNewPresMouseAsPen);
|
|
|
|
BOOL GetPresMouseAsPen() const { return bPresMouseAsPen; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresFirstPage (ULONG nNewFirstPage);
|
|
|
|
ULONG GetPresFirstPage() const { return nPresFirstPage; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetStartPresWithNavigator (BOOL bStart);
|
|
|
|
BOOL GetStartPresWithNavigator() const { return bStartPresWithNavigator; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetAnimationAllowed (BOOL bAllowed) { bAnimationAllowed = bAllowed; }
|
|
|
|
BOOL IsAnimationAllowed() const { return bAnimationAllowed; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresPause( ULONG nSecondsToWait ) { nPresPause = nSecondsToWait; }
|
|
|
|
ULONG GetPresPause() const { return nPresPause; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresShowLogo( BOOL bShowLogo ) { bPresShowLogo = bShowLogo; }
|
|
|
|
BOOL IsPresShowLogo() const { return bPresShowLogo; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresLockedPages (BOOL bLock);
|
|
|
|
BOOL GetPresLockedPages() const { return bPresLockedPages; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresAlwaysOnTop (BOOL bOnTop);
|
|
|
|
BOOL GetPresAlwaysOnTop() const { return bPresAlwaysOnTop; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetPresFullScreen (BOOL bNewFullScreen);
|
|
|
|
BOOL GetPresFullScreen() const { return bPresFullScreen; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetSummationOfParagraphs( BOOL bOn = TRUE ) { bSummationOfParagraphs = bOn; }
|
|
|
|
const BOOL IsSummationOfParagraphs() const { return bSummationOfParagraphs; }
|
2001-05-07 07:14:17 -05:00
|
|
|
|
2003-04-24 08:35:29 -05:00
|
|
|
/** Set the mode that controls whether (and later how) the formatting of the document
|
|
|
|
depends on the current printer metrics.
|
|
|
|
@param nMode
|
|
|
|
Use <const
|
|
|
|
scope="com::sun::star::document::PrinterIndependentLayout">ENABLED</const>
|
|
|
|
to make formatting printer-independent and <const
|
|
|
|
scope="com::sun::star::document::PrinterIndependentLayout">DISABLED</const>
|
|
|
|
to make formatting depend on the current printer metrics.
|
|
|
|
*/
|
|
|
|
void SetPrinterIndependentLayout (sal_Int32 nMode);
|
|
|
|
|
|
|
|
/** Get the flag that controls whether the formatting of the document
|
|
|
|
depends on the current printer metrics.
|
|
|
|
@return
|
|
|
|
Use <const
|
|
|
|
scope="com::sun::star::document::PrinterIndependentLayout">ENABLED</const>
|
|
|
|
when formatting is printer-independent and <const
|
|
|
|
scope="com::sun::star::document::PrinterIndependentLayout">DISABLED</const>
|
|
|
|
when formatting depends on the current printer metrics.
|
|
|
|
*/
|
|
|
|
sal_Int32 GetPrinterIndependentLayout (void);
|
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetOnlineSpell( BOOL bIn );
|
|
|
|
BOOL GetOnlineSpell() const { return bOnlineSpell; }
|
|
|
|
void StopOnlineSpelling();
|
|
|
|
void StartOnlineSpelling(BOOL bForceSpelling=TRUE);
|
2001-05-07 07:14:17 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void ImpOnlineSpellCallback(SpellCallbackInfo* pInfo, SdrObject* pObj, SdrOutliner* pOutl);
|
2001-09-27 04:12:46 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void InsertObject(SdrObject* pObj, SdPage* pPage);
|
|
|
|
void RemoveObject(SdrObject* pObj, SdPage* pPage);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetHideSpell( BOOL bIn );
|
|
|
|
BOOL GetHideSpell() const { return bHideSpell; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
ULONG GetLinkCount();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
List* GetFrameViewList() const { return pFrameViewList; }
|
|
|
|
List* GetCustomShowList(BOOL bCreate = FALSE);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetCustomShow(BOOL bCustShow) { bCustomShow = bCustShow; }
|
|
|
|
BOOL IsCustomShow() const { return bCustomShow; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2003-11-24 10:07:24 -06:00
|
|
|
void NbcSetChanged(sal_Bool bFlag = sal_True);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void SetTextDefaults() const;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void CreateLayoutTemplates();
|
|
|
|
void RenameLayoutTemplate(const String& rOldLayoutName, const String& rNewName);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void StopWorkStartupDelay();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void NewOrLoadCompleted(DocCreationMode eMode);
|
|
|
|
BOOL IsNewOrLoadCompleted() const {return bNewOrLoadCompleted; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2004-01-20 03:14:57 -06:00
|
|
|
::sd::FrameView* GetFrameView(ULONG nPos) {
|
|
|
|
return static_cast< ::sd::FrameView*>(
|
|
|
|
pFrameViewList->GetObject(nPos));}
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
SdAnimationInfo* GetAnimationInfo(SdrObject* pObject) const;
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
SdIMapInfo* GetIMapInfo( SdrObject* pObject ) const;
|
|
|
|
IMapObject* GetHitIMapObject( SdrObject* pObject, const Point& rWinPoint, const Window& rCmpWnd );
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
Graphic GetGraphicFromOle2Obj( const SdrOle2Obj* pOle2Obj );
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
List* GetDeletedPresObjList();
|
2003-12-01 03:06:52 -06:00
|
|
|
/** Clear the list of deleted presentation objects. Call this
|
|
|
|
method when the undo stack is also cleared.
|
|
|
|
*/
|
|
|
|
void ClearDeletedPresObjList (void);
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
CharClass* GetCharClass() const { return mpCharClass; }
|
|
|
|
International* GetInternational() const { return mpInternational; }
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void RestoreLayerNames();
|
|
|
|
void MakeUniqueLayerNames();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void UpdateAllLinks();
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void CheckMasterPages();
|
2001-12-18 08:03:13 -06:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
void Merge(SdrModel& rSourceModel,
|
|
|
|
USHORT nFirstPageNum=0, USHORT nLastPageNum=0xFFFF,
|
|
|
|
USHORT nDestPos=0xFFFF,
|
|
|
|
FASTBOOL bMergeMasterPages=FALSE, FASTBOOL bAllMasterPages=FALSE,
|
|
|
|
FASTBOOL bUndo=TRUE, FASTBOOL bTreadSourceAsConst=FALSE);
|
2002-01-18 08:36:06 -06:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
::com::sun::star::text::WritingMode GetDefaultWritingMode() const;
|
2002-09-12 09:28:56 -05:00
|
|
|
void SetDefaultWritingMode( ::com::sun::star::text::WritingMode eMode );
|
2002-07-18 08:03:41 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
public:
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
static SdDrawDocument* pDocLockedInsertingLinks; // static to prevent recursions while resolving links
|
2000-09-18 11:07:07 -05:00
|
|
|
|
2002-08-01 05:30:12 -05:00
|
|
|
friend SvStream& operator<<(SvStream& rOut, SdDrawDocument& rDoc);
|
|
|
|
friend SvStream& operator>>(SvStream& rIn, SdDrawDocument& rDoc);
|
2002-11-04 07:39:19 -06:00
|
|
|
|
|
|
|
|
|
|
|
/** This method acts as a simplified front end for the more complex
|
|
|
|
<member>CreatePage()</member> method.
|
|
|
|
@param nPageNum
|
|
|
|
The page number as passed to the <member>GetSdPage()</member>
|
|
|
|
method from which to use certain properties for the new pages.
|
|
|
|
These include the auto layout.
|
|
|
|
@return
|
|
|
|
Returns an index of the inserted pages that can be used with the
|
|
|
|
<member>GetSdPage()</member> method.
|
|
|
|
*/
|
|
|
|
USHORT CreatePage (USHORT nPageNum);
|
|
|
|
|
|
|
|
/** Create and insert a set of two new pages: a standard (draw) page and
|
|
|
|
the associated notes page. The new pages are inserted direclty
|
|
|
|
after the specified page set.
|
|
|
|
@param pCurrentPage
|
|
|
|
This page is used to retrieve the layout for the page to
|
|
|
|
create.
|
|
|
|
@param ePageKind
|
|
|
|
This specifies whether <argument>pCurrentPage</argument> is a
|
|
|
|
standard (draw) page or a notes page.
|
|
|
|
@param sStandardPageName
|
|
|
|
Name of the standard page. An empty string leads to using an
|
|
|
|
automatically created name.
|
|
|
|
@param sNotesPageName
|
|
|
|
Name of the standard page. An empty string leads to using an
|
|
|
|
automatically created name.
|
|
|
|
@param eStandardLayout
|
|
|
|
Layout to use for the new standard page. Note that this layout
|
|
|
|
is not used when the given <argument>pCurrentPage</argument> is
|
|
|
|
not a standard page. In this case the layout is taken from the
|
|
|
|
standard page associated with <argument>pCurrentPage</argument>.
|
|
|
|
@param eNotesLayout
|
|
|
|
Layout to use for the new notes page. Note that this layout
|
|
|
|
is not used when the given <argument>pCurrentPage</argument> is
|
|
|
|
not a notes page. In this case the layout is taken from the
|
|
|
|
notes page associated with <argument>pCurrentPage</argument>.
|
|
|
|
@param bIsPageBack
|
|
|
|
This flag indicates whether to show the background shape.
|
|
|
|
@param bIsPageObj
|
|
|
|
This flag indicates whether to show the shapes on the master page.
|
|
|
|
|
|
|
|
@return
|
|
|
|
Returns an index of the inserted pages that can be used with the
|
|
|
|
<member>GetSdPage()</member> method.
|
|
|
|
*/
|
|
|
|
USHORT CreatePage (
|
|
|
|
SdPage* pCurrentPage,
|
|
|
|
PageKind ePageKind,
|
|
|
|
const String& sStandardPageName,
|
|
|
|
const String& sNotesPageName,
|
|
|
|
AutoLayout eStandardLayout,
|
|
|
|
AutoLayout eNotesLayout,
|
|
|
|
BOOL bIsPageBack,
|
|
|
|
BOOL bIsPageObj);
|
|
|
|
|
|
|
|
/** This method acts as a simplified front end for the more complex
|
|
|
|
<member>DuplicatePage()</member> method.
|
|
|
|
@param nPageNum
|
|
|
|
The page number as passed to the <member>GetSdPage()</member>
|
|
|
|
method for which the standard page and the notes page are to be
|
|
|
|
copied.
|
|
|
|
@return
|
|
|
|
Returns an index of the inserted pages that can be used with the
|
|
|
|
<member>GetSdPage()</member> method.
|
|
|
|
*/
|
|
|
|
USHORT DuplicatePage (USHORT nPageNum);
|
|
|
|
|
|
|
|
/** Create and insert a set of two new pages that are copies of the
|
|
|
|
given <argument>pCurrentPage</argument> and its associated notes
|
|
|
|
resp. standard page. The copies are inserted directly after the
|
|
|
|
specified page set.
|
|
|
|
@param pCurrentPage
|
|
|
|
This page and its associated notes/standard page is copied.
|
|
|
|
@param ePageKind
|
|
|
|
This specifies whether <argument>pCurrentPage</argument> is a
|
|
|
|
standard (draw) page or a notes page.
|
|
|
|
@param sStandardPageName
|
|
|
|
Name of the standard page. An empty string leads to using an
|
|
|
|
automatically created name.
|
|
|
|
@param sNotesPageName
|
|
|
|
Name of the standard page. An empty string leads to using an
|
|
|
|
automatically created name.
|
|
|
|
@param eStandardLayout
|
|
|
|
Layout to use for the new standard page. Note that this layout
|
|
|
|
is not used when the given <argument>pCurrentPage</argument> is
|
|
|
|
not a standard page. In this case the layout is taken from the
|
|
|
|
standard page associated with <argument>pCurrentPage</argument>.
|
|
|
|
@param eNotesLayout
|
|
|
|
Layout to use for the new notes page. Note that this layout
|
|
|
|
is not used when the given <argument>pCurrentPage</argument> is
|
|
|
|
not a notes page. In this case the layout is taken from the
|
|
|
|
notes page associated with <argument>pCurrentPage</argument>.
|
|
|
|
@param bIsPageBack
|
|
|
|
This flag indicates whether to show the background shape.
|
|
|
|
@param bIsPageObj
|
|
|
|
This flag indicates whether to show the shapes on the master page.
|
|
|
|
|
|
|
|
@return
|
|
|
|
Returns an index of the inserted pages that can be used with the
|
|
|
|
<member>GetSdPage()</member> method.
|
|
|
|
*/
|
|
|
|
USHORT DuplicatePage (
|
|
|
|
SdPage* pCurrentPage,
|
|
|
|
PageKind ePageKind,
|
|
|
|
const String& sStandardPageName,
|
|
|
|
const String& sNotesPageName,
|
|
|
|
AutoLayout eStandardLayout,
|
|
|
|
AutoLayout eNotesLayout,
|
|
|
|
BOOL bIsPageBack,
|
|
|
|
BOOL bIsPageObj);
|
|
|
|
|
2003-06-26 05:11:08 -05:00
|
|
|
/** return the document fonts for latin, cjk and ctl according to the current
|
|
|
|
languages set at this document */
|
|
|
|
void getDefaultFonts( Font& rLatinFont, Font& rCJKFont, Font& rCTLFont );
|
|
|
|
|
2002-11-04 07:39:19 -06:00
|
|
|
private:
|
2003-04-24 08:35:29 -05:00
|
|
|
/** This member stores the printer independent layout mode. Please
|
|
|
|
refer to <member>SetPrinterIndependentLayout()</member> for its
|
|
|
|
values.
|
|
|
|
*/
|
|
|
|
sal_Int32 mnPrinterIndependentLayout;
|
|
|
|
|
2002-11-04 07:39:19 -06:00
|
|
|
/** Insert a given set of standard and notes page after the given <argument>pCurrentPage</argument>.
|
|
|
|
@param pCurrentPage
|
|
|
|
This page and its associated notes/standard page is copied.
|
|
|
|
@param ePageKind
|
|
|
|
This specifies whether <argument>pCurrentPage</argument> is a
|
|
|
|
standard (draw) page or a notes page.
|
|
|
|
@param sStandardPageName
|
|
|
|
Name of the standard page. An empty string leads to using an
|
|
|
|
automatically created name.
|
|
|
|
@param sNotesPageName
|
|
|
|
Name of the standard page. An empty string leads to using an
|
|
|
|
automatically created name.
|
|
|
|
@param eStandardLayout
|
|
|
|
Layout to use for the new standard page. Note that this layout
|
|
|
|
is not used when the given <argument>pCurrentPage</argument> is
|
|
|
|
not a standard page. In this case the layout is taken from the
|
|
|
|
standard page associated with <argument>pCurrentPage</argument>.
|
|
|
|
@param eNotesLayout
|
|
|
|
Layout to use for the new notes page. Note that this layout
|
|
|
|
is not used when the given <argument>pCurrentPage</argument> is
|
|
|
|
not a notes page. In this case the layout is taken from the
|
|
|
|
notes page associated with <argument>pCurrentPage</argument>.
|
|
|
|
@param bIsPageBack
|
|
|
|
This flag indicates whether to show the background shape.
|
|
|
|
@param bIsPageObj
|
|
|
|
This flag indicates whether to show the shapes on the master page.
|
|
|
|
@param pStandardPage
|
|
|
|
The standard page to insert.
|
|
|
|
@param pNotesPage
|
|
|
|
The notes page to insert.
|
|
|
|
|
|
|
|
@return
|
|
|
|
Returns an index of the inserted pages that can be used with the
|
|
|
|
<member>GetSdPage()</member> method.
|
|
|
|
*/
|
|
|
|
USHORT InsertPageSet (
|
|
|
|
SdPage* pCurrentPage,
|
|
|
|
PageKind ePageKind,
|
|
|
|
const String& sStandardPageName,
|
|
|
|
const String& sNotesPageName,
|
|
|
|
AutoLayout eStandardLayout,
|
|
|
|
AutoLayout eNotesLayout,
|
|
|
|
BOOL bIsPageBack,
|
|
|
|
BOOL bIsPageObj,
|
|
|
|
|
|
|
|
SdPage* pStandardPage,
|
|
|
|
SdPage* pNotesPage);
|
|
|
|
|
|
|
|
/** Set up a newly created page and insert it into the list of pages.
|
|
|
|
@param pPreviousPage
|
|
|
|
A page to take the size and border geometry from.
|
|
|
|
@param pPage
|
|
|
|
This is the page to set up and insert.
|
|
|
|
@param sPageName
|
|
|
|
The name of the new page.
|
|
|
|
@param nInsertionPoint
|
|
|
|
Index of the page before which the new page will be inserted.
|
|
|
|
@param bIsPageBack
|
|
|
|
This flag indicates whether to show the background shape.
|
|
|
|
@param bIsPageObj
|
|
|
|
This flag indicates whether to show the shapes on the master
|
|
|
|
page.
|
|
|
|
*/
|
|
|
|
void SetupNewPage (
|
|
|
|
SdPage* pPreviousPage,
|
|
|
|
SdPage* pPage,
|
|
|
|
const String& sPageName,
|
|
|
|
USHORT nInsertionPoint,
|
|
|
|
BOOL bIsPageBack,
|
|
|
|
BOOL bIsPageObj);
|
2003-10-27 06:29:14 -06:00
|
|
|
|
|
|
|
// #109538#
|
|
|
|
virtual void PageListChanged();
|
|
|
|
virtual void MasterPageListChanged();
|
2002-08-01 05:30:12 -05:00
|
|
|
};
|
2000-09-18 11:07:07 -05:00
|
|
|
|
|
|
|
#endif // _DRAWDOC_HXX
|