/************************************************************** * * 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 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef _PAGEFRM_HXX #define _PAGEFRM_HXX #include #include "ftnboss.hxx" #include #include class SwFlyFrm; class SwFlyFrmFmt; class SwPageDesc; class SwCntntFrm; struct SwPosition; struct SwCrsrMoveState; class SdrObject; class SwAttrSetChg; class Font; // OD 2004-05-07 #i28701# - replaced by class //SV_DECL_PTRARR_SORT(SwSortDrawObjs,SdrObjectPtr,1,2); class SwSortedObjs; // --> OD 2004-07-02 #i28701# class SwAnchoredObject; // <-- enum SwPageChg { CHG_NEWPAGE, CHG_CUTPAGE, CHG_CHGPAGE }; class SwPageFrm: public SwFtnBossFrm { friend class SwFrm; // OD 2004-05-07 #i28701# - use SwSortedObjs *pSortedObjs; SwPageDesc *pDesc; //PageDesc der die Seite beschreibt. sal_uInt16 nPhyPageNum; //Physikalische Seitennummer. sal_Bool bInvalidCntnt :1; sal_Bool bInvalidLayout :1; sal_Bool bInvalidFlyCntnt :1; sal_Bool bInvalidFlyLayout :1; sal_Bool bInvalidFlyInCnt :1; sal_Bool bFtnPage :1; //Diese Seite ist fuer Dokumentende-Fussnoten. sal_Bool bEmptyPage :1; //Dies ist eine explizite Leerseite sal_Bool bEndNotePage :1; //'Fussnotenseite' fuer Endnoten sal_Bool bInvalidSpelling :1; //Das Online-Spelling ist gefordert sal_Bool bInvalidSmartTags :1; //checking for smarttags is needed // SMARTTAGS sal_Bool bInvalidAutoCmplWrds :1; //Auto-Complete Wordliste aktualisieren sal_Bool bInvalidWordCount :1; sal_Bool bHasGrid :1; // Grid for Asian layout // OD 2004-05-17 #i28701# - boolean, indicating that layout of page frame // is in progress. bool mbLayoutInProgress; // OD 12.02.2003 #i9719#, #105645# static const sal_Int8 mnBorderPxWidth; static const sal_Int8 mnShadowPxWidth; void _UpdateAttr( const SfxPoolItem*, const SfxPoolItem*, sal_uInt8 &, SwAttrSetChg *pa = 0, SwAttrSetChg *pb = 0 ); // Anpassen der max. Fussnotenhoehen in den einzelnen Spalten void SetColMaxFtnHeight(); /** determine rectangle for page border OD 12.02.2003 for #i9719# and #105645# @author OD @param _rPageRect input parameter - constant instance reference of the page rectangle. Generally, it's the frame area of the page, but for empty pages in print preview, this parameter is useful. @param _pViewShell input parameter - instance of the view shell, for which the rectangle has to be generated. @param _orBorderRect output parameter - instance reference of the border rectangle for the given page rectangle */ static void GetBorderRect( const SwRect& _rPageRect, ViewShell* _pViewShell, SwRect& _orBorderRect, bool bRightSidebar ); /** determine rectangle for right page shadow OD 12.02.2003 for #i9719# and #105645# @author OD @param _rPageRect input parameter - constant instance reference of the page rectangle. Generally, it's the frame area of the page, but for empty pages in print preview, this parameter is useful. @param _pViewShell input parameter - instance of the view shell, for which the rectangle has to be generated. @param _orRightShadowRect output parameter - instance reference of the right shadow rectangle for the given page rectangle */ static void GetRightShadowRect( const SwRect& _rPageRect, ViewShell* _pViewShell, SwRect& _orRightShadowRect, bool bRightSidebar ); /** determine rectangle for bottom page shadow OD 12.02.2003 for #i9719# and #105645# @author OD @param _rPageRect input parameter - constant instance reference of the page rectangle. Generally, it's the frame area of the page, but for empty pages in print preview, this parameter is useful. @param _pViewShell input parameter - instance of the view shell, for which the rectangle has to be generated. @param _orBottomShadowRect output parameter - instance reference of the bottom shadow rectangle for the given page rectangle */ static void GetBottomShadowRect( const SwRect& _rPageRect, ViewShell* _pViewShell, SwRect& _orBottomShadowRect, bool bRightSidebar ); /** adds the sidebar used for notes to right and left border mod 20.10.2007 for #i6193# @author mod @param aRect input parameter - current rect, we change borders if we want a sidebar @param _pViewShell input parameter - instance of the view shell, for which the rectangle has to be generated. @param bPx input parameter - if set to true, we add in pixel */ static void AddSidebarBorders( Rectangle& aRect, ViewShell* _pViewShell, bool bRight, bool bPx = false); static void AddSidebarBorders( SwRect& aRect, ViewShell* _pViewShell, bool bRight, bool bPx = false); protected: virtual void MakeAll(); virtual void Modify( const SfxPoolItem*, const SfxPoolItem* ); public: DECL_FIXEDMEMPOOL_NEWDEL(SwPageFrm) SwPageFrm( SwFrmFmt*, SwFrm*, SwPageDesc* ); ~SwPageFrm(); //public, damit die ViewShell beim Umschalten vom BrowseMode darauf //zugreifen kann. void PrepareHeader(); //Kopf-/Fusszeilen anlegen/entfernen. void PrepareFooter(); const SwSortedObjs *GetSortedObjs() const { return pSortedObjs; } SwSortedObjs *GetSortedObjs() { return pSortedObjs; } // --> OD 2004-07-02 #i28701# - new methods to append/remove drawing objects void AppendDrawObjToPage( SwAnchoredObject& _rNewObj ); void RemoveDrawObjFromPage( SwAnchoredObject& _rToRemoveObj ); // <-- void AppendFlyToPage( SwFlyFrm *pNew ); void RemoveFlyFromPage( SwFlyFrm *pToRemove ); void MoveFly( SwFlyFrm *pToMove, SwPageFrm *pDest );//optimiertes Remove/Append void SetPageDesc( SwPageDesc *, SwFrmFmt * ); SwPageDesc *GetPageDesc() { return pDesc; } const SwPageDesc *GetPageDesc() const { return pDesc; } SwPageDesc *FindPageDesc(); SwCntntFrm *FindLastBodyCntnt(); inline SwCntntFrm *FindFirstBodyCntnt(); inline const SwCntntFrm *FindFirstBodyCntnt() const; inline const SwCntntFrm *FindLastBodyCntnt() const; //Spezialisiertes GetCntntPos() fuer Felder in Rahmen. void GetCntntPosition( const Point &rPt, SwPosition &rPos ) const; sal_Bool IsEmptyPage() const { return bEmptyPage; } //explizite Leerseite. void UpdateFtnNum(); //Immer nach dem Paste rufen. Erzeugt die Seitengeb. Rahmen und Formatiert //generischen Inhalt. void PreparePage( sal_Bool bFtn ); //Schickt an alle ContentFrames ein Prepare wg. geaenderter Registervorlage void PrepareRegisterChg(); // --> OD 2005-06-09 #i50432# - adjust method description and synopsis. // Appends a fly frame - the given one or a new one - at the page frame. // Needed for and // - return value not needed any more // - second parameter is of type // - third parameter only needed for assertion, but calling method assures // this assertion. Thus, delete it. void PlaceFly( SwFlyFrm* pFly, SwFlyFrmFmt* pFmt ); // <-- virtual sal_Bool GetCrsrOfst( SwPosition *, Point&, SwCrsrMoveState* = 0 ) const; // erfrage vom Client Informationen virtual sal_Bool GetInfo( SfxPoolItem& ) const; virtual void Cut(); virtual void Paste( SwFrm* pParent, SwFrm* pSibling = 0 ); virtual void CheckDirection( sal_Bool bVert ); void CheckGrid( sal_Bool bInvalidate ); void PaintGrid( OutputDevice* pOut, SwRect &rRect ) const; sal_Bool HasGrid() const { return bHasGrid; } //Zeilennummern usw malen void RefreshExtraData( const SwRect & ) const; //Hilfslinien malen. void RefreshSubsidiary( const SwRect& ) const; //Fussnotenschnittstelle sal_Bool IsFtnPage() const { return bFtnPage; } sal_Bool IsEndNotePage() const { return bEndNotePage; } void SetFtnPage( sal_Bool b ) { bFtnPage = b; } void SetEndNotePage( sal_Bool b ) { bEndNotePage = b; } inline sal_uInt16 GetPhyPageNum() const { return nPhyPageNum;} inline void SetPhyPageNum( sal_uInt16 nNum ) { nPhyPageNum = nNum;} inline void DecrPhyPageNum() { --nPhyPageNum; } inline void IncrPhyPageNum() { ++nPhyPageNum; } //Validieren, invalidieren und abfragen des Status der Seite. //Layout/Cntnt und jeweils Fly/nicht Fly werden getrennt betrachtet. inline void InvalidateFlyLayout() const; inline void InvalidateFlyCntnt() const; inline void InvalidateFlyInCnt() const; inline void InvalidateLayout() const; inline void InvalidateCntnt() const; inline void InvalidateSpelling() const; inline void InvalidateSmartTags() const; inline void InvalidateAutoCompleteWords() const; inline void InvalidateWordCount() const; inline void ValidateFlyLayout() const; inline void ValidateFlyCntnt() const; inline void ValidateFlyInCnt() const; inline void ValidateLayout() const; inline void ValidateCntnt() const; inline void ValidateSpelling() const; inline void ValidateSmartTags() const; // SMARTTAGS inline void ValidateAutoCompleteWords() const; inline void ValidateWordCount() const; inline sal_Bool IsInvalid() const; inline sal_Bool IsInvalidFly() const; sal_Bool IsInvalidFlyLayout() const { return bInvalidFlyLayout; } sal_Bool IsInvalidFlyCntnt() const { return bInvalidFlyCntnt; } sal_Bool IsInvalidFlyInCnt() const { return bInvalidFlyInCnt; } sal_Bool IsInvalidLayout() const { return bInvalidLayout; } sal_Bool IsInvalidCntnt() const { return (bInvalidCntnt || bInvalidFlyInCnt); } sal_Bool IsInvalidSpelling() const { return bInvalidSpelling; } sal_Bool IsInvalidSmartTags() const { return bInvalidSmartTags; } // SMARTTAGS sal_Bool IsInvalidAutoCompleteWords() const { return bInvalidAutoCmplWrds; } sal_Bool IsInvalidWordCount() const { return bInvalidWordCount; } /** SwPageFrm::GetDrawBackgrdColor - for #102450# 29.08.2002: determine the color, that is respectively will be drawn as background for the page frame. @author OD @return reference to an instance of class Color */ const Color& GetDrawBackgrdColor() const; /** paint margin area of a page OD 20.11.2002 for #104598#: implement paint of margin area; margin area will be painted for a view shell with a window and if the document is not in online layout. @author OD @param _rOutputRect input parameter - constant instance reference of the rectangle, for which an output has to be generated. @param _pViewShell input parameter - instance of the view shell, on which the output has to be generated. */ void PaintMarginArea( const SwRect& _rOutputRect, ViewShell* _pViewShell ) const; /** paint page border and shadow OD 12.02.2003 for #i9719# and #105645# implement paint of page border and shadow @author OD @param _rPageRect input parameter - constant instance reference of the page rectangle. Generally, it's the frame area of the page, but for empty pages in print preview, this parameter is useful. @param _pViewShell input parameter - instance of the view shell, on which the output has to be generated. */ static void PaintBorderAndShadow( const SwRect& _rPageRect, ViewShell* _pViewShell, bool bPaintRightShadow, bool bRightSidebar ); /** get bound rectangle of border and shadow for repaints OD 12.02.2003 for #i9719# and #105645# author OD @param _rPageRect input parameter - constant instance reference of the page rectangle. Generally, it's the frame area of the page, but for empty pages in print preview, this parameter is useful. @param _pViewShell input parameter - instance of the view shell, for which the rectangle has to be generated. @param _orBorderAndShadowBoundRect output parameter - instance reference of the bounded border and shadow rectangle for the given page rectangle */ static void GetBorderAndShadowBoundRect( const SwRect& _rPageRect, ViewShell* _pViewShell, SwRect& _orBorderAndShadowBoundRect, const bool bRightSidebar ); static void PaintNotesSidebar(const SwRect& _rPageRect, ViewShell* _pViewShell, sal_uInt16 nPageNum, bool bRight); static void PaintNotesSidebarArrows(const Point &aMiddleFirst, const Point &aMiddleSecond, ViewShell* _pViewShell, const Color aColorUp, const Color aColorDown); /** mod #6i193# asks the page on which side a margin should be shown, e.g for notes returns true for left side, false for right side */ sw::sidebarwindows::SidebarPosition SidebarPosition() const; virtual bool FillSelection( SwSelectionList& rList, const SwRect& rRect ) const; // OD 12.02.2003 #i9719#, #105645# inline sal_Int8 BorderPxWidth() const { return mnBorderPxWidth; } inline sal_Int8 ShadowPxWidth() const { return mnShadowPxWidth; } // OD 22.09.2003 #110978# const SwRect PrtWithoutHeaderAndFooter() const; // OD 2004-05-17 #i28701# inline bool IsLayoutInProgress() const { return mbLayoutInProgress; } inline void SetLayoutInProgress( const bool _bLayoutInProgress ) { mbLayoutInProgress = _bLayoutInProgress; } // in case this is am empty page, this function returns the 'reference' page const SwPageFrm& GetFormatPage() const; // return font used to paint the "empty page" string static const Font& GetEmptyPageFont(); static SwTwips GetSidebarBorderWidth( const ViewShell* ); }; inline SwCntntFrm *SwPageFrm::FindFirstBodyCntnt() { SwLayoutFrm *pBody = FindBodyCont(); return pBody ? pBody->ContainsCntnt() : 0; } inline const SwCntntFrm *SwPageFrm::FindFirstBodyCntnt() const { const SwLayoutFrm *pBody = FindBodyCont(); return pBody ? pBody->ContainsCntnt() : 0; } inline const SwCntntFrm *SwPageFrm::FindLastBodyCntnt() const { return ((SwPageFrm*)this)->FindLastBodyCntnt(); } inline void SwPageFrm::InvalidateFlyLayout() const { ((SwPageFrm*)this)->bInvalidFlyLayout = sal_True; } inline void SwPageFrm::InvalidateFlyCntnt() const { ((SwPageFrm*)this)->bInvalidFlyCntnt = sal_True; } inline void SwPageFrm::InvalidateFlyInCnt() const { ((SwPageFrm*)this)->bInvalidFlyInCnt = sal_True; } inline void SwPageFrm::InvalidateLayout() const { ((SwPageFrm*)this)->bInvalidLayout = sal_True; } inline void SwPageFrm::InvalidateCntnt() const { ((SwPageFrm*)this)->bInvalidCntnt = sal_True; } inline void SwPageFrm::InvalidateSpelling() const { ((SwPageFrm*)this)->bInvalidSpelling = sal_True; } // SMARTTAGS inline void SwPageFrm::InvalidateSmartTags() const { ((SwPageFrm*)this)->bInvalidSmartTags = sal_True; } inline void SwPageFrm::InvalidateAutoCompleteWords() const { ((SwPageFrm*)this)->bInvalidAutoCmplWrds = sal_True; } inline void SwPageFrm::InvalidateWordCount() const { ((SwPageFrm*)this)->bInvalidWordCount = sal_True; } inline void SwPageFrm::ValidateFlyLayout() const { ((SwPageFrm*)this)->bInvalidFlyLayout = sal_False; } inline void SwPageFrm::ValidateFlyCntnt() const { ((SwPageFrm*)this)->bInvalidFlyCntnt = sal_False; } inline void SwPageFrm::ValidateFlyInCnt() const { ((SwPageFrm*)this)->bInvalidFlyInCnt = sal_False; } inline void SwPageFrm::ValidateLayout() const { ((SwPageFrm*)this)->bInvalidLayout = sal_False; } inline void SwPageFrm::ValidateCntnt() const { ((SwPageFrm*)this)->bInvalidCntnt = sal_False; } inline void SwPageFrm::ValidateSpelling() const { ((SwPageFrm*)this)->bInvalidSpelling = sal_False; } // SMARTTAGS inline void SwPageFrm::ValidateSmartTags() const { ((SwPageFrm*)this)->bInvalidSmartTags = sal_False; } inline void SwPageFrm::ValidateAutoCompleteWords() const { ((SwPageFrm*)this)->bInvalidAutoCmplWrds = sal_False; } inline void SwPageFrm::ValidateWordCount() const { ((SwPageFrm*)this)->bInvalidWordCount = sal_False; } inline sal_Bool SwPageFrm::IsInvalid() const { return (bInvalidCntnt || bInvalidLayout || bInvalidFlyInCnt); } inline sal_Bool SwPageFrm::IsInvalidFly() const { return bInvalidFlyLayout || bInvalidFlyCntnt; } #define GETGRID( pPage ) const SwTextGridItem *pGrid = NULL; \ {if( pPage && pPage->HasGrid() && GRID_NONE==(pGrid=(SwTextGridItem*)&pPage->\ GetPageDesc()->GetMaster().GetFmtAttr(RES_TEXTGRID))->GetGridType() ) \ pGrid = NULL;} #define GETGRIDWIDTH( pGrid , pDoc ) pDoc->IsSquaredPageMode() ? \ pGrid->GetBaseHeight(): pGrid->GetBaseWidth() #endif //_PAGEFRM_HXX