/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ #ifndef INCLUDED_SW_INC_FESH_HXX #define INCLUDED_SW_INC_FESH_HXX #include #include #include #include #include "swdllapi.h" #include #include #include #include #include #include #include #include #include namespace editeng { class SvxBorderLine; } class SwFlyFrame; class SwTabCols; class SvxBrushItem; class SvxFrameDirectionItem; class SwTableAutoFormat; class SwFrame; class SwFormatFrameSize; class SwFormatRowSplit; class SdrObject; class Color; class Outliner; class SotDataObject; class SwFrameFormat; struct SwSortOptions; class SdrMarkList; namespace svx { class ISdrObjectFilter; } // return values for GetFrameType() und GetSelFrameType(). //! values can be combined via logical or enum class FrameTypeFlags { NONE = 0, PAGE = 1, HEADER = 2, FOOTER = 4, BODY = 8, COLUMN = 16, TABLE = 32, FLY_FREE = 64, FLY_ATCNT = 128, FLY_INCNT = 256, FOOTNOTE = 512, FTNPAGE = 1024, FLY_ANY = 2048, DRAWOBJ = 4096, COLSECT = 8192, COLSECTOUTTAB = 16384 }; namespace o3tl { template<> struct typed_flags : is_typed_flags {}; } //! values can be combined via logical or enum class GotoObjFlags { NONE = 0, DrawControl = 1, DrawSimple = 2, DrawAny = DrawControl | DrawSimple, FlyFrame = 4, FlyGrf = 8, FlyOLE = 16, FlyAny = FlyOLE | FlyGrf | FlyFrame, Any = FlyAny | DrawAny, }; namespace o3tl { template<> struct typed_flags : is_typed_flags {}; } //! values can be combined via logical or enum class FlyProtectFlags { NONE = 0, Content = 1, Size = 2, Pos = 4, Parent = 8, ///< Check only parents. Fixed = 16, /**< Only protection that cannot be withdrawn e.g. by OLE-server; also relevant for dialog. */ }; namespace o3tl { template<> struct typed_flags : is_typed_flags {}; } // For figuring out contents by position (D&D) enum ObjCntType { OBJCNT_NONE, OBJCNT_FLY, OBJCNT_GRF, OBJCNT_OLE, OBJCNT_SIMPLE, OBJCNT_CONTROL, OBJCNT_URLBUTTON, OBJCNT_GROUPOBJ, OBJCNT_DONTCARE ///< Not determinable - different objects are selected. }; //For GetAnyCurRect enum CurRectType { RECT_PAGE, ///< Rect of current page. RECT_PAGE_CALC, ///< ... page will be formatted if required. RECT_PAGE_PRT, ///< Rect of current PrtArea of page. RECT_FRM, ///< Rect of current frame. RECT_FLY_EMBEDDED, ///< Rect of current FlyFrame. RECT_FLY_PRT_EMBEDDED, ///< Rect of PrtArea of FlyFrame RECT_SECTION, ///< Rect of current section. RECT_OUTTABSECTION, ///< Rect of current section but outside of table. RECT_SECTION_PRT, ///< Rect of current PrtArea of section. RECT_OUTTABSECTION_PRT, ///< Rect of current PrtArea of section but outside table. RECT_HEADERFOOTER, ///< Rect of current header/footer RECT_HEADERFOOTER_PRT, ///< Rect of PrtArea of current headers/footers RECT_PAGES_AREA ///< Rect covering the pages area }; struct SwGetCurColNumPara { const SwFrameFormat* pFrameFormat; const SwRect* pPrtRect, *pFrameRect; SwGetCurColNumPara() : pFrameFormat( nullptr ), pPrtRect( nullptr ), pFrameRect( nullptr ) {} }; enum class SwPasteSdr { NONE = 0, Insert = 1, Replace = 2, SetAttr = 3 }; #define SW_ADD_SELECT 1 #define SW_ENTER_GROUP 2 #define SW_LEAVE_FRAME 4 enum class SwMove { UP = 0, DOWN = 1, LEFT = 2, RIGHT = 3 }; // return values for WhichMouseTabCol enum class SwTab { COL_NONE = 0, COL_HORI = 1, COL_VERT = 2, ROW_HORI = 3, ROW_VERT = 4, SEL_HORI = 5, SEL_HORI_RTL = 6, ROWSEL_HORI = 7, ROWSEL_HORI_RTL = 8, COLSEL_HORI = 9, SEL_VERT = 10, ROWSEL_VERT = 11, COLSEL_VERT = 12 }; class SdrDropMarkerOverlay; class SW_DLLPUBLIC SwFEShell : public SwEditShell { private: std::unique_ptr m_pChainTo; std::unique_ptr m_pChainFrom; bool m_bCheckForOLEInCaption; SAL_DLLPRIVATE SwFlyFrame *FindFlyFrame( const css::uno::Reference < css::embed::XEmbeddedObject >& ) const; /// Terminate actions for all shells and call ChangeLink. SAL_DLLPRIVATE void EndAllActionAndCall(); SAL_DLLPRIVATE void ScrollTo( const Point &rPt ); SAL_DLLPRIVATE void ChangeOpaque( SdrLayerID nLayerId ); /** Used for mouse operations on a table: @return a cell frame that is 'close' to rPt. */ SAL_DLLPRIVATE const SwFrame *GetBox( const Point &rPt, bool* pbRow = nullptr, bool* pbCol = nullptr ) const; // 0 == not in any column. SAL_DLLPRIVATE sal_uInt16 _GetCurColNum( const SwFrame *pFrame, SwGetCurColNumPara* pPara ) const; SAL_DLLPRIVATE void _GetTabCols( SwTabCols &rToFill, const SwFrame *pBox ) const; SAL_DLLPRIVATE void _GetTabRows( SwTabCols &rToFill, const SwFrame *pBox ) const; SAL_DLLPRIVATE bool ImpEndCreate(); SAL_DLLPRIVATE ObjCntType GetObjCntType( const SdrObject& rObj ) const; /// Methods for copying of draw objects. SAL_DLLPRIVATE bool CopyDrawSel( SwFEShell* pDestShell, const Point& rSttPt, const Point& rInsPt, bool bIsMove, bool bSelectInsert ); /// Get list of marked SdrObjects; /// helper method for GetSelFrameType, IsSelContainsControl. SAL_DLLPRIVATE const SdrMarkList* _GetMarkList() const; SAL_DLLPRIVATE bool CheckHeadline( bool bRepeat ) const; using SwEditShell::Copy; public: using SwEditShell::Insert; SwFEShell( SwDoc& rDoc, vcl::Window *pWin, const SwViewOption *pOpt = nullptr ); SwFEShell( SwEditShell& rShell, vcl::Window *pWin ); virtual ~SwFEShell(); /// Copy and Paste methods for internal clipboard. bool Copy( SwDoc* pClpDoc, const OUString* pNewClpText = nullptr ); bool Paste( SwDoc* pClpDoc, bool bIncludingPageFrames = false); /// Paste some pages into another doc - used in mailmerge. bool PastePages( SwFEShell& rToFill, sal_uInt16 nStartPage, sal_uInt16 nEndPage); /// Copy-Method for Drag&Drop bool Copy( SwFEShell*, const Point& rSttPt, const Point& rInsPt, bool bIsMove = false, bool bSelectInsert = true ); void SelectFlyFrame( SwFlyFrame& rFrame, bool bNew = false ); /// Is selected frame within another frame? const SwFrameFormat* IsFlyInFly(); /** If an object as been given, exactly this object is selected (instead of searching over position). */ bool SelectObj( const Point& rSelPt, sal_uInt8 nFlag = 0, SdrObject *pObj = nullptr ); void DelSelectedObj(); /** Move selection upwards or downwards (Z-Order). TRUE = to top or bottom. FALSE = run past one other. */ void SelectionToTop ( bool bTop = true ); void SelectionToBottom( bool bBottom = true ); short GetLayerId() const; ///< 1 Heaven, 0 Hell, -1 Ambiguous. void SelectionToHeaven(); ///< Above document. void SelectionToHell(); ///< Below document. /** The following two methods return enum SdrHdlKind. Declared as int in order to spare including SVDRAW.HXX. */ bool IsObjSelectable( const Point& rPt ); /// Same as IsObjSelectable(), but return the object as well. SdrObject* GetObjAt(const Point& rPt); int IsInsideSelectedObj( const Point& rPt ); ///< returns enum values /** Test if there is a draw object at that position and if it should be selected. The 'should' is aimed at Writer text fly frames which may be in front of the draw object. */ bool ShouldObjectBeSelected(const Point& rPt); bool MoveAnchor( SwMove nDir ); /** @return if Upper of frame at current position is section frame Currently only used by the rules. To be replaced by something more sophisticated one day. */ bool IsDirectlyInSection() const; /** For return values see above FrameType. pPt: Cursr or DocPos respectively; bStopAtFly: Stop at flys or continue over anchor. Although (0,TRUE) is kind of a standard, the parameters are not defaulted here in order to force more conscious use especially of bStopAtFly. */ FrameTypeFlags GetFrameType( const Point *pPt, bool bStopAtFly ) const; FrameTypeFlags GetSelFrameType() const; //Selektion (Drawing) /** check whether selected frame contains a control; * companion method to GetSelFrameType, used for preventing * drag&drop of controls into header */ bool IsSelContainsControl() const; ObjCntType GetObjCntType( const Point &rPt, SdrObject *&rpObj ) const; ObjCntType GetObjCntTypeOfSelection( SdrObject** ppObj = nullptr ) const; /// For adjustment of PosAttr when anchor changes. SwRect GetObjRect() const; /// For moving flys with keyboard. SwRect GetFlyRect() const; /** i#17567 - adjustments to allow negative vertical positions for fly frames anchored to paragraph or to character. i#18732 - adjustments for new option 'FollowTextFlow' i#22341 - adjustments for new vertical alignment at top of line */ void CalcBoundRect( SwRect& _orRect, const RndStdIds _nAnchorId, const sal_Int16 _eHoriRelOrient = css::text::RelOrientation::FRAME, const sal_Int16 _eVertRelOrient = css::text::RelOrientation::FRAME, const SwPosition* _pToCharContentPos = nullptr, const bool _bFollowTextFlow = false, bool _bMirror = false, Point* _opRef = nullptr, Size* _opPercent = nullptr, const SwFormatFrameSize* pFormatFrameSize = nullptr ) const; /// Set size of draw objects. void SetObjRect( const SwRect& rRect ); long BeginDrag( const Point *pPt, bool bProp ); long Drag ( const Point *pPt, bool bProp ); long EndDrag ( const Point *pPt, bool bProp ); void BreakDrag(); /// Methods for status line. Point GetAnchorObjDiff() const; Point GetObjAbsPos() const; Size GetObjSize() const; /// SS for envelopes: get all page-bound objects and set them to new page. void GetPageObjs( std::vector& rFillArr ); void SetPageObjsNewPage( std::vector& rFillArr, int nOffset = 1 ); /// Show current selection (frame / draw object as required). virtual void MakeSelVisible() override; /** @return FrameFormat of object that may be under Point. Object does not become selected! */ const SwFrameFormat* GetFormatFromObj( const Point& rPt, SwRect** pRectToFill = nullptr ) const; /// @return a format too, if the point is over the text of any fly. const SwFrameFormat* GetFormatFromAnyObj( const Point& rPt ) const; /** Which Protection is set at selected object? */ FlyProtectFlags IsSelObjProtected( FlyProtectFlags eType ) const; /** Deliver graphic in rName besides graphic name. If graphic is linked give name with path. rbLink is TRUE if graphic is linked. */ const Graphic *GetGrfAtPos( const Point &rDocPos, OUString &rName, bool &rbLink ) const; OUString GetObjTitle() const; void SetObjTitle( const OUString& rTitle ); OUString GetObjDescription() const; void SetObjDescription( const OUString& rDescription ); bool IsFrameSelected() const; bool GetFlyFrameAttr( SfxItemSet &rSet ) const; bool SetFlyFrameAttr( SfxItemSet &rSet ); static SfxItemSet makeItemSetFromFormatAnchor(SfxItemPool& rPool, const SwFormatAnchor &rAnchor); bool ResetFlyFrameAttr( sal_uInt16 nWhich, const SfxItemSet* pSet = nullptr ); const SwFrameFormat *NewFlyFrame( const SfxItemSet &rSet, bool bAnchValid = false, SwFrameFormat *pParent = nullptr ); void SetFlyPos( const Point &rAbsPos); Point FindAnchorPos( const Point &rAbsPos, bool bMoveIt = false ); /** Determines whether a frame or its environment is vertically formatted and right-to-left. also determines, if frame or its environmane is in mongolianlayout (vertical left-to-right) - add output parameter */ bool IsFrameVertical(const bool bEnvironment, bool& bRightToLeft, bool& bVertL2R) const; SwFrameFormat* GetSelectedFrameFormat() const; ///< If frame then frame style, else 0. void SetFrameFormat( SwFrameFormat *pFormat, bool bKeepOrient = false, Point* pDocPos = nullptr ); ///< If frame then set frame style. // Get selected fly SwFlyFrame* GetSelectedFlyFrame() const; // Get current fly in which the cursor is positioned SwFlyFrame* GetCurrFlyFrame(const bool bCalcFrame = true) const; // Get selected fly, but if none Get current fly in which the cursor is positioned SwFlyFrame* GetSelectedOrCurrFlyFrame(const bool bCalcFrame = true) const; /// Find/delete fly containing the cursor. SwFrameFormat* WizardGetFly(); /// Independent selecting of flys. bool GotoNextFly( GotoObjFlags eType = GotoObjFlags::FlyAny ) { return GotoObj( true, eType ); } bool GotoPrevFly( GotoObjFlags eType = GotoObjFlags::FlyAny) { return GotoObj( false, eType); } /// Iterate over flys - for Basic-collections. size_t GetFlyCount( FlyCntType eType = FLYCNTTYPE_ALL, bool bIgnoreTextBoxes = false ) const; const SwFrameFormat* GetFlyNum(size_t nIdx, FlyCntType eType = FLYCNTTYPE_ALL, bool bIgnoreTextBoxes = false) const; /// If a fly is selected, it draws cursor into the first ContentFrame. const SwFrameFormat* SelFlyGrabCursor(); /// Get FlyFrameFormat; fuer UI Macro Anbindung an Flys const SwFrameFormat* GetFlyFrameFormat() const; SwFrameFormat* GetFlyFrameFormat(); /** OLE. Server requires new size. Desired values are adjusted as frame attributes. If the values are not allowed, the formatting clips and determines scaling. See CalcAndSetScale(). The @return value is the applied size. */ Size RequestObjectResize( const SwRect &rRect, const css::uno::Reference < css::embed::XEmbeddedObject >& ); /// The layout has been changed, so the active object has to be moved after that virtual void MoveObjectIfActive( svt::EmbeddedObjectRef& xObj, const Point& rOffset ); /** Client for OleObject has to be up-to-date regarding scaling. Implemented in WrtShell. If a pointer is passed on a size, this is the object's current core-size. Else the size is provided via GetCurFlyRect(). */ virtual void CalcAndSetScale( svt::EmbeddedObjectRef& xObj, const SwRect *pFlyPrtRect = nullptr, const SwRect *pFlyFrameRect = nullptr, const bool bNoTextFramePrtAreaChanged = false ) = 0; /** Connect objects with ActivateWhenVisible at Paint. Called by notxtfrm::Paint, implemented in wrtsh. */ virtual void ConnectObj( svt::EmbeddedObjectRef&, const SwRect &rPrt, const SwRect &rFrame ) = 0; /// Check resize of OLE-Object. bool IsCheckForOLEInCaption() const { return m_bCheckForOLEInCaption; } void SetCheckForOLEInCaption( bool bFlag ) { m_bCheckForOLEInCaption = bFlag; } /// Set name at selected FlyFrame. void SetFlyName( const OUString& rName ); OUString GetFlyName() const; /// get reference to OLE object (if there is one) for selected FlyFrame const css::uno::Reference < css::embed::XEmbeddedObject > GetOleRef() const; /// Created unique name for frame. OUString GetUniqueGrfName() const; OUString GetUniqueOLEName() const; OUString GetUniqueFrameName() const; OUString GetUniqueShapeName() const; /// Jump to named Fly (graphic/OLE). bool GotoFly( const OUString& rName, FlyCntType eType = FLYCNTTYPE_ALL, bool bSelFrame = true ); /// Position is a graphic with URL? const SwFrameFormat* IsURLGrfAtPos( const Point& rPt, OUString* pURL = nullptr, OUString *pTargetFrameName = nullptr, OUString *pURLDescription = nullptr ) const; /** For Chain always connect Fly specified by format with that hit by point. rRect contains rect of Fly (for its highlight). */ SwChainRet Chainable( SwRect &rRect, const SwFrameFormat &rSource, const Point &rPt ) const; SwChainRet Chain( SwFrameFormat &rSource, const Point &rPt ); SwChainRet Chain( SwFrameFormat &rSource, const SwFrameFormat &rDest ); void Unchain( SwFrameFormat &rFormat ); void HideChainMarker(); void SetChainMarker(); Size GetGraphicDefaultSize() const; /// Temporary work around for bug. void CheckUnboundObjects(); /// Attention: Ambiguities if multiple selections. bool GetObjAttr( SfxItemSet &rSet ) const; bool SetObjAttr( const SfxItemSet &rSet ); const SdrObject* GetBestObject( bool bNext, GotoObjFlags eType = GotoObjFlags::DrawAny, bool bFlat = true, const svx::ISdrObjectFilter* pFilter = nullptr ); bool GotoObj( bool bNext, GotoObjFlags eType = GotoObjFlags::DrawAny); /// Set DragMode (e.g. Rotate), but do nothing when frame is selected. void SetDragMode( sal_uInt16 eSdrDragMode ); // Get the current drag mode SdrDragMode GetDragMode() const; // Start cropping the selected image void StartCropImage(); size_t IsObjSelected() const; ///< @return object count, but doesn't count the objects in groups. bool IsObjSelected( const SdrObject& rObj ) const; bool IsObjSameLevelWithMarked(const SdrObject* pObj) const; const SdrMarkList* GetMarkList() const{ return _GetMarkList(); }; void EndTextEdit(); ///< Deletes object if required. /** Anchor type of selected object, -1 if ambiguous or in case of frame selection. Else FLY_AT_PAGE or FLY_AT_PARA resp. from frmatr.hxx. */ short GetAnchorId() const; /** Process of creating draw objects. At the beginning object type is passed. At the end a Cmd can be passed. Here, SDRCREATE_RESTRAINTEND for end or SDRCREATE_NEXTPOINT for a polygon may be relevant. After RESTRAINTEND the object is created and selected. BreakCreate interrupts the process. In this case no object is selected. */ bool BeginCreate( sal_uInt16 /*SdrObjKind ?*/ eSdrObjectKind, const Point &rPos ); bool BeginCreate( sal_uInt16 /*SdrObjKind ?*/ eSdrObjectKind, sal_uInt32 eObjInventor, const Point &); void MoveCreate ( const Point &rPos ); bool EndCreate ( sal_uInt16 eSdrCreateCmd ); void BreakCreate(); bool IsDrawCreate() const; void CreateDefaultShape( sal_uInt16 /*SdrObjKind ?*/ eSdrObjectKind, const Rectangle& rRect, sal_uInt16 nSlotId); /// Functions for Rubberbox, ti select Draw-Objects bool BeginMark( const Point &rPos ); void MoveMark ( const Point &rPos ); bool EndMark (); void BreakMark(); /// Create and destroy group, don't when frame is selected. bool IsGroupSelected(); ///< Can be a mixed selection! void GroupSelection(); ///< Afterwards the group is selected. void UnGroupSelection(); /**< The individual objects are selected, but it is possible that there are groups included. */ bool IsGroupAllowed() const; bool IsUnGroupAllowed() const; void MirrorSelection( bool bHorizontal ); ///< Vertical if FALSE. /** frmatr.hxx. Here no enum because of dependencies. bool value only for internal use! Anchor is newly set according to current document position. Anchor is not re-set. */ void ChgAnchor( int eAnchorId, bool bSameOnly = false, bool bPosCorr = true ); bool SetDrawingAttr( SfxItemSet &rSet ); /** Get selected DrawObj as graphics (MetaFile/Bitmap). Return value indicates if it was converted. */ bool GetDrawObjGraphic( SotClipboardFormatId nFormat, Graphic& rGrf ) const; void Paste( SvStream& rStm, SwPasteSdr nAction, const Point* pPt = nullptr ); bool Paste( const Graphic &rGrf, const OUString& rURL ); bool IsAlignPossible() const; void SetCalcFieldValueHdl(Outliner* pOutliner); void Insert(const OUString& rGrfName, const OUString& rFltName, const Graphic* pGraphic = nullptr, const SfxItemSet* pFlyAttrSet = nullptr, const SfxItemSet* pGrfAttrSet = nullptr, SwFrameFormat* = nullptr ); /// Insertion of a drawing object which have to be already inserted in the DrawModel. void InsertDrawObj( SdrObject& rDrawObj, const Point& rInsertPosition ); bool ReplaceSdrObj( const OUString& rGrfName, const OUString& rFltName, const Graphic* pGrf = nullptr ); // --> #i972# /** for starmath formulas anchored 'as char' it aligns it baseline to baseline changing the previous vertical orientation */ void AlignFormulaToBaseline( const css::uno::Reference < css::embed::XEmbeddedObject >& xObj, SwFlyFrame * pFly = nullptr ); /// aligns all formulas with anchor 'as char' to baseline void AlignAllFormulasToBaseline(); /// Provide information about content situated closes to given Point. Point GetContentPos( const Point& rPoint, bool bNext ) const; /// Convert document position into position relative to the current page. Point GetRelativePagePosition(const Point& rDocPos); /// Hide or show layout-selection and pass call to CursorSh. void ShLooseFcs(); void ShGetFcs( bool bUpdate = true ); /// PageDescriptor-interface void ChgCurPageDesc( const SwPageDesc& ); size_t GetCurPageDesc( const bool bCalcFrame = true ) const; size_t GetMousePageDesc( const Point &rPt ) const; size_t GetPageDescCnt() const; SwPageDesc* FindPageDescByName( const OUString& rName, bool bGetFromPool = false, size_t* pPos = nullptr ); const SwPageDesc& GetPageDesc( size_t i ) const; void ChgPageDesc( size_t i, const SwPageDesc& ); /** if inside all selection only one PageDesc, @return this. Otherwise @return 0 pointer */ const SwPageDesc* GetSelectedPageDescs() const; const SwRect& GetAnyCurRect( CurRectType eType, const Point* pPt = nullptr, const css::uno::Reference < css::embed::XEmbeddedObject >& = css::uno::Reference < css::embed::XEmbeddedObject >() ) const; /// Page number of the page containing Point, O if no page. sal_uInt16 GetPageNumber( const Point &rPoint ) const; bool GetPageNumber( long nYPos, bool bAtCursorPos, sal_uInt16& rPhyNum, sal_uInt16& rVirtNum, OUString &rDisplay ) const; SwFlyFrameFormat* InsertObject( const svt::EmbeddedObjectRef&, const SfxItemSet* pFlyAttrSet = nullptr, const SfxItemSet* pGrfAttrSet = nullptr, SwFrameFormat* = nullptr ); bool FinishOLEObj(); ///< Shutdown server. void GetTableAttr( SfxItemSet & ) const; void SetTableAttr( const SfxItemSet & ); bool HasWholeTabSelection() const; /// Is content of a table cell or at least a table cell completely selected? bool HasBoxSelection() const; bool InsertRow( sal_uInt16 nCnt, bool bBehind ); bool InsertCol( sal_uInt16 nCnt, bool bBehind ); // 0 == at the end. bool DeleteCol(); bool DeleteTable(); bool DeleteRow(bool bCompleteTable = false); bool DeleteTableSel(); ///< Current selection, may be whole table. sal_uInt16 MergeTab(); /**< Merge selected parts of table. @return error via enum. */ /// Split cell vertically or horizontally. bool SplitTab( bool bVert = true, sal_uInt16 nCnt = 1, bool bSameHeight = false ); bool Sort(const SwSortOptions&); //Sortieren. void SetRowHeight( const SwFormatFrameSize &rSz ); /// Pointer must be destroyed by caller != 0. void GetRowHeight( SwFormatFrameSize *&rpSz ) const; void SetRowSplit( const SwFormatRowSplit &rSz ); void GetRowSplit( SwFormatRowSplit *&rpSz ) const; void SetBoxAlign( sal_uInt16 nOrient ); sal_uInt16 GetBoxAlign() const; ///< USHRT_MAX if ambiguous. /// Adjustment of Rowheights. Determine via bTstOnly if more than one row is selected. bool BalanceRowHeight( bool bTstOnly ); void SetTabBorders( const SfxItemSet& rSet ); void GetTabBorders( SfxItemSet& rSet) const; void SetTabLineStyle(const Color* pColor, bool bSetLine = false, const editeng::SvxBorderLine* pBorderLine = nullptr); void SetTabBackground( const SvxBrushItem &rNew ); void GetTabBackground( SvxBrushItem &rToFill ) const; void SetBoxBackground( const SvxBrushItem &rNew ); bool GetBoxBackground( SvxBrushItem &rToFill ) const; ///< FALSE ambiguous. void SetBoxDirection( const SvxFrameDirectionItem& rNew ); bool GetBoxDirection( SvxFrameDirectionItem& rToFill ) const; ///< FALSE ambiguous. void SetRowBackground( const SvxBrushItem &rNew ); bool GetRowBackground( SvxBrushItem &rToFill ) const; ///< FALSE ambiguous. SwTab WhichMouseTabCol( const Point &rPt ) const; void GetTabCols( SwTabCols &rToFill ) const; ///< Info about columns and margins. void SetTabCols( const SwTabCols &rNew, bool bCurRowOnly = true ); void GetMouseTabCols( SwTabCols &rToFill, const Point &rPt ) const; void SetMouseTabCols( const SwTabCols &rNew, bool bCurRowOnly, const Point &rPt ); /// pEnd will be used during MouseMove bool SelTableRowCol( const Point& rPt, const Point* pEnd = nullptr, bool bRowDrag = false ); void GetTabRows( SwTabCols &rToFill ) const; void SetTabRows( const SwTabCols &rNew, bool bCurColOnly ); void GetMouseTabRows( SwTabCols &rToFill, const Point &rPt ) const; void SetMouseTabRows( const SwTabCols &rNew, bool bCurColOnly, const Point &rPt ); void ProtectCells(); /**< If a table selection exists it is destroyed in case cursor is not allowed in readonly. */ void UnProtectCells(); ///< Refers to table selection. void UnProtectTables(); ///< Unprotect all tables in selection. bool HasTableAnyProtection( const OUString* pTableName = nullptr, bool* pFullTableProtection = nullptr ); bool CanUnProtectCells() const; sal_uInt16 GetRowsToRepeat() const; void SetRowsToRepeat( sal_uInt16 nNumOfRows ); sal_uInt16 GetVirtPageNum( const bool bCalcFrame = true ); /** @return the number of table rows currently selected if the selection start at the top of the table. */ sal_uInt16 GetRowSelectionFromTop() const; bool IsInRepeatedHeadline() const { return CheckHeadline( true ); } bool IsInHeadline() const { return CheckHeadline( false ); } /** Adjusts cell widths in such a way, that their content does not need to be wrapped (if possible). bBalance provides for adjustment of selected columns. */ void AdjustCellWidth( bool bBalance = false ); /// Not allowed if only empty cells are selected. bool IsAdjustCellWidthAllowed( bool bBalance = false ) const; /// Set table style of the current table. bool SetTableStyle(const SwTableAutoFormat& rNew); /// Update the direct formatting according to the current table style. /// @param pTableNode Table node to update. When nullptr, current cursor position is used. /// @param bResetDirect Reset direct formatting that might be applied to the cells. bool UpdateTableStyleFormatting(SwTableNode *pTableNode = nullptr, bool bResetDirect = false); bool GetTableAutoFormat( SwTableAutoFormat& rGet ); bool SetColRowWidthHeight( sal_uInt16 eType, sal_uInt16 nDiff = 283 ); bool GetAutoSum( OUString& rFormula ) const; /** Phy: real page count. Virt: consider offset that may have been set by user. */ sal_uInt16 GetPhyPageNum(); void SetNewPageOffset( sal_uInt16 nOffset ); void SetPageOffset( sal_uInt16 nOffset ); ///< Changes last page offset. sal_uInt16 GetPageOffset() const; ///< @return last page offset. void InsertLabel( const SwLabelType eType, const OUString &rText, const OUString& rSeparator, const OUString& rNumberSeparator, const bool bBefore, const sal_uInt16 nId, const OUString& rCharacterStyle, const bool bCpyBrd = true ); /// The ruler needs some information too. sal_uInt16 GetCurColNum( SwGetCurColNumPara* pPara = nullptr ) const; //0 == not in any column. sal_uInt16 GetCurMouseColNum( const Point &rPt, SwGetCurColNumPara* pPara = nullptr ) const; size_t GetCurTabColNum() const; //0 == not in any table. size_t GetCurMouseTabColNum( const Point &rPt ) const; sal_uInt16 GetCurOutColNum( SwGetCurColNumPara* pPara = nullptr ) const; ///< Current outer column. bool IsTableRightToLeft() const; bool IsMouseTableRightToLeft( const Point &rPt ) const; bool IsTableVertical() const; bool IsLastCellInRow() const; /// Width of current range for column-dialog. long GetSectionWidth( SwFormat const & rFormat ) const; void GetConnectableFrameFormats (SwFrameFormat & rFormat, const OUString & rReference, bool bSuccessors, ::std::vector< OUString > & aPrevPageVec, ::std::vector< OUString > & aThisPageVec, ::std::vector< OUString > & aNextPageVec, ::std::vector< OUString > & aRestVec); /** SwFEShell::GetShapeBackgrd method determines background color of the page the selected drawing object is on and returns this color. If no color is found, because no drawing object is selected or ..., color COL_BLACK (default color on constructing object of class Color) is returned. @author OD @returns an object of class Color */ const Color GetShapeBackgrd() const; /** Is default horizontal text direction for selected drawing object right-to-left Because drawing objects only painted for each page only, the default horizontal text direction of a drawing object is given by the corresponding page property. @author OD @returns boolean, indicating, if the horizontal text direction of the page, the selected drawing object is on, is right-to-left. */ bool IsShapeDefaultHoriTextDirR2L() const; void ParkCursorInTab(); SwTextNode * GetNumRuleNodeAtPos(const Point &rPot); bool IsNumLabel( const Point &rPt, int nMaxOffset = -1 ); static bool IsVerticalModeAtNdAndPos( const SwTextNode& _rTextNode, const Point& _rDocPos ); void ToggleHeaderFooterEdit( ); }; void ClearFEShellTabCols(); #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */