/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org 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 version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef _CRSTATE_HXX #define _CRSTATE_HXX #include #include #include #include enum SwFillMode { FILL_TAB, // default, fill with tabs FILL_SPACE, // fill with spaces and tabs FILL_MARGIN, // only align left, center, right FILL_INDENT // by left paragraph indention }; struct SwFillCrsrPos { SwRect aCrsr; // position and size of the ShadowCursor sal_uInt16 nParaCnt; // number of paragraphs to insert sal_uInt16 nTabCnt; // number of tabs respectively size of indentation sal_uInt16 nSpaceCnt; // number of spaces to insert sal_uInt16 nColumnCnt; // number of necessary column breaks sal_Int16 eOrient; // paragraph alignment SwFillMode eMode; // desired fill-up rule SwFillCrsrPos( SwFillMode eMd = FILL_TAB ) : nParaCnt( 0 ), nTabCnt( 0 ), nSpaceCnt( 0 ), nColumnCnt( 0 ), eOrient( com::sun::star::text::HoriOrientation::NONE ), eMode( eMd ) {} }; // Multiportion types: two lines, bidirectional, 270 degrees rotation, // ruby portion and 90 degrees rotation #define MT_TWOLINE 0 #define MT_BIDI 1 #define MT_ROT_270 3 #define MT_RUBY 4 #define MT_ROT_90 7 struct Sw2LinesPos { SwRect aLine; // Position and size of the line SwRect aPortion; // Position and size of the multi portion SwRect aPortion2; // needed for nested multi portions sal_uInt8 nMultiType; // Multiportion type }; /** * SwSpecialPos. This structure is used to pass some additional information * during the call of SwTxtFrm::GetCharRect(). An SwSpecialPos defines a position * inside a portion which does not have a representation in the core string or * which is only represented by one position, e.g., field portions, * number portions, ergo sum and quo vadis portions. * * nCharOfst - The offset inside the special portion. Fields and its * follow fields are treated as one long special portion. * nLineOfst - The number of lines between the beginning of the special * portion and nCharOfst. A line offset required to be * nCharOfst relative to the beginning of the line. * nExtendRange - Setting this identifies portions which are in front or * behind the core string (number portion, quo vadis) * * Examples 1) * * Get the position of the second character inside a number portion: * nCharOfst = 2; nLineOfst = 0; nExtendRange = SP_EXTEND_RANGE_BEFORE; * Call SwTxtFrm:::GetCharRect with core string position 0. * * Example 2) * * Field A - Length = 5 * Follow field B - Length = 9 * Get the position of the third character in follow field B, core position * of field A is 33. * nCharOfst = 7; nLineOfst = 0; nExtendRange = SP_EXTEND_RANGE_NONE; * Call SwTxtFrm:::GetCharRect with core string position 33. */ #define SP_EXTEND_RANGE_NONE 0 #define SP_EXTEND_RANGE_BEFORE 1 #define SP_EXTEND_RANGE_BEHIND 2 struct SwSpecialPos { xub_StrLen nCharOfst; sal_uInt16 nLineOfst; sal_uInt8 nExtendRange; // #i27615# SwSpecialPos() : nCharOfst(0), nLineOfst(0), nExtendRange(SP_EXTEND_RANGE_NONE) {} }; // CrsrTravelling-States (for GetCrsrOfst) enum CrsrMoveState { MV_NONE, // default MV_UPDOWN, // Crsr Up/Down MV_RIGHTMARGIN, // at right margin MV_LEFTMARGIN, // at left margin MV_SETONLYTEXT, // stay with the cursor inside text MV_TBLSEL // not in repeated headlines }; // struct for later extensions struct SwCrsrMoveState { SwFillCrsrPos *pFill; // for automatic filling with tabs etc Sw2LinesPos *p2Lines; // for selections inside/around 2line portions SwSpecialPos* pSpecialPos; // for positions inside fields Point aRealHeight; // contains then the position/height of the cursor CrsrMoveState eState; sal_uInt8 nCursorBidiLevel; sal_Bool bStop; sal_Bool bRealHeight; // should the real height be calculated? sal_Bool bFieldInfo; // should be fields recognized? sal_Bool bPosCorr; // Point had to be corrected sal_Bool bFtnNoInfo; // recognized footnote numbering sal_Bool bExactOnly; // let GetCrsrOfst look for exact matches only, // i.e. never let it run into GetCntntPos sal_Bool bFillRet; // only used temporary in FillMode sal_Bool bSetInReadOnly; // ReadOnly areas may be entered sal_Bool bRealWidth; // Calculation of the width required sal_Bool b2Lines; // Check 2line portions and fill p2Lines sal_Bool bNoScroll; // No scrolling of undersized textframes sal_Bool bPosMatchesBounds; // GetCrsrOfst should not return the next // position if screen position is inside second // have of bound rect sal_Bool bCntntCheck; // #i43742# Cursor position over content? // #i27615# /** cursor in front of label */ sal_Bool bInFrontOfLabel; sal_Bool bInNumPortion; // point is in number portion #i23726# int nInNumPostionOffset; // distance from number portion's start SwCrsrMoveState( CrsrMoveState eSt = MV_NONE ) : pFill( NULL ), p2Lines( NULL ), pSpecialPos( NULL ), eState( eSt ), nCursorBidiLevel( 0 ), bStop( sal_False ), bRealHeight( sal_False ), bFieldInfo( sal_False ), bPosCorr( sal_False ), bFtnNoInfo( sal_False ), bExactOnly( sal_False ), bSetInReadOnly( sal_False ), bRealWidth( sal_False ), b2Lines( sal_False ), bNoScroll( sal_False ), bPosMatchesBounds( sal_False ), bCntntCheck( sal_False ), // #i43742# bInFrontOfLabel( sal_False ), // #i27615# bInNumPortion(sal_False), // #i26726# nInNumPostionOffset(0) // #i26726# {} SwCrsrMoveState( SwFillCrsrPos *pInitFill ) : pFill( pInitFill ), pSpecialPos( NULL ), eState( MV_SETONLYTEXT ), nCursorBidiLevel( 0 ), bStop( sal_False ), bRealHeight( sal_False ), bFieldInfo( sal_False ), bPosCorr( sal_False ), bFtnNoInfo( sal_False ), bExactOnly( sal_False ), bSetInReadOnly( sal_False ), bRealWidth( sal_False ), b2Lines( sal_False ), bNoScroll( sal_False ), bPosMatchesBounds( sal_False ), bCntntCheck( sal_False ), // #i43742# bInFrontOfLabel( sal_False ), // #i27615# bInNumPortion(sal_False), // #i23726# nInNumPostionOffset(0) // #i23726# {} }; #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */