| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  $RCSfile: trvlfrm.cxx,v $ | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-07-08 10:04:45 +00:00
										 |  |  |  *  $Revision: 1.45 $ | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-07-08 10:04:45 +00:00
										 |  |  |  *  last change: $Author: obo $ $Date: 2005-07-08 11:04:45 $ | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +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): _______________________________________ | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  ************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma hdrstop
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _HINTIDS_HXX
 | 
					
						
							|  |  |  | #include <hintids.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _BIGINT_HXX //autogen
 | 
					
						
							|  |  |  | #include <tools/bigint.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _SVX_PROTITEM_HXX //autogen
 | 
					
						
							|  |  |  | #include <svx/protitem.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _SV_SETTINGS_HXX //autogen
 | 
					
						
							|  |  |  | #include <vcl/settings.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _SV_OUTDEV_HXX //autogen
 | 
					
						
							|  |  |  | #include <vcl/outdev.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _FMTPDSC_HXX //autogen
 | 
					
						
							|  |  |  | #include <fmtpdsc.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _FMTSRND_HXX //autogen
 | 
					
						
							|  |  |  | #include <fmtsrnd.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-03-02 10:21:22 +00:00
										 |  |  | #ifndef _PAGEDESC_HXX
 | 
					
						
							|  |  |  | #include <pagedesc.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef _PAGEFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <pagefrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _ROOTFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <rootfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _CNTFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <cntfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _FTNFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <ftnfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _FLYFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <flyfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _TABFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <tabfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  | #ifndef _ROWFRM_HXX
 | 
					
						
							|  |  |  | #include <rowfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | #ifndef _CELLFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <cellfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _TXTFRM_HXX //autogen
 | 
					
						
							|  |  |  | #include <txtfrm.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _VIEWSH_HXX //autogen
 | 
					
						
							|  |  |  | #include <viewsh.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-09-08 15:10:36 +00:00
										 |  |  | #ifndef _VIEWOPT_HXX
 | 
					
						
							|  |  |  | #include <viewopt.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | #ifndef _DOC_HXX //autogen
 | 
					
						
							|  |  |  | #include <doc.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _VISCRS_HXX //autogen
 | 
					
						
							|  |  |  | #include <viscrs.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _PAM_HXX //autogen
 | 
					
						
							|  |  |  | #include <pam.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _NODE_HXX //autogen
 | 
					
						
							|  |  |  | #include <node.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _FRMFMT_HXX //autogen
 | 
					
						
							|  |  |  | #include <frmfmt.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _SWTABLE_HXX //autogen
 | 
					
						
							|  |  |  | #include <swtable.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _DFLYOBJ_HXX //autogen
 | 
					
						
							|  |  |  | #include <dflyobj.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _CRSTATE_HXX //autogen
 | 
					
						
							|  |  |  | #include <crstate.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _FRMTOOL_HXX //autogen
 | 
					
						
							|  |  |  | #include <frmtool.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _HINTS_HXX //autogen
 | 
					
						
							|  |  |  | #include <hints.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef _FRMSH_HXX
 | 
					
						
							|  |  |  | #include <frmsh.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-02-26 14:31:21 +00:00
										 |  |  | #ifndef _NDTXT_HXX
 | 
					
						
							|  |  |  | #include <ndtxt.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  | // OD 2004-05-24 #i28701#
 | 
					
						
							|  |  |  | #ifndef _SORTEDOBJS_HXX
 | 
					
						
							|  |  |  | #include <sortedobjs.hxx>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | //Fuer SwFlyFrm::GetCrsrOfst
 | 
					
						
							|  |  |  | class SwCrsrOszControl | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     // damit schon der Compiler die Klasse initialisieren kann, keinen
 | 
					
						
							|  |  |  |     // DTOR und member als publics:
 | 
					
						
							|  |  |  |     const SwFlyFrm *pEntry; | 
					
						
							|  |  |  |     const SwFlyFrm *pStk1; | 
					
						
							|  |  |  |     const SwFlyFrm *pStk2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //public:
 | 
					
						
							|  |  |  | //    SwCrsrOszControl() : pStk1( 0 ), pStk2( 0 ) {}; // ; <- ????
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     BOOL ChkOsz( const SwFlyFrm *pFly ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             BOOL bRet = TRUE; | 
					
						
							|  |  |  |             if ( pFly != pStk1 && pFly != pStk2 ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 pStk1 = pStk2; | 
					
						
							|  |  |  |                 pStk2 = pFly; | 
					
						
							|  |  |  |                 bRet  = FALSE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return bRet; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     void Entry( const SwFlyFrm *pFly ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if ( !pEntry ) | 
					
						
							|  |  |  |                 pEntry = pStk1 = pFly; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     void Exit( const SwFlyFrm *pFly ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if ( pFly == pEntry ) | 
					
						
							|  |  |  |                 pEntry = pStk1 = pStk2 = 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static SwCrsrOszControl aOszCtrl = { 0, 0, 0 }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwLayoutFrm::GetCrsrOfst() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung:       Sucht denjenigen CntntFrm, innerhalb dessen | 
					
						
							|  |  |  | |*                      PrtArea der Point liegt. | 
					
						
							|  |  |  | |*  Ersterstellung      MA 20. Jul. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 23. May. 95 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | BOOL SwLayoutFrm::GetCrsrOfst( SwPosition *pPos, Point &rPoint, | 
					
						
							| 
									
										
										
										
											2004-05-17 15:16:56 +00:00
										 |  |  |                                SwCrsrMoveState* pCMS ) const | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     BOOL bRet = FALSE; | 
					
						
							|  |  |  |     const SwFrm *pFrm = Lower(); | 
					
						
							|  |  |  |     while ( !bRet && pFrm ) | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         pFrm->Calc(); | 
					
						
							| 
									
										
										
										
											2000-11-09 13:03:01 +00:00
										 |  |  |         SwRect aPaintRect( pFrm->PaintArea() ); | 
					
						
							|  |  |  |         if ( aPaintRect.IsInside( rPoint ) && | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             pFrm->GetCrsrOfst( pPos, rPoint, pCMS ) ) | 
					
						
							|  |  |  |             bRet = TRUE; | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |             pFrm = pFrm->GetNext(); | 
					
						
							|  |  |  |         if ( pCMS && pCMS->bStop ) | 
					
						
							|  |  |  |             return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return bRet; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwPageFrm::GetCrsrOfst() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung:       Sucht die Seite, innerhalb der der gesuchte Point | 
					
						
							|  |  |  | |*                      liegt. | 
					
						
							|  |  |  | |*  Ersterstellung      MA 20. Jul. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 18. Jul. 96 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | #pragma optimize("e",off)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL SwPageFrm::GetCrsrOfst( SwPosition *pPos, Point &rPoint, | 
					
						
							| 
									
										
										
										
											2004-05-17 15:16:56 +00:00
										 |  |  |                              SwCrsrMoveState* pCMS ) const | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     BOOL bRet     = FALSE; | 
					
						
							|  |  |  |     const SwPageFrm *pPage = this; | 
					
						
							| 
									
										
										
										
											2001-10-19 09:32:09 +00:00
										 |  |  |     Point aStPoint( rPoint ); | 
					
						
							|  |  |  |     Point aPoint; | 
					
						
							|  |  |  |     while ( !bRet && pPage ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         aPoint = aStPoint; | 
					
						
							|  |  |  |         SwTwips nTmp = pPage->Frm().Top(); | 
					
						
							|  |  |  |         if ( pPage->GetPrev() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwTwips nPreTmp = pPage->GetPrev()->Frm().Bottom(); | 
					
						
							|  |  |  |             if ( (aPoint.Y() > nPreTmp) && | 
					
						
							|  |  |  |                  (aPoint.Y() < nTmp)    && | 
					
						
							|  |  |  |                  ((aPoint.Y() - nPreTmp) >= (nTmp - aPoint.Y())) ) | 
					
						
							|  |  |  |                 aPoint.Y() = nTmp; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else if ( aPoint.Y() < nTmp ) | 
					
						
							|  |  |  |             aPoint.Y() = nTmp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         nTmp = pPage->Frm().Bottom(); | 
					
						
							|  |  |  |         if ( pPage->GetNext() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwTwips nNxtTmp = pPage->GetNext()->Frm().Top(); | 
					
						
							|  |  |  |             if ( (aPoint.Y() > nTmp) && | 
					
						
							|  |  |  |                  (aPoint.Y() < nNxtTmp) && | 
					
						
							|  |  |  |                  ((nNxtTmp - aPoint.Y()) >= (aPoint.Y() - nTmp)) ) | 
					
						
							|  |  |  |                 aPoint.Y() = nTmp; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else if ( aPoint.Y() > nTmp ) | 
					
						
							|  |  |  |             aPoint.Y() = nTmp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Wenn der Punkt in der Fix-Richtung neben der Seite liegt wird er
 | 
					
						
							|  |  |  |         //hineingezogen.
 | 
					
						
							|  |  |  |         const SwTwips nVarA = pPage->Frm().Pos().X(); | 
					
						
							|  |  |  |         const SwTwips nVarB = pPage->Frm().Right(); | 
					
						
							|  |  |  |         if ( nVarA > aPoint.X() ) | 
					
						
							|  |  |  |             aPoint.X() = nVarA; | 
					
						
							|  |  |  |         else if ( nVarB < aPoint.X() ) | 
					
						
							|  |  |  |             aPoint.X() = nVarB; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         //Weitere versuche mit der aktuellen Seite nur dann, wenn sich der
 | 
					
						
							|  |  |  |         //Point innerhalb der Seite befindet.
 | 
					
						
							|  |  |  |         const BOOL bInside = pPage->Frm().IsInside( aPoint ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Koennte ein Freifliegender gemeint sein?
 | 
					
						
							|  |  |  |         //Wenn sein Inhalt geschuetzt werden soll, so ist nix mit Crsr
 | 
					
						
							|  |  |  |         //hineinsetzen, dadurch sollten alle Aenderungen unmoeglich sein.
 | 
					
						
							|  |  |  |         if ( bInside && pPage->GetSortedObjs() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             SwOrderIter aIter( pPage ); | 
					
						
							|  |  |  |             aIter.Top(); | 
					
						
							|  |  |  |             while ( aIter() ) | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |                 const SwVirtFlyDrawObj* pObj = | 
					
						
							|  |  |  |                                 static_cast<const SwVirtFlyDrawObj*>(aIter()); | 
					
						
							|  |  |  |                 const SwFlyFrm* pFly = pObj ? pObj->GetFlyFrm() : 0; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 if ( pFly && | 
					
						
							| 
									
										
										
										
											2004-02-26 14:31:21 +00:00
										 |  |  |                      ( ( pCMS ? pCMS->bSetInReadOnly : FALSE ) || | 
					
						
							|  |  |  |                        !pFly->IsProtected() ) && | 
					
						
							|  |  |  |                      pFly->GetCrsrOfst( pPos, aPoint, pCMS ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     bRet = TRUE; | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2004-02-26 14:31:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 if ( pCMS && pCMS->bStop ) | 
					
						
							|  |  |  |                     return FALSE; | 
					
						
							|  |  |  |                 aIter.Prev(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ( !bRet && bInside ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             //Wenn kein Cntnt unterhalb der Seite 'antwortet', so korrigieren
 | 
					
						
							|  |  |  |             //wir den StartPoint und fangen nochmal eine Seite vor der
 | 
					
						
							|  |  |  |             //aktuellen an. Mit Flys ist es dann allerdings vorbei.
 | 
					
						
							|  |  |  |             if ( pPage->SwLayoutFrm::GetCrsrOfst( pPos, aPoint, pCMS ) ) | 
					
						
							|  |  |  |                 bRet = TRUE; | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 if ( pCMS && (pCMS->bStop || pCMS->bExactOnly) ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     ((SwCrsrMoveState*)pCMS)->bStop = TRUE; | 
					
						
							|  |  |  |                     return FALSE; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 const SwCntntFrm *pCnt = pPage->GetCntntPos( | 
					
						
							|  |  |  |                                     aPoint, FALSE, FALSE, FALSE, pCMS, FALSE ); | 
					
						
							|  |  |  |                 if ( pCMS && pCMS->bStop ) | 
					
						
							|  |  |  |                     return FALSE; | 
					
						
							|  |  |  |                 ASSERT( pCnt, "Crsr is gone to a Black hole" ); | 
					
						
							|  |  |  |                 if( pCMS && pCMS->pFill && pCnt->IsTxtFrm() ) | 
					
						
							| 
									
										
										
										
											2004-02-26 14:31:21 +00:00
										 |  |  |                     bRet = pCnt->GetCrsrOfst( pPos, rPoint, pCMS ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 else | 
					
						
							| 
									
										
										
										
											2004-02-26 14:31:21 +00:00
										 |  |  |                     bRet = pCnt->GetCrsrOfst( pPos, aPoint, pCMS ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if ( !bRet ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     // Set point to pCnt, delete mark
 | 
					
						
							|  |  |  |                     // this may happen, if pCnt is hidden
 | 
					
						
							|  |  |  |                     *pPos = SwPosition( *pCnt->GetNode(), SwIndex( (SwTxtNode*)pCnt->GetNode(), 0 ) ); | 
					
						
							|  |  |  |                     bRet = TRUE; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         pPage = (const SwPageFrm*)pPage->GetNext(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ( bRet ) | 
					
						
							|  |  |  |         rPoint = aPoint; | 
					
						
							|  |  |  |     return bRet; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma optimize("",on)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwRootFrm::GetCrsrOfst() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung:       Reicht Primaer den Aufruf an die erste Seite weiter. | 
					
						
							|  |  |  | |*                      Wenn der 'reingereichte Point veraendert wird, | 
					
						
							|  |  |  | |*                      so wird FALSE zurueckgegeben. | 
					
						
							|  |  |  | |*  Ersterstellung      MA 01. Jun. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 30. Nov. 94 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | BOOL SwRootFrm::GetCrsrOfst( SwPosition *pPos, Point &rPoint, | 
					
						
							| 
									
										
										
										
											2004-05-17 15:16:56 +00:00
										 |  |  |                              SwCrsrMoveState* pCMS ) const | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-02-14 08:52:23 +00:00
										 |  |  |     sal_Bool bOldAction = IsCallbackActionEnabled(); | 
					
						
							|  |  |  |     ((SwRootFrm*)this)->SetCallbackActionEnabled( FALSE ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     ASSERT( (Lower() && Lower()->IsPageFrm()), "Keinen PageFrm gefunden." ); | 
					
						
							|  |  |  |     if( pCMS && pCMS->pFill ) | 
					
						
							|  |  |  |         ((SwCrsrMoveState*)pCMS)->bFillRet = FALSE; | 
					
						
							|  |  |  |     Point aOldPoint = rPoint; | 
					
						
							|  |  |  |     const SwPageFrm *pPage = (SwPageFrm*)Lower(); | 
					
						
							|  |  |  |     pPage->SwPageFrm::GetCrsrOfst( pPos, rPoint, pCMS ); | 
					
						
							| 
									
										
										
										
											2001-02-14 08:52:23 +00:00
										 |  |  |     ((SwRootFrm*)this)->SetCallbackActionEnabled( bOldAction ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     if( pCMS ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if( pCMS->bStop ) | 
					
						
							|  |  |  |             return FALSE; | 
					
						
							|  |  |  |         if( pCMS->pFill ) | 
					
						
							|  |  |  |             return pCMS->bFillRet; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return aOldPoint == rPoint; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwCellFrm::GetCrsrOfst() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung        Wenn es sich um eine Cntnt-tragende Cell handelt wird | 
					
						
							|  |  |  | |*                      der Crsr notfalls mit Gewalt in einen der CntntFrms | 
					
						
							|  |  |  | |*                      gesetzt. | 
					
						
							|  |  |  | |*                      In geschuetzte Zellen gibt es hier keinen Eingang. | 
					
						
							|  |  |  | |*  Ersterstellung      MA 04. Jun. 93 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 23. May. 95 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | BOOL SwCellFrm::GetCrsrOfst( SwPosition *pPos, Point &rPoint, | 
					
						
							| 
									
										
										
										
											2004-05-17 15:16:56 +00:00
										 |  |  |                              SwCrsrMoveState* pCMS ) const | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |     // cell frame does not necessarily have a lower (split table cell)
 | 
					
						
							|  |  |  |     if ( !Lower() ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if ( !(pCMS?pCMS->bSetInReadOnly:FALSE) && | 
					
						
							|  |  |  |          GetFmt()->GetProtect().IsCntntProtected() ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( pCMS && pCMS->eState == MV_TBLSEL ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         const SwTabFrm *pTab = FindTabFrm(); | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |         if ( pTab->IsFollow() && pTab->IsInHeadline( *this ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         { | 
					
						
							|  |  |  |             ((SwCrsrMoveState*)pCMS)->bStop = TRUE; | 
					
						
							|  |  |  |             return FALSE; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |     if ( Lower() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |         if ( Lower()->IsLayoutFrm() ) | 
					
						
							|  |  |  |             return SwLayoutFrm::GetCrsrOfst( pPos, rPoint, pCMS ); | 
					
						
							|  |  |  |         else | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |             Calc(); | 
					
						
							|  |  |  |             BOOL bRet = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             const SwFrm *pFrm = Lower(); | 
					
						
							|  |  |  |             while ( pFrm && !bRet ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                 pFrm->Calc(); | 
					
						
							|  |  |  |                 if ( pFrm->Frm().IsInside( rPoint ) ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     bRet = pFrm->GetCrsrOfst( pPos, rPoint, pCMS ); | 
					
						
							|  |  |  |                     if ( pCMS && pCMS->bStop ) | 
					
						
							|  |  |  |                         return FALSE; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 pFrm = pFrm->GetNext(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |             if ( !bRet ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                 Point *pPoint = pCMS && pCMS->pFill ? new Point( rPoint ) : NULL; | 
					
						
							|  |  |  |                 const SwCntntFrm *pCnt = GetCntntPos( rPoint, TRUE ); | 
					
						
							|  |  |  |                 if( pPoint && pCnt->IsTxtFrm() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     pCnt->GetCrsrOfst( pPos, *pPoint, pCMS ); | 
					
						
							|  |  |  |                     rPoint = *pPoint; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                     pCnt->GetCrsrOfst( pPos, rPoint, pCMS ); | 
					
						
							|  |  |  |                 delete pPoint; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |             return TRUE; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwFlyFrm::GetCrsrOfst() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Ersterstellung      MA 15. Dec. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 23. May. 95 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | //Problem: Wenn zwei Flys genau gleich gross sind und auf derselben
 | 
					
						
							|  |  |  | //Position stehen, so liegt jeder innerhalb des anderen.
 | 
					
						
							|  |  |  | //Da jeweils geprueft wird, ob der Point nicht zufaellig innerhalb eines
 | 
					
						
							|  |  |  | //anderen Flys liegt, der sich vollstaendig innerhalb des aktuellen befindet
 | 
					
						
							|  |  |  | //und ggf. ein rekursiver Aufruf erfolgt wuerde o.g. Situation zu einer
 | 
					
						
							|  |  |  | //endlosen Rekursion fuehren.
 | 
					
						
							|  |  |  | //Mit der Hilfsklasse SwCrsrOszControl unterbinden wir die Rekursion. Das
 | 
					
						
							|  |  |  | //GetCrsrOfst entscheidet sich bei einer Rekursion fuer denjenigen der
 | 
					
						
							|  |  |  | //am weitesten oben liegt.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL SwFlyFrm::GetCrsrOfst( SwPosition *pPos, Point &rPoint, | 
					
						
							| 
									
										
										
										
											2004-05-17 15:16:56 +00:00
										 |  |  |                             SwCrsrMoveState* pCMS ) const | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     aOszCtrl.Entry( this ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Wenn der Point innerhalb des Fly sitzt wollen wir energisch
 | 
					
						
							|  |  |  |     //versuchen den Crsr hineinzusetzen.
 | 
					
						
							|  |  |  |     //Wenn der Point allerdings in einem Flys sitzt, der sich vollstaendig
 | 
					
						
							|  |  |  |     //innerhalb des aktuellen befindet, so wird fuer diesen das
 | 
					
						
							|  |  |  |     //GetCrsrOfst gerufen.
 | 
					
						
							|  |  |  |     Calc(); | 
					
						
							|  |  |  |     BOOL bInside = Frm().IsInside( rPoint ) && Lower(), | 
					
						
							|  |  |  |          bRet = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Wenn der Frm eine Grafik enthaelt, aber nur Text gewuenscht ist, so
 | 
					
						
							|  |  |  |     //nimmt er den Crsr grundsaetzlich nicht an.
 | 
					
						
							|  |  |  |     if ( bInside && pCMS && pCMS->eState == MV_SETONLYTEXT && | 
					
						
							|  |  |  |          (!Lower() || Lower()->IsNoTxtFrm()) ) | 
					
						
							|  |  |  |         bInside = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwPageFrm *pPage = FindPageFrm(); | 
					
						
							|  |  |  |     if ( bInside && pPage && pPage->GetSortedObjs() ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SwOrderIter aIter( pPage ); | 
					
						
							|  |  |  |         aIter.Top(); | 
					
						
							|  |  |  |         while ( aIter() && !bRet ) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |             const SwVirtFlyDrawObj* pObj = static_cast<const SwVirtFlyDrawObj*>(aIter()); | 
					
						
							|  |  |  |             const SwFlyFrm* pFly = pObj ? pObj->GetFlyFrm() : 0; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             if ( pFly && pFly->Frm().IsInside( rPoint ) && | 
					
						
							|  |  |  |                  Frm().IsInside( pFly->Frm() ) ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 if ( aOszCtrl.ChkOsz( pFly ) || | 
					
						
							|  |  |  |                      TRUE == (bRet = pFly->GetCrsrOfst( pPos, rPoint, pCMS ))) | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                 if ( pCMS && pCMS->bStop ) | 
					
						
							|  |  |  |                     return FALSE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             aIter.Next(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while ( bInside && !bRet ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         const SwFrm *pFrm = Lower(); | 
					
						
							|  |  |  |         while ( pFrm && !bRet ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             pFrm->Calc(); | 
					
						
							|  |  |  |             if ( pFrm->Frm().IsInside( rPoint ) ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 bRet = pFrm->GetCrsrOfst( pPos, rPoint, pCMS ); | 
					
						
							|  |  |  |                 if ( pCMS && pCMS->bStop ) | 
					
						
							|  |  |  |                     return FALSE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             pFrm = pFrm->GetNext(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ( !bRet ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             Point *pPoint = pCMS && pCMS->pFill ? new Point( rPoint ) : NULL; | 
					
						
							|  |  |  |             const SwCntntFrm *pCnt = GetCntntPos( | 
					
						
							|  |  |  |                                             rPoint, TRUE, FALSE, FALSE, pCMS ); | 
					
						
							|  |  |  |             if ( pCMS && pCMS->bStop ) | 
					
						
							|  |  |  |                 return FALSE; | 
					
						
							|  |  |  |             if( pPoint && pCnt->IsTxtFrm() ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 pCnt->GetCrsrOfst( pPos, *pPoint, pCMS ); | 
					
						
							|  |  |  |                 rPoint = *pPoint; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |                 pCnt->GetCrsrOfst( pPos, rPoint, pCMS ); | 
					
						
							|  |  |  |             delete pPoint; | 
					
						
							|  |  |  |             bRet = TRUE; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     aOszCtrl.Exit( this ); | 
					
						
							|  |  |  |     return bRet; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    Beschreibung      Layoutabhaengiges Cursortravelling | 
					
						
							|  |  |  | |*    Ersterstellung    MA 23. Jul. 92 | 
					
						
							|  |  |  | |*    Letzte Aenderung  MA 06. Sep. 93 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | BOOL SwCntntFrm::LeftMargin(SwPaM *pPam) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if( pPam->GetNode() != (SwCntntNode*)GetNode() ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |     ((SwCntntNode*)GetNode())-> | 
					
						
							|  |  |  |         MakeStartIndex((SwIndex *) &pPam->GetPoint()->nContent); | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL SwCntntFrm::RightMargin(SwPaM *pPam, BOOL) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if( pPam->GetNode() != (SwCntntNode*)GetNode() ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |     ((SwCntntNode*)GetNode())-> | 
					
						
							|  |  |  |         MakeEndIndex((SwIndex *) &pPam->GetPoint()->nContent); | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const SwCntntFrm *lcl_GetNxtCnt( const SwCntntFrm* pCnt ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pCnt->GetNextCntntFrm(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const SwCntntFrm *lcl_GetPrvCnt( const SwCntntFrm* pCnt ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pCnt->GetPrevCntntFrm(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef const SwCntntFrm *(*GetNxtPrvCnt)( const SwCntntFrm* ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //Frame in wiederholter Headline?
 | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  | FASTBOOL lcl_IsInRepeatedHeadline( const SwFrm *pFrm, | 
					
						
							|  |  |  |                                     const SwTabFrm** ppTFrm = 0 ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |     const SwTabFrm *pTab = pFrm->FindTabFrm(); | 
					
						
							|  |  |  |     if( ppTFrm ) | 
					
						
							|  |  |  |         *ppTFrm = pTab; | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |     return pTab && pTab->IsFollow() && pTab->IsInHeadline( *pFrm ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //Ueberspringen geschuetzter Tabellenzellen. Optional auch
 | 
					
						
							|  |  |  | //Ueberspringen von wiederholten Headlines.
 | 
					
						
							|  |  |  | //MA 26. Jan. 98: Chg auch andere Geschuetzte Bereiche ueberspringen.
 | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  | // FME: Skip follow flow cells
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | const SwCntntFrm * MA_FASTCALL lcl_MissProtectedFrames( const SwCntntFrm *pCnt, | 
					
						
							|  |  |  |                                                        GetNxtPrvCnt fnNxtPrv, | 
					
						
							|  |  |  |                                                        FASTBOOL bMissHeadline, | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                                                        FASTBOOL bInReadOnly, | 
					
						
							|  |  |  |                                                        FASTBOOL bMissFollowFlowLine ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     if ( pCnt && pCnt->IsInTab() ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         BOOL bProtect = TRUE; | 
					
						
							|  |  |  |         while ( pCnt && bProtect ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwLayoutFrm *pCell = pCnt->GetUpper(); | 
					
						
							|  |  |  |             while ( pCell && !pCell->IsCellFrm() ) | 
					
						
							|  |  |  |                 pCell = pCell->GetUpper(); | 
					
						
							|  |  |  |             if ( !pCell || | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                     ( ( bInReadOnly || !pCell->GetFmt()->GetProtect().IsCntntProtected() ) && | 
					
						
							|  |  |  |                       ( !bMissHeadline || !lcl_IsInRepeatedHeadline( pCell ) ) && | 
					
						
							|  |  |  |                       ( !bMissFollowFlowLine || !pCell->IsInFollowFlowRow() ) ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 bProtect = FALSE; | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |                 pCnt = (*fnNxtPrv)( pCnt ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if ( !bInReadOnly ) | 
					
						
							|  |  |  |         while ( pCnt && pCnt->IsProtected() ) | 
					
						
							|  |  |  |             pCnt = (*fnNxtPrv)( pCnt ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return pCnt; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL MA_FASTCALL lcl_UpDown( SwPaM *pPam, const SwCntntFrm *pStart, | 
					
						
							|  |  |  |                     GetNxtPrvCnt fnNxtPrv, BOOL bInReadOnly ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT( pPam->GetNode() == (SwCntntNode*)pStart->GetNode(), | 
					
						
							|  |  |  |             "lcl_UpDown arbeitet nicht fuer andere." ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwCntntFrm *pCnt = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Wenn gerade eine Tabellenselection laeuft muss ein bischen getricktst
 | 
					
						
							|  |  |  |     //werden: Beim hochlaufen an den Anfang der Zelle gehen, beim runterlaufen
 | 
					
						
							|  |  |  |     //an das Ende der Zelle gehen.
 | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |     FASTBOOL bTblSel = false; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     if ( pStart->IsInTab() && | 
					
						
							|  |  |  |         pPam->GetNode( TRUE )->StartOfSectionNode() != | 
					
						
							|  |  |  |         pPam->GetNode( FALSE )->StartOfSectionNode() ) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |         bTblSel = true; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         const SwLayoutFrm  *pCell = pStart->GetUpper(); | 
					
						
							|  |  |  |         while ( !pCell->IsCellFrm() ) | 
					
						
							|  |  |  |             pCell = pCell->GetUpper(); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         //
 | 
					
						
							|  |  |  |         // Check, if cell has a Prev/Follow cell:
 | 
					
						
							|  |  |  |         //
 | 
					
						
							|  |  |  |         const bool bFwd = ( fnNxtPrv == lcl_GetNxtCnt ); | 
					
						
							|  |  |  |         const SwLayoutFrm* pTmpCell = bFwd ? | 
					
						
							|  |  |  |             ((SwCellFrm*)pCell)->GetFollowCell() : | 
					
						
							|  |  |  |             ((SwCellFrm*)pCell)->GetPreviousCell(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const SwCntntFrm* pTmpStart = pStart; | 
					
						
							|  |  |  |         while ( pTmpCell && ( pTmpStart = pTmpCell->ContainsCntnt() ) ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             pCell = pTmpCell; | 
					
						
							|  |  |  |             pTmpCell = bFwd ? | 
					
						
							|  |  |  |                 ((SwCellFrm*)pCell)->GetFollowCell() : | 
					
						
							|  |  |  |                 ((SwCellFrm*)pCell)->GetPreviousCell(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         const SwCntntFrm *pNxt = pCnt = pTmpStart; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         while ( pCell->IsAnLower( pNxt ) ) | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |         { | 
					
						
							|  |  |  |             pCnt = pNxt; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             pNxt = (*fnNxtPrv)( pNxt ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pCnt = (*fnNxtPrv)( pCnt ? pCnt : pStart ); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |     pCnt = ::lcl_MissProtectedFrames( pCnt, fnNxtPrv, TRUE, bInReadOnly, bTblSel ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwTabFrm *pStTab = pStart->FindTabFrm(); | 
					
						
							|  |  |  |     const SwTabFrm *pTable; | 
					
						
							|  |  |  |     const BOOL bTab = pStTab || (pCnt && pCnt->IsInTab()) ? TRUE : FALSE; | 
					
						
							|  |  |  |     BOOL bEnd = bTab ? FALSE : TRUE; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-21 08:56:56 +00:00
										 |  |  |     const SwFrm* pVertRefFrm = pStart; | 
					
						
							|  |  |  |     if ( bTblSel && pStTab ) | 
					
						
							|  |  |  |         pVertRefFrm = pStTab; | 
					
						
							|  |  |  |     SWRECTFN( pVertRefFrm ) | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     SwTwips nX; | 
					
						
							|  |  |  |     if ( bTab ) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         //
 | 
					
						
							|  |  |  |         // pStart or pCnt is inside a table. nX will be used for travelling:
 | 
					
						
							|  |  |  |         //
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         SwRect aRect( pStart->Frm() ); | 
					
						
							|  |  |  |         pStart->GetCharRect( aRect, *pPam->GetPoint() ); | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  |         Point aCenter = aRect.Center(); | 
					
						
							|  |  |  |         nX = bVert ? aCenter.Y() : aCenter.X(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         pTable = pCnt ? pCnt->FindTabFrm() : 0; | 
					
						
							|  |  |  |         if ( !pTable ) | 
					
						
							|  |  |  |             pTable = pStTab; | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         if ( pStTab && | 
					
						
							|  |  |  |             !pStTab->GetUpper()->IsInTab() && | 
					
						
							|  |  |  |             !pTable->GetUpper()->IsInTab() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         { | 
					
						
							|  |  |  |             const SwFrm *pCell = pStart->GetUpper(); | 
					
						
							|  |  |  |             while ( pCell && !pCell->IsCellFrm() ) | 
					
						
							|  |  |  |                 pCell = pCell->GetUpper(); | 
					
						
							|  |  |  |             ASSERT( pCell, "Zelle nicht gefunden." ); | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  |             nX =  (pCell->Frm().*fnRect->fnGetLeft)() + | 
					
						
							|  |  |  |                   (pCell->Frm().*fnRect->fnGetWidth)() / 2; | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             //Der Fluss fuehrt von einer Tabelle in die nachste. Der X-Wert
 | 
					
						
							|  |  |  |             //muss ausgehend von der Mitte der Startzelle um die Verschiebung
 | 
					
						
							|  |  |  |             //der Tabellen korrigiert werden.
 | 
					
						
							|  |  |  |             if ( pStTab != pTable ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 nX += (pTable->Frm().*fnRect->fnGetLeft)() - | 
					
						
							|  |  |  |                       (pStTab->Frm().*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |         //
 | 
					
						
							|  |  |  |         // Restrict nX to the left and right borders of pTab:
 | 
					
						
							|  |  |  |         // (is this really necessary?)
 | 
					
						
							|  |  |  |         //
 | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         if ( !pTable->GetUpper()->IsInTab() ) | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |             const sal_Bool bRTL = pTable->IsRightToLeft(); | 
					
						
							|  |  |  |             const long nPrtLeft = bRTL ? | 
					
						
							|  |  |  |                                 (pTable->*fnRect->fnGetPrtRight)() : | 
					
						
							|  |  |  |                                 (pTable->*fnRect->fnGetPrtLeft)(); | 
					
						
							|  |  |  |             if ( bRTL != nX < nPrtLeft ) | 
					
						
							|  |  |  |                 nX = nPrtLeft; | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                    const long nPrtRight = bRTL ? | 
					
						
							|  |  |  |                                     (pTable->*fnRect->fnGetPrtLeft)() : | 
					
						
							|  |  |  |                                     (pTable->*fnRect->fnGetPrtRight)(); | 
					
						
							|  |  |  |                 if ( bRTL != nX > nPrtRight ) | 
					
						
							|  |  |  |                     nX = nPrtRight; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     do | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         //Wenn ich im DokumentBody bin, so will ich da auch bleiben
 | 
					
						
							|  |  |  |         if ( pStart->IsInDocBody() ) | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             while ( pCnt && (!pCnt->IsInDocBody() || | 
					
						
							|  |  |  |                              (pCnt->IsTxtFrm() && ((SwTxtFrm*)pCnt)->IsHiddenNow()))) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 pCnt = (*fnNxtPrv)( pCnt ); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                 pCnt = ::lcl_MissProtectedFrames( pCnt, fnNxtPrv, TRUE, bInReadOnly, bTblSel ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         //Wenn ich im Fussnotenbereich bin, so versuche ich notfalls den naechsten
 | 
					
						
							|  |  |  |         //Fussnotenbereich zu erreichen.
 | 
					
						
							|  |  |  |         else if ( pStart->IsInFtn() ) | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             while ( pCnt && !pCnt->IsInFtn() ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 pCnt = (*fnNxtPrv)( pCnt ); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                 pCnt = ::lcl_MissProtectedFrames( pCnt, fnNxtPrv, TRUE, bInReadOnly, bTblSel ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         //In Flys kann es Blind weitergehen solange ein Cntnt
 | 
					
						
							|  |  |  |         //gefunden wird.
 | 
					
						
							|  |  |  |         else if ( pStart->IsInFly() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if ( pCnt && pCnt->IsTxtFrm() && ((SwTxtFrm*)pCnt)->IsHiddenNow() ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 pCnt = (*fnNxtPrv)( pCnt ); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                 pCnt = ::lcl_MissProtectedFrames( pCnt, fnNxtPrv, TRUE, bInReadOnly, bTblSel ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Andernfalls weigere ich mich einfach den derzeitigen Bereich zu
 | 
					
						
							|  |  |  |         //verlassen.
 | 
					
						
							|  |  |  |         else if ( pCnt ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwFrm *pUp = pStart->GetUpper();               //Head/Foot
 | 
					
						
							|  |  |  |             while ( pUp && pUp->GetUpper() && !(pUp->GetType() & 0x0018 ) ) | 
					
						
							|  |  |  |                 pUp = pUp->GetUpper(); | 
					
						
							|  |  |  |             BOOL bSame = FALSE; | 
					
						
							|  |  |  |             const SwFrm *pCntUp = pCnt->GetUpper(); | 
					
						
							|  |  |  |             while ( pCntUp && !bSame ) | 
					
						
							|  |  |  |             {   if ( pUp == pCntUp ) | 
					
						
							|  |  |  |                     bSame = TRUE; | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                     pCntUp = pCntUp->GetUpper(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if ( !bSame ) | 
					
						
							|  |  |  |                 pCnt = 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ( bTab ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if ( !pCnt ) | 
					
						
							|  |  |  |                 bEnd = TRUE; | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             {   const SwTabFrm *pTab = pCnt->FindTabFrm(); | 
					
						
							|  |  |  |                 if( !pTab ) | 
					
						
							|  |  |  |                     bEnd = TRUE; | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     if ( pTab != pTable ) | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |                     { | 
					
						
							|  |  |  |                         //Der Fluss fuehrt von einer Tabelle in die nachste. Der
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         //X-Wert muss um die Verschiebung der Tabellen korrigiert
 | 
					
						
							|  |  |  |                         //werden.
 | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |                          if ( pTable && | 
					
						
							|  |  |  |                               !pTab->GetUpper()->IsInTab() && | 
					
						
							|  |  |  |                             !pTable->GetUpper()->IsInTab() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                             nX += pTab->Frm().Left() - pTable->Frm().Left(); | 
					
						
							|  |  |  |                         pTable = pTab; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |                     const SwLayoutFrm *pCell = pTable ? pCnt->GetUpper() : 0; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                     while ( pCell && !pCell->IsCellFrm() ) | 
					
						
							|  |  |  |                         pCell = pCell->GetUpper(); | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                     Point aInsideCell; | 
					
						
							|  |  |  |                     Point aInsideCnt; | 
					
						
							| 
									
										
										
										
											2002-09-26 12:47:44 +00:00
										 |  |  |                     if ( pCell ) | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  |                     { | 
					
						
							| 
									
										
										
										
											2002-09-26 12:47:44 +00:00
										 |  |  |                         long nTmpTop = (pCell->Frm().*fnRect->fnGetTop)(); | 
					
						
							|  |  |  |                         if ( bVert ) | 
					
						
							|  |  |  |                         { | 
					
						
							| 
									
										
										
										
											2002-09-27 05:59:38 +00:00
										 |  |  |                             if ( nTmpTop ) | 
					
						
							|  |  |  |                                 --nTmpTop; | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-09-27 05:59:38 +00:00
										 |  |  |                             aInsideCell = Point( nTmpTop, nX ); | 
					
						
							| 
									
										
										
										
											2002-09-26 12:47:44 +00:00
										 |  |  |                         } | 
					
						
							|  |  |  |                         else | 
					
						
							| 
									
										
										
										
											2002-09-27 05:59:38 +00:00
										 |  |  |                             aInsideCell = Point( nX, nTmpTop ); | 
					
						
							| 
									
										
										
										
											2002-09-26 12:47:44 +00:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-09-26 12:47:44 +00:00
										 |  |  |                     long nTmpTop = (pCnt->Frm().*fnRect->fnGetTop)(); | 
					
						
							|  |  |  |                     if ( bVert ) | 
					
						
							|  |  |  |                     { | 
					
						
							| 
									
										
										
										
											2002-09-27 05:59:38 +00:00
										 |  |  |                         if ( nTmpTop ) | 
					
						
							|  |  |  |                             --nTmpTop; | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-09-27 05:59:38 +00:00
										 |  |  |                         aInsideCnt = Point( nTmpTop, nX ); | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  |                     } | 
					
						
							|  |  |  |                     else | 
					
						
							| 
									
										
										
										
											2002-09-27 05:59:38 +00:00
										 |  |  |                         aInsideCnt = Point( nX, nTmpTop ); | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                     if ( pCell && pCell->Frm().IsInside( aInsideCell ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                     { | 
					
						
							|  |  |  |                         bEnd = TRUE; | 
					
						
							|  |  |  |                         //Jetzt noch schnell den richtigen Cntnt in der Zelle
 | 
					
						
							|  |  |  |                         //greifen.
 | 
					
						
							| 
									
										
										
										
											2004-06-01 06:44:35 +00:00
										 |  |  |                         if ( !pCnt->Frm().IsInside( aInsideCnt ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         { | 
					
						
							|  |  |  |                             pCnt = pCell->ContainsCntnt(); | 
					
						
							|  |  |  |                             if ( fnNxtPrv == lcl_GetPrvCnt ) | 
					
						
							|  |  |  |                                 while ( pCell->IsAnLower(pCnt->GetNextCntntFrm()) ) | 
					
						
							|  |  |  |                                     pCnt = pCnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2002-09-26 12:17:23 +00:00
										 |  |  |                     else if ( pCnt->Frm().IsInside( aInsideCnt ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         bEnd = TRUE; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if ( !bEnd ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 pCnt = (*fnNxtPrv)( pCnt ); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                 pCnt = ::lcl_MissProtectedFrames( pCnt, fnNxtPrv, TRUE, bInReadOnly, bTblSel ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } while ( !bEnd || | 
					
						
							|  |  |  |               (pCnt && pCnt->IsTxtFrm() && ((SwTxtFrm*)pCnt)->IsHiddenNow())); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if( pCnt ) | 
					
						
							|  |  |  |     {   // setze den Point auf den Content-Node
 | 
					
						
							|  |  |  |         SwCntntNode *pCNd = (SwCntntNode*)pCnt->GetNode(); | 
					
						
							|  |  |  |         pPam->GetPoint()->nNode = *pCNd; | 
					
						
							|  |  |  |         if ( fnNxtPrv == lcl_GetPrvCnt ) | 
					
						
							|  |  |  |             pCNd->MakeEndIndex( (SwIndex*)&pPam->GetPoint()->nContent ); | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |             pCNd->MakeStartIndex( (SwIndex*)&pPam->GetPoint()->nContent ); | 
					
						
							|  |  |  |         return TRUE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL SwCntntFrm::UnitUp( SwPaM* pPam, const SwTwips, BOOL bInReadOnly ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return ::lcl_UpDown( pPam, this, lcl_GetPrvCnt, bInReadOnly ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL SwCntntFrm::UnitDown( SwPaM* pPam, const SwTwips, BOOL bInReadOnly ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return ::lcl_UpDown( pPam, this, lcl_GetNxtCnt, bInReadOnly ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwRootFrm::GetCurrPage() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung:       Liefert die Nummer der aktuellen Seite. | 
					
						
							|  |  |  | |*          Wenn die Methode einen PaM bekommt, so ist die aktuelle Seite | 
					
						
							|  |  |  | |*          diejenige in der der PaM sitzt. Anderfalls ist die aktuelle | 
					
						
							|  |  |  | |*          Seite die erste Seite innerhalb der VisibleArea. | 
					
						
							|  |  |  | |*          Es wird nur auf den vorhandenen Seiten gearbeitet! | 
					
						
							|  |  |  | |*  Ersterstellung      MA 20. May. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 09. Oct. 97 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | USHORT SwRootFrm::GetCurrPage( const SwPaM *pActualCrsr ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT( pActualCrsr, "Welche Seite soll's denn sein?" ); | 
					
						
							|  |  |  |     const SwFrm *pActFrm = GetFmt()->GetDoc()->GetNodes()[pActualCrsr->GetPoint()->nNode]-> | 
					
						
							|  |  |  |                                     GetCntntNode()->GetFrm( 0, | 
					
						
							|  |  |  |                                                     pActualCrsr->GetPoint(), | 
					
						
							|  |  |  |                                                     FALSE ); | 
					
						
							|  |  |  |     return pActFrm->FindPageFrm()->GetPhyPageNum(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwRootFrm::SetCurrPage() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung:       Liefert einen PaM der am Anfang der gewuenschten | 
					
						
							|  |  |  | |*          Seite sitzt. | 
					
						
							|  |  |  | |*          Formatiert wird soweit notwendig | 
					
						
							|  |  |  | |*          Liefert Null, wenn die Operation nicht moeglich ist. | 
					
						
							|  |  |  | |*          Der PaM sitzt in der letzten Seite, wenn die Seitenzahl zu gross | 
					
						
							|  |  |  | |*          gewaehlt wurde. | 
					
						
							|  |  |  | |*  Ersterstellung      MA 20. May. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 09. Oct. 97 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | USHORT SwRootFrm::SetCurrPage( SwCursor* pToSet, USHORT nPageNum ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT( Lower() && Lower()->IsPageFrm(), "Keine Seite vorhanden." ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     SwPageFrm *pPage = (SwPageFrm*)Lower(); | 
					
						
							|  |  |  |     BOOL bEnd =FALSE; | 
					
						
							|  |  |  |     while ( !bEnd && pPage->GetPhyPageNum() != nPageNum ) | 
					
						
							|  |  |  |     {   if ( pPage->GetNext() ) | 
					
						
							|  |  |  |             pPage = (SwPageFrm*)pPage->GetNext(); | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         {   //Ersten CntntFrm Suchen, und solange Formatieren bis
 | 
					
						
							|  |  |  |             //eine neue Seite angefangen wird oder bis die CntntFrm's alle
 | 
					
						
							|  |  |  |             //sind.
 | 
					
						
							|  |  |  |             const SwCntntFrm *pCntnt = pPage->ContainsCntnt(); | 
					
						
							|  |  |  |             while ( pCntnt && pPage->IsAnLower( pCntnt ) ) | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |             { | 
					
						
							|  |  |  |                 pCntnt->Calc(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             //Jetzt ist entweder eine neue Seite da, oder die letzte Seite
 | 
					
						
							|  |  |  |             //ist gefunden.
 | 
					
						
							|  |  |  |             if ( pPage->GetNext() ) | 
					
						
							|  |  |  |                 pPage = (SwPageFrm*)pPage->GetNext(); | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |                 bEnd = TRUE; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     //pPage zeigt jetzt auf die 'gewuenschte' Seite. Jetzt muss noch der
 | 
					
						
							|  |  |  |     //PaM auf den Anfang des ersten CntntFrm im Body-Text erzeugt werden.
 | 
					
						
							|  |  |  |     //Wenn es sich um eine Fussnotenseite handelt, wird der PaM in die erste
 | 
					
						
							|  |  |  |     //Fussnote gesetzt.
 | 
					
						
							|  |  |  |     const SwCntntFrm *pCntnt = pPage->ContainsCntnt(); | 
					
						
							|  |  |  |     if ( pPage->IsFtnPage() ) | 
					
						
							|  |  |  |         while ( pCntnt && !pCntnt->IsInFtn() ) | 
					
						
							|  |  |  |             pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |         while ( pCntnt && !pCntnt->IsInDocBody() ) | 
					
						
							|  |  |  |             pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |     if ( pCntnt ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SwCntntNode* pCNd = (SwCntntNode*)pCntnt->GetNode(); | 
					
						
							|  |  |  |         pToSet->GetPoint()->nNode = *pCNd; | 
					
						
							|  |  |  |         pCNd->MakeStartIndex( (SwIndex*)&pToSet->GetPoint()->nContent ); | 
					
						
							|  |  |  |         pToSet->GetPoint()->nContent = ((SwTxtFrm*)pCntnt)->GetOfst(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         SwShellCrsr* pSCrsr = (SwShellCrsr*)*pToSet; | 
					
						
							|  |  |  |         if( pSCrsr ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             Point &rPt = pSCrsr->GetPtPos(); | 
					
						
							|  |  |  |             rPt = pCntnt->Frm().Pos(); | 
					
						
							|  |  |  |             rPt += pCntnt->Prt().Pos(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return pPage->GetPhyPageNum(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    SwCntntFrm::StartxxPage(), EndxxPage() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    Beschreibung      Cursor an Anfang/Ende der aktuellen/vorherigen/ | 
					
						
							|  |  |  | |*      naechsten Seite. Alle sechs Methoden rufen GetFrmInPage() mit der | 
					
						
							|  |  |  | |*      entsprechenden Parametrisierung. | 
					
						
							|  |  |  | |*      Zwei Parameter steuern die Richtung: einer bestimmt die Seite, der | 
					
						
							|  |  |  | |*      andere Anfang/Ende. | 
					
						
							|  |  |  | |*      Fuer die Bestimmung der Seite und des Cntnt (Anfang/Ende) werden | 
					
						
							|  |  |  | |*      die im folgenden definierten Funktionen benutzt. | 
					
						
							|  |  |  | |*    Ersterstellung    MA 15. Oct. 92 | 
					
						
							|  |  |  | |*    Letzte Aenderung  MA 28. Feb. 93 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | SwCntntFrm *GetFirstSub( const SwLayoutFrm *pLayout ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return ((SwPageFrm*)pLayout)->FindFirstBodyCntnt(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SwCntntFrm *GetLastSub( const SwLayoutFrm *pLayout ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return ((SwPageFrm*)pLayout)->FindLastBodyCntnt(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SwLayoutFrm *GetNextFrm( const SwLayoutFrm *pFrm ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-01-28 14:27:06 +00:00
										 |  |  |     SwLayoutFrm *pNext = | 
					
						
							|  |  |  |         (pFrm->GetNext() && pFrm->GetNext()->IsLayoutFrm()) ? | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                                             (SwLayoutFrm*)pFrm->GetNext() : 0; | 
					
						
							| 
									
										
										
										
											2005-01-28 14:27:06 +00:00
										 |  |  |     // #i39402# in case of an empty page
 | 
					
						
							|  |  |  |     if(pNext && !pNext->ContainsCntnt()) | 
					
						
							|  |  |  |         pNext = (pNext->GetNext() && pNext->GetNext()->IsLayoutFrm()) ? | 
					
						
							|  |  |  |                                             (SwLayoutFrm*)pNext->GetNext() : 0; | 
					
						
							|  |  |  |     return pNext; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SwLayoutFrm *GetThisFrm( const SwLayoutFrm *pFrm ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return (SwLayoutFrm*)pFrm; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SwLayoutFrm *GetPrevFrm( const SwLayoutFrm *pFrm ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-01-28 14:27:06 +00:00
										 |  |  |     SwLayoutFrm *pPrev = | 
					
						
							|  |  |  |         (pFrm->GetPrev() && pFrm->GetPrev()->IsLayoutFrm()) ? | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                                             (SwLayoutFrm*)pFrm->GetPrev() : 0; | 
					
						
							| 
									
										
										
										
											2005-01-28 14:27:06 +00:00
										 |  |  |     // #i39402# in case of an empty page
 | 
					
						
							|  |  |  |     if(pPrev && !pPrev->ContainsCntnt()) | 
					
						
							|  |  |  |         pPrev = (pPrev->GetPrev() && pPrev->GetPrev()->IsLayoutFrm()) ? | 
					
						
							|  |  |  |                                             (SwLayoutFrm*)pPrev->GetPrev() : 0; | 
					
						
							|  |  |  |     return pPrev; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //Jetzt koennen auch die Funktionspointer initalisiert werden;
 | 
					
						
							|  |  |  | //sie sind in cshtyp.hxx declariert.
 | 
					
						
							|  |  |  | SwPosPage fnPageStart = GetFirstSub; | 
					
						
							|  |  |  | SwPosPage fnPageEnd = GetLastSub; | 
					
						
							|  |  |  | SwWhichPage fnPagePrev = GetPrevFrm; | 
					
						
							|  |  |  | SwWhichPage fnPageCurr = GetThisFrm; | 
					
						
							|  |  |  | SwWhichPage fnPageNext = GetNextFrm; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //Liefert den ersten/den letzten Contentframe (gesteuert ueber
 | 
					
						
							|  |  |  | //den Parameter fnPosPage) in der
 | 
					
						
							|  |  |  | //aktuellen/vorhergehenden/folgenden Seite (gesteuert durch den
 | 
					
						
							|  |  |  | //Parameter fnWhichPage).
 | 
					
						
							|  |  |  | BOOL GetFrmInPage( const SwCntntFrm *pCnt, SwWhichPage fnWhichPage, | 
					
						
							|  |  |  |                    SwPosPage fnPosPage, SwPaM *pPam ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     //Erstmal die gewuenschte Seite besorgen, anfangs die aktuelle, dann
 | 
					
						
							|  |  |  |     //die die per fnWichPage gewuenscht wurde
 | 
					
						
							|  |  |  |     const SwLayoutFrm *pLayoutFrm = pCnt->FindPageFrm(); | 
					
						
							|  |  |  |     if ( !pLayoutFrm || (0 == (pLayoutFrm = (*fnWhichPage)(pLayoutFrm))) ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Jetzt den gewuenschen CntntFrm unterhalb der Seite
 | 
					
						
							|  |  |  |     if( 0 == (pCnt = (*fnPosPage)(pLayoutFrm)) ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |         // repeated headlines in tables
 | 
					
						
							|  |  |  |         if ( pCnt->IsInTab() && fnPosPage == GetFirstSub ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwTabFrm* pTab = pCnt->FindTabFrm(); | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |             if ( pTab->IsFollow() ) | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |                 if ( pTab->IsInHeadline( *pCnt ) ) | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 { | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |                     SwLayoutFrm* pRow = pTab->GetFirstNonHeadlineRow(); | 
					
						
							|  |  |  |                     if ( pRow ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         // We are in the first line of a follow table
 | 
					
						
							|  |  |  |                         // with repeated headings.
 | 
					
						
							|  |  |  |                         // To actually make a "real" move we take the first content
 | 
					
						
							|  |  |  |                         // of the next row
 | 
					
						
							|  |  |  |                         pCnt = pRow->ContainsCntnt(); | 
					
						
							|  |  |  |                         if ( ! pCnt ) | 
					
						
							|  |  |  |                             return FALSE; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         SwCntntNode *pCNd = (SwCntntNode*)pCnt->GetNode(); | 
					
						
							|  |  |  |         pPam->GetPoint()->nNode = *pCNd; | 
					
						
							|  |  |  |         xub_StrLen nIdx; | 
					
						
							|  |  |  |         if( fnPosPage == GetFirstSub ) | 
					
						
							|  |  |  |             nIdx = ((SwTxtFrm*)pCnt)->GetOfst(); | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |             nIdx = pCnt->GetFollow() ? | 
					
						
							|  |  |  |                     ((SwTxtFrm*)pCnt)->GetFollow()->GetOfst()-1 : pCNd->Len(); | 
					
						
							|  |  |  |         pPam->GetPoint()->nContent.Assign( pCNd, nIdx ); | 
					
						
							|  |  |  |         return TRUE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwLayoutFrm::GetCntntPos() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung        Es wird der nachstliegende Cntnt zum uebergebenen | 
					
						
							|  |  |  | |*                      gesucht. Betrachtet werden die vorhergehende, die | 
					
						
							|  |  |  | |*                      aktuelle und die folgende Seite. | 
					
						
							|  |  |  | |*                      Wenn kein Inhalt gefunden wird, so wird der Bereich | 
					
						
							|  |  |  |  *                      erweitert bis einer gefunden wird. | 
					
						
							|  |  |  | |*                      Zurueckgegeben wird die 'Semantisch richtige' Position | 
					
						
							|  |  |  | |*                      innerhalb der PrtArea des gefundenen CntntFrm | 
					
						
							|  |  |  | |*  Ersterstellung      MA 15. Jul. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 09. Jan. 97 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | ULONG CalcDiff( const Point &rPt1, const Point &rPt2 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     //Jetzt die Entfernung zwischen den beiden Punkten berechnen.
 | 
					
						
							|  |  |  |     //'Delta' X^2 + 'Delta'Y^2 = 'Entfernung'^2
 | 
					
						
							|  |  |  |     ULONG dX = Max( rPt1.X(), rPt2.X() ) - | 
					
						
							|  |  |  |                Min( rPt1.X(), rPt2.X() ), | 
					
						
							|  |  |  |           dY = Max( rPt1.Y(), rPt2.Y() ) - | 
					
						
							|  |  |  |                Min( rPt1.Y(), rPt2.Y() ); | 
					
						
							|  |  |  |     BigInt dX1( dX ), dY1( dY ); | 
					
						
							|  |  |  |     dX1 *= dX1; dY1 *= dY1; | 
					
						
							|  |  |  |     return ::SqRt( dX1 + dY1 ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // lcl_Inside ueberprueft, ob der Punkt innerhalb des Seitenteils liegt, in dem
 | 
					
						
							|  |  |  | // auch der CntntFrame liegt. Als Seitenteile gelten in diesem Zusammenhang
 | 
					
						
							|  |  |  | // Kopfzeile, Seitenbody, Fusszeile und FussnotenContainer.
 | 
					
						
							|  |  |  | // Dies dient dazu, dass ein CntntFrm, der im "richtigen" Seitenteil liegt,
 | 
					
						
							|  |  |  | // eher akzeptiert wird als ein anderer, der nicht dort liegt, auch wenn
 | 
					
						
							|  |  |  | // dessen Abstand zum Punkt geringer ist.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const SwLayoutFrm* lcl_Inside( const SwCntntFrm *pCnt, Point& rPt ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const SwLayoutFrm* pUp = pCnt->GetUpper(); | 
					
						
							|  |  |  |     while( pUp ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if( pUp->IsPageBodyFrm() || pUp->IsFooterFrm() || pUp->IsHeaderFrm() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if( rPt.Y() >= pUp->Frm().Top() && rPt.Y() <= pUp->Frm().Bottom() ) | 
					
						
							|  |  |  |                 return pUp; | 
					
						
							|  |  |  |             return NULL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if( pUp->IsFtnContFrm() ) | 
					
						
							|  |  |  |             return pUp->Frm().IsInside( rPt ) ? pUp : NULL; | 
					
						
							|  |  |  |         pUp = pUp->GetUpper(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //Fuer MSC keine Optimierung mit e (enable register...) hier, sonst gibts
 | 
					
						
							|  |  |  | //einen Bug (ID: 2857)
 | 
					
						
							|  |  |  | #pragma optimize("e",off)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const SwCntntFrm *SwLayoutFrm::GetCntntPos( Point& rPoint, | 
					
						
							|  |  |  |                                             const BOOL bDontLeave, | 
					
						
							|  |  |  |                                             const BOOL bBodyOnly, | 
					
						
							|  |  |  |                                             const BOOL bCalc, | 
					
						
							|  |  |  |                                             const SwCrsrMoveState *pCMS, | 
					
						
							|  |  |  |                                             const BOOL bDefaultExpand ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     //Ersten CntntFrm ermitteln.
 | 
					
						
							|  |  |  |     const SwLayoutFrm *pStart = (!bDontLeave && bDefaultExpand && GetPrev()) ? | 
					
						
							|  |  |  |                                     (SwLayoutFrm*)GetPrev() : this; | 
					
						
							|  |  |  |     const SwCntntFrm *pCntnt = pStart->ContainsCntnt(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( !pCntnt && (GetPrev() && !bDontLeave) ) | 
					
						
							|  |  |  |         pCntnt = ContainsCntnt(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( bBodyOnly && pCntnt && !pCntnt->IsInDocBody() ) | 
					
						
							|  |  |  |         while ( pCntnt && !pCntnt->IsInDocBody() ) | 
					
						
							|  |  |  |             pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwCntntFrm *pActual= pCntnt; | 
					
						
							|  |  |  |     const SwLayoutFrm *pInside = NULL; | 
					
						
							|  |  |  |     USHORT nMaxPage = GetPhyPageNum() + (bDefaultExpand ? 1 : 0); | 
					
						
							|  |  |  |     Point aPoint = rPoint; | 
					
						
							|  |  |  |     ULONG nDistance = ULONG_MAX; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while ( TRUE )  //Sicherheitsschleifchen, damit immer einer gefunden wird.
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         while ( pCntnt && | 
					
						
							|  |  |  |                 ((!bDontLeave || IsAnLower( pCntnt )) && | 
					
						
							|  |  |  |                 (pCntnt->GetPhyPageNum() <= nMaxPage)) ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if ( ( bCalc || pCntnt->Frm().Width() ) && | 
					
						
							|  |  |  |                  ( !bBodyOnly || pCntnt->IsInDocBody() ) ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 //Wenn der Cntnt in einem geschuetzen Bereich (Zelle, Ftn, Section)
 | 
					
						
							|  |  |  |                 //liegt, wird der nachste Cntnt der nicht geschuetzt ist gesucht.
 | 
					
						
							|  |  |  |                 const SwCntntFrm *pComp = pCntnt; | 
					
						
							|  |  |  |                 pCntnt = ::lcl_MissProtectedFrames( pCntnt, lcl_GetNxtCnt, FALSE, | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                                         pCMS ? pCMS->bSetInReadOnly : FALSE, FALSE ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 if ( pComp != pCntnt ) | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if ( !pCntnt->IsTxtFrm() || !((SwTxtFrm*)pCntnt)->IsHiddenNow() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     if ( bCalc ) | 
					
						
							|  |  |  |                         pCntnt->Calc(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     SwRect aCntFrm( pCntnt->UnionFrm() ); | 
					
						
							|  |  |  |                     if ( aCntFrm.IsInside( rPoint ) ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         pActual = pCntnt; | 
					
						
							|  |  |  |                         aPoint = rPoint; | 
					
						
							|  |  |  |                         break; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     //Die Strecke von rPoint zum dichtesten Punkt von pCntnt wird
 | 
					
						
							|  |  |  |                     //jetzt berechnet.
 | 
					
						
							|  |  |  |                     Point aCntntPoint( rPoint ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     //Erst die Vertikale Position einstellen
 | 
					
						
							|  |  |  |                     if ( aCntFrm.Top() > aCntntPoint.Y() ) | 
					
						
							|  |  |  |                         aCntntPoint.Y() = aCntFrm.Top(); | 
					
						
							|  |  |  |                     else if ( aCntFrm.Bottom() < aCntntPoint.Y() ) | 
					
						
							|  |  |  |                         aCntntPoint.Y() = aCntFrm.Bottom(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     //Jetzt die Horizontale Position
 | 
					
						
							|  |  |  |                     if ( aCntFrm.Left() > aCntntPoint.X() ) | 
					
						
							|  |  |  |                         aCntntPoint.X() = aCntFrm.Left(); | 
					
						
							|  |  |  |                     else if ( aCntFrm.Right() < aCntntPoint.X() ) | 
					
						
							|  |  |  |                         aCntntPoint.X() = aCntFrm.Right(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     // pInside ist ein Seitenbereich, in dem der Punkt liegt,
 | 
					
						
							|  |  |  |                     // sobald pInside!=0 ist, werden nur noch Frames akzeptiert,
 | 
					
						
							|  |  |  |                     // die innerhalb liegen.
 | 
					
						
							|  |  |  |                     if( !pInside || ( pInside->IsAnLower( pCntnt ) && | 
					
						
							|  |  |  |                         ( !pCntnt->IsInFtn() || pInside->IsFtnContFrm() ) ) ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         const ULONG nDiff = ::CalcDiff( aCntntPoint, rPoint ); | 
					
						
							|  |  |  |                         BOOL bBetter = nDiff < nDistance;  // Dichter dran
 | 
					
						
							|  |  |  |                         if( !pInside ) | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             pInside = lcl_Inside( pCntnt, rPoint ); | 
					
						
							|  |  |  |                             if( pInside )  // Im "richtigen" Seitenteil
 | 
					
						
							|  |  |  |                                 bBetter = TRUE; | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         if( bBetter ) | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             aPoint = aCntntPoint; | 
					
						
							|  |  |  |                             nDistance = nDiff; | 
					
						
							|  |  |  |                             pActual = pCntnt; | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |             if ( bBodyOnly ) | 
					
						
							|  |  |  |                 while ( pCntnt && !pCntnt->IsInDocBody() ) | 
					
						
							|  |  |  |                     pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ( !pActual ) | 
					
						
							|  |  |  |         {   //Wenn noch keiner gefunden wurde muss der Suchbereich erweitert
 | 
					
						
							|  |  |  |             //werden, irgenwann muessen wir einen Finden!
 | 
					
						
							|  |  |  |             //MA 09. Jan. 97: Opt fuer viele leere Seiten, wenn wir nur im
 | 
					
						
							|  |  |  |             //Body suchen, koennen wir den Suchbereich gleich in einem
 | 
					
						
							|  |  |  |             //Schritt hinreichend erweitern.
 | 
					
						
							|  |  |  |             if ( bBodyOnly ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 while ( !pCntnt && pStart->GetPrev() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     ++nMaxPage; | 
					
						
							|  |  |  |                     if( !pStart->GetPrev()->IsLayoutFrm() ) | 
					
						
							|  |  |  |                         return 0; | 
					
						
							|  |  |  |                     pStart = (SwLayoutFrm*)pStart->GetPrev(); | 
					
						
							|  |  |  |                     pCntnt = pStart->IsInDocBody() | 
					
						
							|  |  |  |                                 ? pStart->ContainsCntnt() | 
					
						
							|  |  |  |                                 : pStart->FindPageFrm()->FindFirstBodyCntnt(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if ( !pCntnt )  //irgendwann muessen wir mit irgendeinem Anfangen!
 | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     pCntnt = pStart->FindPageFrm()->GetUpper()->ContainsCntnt(); | 
					
						
							|  |  |  |                     while ( pCntnt && !pCntnt->IsInDocBody() ) | 
					
						
							|  |  |  |                         pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |                     if ( !pCntnt ) | 
					
						
							|  |  |  |                         return 0;   //Es gibt noch keine Dokumentinhalt!
 | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 ++nMaxPage; | 
					
						
							|  |  |  |                 if ( pStart->GetPrev() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     if( !pStart->GetPrev()->IsLayoutFrm() ) | 
					
						
							|  |  |  |                         return 0; | 
					
						
							|  |  |  |                     pStart = (SwLayoutFrm*)pStart->GetPrev(); | 
					
						
							|  |  |  |                     pCntnt = pStart->ContainsCntnt(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else //irgendwann muessen wir mit irgendeinem Anfangen!
 | 
					
						
							|  |  |  |                     pCntnt = pStart->FindPageFrm()->GetUpper()->ContainsCntnt(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             pActual = pCntnt; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef PRODUCT
 | 
					
						
							|  |  |  |     ASSERT( pActual, "Keinen Cntnt gefunden." ); | 
					
						
							|  |  |  |     if ( bBodyOnly ) | 
					
						
							|  |  |  |         ASSERT( pActual->IsInDocBody(), "Cnt nicht im Body." ); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Spezialfall fuer das selektieren von Tabellen, nicht in wiederholte
 | 
					
						
							|  |  |  |     //TblHedlines.
 | 
					
						
							|  |  |  |     if ( pActual->IsInTab() && pCMS && pCMS->eState == MV_TBLSEL ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         const SwTabFrm *pTab = pActual->FindTabFrm(); | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |         if ( pTab->IsFollow() && pTab->IsInHeadline( *pActual ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         { | 
					
						
							|  |  |  |             ((SwCrsrMoveState*)pCMS)->bStop = TRUE; | 
					
						
							|  |  |  |             return 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Jetzt noch eine kleine Korrektur beim ersten/letzten
 | 
					
						
							|  |  |  |     Size aActualSize( pActual->Prt().SSize() ); | 
					
						
							|  |  |  |     if ( aActualSize.Height() > pActual->GetUpper()->Prt().Height() ) | 
					
						
							|  |  |  |         aActualSize.Height() = pActual->GetUpper()->Prt().Height(); | 
					
						
							| 
									
										
										
										
											2002-11-15 14:58:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     SWRECTFN( pActual ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     if ( !pActual->GetPrev() && | 
					
						
							| 
									
										
										
										
											2002-11-15 14:58:53 +00:00
										 |  |  |          (*fnRect->fnYDiff)( (pActual->*fnRect->fnGetPrtTop)(), | 
					
						
							|  |  |  |                               bVert ? rPoint.X() : rPoint.Y() ) > 0 ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         aPoint.Y() = pActual->Frm().Top() + pActual->Prt().Top(); | 
					
						
							|  |  |  |         aPoint.X() = pActual->Frm().Left() + | 
					
						
							|  |  |  |                         ( pActual->IsRightToLeft() || bVert ? | 
					
						
							|  |  |  |                           pActual->Prt().Right() : | 
					
						
							|  |  |  |                           pActual->Prt().Left() ); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     else if ( !pActual->GetNext() && | 
					
						
							| 
									
										
										
										
											2002-11-15 14:58:53 +00:00
										 |  |  |               (*fnRect->fnYDiff)( (pActual->*fnRect->fnGetPrtBottom)(), | 
					
						
							|  |  |  |                                    bVert ? rPoint.X() : rPoint.Y() ) < 0 ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         aPoint.Y() = pActual->Frm().Top() + pActual->Prt().Bottom(); | 
					
						
							|  |  |  |         aPoint.X() = pActual->Frm().Left() + | 
					
						
							|  |  |  |                         ( pActual->IsRightToLeft() || bVert ? | 
					
						
							|  |  |  |                           pActual->Prt().Left() : | 
					
						
							|  |  |  |                           pActual->Prt().Right() ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2002-11-15 14:58:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     //Und den Point in die PrtArea bringen
 | 
					
						
							|  |  |  |     if ( bCalc ) | 
					
						
							|  |  |  |         pActual->Calc(); | 
					
						
							|  |  |  |     const SwRect aRect( pActual->Frm().Pos() + pActual->Prt().Pos(), | 
					
						
							|  |  |  |                         aActualSize ); | 
					
						
							|  |  |  |     if ( aPoint.Y() < aRect.Top() ) | 
					
						
							|  |  |  |         aPoint.Y() = aRect.Top(); | 
					
						
							|  |  |  |     else if ( aPoint.Y() > aRect.Bottom() ) | 
					
						
							|  |  |  |         aPoint.Y() = aRect.Bottom(); | 
					
						
							|  |  |  |     if ( aPoint.X() < aRect.Left() ) | 
					
						
							|  |  |  |         aPoint.X() = aRect.Left(); | 
					
						
							|  |  |  |     else if ( aPoint.X() > aRect.Right() ) | 
					
						
							|  |  |  |         aPoint.X() = aRect.Right(); | 
					
						
							|  |  |  |     rPoint = aPoint; | 
					
						
							|  |  |  |     return pActual; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma optimize("",on)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwPageFrm::GetCntntPosition() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung        Analog zu SwLayoutFrm::GetCntntPos(). | 
					
						
							|  |  |  | |*                      Spezialisiert fuer Felder in Rahmen. | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Ersterstellung      MA 22. Mar. 95 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 07. Nov. 95 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | void SwPageFrm::GetCntntPosition( const Point &rPt, SwPosition &rPos ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     //Ersten CntntFrm ermitteln.
 | 
					
						
							|  |  |  |     const SwCntntFrm *pCntnt = ContainsCntnt(); | 
					
						
							|  |  |  |     if ( pCntnt ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         //Einen weiter zurueck schauen (falls moeglich).
 | 
					
						
							|  |  |  |         const SwCntntFrm *pTmp = pCntnt->GetPrevCntntFrm(); | 
					
						
							|  |  |  |         while ( pTmp && !pTmp->IsInDocBody() ) | 
					
						
							|  |  |  |             pTmp = pTmp->GetPrevCntntFrm(); | 
					
						
							|  |  |  |         if ( pTmp ) | 
					
						
							|  |  |  |             pCntnt = pTmp; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |         pCntnt = GetUpper()->ContainsCntnt(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwCntntFrm *pAct = pCntnt; | 
					
						
							|  |  |  |     Point aAct       = rPt; | 
					
						
							|  |  |  |     ULONG nDist      = ULONG_MAX; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while ( pCntnt ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SwRect aCntFrm( pCntnt->UnionFrm() ); | 
					
						
							|  |  |  |         if ( aCntFrm.IsInside( rPt ) ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             //dichter gehts nimmer.
 | 
					
						
							|  |  |  |             pAct = pCntnt; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Die Strecke von rPt zum dichtesten Punkt von pCntnt berechnen.
 | 
					
						
							|  |  |  |         Point aPoint( rPt ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Erst die vertikale Position einstellen
 | 
					
						
							|  |  |  |         if ( aCntFrm.Top() > rPt.Y() ) | 
					
						
							|  |  |  |             aPoint.Y() = aCntFrm.Top(); | 
					
						
							|  |  |  |         else if ( aCntFrm.Bottom() < rPt.Y() ) | 
					
						
							|  |  |  |             aPoint.Y() = aCntFrm.Bottom(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Jetzt die horizontale Position
 | 
					
						
							|  |  |  |         if ( aCntFrm.Left() > rPt.X() ) | 
					
						
							|  |  |  |             aPoint.X() = aCntFrm.Left(); | 
					
						
							|  |  |  |         else if ( aCntFrm.Right() < rPt.X() ) | 
					
						
							|  |  |  |             aPoint.X() = aCntFrm.Right(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const ULONG nDiff = ::CalcDiff( aPoint, rPt ); | 
					
						
							|  |  |  |         if ( nDiff < nDist ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             aAct    = aPoint; | 
					
						
							|  |  |  |             nDist   = nDiff; | 
					
						
							|  |  |  |             pAct    = pCntnt; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else if ( aCntFrm.Top() > Frm().Bottom() ) | 
					
						
							|  |  |  |             //Dichter wirds im Sinne der Felder nicht mehr!
 | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |         while ( pCntnt && !pCntnt->IsInDocBody() ) | 
					
						
							|  |  |  |             pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Und den Point in die PrtArea bringen
 | 
					
						
							|  |  |  |     const SwRect aRect( pAct->Frm().Pos() + pAct->Prt().Pos(), pAct->Prt().SSize() ); | 
					
						
							|  |  |  |     if ( aAct.Y() < aRect.Top() ) | 
					
						
							|  |  |  |         aAct.Y() = aRect.Top(); | 
					
						
							|  |  |  |     else if ( aAct.Y() > aRect.Bottom() ) | 
					
						
							|  |  |  |         aAct.Y() = aRect.Bottom(); | 
					
						
							|  |  |  |     if ( aAct.X() < aRect.Left() ) | 
					
						
							|  |  |  |         aAct.X() = aRect.Left(); | 
					
						
							|  |  |  |     else if ( aAct.X() > aRect.Right() ) | 
					
						
							|  |  |  |         aAct.X() = aRect.Right(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if( !pAct->IsValid() ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // CntntFrm nicht formatiert -> immer auf Node-Anfang
 | 
					
						
							|  |  |  |         SwCntntNode* pCNd = (SwCntntNode*)pAct->GetNode(); | 
					
						
							|  |  |  |         ASSERT( pCNd, "Wo ist mein CntntNode?" ); | 
					
						
							|  |  |  |         rPos.nNode = *pCNd; | 
					
						
							|  |  |  |         rPos.nContent.Assign( pCNd, 0 ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SwCrsrMoveState aTmpState( MV_SETONLYTEXT ); | 
					
						
							|  |  |  |         pAct->GetCrsrOfst( &rPos, aAct, &aTmpState ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  | |*  SwRootFrm::GetNextPrevCntntPos() | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung        Es wird der naechstliegende Cntnt zum uebergebenen | 
					
						
							|  |  |  | |*                      Point gesucht. Es wird nur im BodyText gesucht. | 
					
						
							|  |  |  | |*  Ersterstellung      MA 15. Jul. 92 | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  | |*  Letzte Aenderung    JP 11.10.2001 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-08 10:04:45 +00:00
										 |  |  | // --> OD 2005-05-25 #123110# - helper class to disable creation of an action
 | 
					
						
							|  |  |  | // by a callback event - e.g., change event from a drawing object
 | 
					
						
							|  |  |  | class DisableCallbackAction | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         SwRootFrm& mrRootFrm; | 
					
						
							|  |  |  |         BOOL mbOldCallbackActionState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         DisableCallbackAction( const SwRootFrm& _rRootFrm ) : | 
					
						
							|  |  |  |             mrRootFrm( const_cast<SwRootFrm&>(_rRootFrm) ), | 
					
						
							|  |  |  |             mbOldCallbackActionState( _rRootFrm.IsCallbackActionEnabled() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             mrRootFrm.SetCallbackActionEnabled( FALSE ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ~DisableCallbackAction() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             mrRootFrm.SetCallbackActionEnabled( mbOldCallbackActionState ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | // <--
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | //!!!!! Es wird nur der vertikal naechstliegende gesucht.
 | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  | //JP 11.10.2001: only in tables we try to find the right column - Bug 72294
 | 
					
						
							|  |  |  | Point SwRootFrm::GetNextPrevCntntPos( const Point& rPoint, BOOL bNext ) const | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-08 10:04:45 +00:00
										 |  |  |     // --> OD 2005-05-25 #123110# - disable creation of an action by a callback
 | 
					
						
							|  |  |  |     // event during processing of this method. Needed because formatting is
 | 
					
						
							|  |  |  |     // triggered by this method.
 | 
					
						
							|  |  |  |     DisableCallbackAction aDisableCallbackAction( *this ); | 
					
						
							|  |  |  |     // <--
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     //Ersten CntntFrm und seinen Nachfolger im Body-Bereich suchen
 | 
					
						
							|  |  |  |     //Damit wir uns nicht tot suchen (und vor allem nicht zuviel formatieren)
 | 
					
						
							|  |  |  |     //gehen wir schon mal von der richtigen Seite aus.
 | 
					
						
							|  |  |  |     SwLayoutFrm *pPage = (SwLayoutFrm*)Lower(); | 
					
						
							| 
									
										
										
										
											2001-10-17 09:35:11 +00:00
										 |  |  |     if( pPage ) | 
					
						
							|  |  |  |         while( pPage->GetNext() && pPage->Frm().Bottom() < rPoint.Y() ) | 
					
						
							|  |  |  |             pPage = (SwLayoutFrm*)pPage->GetNext(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     const SwCntntFrm *pCnt = pPage ? pPage->ContainsCntnt() : ContainsCntnt(); | 
					
						
							|  |  |  |     while ( pCnt && !pCnt->IsInDocBody() ) | 
					
						
							|  |  |  |         pCnt = pCnt->GetNextCntntFrm(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( !pCnt ) | 
					
						
							|  |  |  |         return Point( 0, 0 ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pCnt->Calc(); | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |     if( !bNext ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |         // Solange der Point vor dem ersten CntntFrm liegt und es noch
 | 
					
						
							|  |  |  |         // vorhergehende Seiten gibt gehe ich jeweils eine Seite nach vorn.
 | 
					
						
							|  |  |  |         while ( rPoint.Y() < pCnt->Frm().Top() && pPage->GetPrev() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             pPage = (SwLayoutFrm*)pPage->GetPrev(); | 
					
						
							|  |  |  |             pCnt = pPage->ContainsCntnt(); | 
					
						
							|  |  |  |             while ( !pCnt ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 pPage = (SwLayoutFrm*)pPage->GetPrev(); | 
					
						
							|  |  |  |                 if ( pPage ) | 
					
						
							|  |  |  |                     pCnt = pPage->ContainsCntnt(); | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                     return ContainsCntnt()->UnionFrm().Pos(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             pCnt->Calc(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     //Liegt der Point ueber dem ersten CntntFrm?
 | 
					
						
							|  |  |  |     if ( rPoint.Y() < pCnt->Frm().Top() && !lcl_IsInRepeatedHeadline( pCnt ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         return pCnt->UnionFrm().Pos(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while ( pCnt ) | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         //Liegt der Point im aktuellen CntntFrm?
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         SwRect aCntFrm( pCnt->UnionFrm() ); | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |         if ( aCntFrm.IsInside( rPoint ) && !lcl_IsInRepeatedHeadline( pCnt )) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             return rPoint; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Ist der aktuelle der letzte CntntFrm? ||
 | 
					
						
							|  |  |  |         //Wenn der naechste CntntFrm hinter dem Point liegt, ist der
 | 
					
						
							|  |  |  |         //aktuelle der gesuchte.
 | 
					
						
							|  |  |  |         const SwCntntFrm *pNxt = pCnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |         while ( pNxt && !pNxt->IsInDocBody() ) | 
					
						
							|  |  |  |             pNxt = pNxt->GetNextCntntFrm(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |         //Liegt der Point hinter dem letzten CntntFrm?
 | 
					
						
							|  |  |  |         if ( !pNxt ) | 
					
						
							|  |  |  |             return Point( aCntFrm.Right(), aCntFrm.Bottom() ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |         //Wenn der naechste CntntFrm hinter dem Point liegt ist er der
 | 
					
						
							|  |  |  |         //gesuchte.
 | 
					
						
							|  |  |  |         const SwTabFrm* pTFrm; | 
					
						
							|  |  |  |         pNxt->Calc(); | 
					
						
							|  |  |  |         if( pNxt->Frm().Top() > rPoint.Y() && | 
					
						
							|  |  |  |             !lcl_IsInRepeatedHeadline( pCnt, &pTFrm ) && | 
					
						
							|  |  |  |             ( !pTFrm || pNxt->Frm().Left() > rPoint.X() )) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if( bNext ) | 
					
						
							|  |  |  |                 return pNxt->Frm().Pos(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             return Point( aCntFrm.Right(), aCntFrm.Bottom() ); | 
					
						
							| 
									
										
										
										
											2001-10-11 14:32:13 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         pCnt = pNxt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return Point( 0, 0 ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-01-18 13:28:02 +00:00
										 |  |  | // MB 22.11.2004
 | 
					
						
							|  |  |  | Point SwRootFrm::GetContentFromPos( const Point &rPoint, int offset ) const { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // First of all we search for the page which
 | 
					
						
							|  |  |  |     // corrosponds to the given position
 | 
					
						
							|  |  |  |     SwLayoutFrm *pPage = (SwLayoutFrm*)Lower(); | 
					
						
							|  |  |  |     if( pPage ) | 
					
						
							|  |  |  |         while( pPage->GetNext() && pPage->Frm().Bottom() < rPoint.Y() ) | 
					
						
							|  |  |  |             pPage = (SwLayoutFrm*)pPage->GetNext(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Retrieve the first content frame on the page in question
 | 
					
						
							|  |  |  |     const SwCntntFrm *pCnt = pPage ? pPage->ContainsCntnt() : ContainsCntnt(); | 
					
						
							|  |  |  |     if(!pCnt) | 
					
						
							|  |  |  |         return Point( 0, 0 ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ViewShell *pSh = GetShell(); | 
					
						
							|  |  |  |     const SwRect &visArea = pSh->VisArea(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Initial search distance
 | 
					
						
							|  |  |  |     float fDistance = FLT_MAX; | 
					
						
							|  |  |  |     const SwCntntFrm *pGuess = pCnt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Now search for the content frame which is located
 | 
					
						
							|  |  |  |     // as close as possible to the given postion.
 | 
					
						
							|  |  |  |     do { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Found if the position is contained in this frame
 | 
					
						
							|  |  |  |         pCnt->Calc(); | 
					
						
							|  |  |  |         SwRect aCntFrm(pCnt->UnionFrm()); | 
					
						
							|  |  |  |         if(aCntFrm.IsInside(rPoint)) | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Step to the next frame.
 | 
					
						
							|  |  |  |         const SwCntntFrm *pNxt = pCnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |         while(pNxt && !pNxt->IsInDocBody()) | 
					
						
							|  |  |  |             pNxt = pNxt->GetNextCntntFrm(); | 
					
						
							|  |  |  |         if(pNxt) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // stop if the next content frame
 | 
					
						
							|  |  |  |             // is on a page that is not visible...
 | 
					
						
							|  |  |  |             const SwPageFrm *pPageFrm = pNxt->FindPageFrm(); | 
					
						
							|  |  |  |             if(visArea.GetIntersection(pPageFrm->UnionFrm()).IsEmpty()) | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             Point pkClosest; | 
					
						
							|  |  |  |             float fCurrentDistance = aCntFrm.GetDistance(rPoint,pkClosest); | 
					
						
							|  |  |  |             if(fCurrentDistance < fDistance) { | 
					
						
							|  |  |  |                 pGuess = pCnt; | 
					
						
							|  |  |  |                 fDistance = fCurrentDistance; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         pCnt = pNxt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } while(pCnt); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // In case we found the "closest frame",
 | 
					
						
							|  |  |  |     // step one frame back (if possible)
 | 
					
						
							|  |  |  |     if(pCnt = pGuess) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // step right?
 | 
					
						
							|  |  |  |         if(offset & 1) { | 
					
						
							|  |  |  |             const SwCntntFrm *pNext = pCnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |             if(pNext) { | 
					
						
							|  |  |  |                 SwRect aNextCntFrm(pNext->UnionFrm()); | 
					
						
							|  |  |  |                 if(pNext->IsInDocBody()) | 
					
						
							|  |  |  |                     if(aNextCntFrm.Left() > rPoint.X()) | 
					
						
							|  |  |  |                         pCnt=pNext; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // step left?
 | 
					
						
							|  |  |  |         else if(offset & 2) { | 
					
						
							|  |  |  |             const SwCntntFrm *pPrev = pCnt->GetPrevCntntFrm(); | 
					
						
							|  |  |  |             if(pPrev) { | 
					
						
							|  |  |  |                 SwRect aPrevCntFrm(pPrev->UnionFrm()); | 
					
						
							|  |  |  |                 if(pPrev->IsInDocBody()) | 
					
						
							|  |  |  |                     if(aPrevCntFrm.Right() < rPoint.X()) | 
					
						
							|  |  |  |                         pCnt=pPrev; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // step up?
 | 
					
						
							|  |  |  |         if(offset & 8) { | 
					
						
							|  |  |  |             const SwCntntFrm *pPrev = pCnt->GetPrevCntntFrm(); | 
					
						
							|  |  |  |             while(pPrev) { | 
					
						
							|  |  |  |                 SwRect aPrevCntFrm(pPrev->UnionFrm()); | 
					
						
							|  |  |  |                 if(pPrev->IsInDocBody()) { | 
					
						
							|  |  |  |                     if(aPrevCntFrm.Top() < rPoint.Y()) { | 
					
						
							|  |  |  |                         pCnt=pPrev; | 
					
						
							|  |  |  |                         break; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 pPrev = pPrev->GetPrevCntntFrm(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // step down?
 | 
					
						
							|  |  |  |         else if(offset & 4) { | 
					
						
							|  |  |  |             const SwCntntFrm *pNext = pCnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |             while(pNext) { | 
					
						
							|  |  |  |                 SwRect aNextCntFrm(pNext->UnionFrm()); | 
					
						
							|  |  |  |                 if(pNext->IsInDocBody()) { | 
					
						
							|  |  |  |                     if(aNextCntFrm.Bottom() > rPoint.Y()) { | 
					
						
							|  |  |  |                         pCnt=pNext; | 
					
						
							|  |  |  |                         break; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 pNext = pNext->GetNextCntntFrm(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         SwRect aCntFrm(pCnt->UnionFrm()); | 
					
						
							|  |  |  |         return aCntFrm.Pos(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return rPoint; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwRootFrm::GetPagePos() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Beschreibung:   Liefert die absolute Dokumentpositon der gewuenschten | 
					
						
							|  |  |  | |*          Seite. | 
					
						
							|  |  |  | |*          Formatiert wird nur soweit notwendig und nur dann wenn bFormat=TRUE | 
					
						
							|  |  |  | |*          Liefert Null, wenn die Operation nicht moeglich ist. | 
					
						
							|  |  |  | |*          Die Pos ist die der letzten Seite, wenn die Seitenzahl zu gross | 
					
						
							|  |  |  | |*          gewaehlt wurde. | 
					
						
							|  |  |  | |*  Ersterstellung      MA 01. Jun. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 09. Oct. 97 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | Point SwRootFrm::GetPagePos( USHORT nPageNum ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT( Lower() && Lower()->IsPageFrm(), "Keine Seite vorhanden." ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwPageFrm *pPage = (const SwPageFrm*)Lower(); | 
					
						
							|  |  |  |     while ( TRUE ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ( pPage->GetPhyPageNum() >= nPageNum || !pPage->GetNext() ) | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         pPage = (const SwPageFrm*)pPage->GetNext(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return pPage->Frm().Pos(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | /** get page frame by phyiscal page number
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     OD 14.01.2003 #103492# | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @return pointer to the page frame with the given physical page number | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | SwPageFrm* SwRootFrm::GetPageByPageNum( sal_uInt16 _nPageNum ) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2003-12-01 16:19:20 +00:00
										 |  |  |     const SwPageFrm* pPageFrm = static_cast<const SwPageFrm*>( Lower() ); | 
					
						
							|  |  |  |     while ( pPageFrm && pPageFrm->GetPhyPageNum() < _nPageNum ) | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2003-12-01 16:19:20 +00:00
										 |  |  |           pPageFrm = static_cast<const SwPageFrm*>( pPageFrm->GetNext() ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( pPageFrm && pPageFrm->GetPhyPageNum() == _nPageNum ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return const_cast<SwPageFrm*>( pPageFrm ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-03-15 10:47:59 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwRootFrm::IsDummyPage(USHORT) | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Description: Returns TRUE, when the given physical pagenumber does't exist | 
					
						
							|  |  |  | |*               or this page is an empty page. | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | BOOL SwRootFrm::IsDummyPage( USHORT nPageNum ) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if( !Lower() || !nPageNum || nPageNum > GetPageNum() ) | 
					
						
							|  |  |  |         return TRUE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwPageFrm *pPage = (const SwPageFrm*)Lower(); | 
					
						
							|  |  |  |     while( pPage && nPageNum < pPage->GetPhyPageNum() ) | 
					
						
							|  |  |  |         pPage = (const SwPageFrm*)pPage->GetNext(); | 
					
						
							|  |  |  |     return pPage ? pPage->IsEmptyPage() : TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    SwFrm::IsProtected() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    Beschreibung      Ist der Frm bzw. die Section in der er steht | 
					
						
							|  |  |  | |*                      geschuetzt? | 
					
						
							|  |  |  | |*                      Auch Fly in Fly in ... und Fussnoten | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    Ersterstellung    MA 28. Jul. 93 | 
					
						
							|  |  |  | |*    Letzte Aenderung  MA 06. Nov. 97 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | BOOL SwFrm::IsProtected() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     //Der Frm kann in Rahmen, Zellen oder Bereichen geschuetzt sein.
 | 
					
						
							|  |  |  |     //Geht auch FlyFrms rekursiv hoch. Geht auch von Fussnoten zum Anker.
 | 
					
						
							|  |  |  |     const SwFrm *pFrm = this; | 
					
						
							|  |  |  |     do | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ( pFrm->IsCntntFrm() ) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2002-10-02 11:54:53 +00:00
										 |  |  |             if ( ((SwCntntFrm*)pFrm)->GetNode() && | 
					
						
							|  |  |  |                  ((SwCntntFrm*)pFrm)->GetNode()->IsInProtectSect() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 return TRUE; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2002-10-02 11:54:53 +00:00
										 |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if ( ((SwLayoutFrm*)pFrm)->GetFmt() && | 
					
						
							|  |  |  |                  ((SwLayoutFrm*)pFrm)->GetFmt()-> | 
					
						
							|  |  |  |                  GetProtect().IsCntntProtected() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             return TRUE; | 
					
						
							| 
									
										
										
										
											2002-10-02 11:54:53 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         if ( pFrm->IsFlyFrm() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             //Der Schutz des Inhaltes kann bei Verkettung vom Master der Kette
 | 
					
						
							|  |  |  |             //vorgegeben werden.
 | 
					
						
							|  |  |  |             if ( ((SwFlyFrm*)pFrm)->GetPrevLink() ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SwFlyFrm *pMaster = (SwFlyFrm*)pFrm; | 
					
						
							|  |  |  |                 do | 
					
						
							|  |  |  |                 {   pMaster = pMaster->GetPrevLink(); | 
					
						
							|  |  |  |                 } while ( pMaster->GetPrevLink() ); | 
					
						
							|  |  |  |                 if ( pMaster->IsProtected() ) | 
					
						
							|  |  |  |                     return TRUE; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2004-06-28 12:41:51 +00:00
										 |  |  |             pFrm = ((SwFlyFrm*)pFrm)->GetAnchorFrm(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |         else if ( pFrm->IsFtnFrm() ) | 
					
						
							|  |  |  |             pFrm = ((SwFtnFrm*)pFrm)->GetRef(); | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |             pFrm = pFrm->GetUpper(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } while ( pFrm ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    SwFrm::GetPhyPageNum() | 
					
						
							|  |  |  | |*    Beschreibung:     Liefert die physikalische Seitennummer | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    Ersterstellung    OK 06.07.93 08:35 | 
					
						
							|  |  |  | |*    Letzte Aenderung  MA 30. Nov. 94 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | USHORT SwFrm::GetPhyPageNum() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const SwPageFrm *pPage = FindPageFrm(); | 
					
						
							|  |  |  |     return pPage ? pPage->GetPhyPageNum() : 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-03-02 10:21:22 +00:00
										 |  |  | /*-----------------26.02.01 11:25-------------------
 | 
					
						
							|  |  |  |  * SwFrm::WannaRightPage() | 
					
						
							|  |  |  |  * decides if the page want to be a rightpage or not. | 
					
						
							|  |  |  |  * If the first content of the page has a page descriptor, | 
					
						
							|  |  |  |  * we take the follow of the page descriptor of the last not empty page. | 
					
						
							|  |  |  |  * If this descriptor allows only right(left) pages and the page | 
					
						
							|  |  |  |  * isn't an empty page then it wanna be such right(left) page. | 
					
						
							|  |  |  |  * If the descriptor allows right and left pages, we look for a number offset | 
					
						
							|  |  |  |  * in the first content. If there is one, odd number results right pages, | 
					
						
							|  |  |  |  * even number results left pages. | 
					
						
							|  |  |  |  * If there is no number offset, we take the physical page number instead, | 
					
						
							|  |  |  |  * but a previous empty page don't count. | 
					
						
							|  |  |  |  * --------------------------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BOOL SwFrm::WannaRightPage() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const SwPageFrm *pPage = FindPageFrm(); | 
					
						
							|  |  |  |     if ( !pPage || !pPage->GetUpper() ) | 
					
						
							|  |  |  |         return TRUE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwFrm *pFlow = pPage->FindFirstBodyCntnt(); | 
					
						
							|  |  |  |     SwPageDesc *pDesc = 0; | 
					
						
							|  |  |  |     USHORT nPgNum = 0; | 
					
						
							|  |  |  |     if ( pFlow ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ( pFlow->IsInTab() ) | 
					
						
							|  |  |  |             pFlow = pFlow->FindTabFrm(); | 
					
						
							| 
									
										
										
										
											2001-03-15 09:16:52 +00:00
										 |  |  |         const SwFlowFrm *pTmp = SwFlowFrm::CastFlowFrm( pFlow ); | 
					
						
							|  |  |  |         if ( !pTmp->IsFollow() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwFmtPageDesc& rPgDesc = pFlow->GetAttrSet()->GetPageDesc(); | 
					
						
							|  |  |  |             pDesc = (SwPageDesc*)rPgDesc.GetPageDesc(); | 
					
						
							|  |  |  |             nPgNum = rPgDesc.GetNumOffset(); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2001-03-02 10:21:22 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     if ( !pDesc ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SwPageFrm *pPrv = (SwPageFrm*)pPage->GetPrev(); | 
					
						
							|  |  |  |         if( pPrv && pPrv->IsEmptyPage() ) | 
					
						
							|  |  |  |             pPrv = (SwPageFrm*)pPrv->GetPrev(); | 
					
						
							|  |  |  |         if( pPrv ) | 
					
						
							|  |  |  |             pDesc = pPrv->GetPageDesc()->GetFollow(); | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwDoc* pDoc = pPage->GetFmt()->GetDoc(); | 
					
						
							|  |  |  |             pDesc = (SwPageDesc*)&pDoc->GetPageDesc( 0 ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     ASSERT( pDesc, "No pagedescriptor" ); | 
					
						
							|  |  |  |     BOOL bOdd; | 
					
						
							|  |  |  |     if( nPgNum ) | 
					
						
							|  |  |  |         bOdd = nPgNum % 2 ? TRUE : FALSE; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         bOdd = pPage->OnRightPage(); | 
					
						
							|  |  |  |         if( pPage->GetPrev() && ((SwPageFrm*)pPage->GetPrev())->IsEmptyPage() ) | 
					
						
							|  |  |  |             bOdd = !bOdd; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if( !pPage->IsEmptyPage() ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if( !pDesc->GetRightFmt() ) | 
					
						
							|  |  |  |             bOdd = FALSE; | 
					
						
							|  |  |  |         else if( !pDesc->GetLeftFmt() ) | 
					
						
							|  |  |  |             bOdd = TRUE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return bOdd; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    SwFrm::GetVirtPageNum() | 
					
						
							|  |  |  | |*    Beschreibung:     Liefert die virtuelle Seitennummer mit Offset | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*    Ersterstellung    OK 06.07.93 08:35 | 
					
						
							|  |  |  | |*    Letzte Aenderung  MA 30. Nov. 94 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | USHORT SwFrm::GetVirtPageNum() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const SwPageFrm *pPage = FindPageFrm(); | 
					
						
							|  |  |  |     if ( !pPage || !pPage->GetUpper() ) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     USHORT nPhyPage = pPage->GetPhyPageNum(); | 
					
						
							|  |  |  |     if ( !((SwRootFrm*)pPage->GetUpper())->IsVirtPageNum() ) | 
					
						
							|  |  |  |         return nPhyPage; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Den am naechsten stehenden Absatz mit virtueller Seitennummer suchen.
 | 
					
						
							|  |  |  |     //Da das rueckwaertsuchen insgesamt sehr viel Zeit verschlingt suchen
 | 
					
						
							|  |  |  |     //wir jetzt gezielt ueber die Abhaengigkeiten.
 | 
					
						
							|  |  |  |     //von den PageDescs bekommen wir die Attribute, von den Attributen
 | 
					
						
							|  |  |  |     //wiederum bekommen wir die Absaetze.
 | 
					
						
							|  |  |  |     const SwPageFrm *pVirtPage = 0; | 
					
						
							|  |  |  |     const SwFrm *pFrm = 0; | 
					
						
							|  |  |  |     const SfxItemPool &rPool = pPage->GetFmt()->GetDoc()->GetAttrPool(); | 
					
						
							|  |  |  |     const SfxPoolItem* pItem; | 
					
						
							|  |  |  |     USHORT nMaxItems = rPool.GetItemCount( RES_PAGEDESC ); | 
					
						
							|  |  |  |     for( USHORT n = 0; n < nMaxItems; ++n ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if( 0 == (pItem = rPool.GetItem( RES_PAGEDESC, n ) )) | 
					
						
							|  |  |  |             continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const SwFmtPageDesc *pDesc = (SwFmtPageDesc*)pItem; | 
					
						
							|  |  |  |         if ( pDesc->GetNumOffset() && pDesc->GetDefinedIn() ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             const SwModify *pMod = pDesc->GetDefinedIn(); | 
					
						
							|  |  |  |             SwVirtPageNumInfo aInfo( pPage ); | 
					
						
							|  |  |  |             pMod->GetInfo( aInfo ); | 
					
						
							|  |  |  |             if ( aInfo.GetPage() ) | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2001-03-02 10:21:22 +00:00
										 |  |  |                 if( !pVirtPage || ( pVirtPage && aInfo.GetPage()-> | 
					
						
							|  |  |  |                     GetPhyPageNum() > pVirtPage->GetPhyPageNum() ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     pVirtPage = aInfo.GetPage(); | 
					
						
							|  |  |  |                     pFrm = aInfo.GetFrm(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-03-02 10:21:22 +00:00
										 |  |  |     if ( pFrm ) | 
					
						
							|  |  |  |         return nPhyPage - pFrm->GetPhyPageNum() + | 
					
						
							|  |  |  |                pFrm->GetAttrSet()->GetPageDesc().GetNumOffset(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     return nPhyPage; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwRootFrm::MakeTblCrsrs() | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Ersterstellung      MA 14. May. 93 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 02. Feb. 94 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | //Ermitteln und einstellen derjenigen Zellen die von der Selektion
 | 
					
						
							|  |  |  | //eingeschlossen sind.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-07-09 08:16:51 +00:00
										 |  |  | bool SwRootFrm::MakeTblCrsrs( SwTableCursor& rTblCrsr ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     //Union-Rects und Tabellen (Follows) der Selektion besorgen.
 | 
					
						
							|  |  |  |     ASSERT( rTblCrsr.GetCntntNode() && rTblCrsr.GetCntntNode( FALSE ), | 
					
						
							|  |  |  |             "Tabselection nicht auf Cnt." ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-07-09 08:16:51 +00:00
										 |  |  |     bool bRet = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     Point aPtPt, aMkPt; | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SwShellCrsr* pShCrsr =  rTblCrsr.operator SwShellCrsr*(); | 
					
						
							|  |  |  |         // Aufgrund eines CompilerBugs von Linux muss
 | 
					
						
							|  |  |  |         // der Zeigeroperator explizit gerufen werden
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if( pShCrsr ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             aPtPt = pShCrsr->GetPtPos(); | 
					
						
							|  |  |  |             aMkPt = pShCrsr->GetMkPos(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     const SwLayoutFrm *pStart = rTblCrsr.GetCntntNode()->GetFrm( | 
					
						
							|  |  |  |                                             &aPtPt, 0, FALSE )->GetUpper(), | 
					
						
							|  |  |  |                       *pEnd   = rTblCrsr.GetCntntNode(FALSE)->GetFrm( | 
					
						
							|  |  |  |                                             &aMkPt, 0, FALSE )->GetUpper(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |     /* #109590# Only change table boxes if the frames are
 | 
					
						
							|  |  |  |         valid. Needed because otherwise the table cursor after moving | 
					
						
							|  |  |  |         table cells by dnd resulted in an empty tables cursor.  */ | 
					
						
							|  |  |  |     if (pStart->IsValid() && pEnd->IsValid()) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SwSelUnions aUnions; | 
					
						
							|  |  |  |         ::MakeSelUnions( aUnions, pStart, pEnd ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |         SwSelBoxes aNew; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |         const FASTBOOL bReadOnlyAvailable = rTblCrsr.IsReadOnlyAvailable(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for ( USHORT i = 0; i < aUnions.Count(); ++i ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |             SwSelUnion *pUnion = aUnions[i]; | 
					
						
							|  |  |  |             const SwTabFrm *pTable = pUnion->GetTable(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |             // Skip any repeated headlines in the follow:
 | 
					
						
							|  |  |  |             SwLayoutFrm* pRow = pTable->IsFollow() ? | 
					
						
							|  |  |  |                                 pTable->GetFirstNonHeadlineRow() : | 
					
						
							|  |  |  |                                 (SwLayoutFrm*)pTable->Lower(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |             while ( pRow ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                 if ( pRow->Frm().IsOver( pUnion->GetUnion() ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                     const SwLayoutFrm *pCell = pRow->FirstCell(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     while ( pCell && pRow->IsAnLower( pCell ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                     { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                         ASSERT( pCell->IsCellFrm(), "Frame ohne Celle" ); | 
					
						
							|  |  |  |                         if( IsFrmInTblSel( pUnion->GetUnion(), pCell ) && | 
					
						
							|  |  |  |                             (bReadOnlyAvailable || | 
					
						
							|  |  |  |                              !pCell->GetFmt()->GetProtect().IsCntntProtected())) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                             SwTableBox* pInsBox = (SwTableBox*) | 
					
						
							|  |  |  |                                 ((SwCellFrm*)pCell)->GetTabBox(); | 
					
						
							|  |  |  |                             aNew.Insert( pInsBox ); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         if ( pCell->GetNext() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                             pCell = (const SwLayoutFrm*)pCell->GetNext(); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                             if ( pCell->Lower() && pCell->Lower()->IsRowFrm() ) | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                                 pCell = pCell->FirstCell(); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         else | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             const SwLayoutFrm* pLastCell = pCell; | 
					
						
							|  |  |  |                             do | 
					
						
							|  |  |  |                             { | 
					
						
							|  |  |  |                                 pCell = pCell->GetNextLayoutLeaf(); | 
					
						
							|  |  |  |                             } while ( pCell && pLastCell->IsAnLower( pCell ) ); | 
					
						
							|  |  |  |                             // Fuer (spaltige) Bereiche...
 | 
					
						
							|  |  |  |                             if( pCell && pCell->IsInTab() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                             { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                                 while( !pCell->IsCellFrm() ) | 
					
						
							|  |  |  |                                 { | 
					
						
							|  |  |  |                                     pCell = pCell->GetUpper(); | 
					
						
							|  |  |  |                                     ASSERT( pCell, "Where's my cell?" ); | 
					
						
							|  |  |  |                                 } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                             } | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |                 pRow = (SwLayoutFrm*)pRow->GetNext(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |         SwSelBoxes& rOld = (SwSelBoxes&)rTblCrsr.GetBoxes(); | 
					
						
							|  |  |  |         USHORT nOld = 0, nNew = 0; | 
					
						
							|  |  |  |         while ( nOld < rOld.Count() && nNew < aNew.Count() ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |             const SwTableBox* pPOld = *( rOld.GetData() + nOld ); | 
					
						
							|  |  |  |             const SwTableBox* pPNew = *( aNew.GetData() + nNew ); | 
					
						
							|  |  |  |             if( pPOld == pPNew ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 // diese Box bleibt erhalten
 | 
					
						
							|  |  |  |                 ++nOld; | 
					
						
							|  |  |  |                 aNew.Remove( nNew ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else if( pPOld->GetSttIdx() < pPNew->GetSttIdx() ) | 
					
						
							|  |  |  |                 rTblCrsr.DeleteBox( nOld ); | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 rTblCrsr.InsertBox( *pPNew ); | 
					
						
							|  |  |  |                 ++nOld; | 
					
						
							|  |  |  |                 ++nNew; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |         while( nOld < rOld.Count() ) | 
					
						
							|  |  |  |             rTblCrsr.DeleteBox( nOld ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |         for( ; nNew < aNew.Count(); ++nNew ) | 
					
						
							|  |  |  |             rTblCrsr.InsertBox( **( aNew.GetData() + nNew ) ); | 
					
						
							| 
									
										
										
										
											2003-07-09 08:16:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         bRet = true; | 
					
						
							| 
									
										
										
										
											2003-06-12 06:38:43 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2003-07-09 08:16:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return bRet; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  SwRootFrm::CalcFrmRects | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*  Ersterstellung      MA 24. Aug. 92 | 
					
						
							|  |  |  | |*  Letzte Aenderung    MA 24. Aug. 93 | 
					
						
							|  |  |  | |* | 
					
						
							|  |  |  | |*************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * nun koennen folgende Situationen auftreten: | 
					
						
							|  |  |  |  *  1. Start und Ende liegen in einer Bildschirm - Zeile und im | 
					
						
							|  |  |  |  *     gleichen Node | 
					
						
							|  |  |  |  *      -> aus Start und End ein Rectangle, dann Ok | 
					
						
							|  |  |  |  *  2. Start und Ende liegen in einem Frame (dadurch im gleichen Node!) | 
					
						
							|  |  |  |  *      -> Start nach rechts, End nach links erweitern, | 
					
						
							|  |  |  |  *         und bei mehr als 2 Bildschirm - Zeilen, das dazwischen | 
					
						
							|  |  |  |  *         liegende berechnen | 
					
						
							|  |  |  |  *  3. Start und Ende liegen in verschiedenen Frames | 
					
						
							|  |  |  |  *      -> Start nach rechts erweitern, bis Frame-Ende Rect berechnen | 
					
						
							|  |  |  |  *         Ende nach links erweitern, bis Frame-Start Rect berechnen | 
					
						
							|  |  |  |  *         und bei mehr als 2 Frames von allen dazwischen liegenden | 
					
						
							|  |  |  |  *         Frames die PrtArea dazu. | 
					
						
							|  |  |  |  *  4. Wenn es sich um eine Tabellenselektion handelt wird fuer jeden | 
					
						
							|  |  |  |  *     PaM im Ring der CellFrm besorgt, dessen PrtArea wird zu den | 
					
						
							|  |  |  |  *     Rechtecken addiert. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Grosser Umbau wg. der FlyFrm; denn diese muessen ausgespart werden. | 
					
						
							|  |  |  |  * Ausnahmen: - Der Fly in dem die Selektion stattfindet (wenn sie in einem Fly | 
					
						
							|  |  |  |  *              stattfindet). | 
					
						
							|  |  |  |  *            - Die Flys, die vom Text unterlaufen werden. | 
					
						
							|  |  |  |  * Arbeitsweise: Zuerst wird eine SwRegion mit der Root initialisiert. | 
					
						
							|  |  |  |  *               Aus der Region werden die zu invertierenden Bereiche | 
					
						
							|  |  |  |  *               ausgestantzt. Die Region wird Komprimiert und letztlich | 
					
						
							|  |  |  |  *               invertiert. Damit liegen dann die zu invertierenden | 
					
						
							|  |  |  |  *               Rechtecke vor. | 
					
						
							|  |  |  |  *               Am Ende werden die Flys aus der Region ausgestanzt. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline void Sub( SwRegionRects& rRegion, const SwRect& rRect ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if( rRect.Width() > 1 && rRect.Height() > 1 && | 
					
						
							|  |  |  |         rRect.IsOver( rRegion.GetOrigin() )) | 
					
						
							|  |  |  |         rRegion -= rRect; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void SwRootFrm::CalcFrmRects( SwShellCrsr &rCrsr, BOOL bIsTblMode ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ViewShell *pSh = GetShell(); | 
					
						
							| 
									
										
										
										
											2004-09-08 15:10:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | // --> FME 2004-06-08 #i12836# enhanced pdf
 | 
					
						
							|  |  |  |     SwRegionRects aRegion( pSh && !pSh->GetViewOptions()->IsPDFExport() ? | 
					
						
							|  |  |  |                            pSh->VisArea() : | 
					
						
							|  |  |  |                            Frm() ); | 
					
						
							|  |  |  | // <--
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     const SwNodes &rNds = GetFmt()->GetDoc()->GetNodes(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Erstmal die CntntFrms zum Start und End besorgen, die brauch ich auf
 | 
					
						
							|  |  |  |     //jedenfall.
 | 
					
						
							|  |  |  |     SwPosition *pStartPos = rCrsr.Start(), | 
					
						
							|  |  |  |                *pEndPos   = rCrsr.GetPoint() == pStartPos ? | 
					
						
							|  |  |  |                                 rCrsr.GetMark() : rCrsr.GetPoint(); | 
					
						
							|  |  |  |     const SwCntntFrm *pStartFrm = rNds[ pStartPos->nNode ]-> | 
					
						
							|  |  |  |         GetCntntNode()->GetFrm( &rCrsr.GetSttPos(), pStartPos ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const SwCntntFrm *pEndFrm   = rNds[ pEndPos->nNode ]-> | 
					
						
							|  |  |  |         GetCntntNode()->GetFrm( &rCrsr.GetEndPos(), pEndPos ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT( (pStartFrm && pEndFrm), "Keine CntntFrms gefunden." ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Damit die FlyFrms, in denen selektierte Frames stecken, nicht
 | 
					
						
							|  |  |  |     //abgezogen werden
 | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |     SwSortedObjs aSortObjs; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     if ( pStartFrm->IsInFly() ) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |         const SwAnchoredObject* pObj = pStartFrm->FindFlyFrm(); | 
					
						
							|  |  |  |         aSortObjs.Insert( *(const_cast<SwAnchoredObject*>(pObj)) ); | 
					
						
							|  |  |  |         const SwAnchoredObject* pObj2 = pEndFrm->FindFlyFrm(); | 
					
						
							|  |  |  |         aSortObjs.Insert( *(const_cast<SwAnchoredObject*>(pObj2)) ); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Fall 4: Tabellenselection
 | 
					
						
							|  |  |  |     if( bIsTblMode ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         const SwFrm *pCell = pStartFrm->GetUpper(); | 
					
						
							|  |  |  |         while ( !pCell->IsCellFrm() ) | 
					
						
							|  |  |  |             pCell = pCell->GetUpper(); | 
					
						
							|  |  |  |         SwRect aTmp( pCell->Prt() ); | 
					
						
							|  |  |  |         aTmp.Pos() += pCell->Frm().Pos(); | 
					
						
							|  |  |  |         aRegion.ChangeOrigin( aTmp ); | 
					
						
							|  |  |  |         aRegion.Remove( 0, aRegion.Count() ); | 
					
						
							|  |  |  |         aRegion.Insert( aTmp, 0 ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // falls eine nicht erlaubte Selection besteht, dann korrigiere das
 | 
					
						
							|  |  |  |         // nicht erlaubt ist Header/Footer/TableHeadline ueber 2 Seiten
 | 
					
						
							|  |  |  |         do {    // middle check loop
 | 
					
						
							|  |  |  |             const SwLayoutFrm* pSttLFrm = pStartFrm->GetUpper(); | 
					
						
							|  |  |  |             const USHORT cHdFtTblHd = FRM_HEADER | FRM_FOOTER | FRM_TAB; | 
					
						
							|  |  |  |             while( pSttLFrm && | 
					
						
							|  |  |  |                 ! (cHdFtTblHd & pSttLFrm->GetType() )) | 
					
						
							|  |  |  |                 pSttLFrm = pSttLFrm->GetUpper(); | 
					
						
							|  |  |  |             if( !pSttLFrm ) | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             const SwLayoutFrm* pEndLFrm = pEndFrm->GetUpper(); | 
					
						
							|  |  |  |             while( pEndLFrm && | 
					
						
							|  |  |  |                 ! (cHdFtTblHd & pEndLFrm->GetType() )) | 
					
						
							|  |  |  |                 pEndLFrm = pEndLFrm->GetUpper(); | 
					
						
							|  |  |  |             if( !pEndLFrm ) | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             ASSERT( pEndLFrm->GetType() == pSttLFrm->GetType(), | 
					
						
							|  |  |  |                     "Selection ueber unterschiedliche Inhalte" ); | 
					
						
							|  |  |  |             switch( pSttLFrm->GetType() ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |             case FRM_HEADER: | 
					
						
							|  |  |  |             case FRM_FOOTER: | 
					
						
							|  |  |  |                 // auf unterschiedlichen Seiten ??
 | 
					
						
							|  |  |  |                 // dann immer auf die Start-Seite
 | 
					
						
							|  |  |  |                 if( pEndLFrm->FindPageFrm() != pSttLFrm->FindPageFrm() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     // End- auf den Start-CntntFrame setzen
 | 
					
						
							|  |  |  |                     if( pStartPos == rCrsr.GetPoint() ) | 
					
						
							|  |  |  |                         pEndFrm = pStartFrm; | 
					
						
							|  |  |  |                     else | 
					
						
							|  |  |  |                         pStartFrm = pEndFrm; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case FRM_TAB: | 
					
						
							|  |  |  |                 // auf unterschiedlichen Seiten ??
 | 
					
						
							|  |  |  |                 // existiert
 | 
					
						
							|  |  |  |                 // dann teste auf Tabelle-Headline
 | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     const SwTabFrm* pTabFrm = (SwTabFrm*)pSttLFrm; | 
					
						
							|  |  |  |                     if( ( pTabFrm->GetFollow() || | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                           ((SwTabFrm*)pEndLFrm)->GetFollow() ) && | 
					
						
							| 
									
										
										
										
											2004-05-03 12:47:58 +00:00
										 |  |  |                         pTabFrm->GetTable()->GetRowsToRepeat() > 0 && | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                         pTabFrm->GetLower() != ((SwTabFrm*)pEndLFrm)->GetLower() && | 
					
						
							|  |  |  |                         ( lcl_IsInRepeatedHeadline( pStartFrm ) || | 
					
						
							|  |  |  |                           lcl_IsInRepeatedHeadline( pEndFrm ) ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                     { | 
					
						
							|  |  |  |                         // End- auf den Start-CntntFrame setzen
 | 
					
						
							|  |  |  |                         if( pStartPos == rCrsr.GetPoint() ) | 
					
						
							|  |  |  |                             pEndFrm = pStartFrm; | 
					
						
							|  |  |  |                         else | 
					
						
							|  |  |  |                             pStartFrm = pEndFrm; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } while( FALSE ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |         SwCrsrMoveState aTmpState( MV_NONE ); | 
					
						
							|  |  |  |         aTmpState.b2Lines = sal_True; | 
					
						
							| 
									
										
										
										
											2001-09-10 14:02:49 +00:00
										 |  |  |         aTmpState.bNoScroll = sal_True; | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |         aTmpState.nCursorBidiLevel = pStartFrm->IsRightToLeft() ? 1 : 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |         //CntntRects zu Start- und EndFrms.
 | 
					
						
							|  |  |  |         SwRect aStRect, aEndRect; | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |         pStartFrm->GetCharRect( aStRect, *pStartPos, &aTmpState ); | 
					
						
							|  |  |  |         Sw2LinesPos *pSt2Pos = aTmpState.p2Lines; | 
					
						
							|  |  |  |         aTmpState.p2Lines = NULL; | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |         aTmpState.nCursorBidiLevel = pEndFrm->IsRightToLeft() ? 1 : 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |         pEndFrm->GetCharRect  ( aEndRect, *pEndPos, &aTmpState ); | 
					
						
							|  |  |  |         Sw2LinesPos *pEnd2Pos = aTmpState.p2Lines; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-12-12 09:49:12 +00:00
										 |  |  |         SwRect aStFrm ( pStartFrm->UnionFrm( sal_True ) ); | 
					
						
							|  |  |  |         aStFrm.Intersection( pStartFrm->PaintArea() ); | 
					
						
							|  |  |  |         SwRect aEndFrm( pStartFrm == pEndFrm ? aStFrm : | 
					
						
							|  |  |  |                                                pEndFrm->UnionFrm( sal_True ) ); | 
					
						
							|  |  |  |         if( pStartFrm != pEndFrm ) | 
					
						
							|  |  |  |             aEndFrm.Intersection( pEndFrm->PaintArea() ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |         SWRECTFN( pStartFrm ) | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |         const BOOL bR2L = pStartFrm->IsRightToLeft(); | 
					
						
							|  |  |  |         const BOOL bEndR2L = pEndFrm->IsRightToLeft(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |         // If there's no doubleline portion involved or start and end are both
 | 
					
						
							|  |  |  |         // in the same doubleline portion, all works fine, but otherwise
 | 
					
						
							|  |  |  |         // we need the following...
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |         if( pSt2Pos != pEnd2Pos && ( !pSt2Pos || !pEnd2Pos || | 
					
						
							|  |  |  |             pSt2Pos->aPortion != pEnd2Pos->aPortion ) ) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             // If we have a start(end) position inside a doubleline portion
 | 
					
						
							|  |  |  |             // the surrounded part of the doubleline portion is subtracted
 | 
					
						
							|  |  |  |             // from the region and the aStRect(aEndRect) is set to the
 | 
					
						
							|  |  |  |             // end(start) of the doubleline portion.
 | 
					
						
							|  |  |  |             if( pSt2Pos ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SwRect aTmp( aStRect ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 // BiDi-Portions are swimming against the current.
 | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 const sal_Bool bPorR2L = ( MT_BIDI == pSt2Pos->nMultiType ) ? | 
					
						
							|  |  |  |                                            ! bR2L : | 
					
						
							|  |  |  |                                              bR2L; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if( MT_BIDI == pSt2Pos->nMultiType && | 
					
						
							|  |  |  |                     (pSt2Pos->aPortion2.*fnRect->fnGetWidth)() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     // nested bidi portion
 | 
					
						
							|  |  |  |                     long nRightAbs = (pSt2Pos->aPortion.*fnRect->fnGetRight)(); | 
					
						
							|  |  |  |                     nRightAbs -= (pSt2Pos->aPortion2.*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |                     long nLeftAbs = nRightAbs - (pSt2Pos->aPortion2.*fnRect->fnGetWidth)(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     (aTmp.*fnRect->fnSetRight)( nRightAbs ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     if ( ! pEnd2Pos || pEnd2Pos->aPortion != pSt2Pos->aPortion ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         SwRect aTmp2( pSt2Pos->aPortion ); | 
					
						
							|  |  |  |                         (aTmp2.*fnRect->fnSetRight)( nLeftAbs ); | 
					
						
							|  |  |  |                         aTmp2.Intersection( aEndFrm ); | 
					
						
							|  |  |  |                         Sub( aRegion, aTmp2 ); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 else | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     if( bPorR2L ) | 
					
						
							|  |  |  |                         (aTmp.*fnRect->fnSetLeft)( | 
					
						
							|  |  |  |                             (pSt2Pos->aPortion.*fnRect->fnGetLeft)() ); | 
					
						
							|  |  |  |                     else | 
					
						
							|  |  |  |                         (aTmp.*fnRect->fnSetRight)( | 
					
						
							|  |  |  |                             (pSt2Pos->aPortion.*fnRect->fnGetRight)() ); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 if( MT_ROT_90 == pSt2Pos->nMultiType || | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                     (pSt2Pos->aPortion.*fnRect->fnGetTop)() == | 
					
						
							|  |  |  |                     (aTmp.*fnRect->fnGetTop)() ) | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 { | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                     (aTmp.*fnRect->fnSetTop)( | 
					
						
							|  |  |  |                         (pSt2Pos->aLine.*fnRect->fnGetTop)() ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 aTmp.Intersection( aStFrm ); | 
					
						
							|  |  |  |                 Sub( aRegion, aTmp ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 SwTwips nTmp = (pSt2Pos->aLine.*fnRect->fnGetBottom)(); | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 if( MT_ROT_90 != pSt2Pos->nMultiType && | 
					
						
							| 
									
										
										
										
											2001-12-12 13:44:09 +00:00
										 |  |  |                     (aStRect.*fnRect->fnBottomDist)( nTmp ) > 0 ) | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     (aTmp.*fnRect->fnSetTop)( (aTmp.*fnRect->fnGetBottom)() ); | 
					
						
							|  |  |  |                     (aTmp.*fnRect->fnSetBottom)( nTmp ); | 
					
						
							| 
									
										
										
										
											2001-12-12 13:44:09 +00:00
										 |  |  |                     if( (aStRect.*fnRect->fnBottomDist)( | 
					
						
							|  |  |  |                         (pSt2Pos->aPortion.*fnRect->fnGetBottom)() ) > 0 ) | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                     { | 
					
						
							|  |  |  |                         if( bPorR2L ) | 
					
						
							|  |  |  |                             (aTmp.*fnRect->fnSetRight)( | 
					
						
							|  |  |  |                                 (pSt2Pos->aPortion.*fnRect->fnGetRight)() ); | 
					
						
							|  |  |  |                         else | 
					
						
							|  |  |  |                             (aTmp.*fnRect->fnSetLeft)( | 
					
						
							|  |  |  |                                 (pSt2Pos->aPortion.*fnRect->fnGetLeft)() ); | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                     aTmp.Intersection( aStFrm ); | 
					
						
							|  |  |  |                     Sub( aRegion, aTmp ); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 aStRect = pSt2Pos->aLine; | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 (aStRect.*fnRect->fnSetLeft)( bR2L ? | 
					
						
							|  |  |  |                         (pSt2Pos->aPortion.*fnRect->fnGetLeft)() : | 
					
						
							|  |  |  |                         (pSt2Pos->aPortion.*fnRect->fnGetRight)() ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 (aStRect.*fnRect->fnSetWidth)( 1 ); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |             if( pEnd2Pos ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SWRECTFN( pEndFrm ) | 
					
						
							|  |  |  |                 SwRect aTmp( aEndRect ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 // BiDi-Portions are swimming against the current.
 | 
					
						
							|  |  |  |                 const sal_Bool bPorR2L = ( MT_BIDI == pEnd2Pos->nMultiType ) ? | 
					
						
							|  |  |  |                                            ! bEndR2L : | 
					
						
							|  |  |  |                                              bEndR2L; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if( MT_BIDI == pEnd2Pos->nMultiType && | 
					
						
							|  |  |  |                     (pEnd2Pos->aPortion2.*fnRect->fnGetWidth)() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     // nested bidi portion
 | 
					
						
							|  |  |  |                     long nRightAbs = (pEnd2Pos->aPortion.*fnRect->fnGetRight)(); | 
					
						
							|  |  |  |                     nRightAbs = nRightAbs - (pEnd2Pos->aPortion2.*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |                     long nLeftAbs = nRightAbs - (pEnd2Pos->aPortion2.*fnRect->fnGetWidth)(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     (aTmp.*fnRect->fnSetLeft)( nLeftAbs ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     if ( ! pSt2Pos || pSt2Pos->aPortion != pEnd2Pos->aPortion ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         SwRect aTmp2( pEnd2Pos->aPortion ); | 
					
						
							|  |  |  |                         (aTmp2.*fnRect->fnSetLeft)( nRightAbs ); | 
					
						
							|  |  |  |                         aTmp2.Intersection( aEndFrm ); | 
					
						
							|  |  |  |                         Sub( aRegion, aTmp2 ); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 else | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     if ( bPorR2L ) | 
					
						
							|  |  |  |                         (aTmp.*fnRect->fnSetRight)( | 
					
						
							|  |  |  |                             (pEnd2Pos->aPortion.*fnRect->fnGetRight)() ); | 
					
						
							|  |  |  |                     else | 
					
						
							|  |  |  |                         (aTmp.*fnRect->fnSetLeft)( | 
					
						
							|  |  |  |                             (pEnd2Pos->aPortion.*fnRect->fnGetLeft)() ); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 if( MT_ROT_90 == pEnd2Pos->nMultiType || | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                     (pEnd2Pos->aPortion.*fnRect->fnGetBottom)() == | 
					
						
							|  |  |  |                     (aEndRect.*fnRect->fnGetBottom)() ) | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 { | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                     (aTmp.*fnRect->fnSetBottom)( | 
					
						
							|  |  |  |                         (pEnd2Pos->aLine.*fnRect->fnGetBottom)() ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 aTmp.Intersection( aEndFrm ); | 
					
						
							|  |  |  |                 Sub( aRegion, aTmp ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 // The next statement means neither ruby nor rotate(90):
 | 
					
						
							|  |  |  |                 if( !( MT_RUBY & pEnd2Pos->nMultiType ) ) | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     SwTwips nTmp = (pEnd2Pos->aLine.*fnRect->fnGetTop)(); | 
					
						
							|  |  |  |                     if( (aEndRect.*fnRect->fnGetTop)() != nTmp ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         (aTmp.*fnRect->fnSetBottom)( | 
					
						
							|  |  |  |                             (aTmp.*fnRect->fnGetTop)() ); | 
					
						
							|  |  |  |                         (aTmp.*fnRect->fnSetTop)( nTmp ); | 
					
						
							|  |  |  |                         if( (aEndRect.*fnRect->fnGetTop)() != | 
					
						
							|  |  |  |                             (pEnd2Pos->aPortion.*fnRect->fnGetTop)() ) | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                         if( bPorR2L ) | 
					
						
							|  |  |  |                             (aTmp.*fnRect->fnSetLeft)( | 
					
						
							|  |  |  |                                 (pEnd2Pos->aPortion.*fnRect->fnGetLeft)() ); | 
					
						
							|  |  |  |                         else | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                             (aTmp.*fnRect->fnSetRight)( | 
					
						
							|  |  |  |                                 (pEnd2Pos->aPortion.*fnRect->fnGetRight)() ); | 
					
						
							|  |  |  |                         aTmp.Intersection( aEndFrm ); | 
					
						
							|  |  |  |                         Sub( aRegion, aTmp ); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 aEndRect = pEnd2Pos->aLine; | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 (aEndRect.*fnRect->fnSetLeft)( bEndR2L ? | 
					
						
							|  |  |  |                         (pEnd2Pos->aPortion.*fnRect->fnGetRight)() : | 
					
						
							|  |  |  |                         (pEnd2Pos->aPortion.*fnRect->fnGetLeft)() ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 (aEndRect.*fnRect->fnSetWidth)( 1 ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |         else if( pSt2Pos && pEnd2Pos && | 
					
						
							|  |  |  |                  MT_BIDI == pSt2Pos->nMultiType && | 
					
						
							|  |  |  |                  MT_BIDI == pEnd2Pos->nMultiType && | 
					
						
							|  |  |  |                  pSt2Pos->aPortion == pEnd2Pos->aPortion && | 
					
						
							|  |  |  |                  pSt2Pos->aPortion2 != pEnd2Pos->aPortion2 ) | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |             // This is the ugly special case, where the selection starts and
 | 
					
						
							|  |  |  |             // ends in the same bidi portion but one start or end is inside a
 | 
					
						
							|  |  |  |             // nested bidi portion.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ( (pSt2Pos->aPortion2.*fnRect->fnGetWidth)() ) | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 SwRect aTmp( aStRect ); | 
					
						
							|  |  |  |                 long nRightAbs = (pSt2Pos->aPortion.*fnRect->fnGetRight)(); | 
					
						
							|  |  |  |                 nRightAbs -= (pSt2Pos->aPortion2.*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |                 long nLeftAbs = nRightAbs - (pSt2Pos->aPortion2.*fnRect->fnGetWidth)(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 (aTmp.*fnRect->fnSetRight)( nRightAbs ); | 
					
						
							| 
									
										
										
										
											2000-11-30 13:11:05 +00:00
										 |  |  |                 aTmp.Intersection( aStFrm ); | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |                 Sub( aRegion, aTmp ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 aStRect = pSt2Pos->aLine; | 
					
						
							|  |  |  |                 (aStRect.*fnRect->fnSetLeft)( bR2L ? nRightAbs : nLeftAbs ); | 
					
						
							|  |  |  |                 (aStRect.*fnRect->fnSetWidth)( 1 ); | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             SWRECTFN( pEndFrm ) | 
					
						
							|  |  |  |             if ( (pEnd2Pos->aPortion2.*fnRect->fnGetWidth)() ) | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |                 SwRect aTmp( aEndRect ); | 
					
						
							|  |  |  |                 long nRightAbs = (pEnd2Pos->aPortion.*fnRect->fnGetRight)(); | 
					
						
							|  |  |  |                 nRightAbs -= (pEnd2Pos->aPortion2.*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |                 long nLeftAbs = nRightAbs - (pEnd2Pos->aPortion2.*fnRect->fnGetWidth)(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 (aTmp.*fnRect->fnSetLeft)( nLeftAbs ); | 
					
						
							| 
									
										
										
										
											2000-11-30 13:11:05 +00:00
										 |  |  |                 aTmp.Intersection( aEndFrm ); | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |                 Sub( aRegion, aTmp ); | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 aEndRect = pEnd2Pos->aLine; | 
					
						
							|  |  |  |                 (aEndRect.*fnRect->fnSetLeft)( bEndR2L ? nLeftAbs : nRightAbs ); | 
					
						
							|  |  |  |                 (aEndRect.*fnRect->fnSetWidth)( 1 ); | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-11-30 13:11:05 +00:00
										 |  |  |         // The charrect may be outside the paintarea (for cursortravelling)
 | 
					
						
							|  |  |  |         // but the selection has to be restricted to the paintarea
 | 
					
						
							|  |  |  |         if( aStRect.Left() < aStFrm.Left() ) | 
					
						
							|  |  |  |             aStRect.Left( aStFrm.Left() ); | 
					
						
							|  |  |  |         else if( aStRect.Left() > aStFrm.Right() ) | 
					
						
							|  |  |  |             aStRect.Left( aStFrm.Right() ); | 
					
						
							|  |  |  |         SwTwips nTmp = aStRect.Right(); | 
					
						
							|  |  |  |         if( nTmp < aStFrm.Left() ) | 
					
						
							|  |  |  |             aStRect.Right( aStFrm.Left() ); | 
					
						
							|  |  |  |         else if( nTmp > aStFrm.Right() ) | 
					
						
							|  |  |  |             aStRect.Right( aStFrm.Right() ); | 
					
						
							|  |  |  |         if( aEndRect.Left() < aEndFrm.Left() ) | 
					
						
							|  |  |  |             aEndRect.Left( aEndFrm.Left() ); | 
					
						
							|  |  |  |         else if( aEndRect.Left() > aEndFrm.Right() ) | 
					
						
							|  |  |  |             aEndRect.Left( aEndFrm.Right() ); | 
					
						
							|  |  |  |         nTmp = aEndRect.Right(); | 
					
						
							|  |  |  |         if( nTmp < aEndFrm.Left() ) | 
					
						
							|  |  |  |             aEndRect.Right( aEndFrm.Left() ); | 
					
						
							|  |  |  |         else if( nTmp > aEndFrm.Right() ) | 
					
						
							|  |  |  |             aEndRect.Right( aEndFrm.Right() ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |         if( pStartFrm == pEndFrm ) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |             sal_Bool bSameRotatedOrBidi = pSt2Pos && pEnd2Pos && | 
					
						
							|  |  |  |                 ( MT_BIDI & pSt2Pos->nMultiType ) && | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 pSt2Pos->aPortion == pEnd2Pos->aPortion; | 
					
						
							|  |  |  |             //case 1: (Same frame and same row)
 | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |             if( bSameRotatedOrBidi || | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 (aStRect.*fnRect->fnGetTop)() == (aEndRect.*fnRect->fnGetTop)() ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 Point aTmpSt( aStRect.Pos() ); | 
					
						
							|  |  |  |                 Point aTmpEnd( aEndRect.Right(), aEndRect.Bottom() ); | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 if( bSameRotatedOrBidi || bR2L ) | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 { | 
					
						
							| 
									
										
										
										
											2001-11-14 13:41:25 +00:00
										 |  |  |                     if( aTmpSt.Y() > aTmpEnd.Y() ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         long nTmpY = aTmpEnd.Y(); | 
					
						
							|  |  |  |                         aTmpEnd.Y() = aTmpSt.Y(); | 
					
						
							|  |  |  |                         aTmpSt.Y() = nTmpY; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     if( aTmpSt.X() > aTmpEnd.X() ) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         long nTmpX = aTmpEnd.X(); | 
					
						
							|  |  |  |                         aTmpEnd.X() = aTmpSt.X(); | 
					
						
							|  |  |  |                         aTmpSt.X() = nTmpX; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 SwRect aTmp = SwRect( aTmpSt, aTmpEnd ); | 
					
						
							|  |  |  |                 // Bug 34888: falls Inhalt selektiert ist, der keinen Platz
 | 
					
						
							|  |  |  |                 //            einnimmt (z.B. PostIts,RefMarks, TOXMarks),
 | 
					
						
							|  |  |  |                 //            dann mindestens die Breite des Crsr setzen.
 | 
					
						
							|  |  |  |                 if( 1 == (aTmp.*fnRect->fnGetWidth)() && | 
					
						
							|  |  |  |                     pStartPos->nContent.GetIndex() != | 
					
						
							|  |  |  |                     pEndPos->nContent.GetIndex() ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     OutputDevice* pOut = pSh->GetOut(); | 
					
						
							|  |  |  |                     long nCrsrWidth = pOut->GetSettings().GetStyleSettings(). | 
					
						
							|  |  |  |                                         GetCursorSize(); | 
					
						
							|  |  |  |                     (aTmp.*fnRect->fnSetWidth)( pOut->PixelToLogic( | 
					
						
							|  |  |  |                                               Size( nCrsrWidth, 0 ) ).Width() ); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 aTmp.Intersection( aStFrm ); | 
					
						
							|  |  |  |                 Sub( aRegion, aTmp ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             //case 2: (Same frame, but not the same line)
 | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SwTwips lLeft, lRight; | 
					
						
							|  |  |  |                 if( pSt2Pos && pEnd2Pos && pSt2Pos->aPortion == pEnd2Pos->aPortion ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     lLeft = (pSt2Pos->aPortion.*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |                     lRight = (pSt2Pos->aPortion.*fnRect->fnGetRight)(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     lLeft = (pStartFrm->Frm().*fnRect->fnGetLeft)() + | 
					
						
							|  |  |  |                             (pStartFrm->Prt().*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |                     lRight = (pStartFrm->Frm().*fnRect->fnGetLeft)() + | 
					
						
							|  |  |  |                              (pStartFrm->Prt().*fnRect->fnGetRight)(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if( lLeft < (aStFrm.*fnRect->fnGetLeft)() ) | 
					
						
							|  |  |  |                     lLeft = (aStFrm.*fnRect->fnGetLeft)(); | 
					
						
							|  |  |  |                 if( lRight > (aStFrm.*fnRect->fnGetRight)() ) | 
					
						
							|  |  |  |                     lRight = (aStFrm.*fnRect->fnGetRight)(); | 
					
						
							|  |  |  |                 SwRect aSubRect( aStRect ); | 
					
						
							|  |  |  |                 //First line
 | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 if( bR2L ) | 
					
						
							|  |  |  |                     (aSubRect.*fnRect->fnSetLeft)( lLeft ); | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                     (aSubRect.*fnRect->fnSetRight)( lRight ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 Sub( aRegion, aSubRect ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 //If there's at least a twips between start- and endline,
 | 
					
						
							|  |  |  |                 //so the whole area between will be added.
 | 
					
						
							|  |  |  |                 SwTwips aTmpBottom = (aStRect.*fnRect->fnGetBottom)(); | 
					
						
							|  |  |  |                 SwTwips aTmpTop = (aEndRect.*fnRect->fnGetTop)(); | 
					
						
							|  |  |  |                 if( aTmpBottom != aTmpTop ) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     (aSubRect.*fnRect->fnSetLeft)( lLeft ); | 
					
						
							|  |  |  |                     (aSubRect.*fnRect->fnSetRight)( lRight ); | 
					
						
							|  |  |  |                     (aSubRect.*fnRect->fnSetTop)( aTmpBottom ); | 
					
						
							| 
									
										
										
										
											2002-08-19 10:16:14 +00:00
										 |  |  |                     (aSubRect.*fnRect->fnSetBottom)( aTmpTop ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                     Sub( aRegion, aSubRect ); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 //and the last line
 | 
					
						
							|  |  |  |                 aSubRect = aEndRect; | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 if( bR2L ) | 
					
						
							|  |  |  |                     (aSubRect.*fnRect->fnSetRight)( lRight ); | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                     (aSubRect.*fnRect->fnSetLeft)( lLeft ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 Sub( aRegion, aSubRect ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         //case 3: (Different frames, maybe with ohther frames between
 | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             //The startframe first...
 | 
					
						
							|  |  |  |             SwRect aSubRect( aStRect ); | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |             if( bR2L ) | 
					
						
							|  |  |  |                 (aSubRect.*fnRect->fnSetLeft)( (aStFrm.*fnRect->fnGetLeft)()); | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |                 (aSubRect.*fnRect->fnSetRight)( (aStFrm.*fnRect->fnGetRight)()); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |             Sub( aRegion, aSubRect ); | 
					
						
							|  |  |  |             SwTwips nTmp = (aStRect.*fnRect->fnGetBottom)(); | 
					
						
							|  |  |  |             if( (aStFrm.*fnRect->fnGetBottom)() != nTmp ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 aSubRect = aStFrm; | 
					
						
							|  |  |  |                 (aSubRect.*fnRect->fnSetTop)( nTmp ); | 
					
						
							|  |  |  |                 Sub( aRegion, aSubRect ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             //Now the frames between, if there are any
 | 
					
						
							|  |  |  |             BOOL bBody = pStartFrm->IsInDocBody(); | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |             const SwTableBox* pCellBox = pStartFrm->GetUpper()->IsCellFrm() ? | 
					
						
							|  |  |  |                                          ((SwCellFrm*)pStartFrm->GetUpper())->GetTabBox() : 0; | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |             const SwCntntFrm *pCntnt = pStartFrm->GetNextCntntFrm(); | 
					
						
							|  |  |  |             SwRect aPrvRect; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             while ( pCntnt != pEndFrm ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 if ( pCntnt->IsInFly() ) | 
					
						
							|  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |                     const SwAnchoredObject* pObj = pCntnt->FindFlyFrm(); | 
					
						
							|  |  |  |                     aSortObjs.Insert( *(const_cast<SwAnchoredObject*>(pObj)) ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-13 10:19:26 +00:00
										 |  |  |                 // Consider only frames which have the same IsInDocBody value like pStartFrm
 | 
					
						
							|  |  |  |                 // If pStartFrm is inside a SwCellFrm, consider only frames which are inside the
 | 
					
						
							|  |  |  |                 // same cell frame (or its follow cell)
 | 
					
						
							|  |  |  |                 const SwTableBox* pTmpCellBox = pCntnt->GetUpper()->IsCellFrm() ? | 
					
						
							|  |  |  |                                                 ((SwCellFrm*)pCntnt->GetUpper())->GetTabBox() : 0; | 
					
						
							|  |  |  |                 if ( bBody == pCntnt->IsInDocBody() && | 
					
						
							| 
									
										
										
										
											2005-03-23 10:53:58 +00:00
										 |  |  |                     ( !pCellBox || pCellBox == pTmpCellBox ) ) | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     SwRect aCRect( pCntnt->UnionFrm( sal_True ) ); | 
					
						
							|  |  |  |                     aCRect.Intersection( pCntnt->PaintArea() ); | 
					
						
							|  |  |  |                     if( aCRect.IsOver( aRegion.GetOrigin() )) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         SwRect aTmp( aPrvRect ); | 
					
						
							|  |  |  |                         aTmp.Union( aCRect ); | 
					
						
							|  |  |  |                         if ( (aPrvRect.Height() * aPrvRect.Width() + | 
					
						
							|  |  |  |                             aCRect.Height()   * aCRect.Width()) == | 
					
						
							|  |  |  |                             (aTmp.Height() * aTmp.Width()) ) | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             aPrvRect.Union( aCRect ); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         else | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             if ( aPrvRect.HasArea() ) | 
					
						
							|  |  |  |                                 Sub( aRegion, aPrvRect ); | 
					
						
							|  |  |  |                             aPrvRect = aCRect; | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 pCntnt = pCntnt->GetNextCntntFrm(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if ( aPrvRect.HasArea() ) | 
					
						
							|  |  |  |                 Sub( aRegion, aPrvRect ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             //At least the endframe...
 | 
					
						
							|  |  |  |             bVert = pEndFrm->IsVertical(); | 
					
						
							|  |  |  |             bRev = pEndFrm->IsReverse(); | 
					
						
							|  |  |  |             fnRect = bVert ? ( bRev ? fnRectVL2R : fnRectVert ) : | 
					
						
							|  |  |  |                              ( bRev ? fnRectB2T : fnRectHori ); | 
					
						
							|  |  |  |             nTmp = (aEndRect.*fnRect->fnGetTop)(); | 
					
						
							|  |  |  |             if( (aEndFrm.*fnRect->fnGetTop)() != nTmp ) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 aSubRect = aEndFrm; | 
					
						
							| 
									
										
										
										
											2002-08-19 10:16:14 +00:00
										 |  |  |                 (aSubRect.*fnRect->fnSetBottom)( nTmp ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |                 Sub( aRegion, aSubRect ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             aSubRect = aEndRect; | 
					
						
							| 
									
										
										
										
											2003-03-27 14:45:43 +00:00
										 |  |  |             if( bEndR2L ) | 
					
						
							| 
									
										
										
										
											2002-02-15 13:33:06 +00:00
										 |  |  |                 (aSubRect.*fnRect->fnSetRight)((aEndFrm.*fnRect->fnGetRight)()); | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |                 (aSubRect.*fnRect->fnSetLeft)( (aEndFrm.*fnRect->fnGetLeft)() ); | 
					
						
							| 
									
										
										
										
											2001-10-23 10:42:19 +00:00
										 |  |  |             Sub( aRegion, aSubRect ); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2001-01-29 11:34:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  | //      aRegion.Compress( FALSE );
 | 
					
						
							|  |  |  |         aRegion.Invert(); | 
					
						
							| 
									
										
										
										
											2000-11-30 10:09:18 +00:00
										 |  |  |         delete pSt2Pos; | 
					
						
							|  |  |  |         delete pEnd2Pos; | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Flys mit Durchlauf ausstanzen. Nicht ausgestanzt werden Flys:
 | 
					
						
							|  |  |  |     //- die Lower des StartFrm/EndFrm sind (FlyInCnt und alle Flys die wiederum
 | 
					
						
							|  |  |  |     //  darin sitzen)
 | 
					
						
							|  |  |  |     //- in der Z-Order ueber denjenigen Flys stehen in denen sich der StartFrm
 | 
					
						
							|  |  |  |     //  befindet.
 | 
					
						
							|  |  |  |     const SwPageFrm *pPage      = pStartFrm->FindPageFrm(); | 
					
						
							|  |  |  |     const SwPageFrm *pEndPage   = pEndFrm->FindPageFrm(); | 
					
						
							|  |  |  |     const SwFlyFrm  *pStartFly  = pStartFrm->FindFlyFrm(); | 
					
						
							|  |  |  |     const SwFlyFrm  *pEndFly    = pEndFrm->FindFlyFrm(); | 
					
						
							|  |  |  |     while ( pPage ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ( pPage->GetSortedObjs() ) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |             const SwSortedObjs &rObjs = *pPage->GetSortedObjs(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |             for ( USHORT i = 0; i < rObjs.Count(); ++i ) | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |                 SwAnchoredObject* pAnchoredObj = rObjs[i]; | 
					
						
							|  |  |  |                 if ( !pAnchoredObj->ISA(SwFlyFrm) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                     continue; | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |                 const SwFlyFrm* pFly = static_cast<const SwFlyFrm*>(pAnchoredObj); | 
					
						
							|  |  |  |                 const SwVirtFlyDrawObj* pObj = pFly->GetVirtDrawObj(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                 const SwFmtSurround &rSur = pFly->GetFmt()->GetSurround(); | 
					
						
							|  |  |  |                 if ( !pFly->IsAnLower( pStartFrm ) && | 
					
						
							|  |  |  |                      (rSur.GetSurround() != SURROUND_THROUGHT && | 
					
						
							|  |  |  |                       !rSur.IsContour()) ) | 
					
						
							|  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |                     if ( aSortObjs.Contains( *pAnchoredObj ) ) | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     FASTBOOL bSub = TRUE; | 
					
						
							|  |  |  |                     const UINT32 nPos = pObj->GetOrdNum(); | 
					
						
							|  |  |  |                     for ( USHORT k = 0; bSub && k < aSortObjs.Count(); ++k ) | 
					
						
							|  |  |  |                     { | 
					
						
							| 
									
										
										
										
											2004-08-02 13:13:41 +00:00
										 |  |  |                         ASSERT( aSortObjs[k]->ISA(SwFlyFrm), | 
					
						
							|  |  |  |                                 "<SwRootFrm::CalcFrmRects(..)> - object in <aSortObjs> of unexcepted type" ); | 
					
						
							|  |  |  |                         const SwFlyFrm* pTmp = static_cast<SwFlyFrm*>(aSortObjs[k]); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         do | 
					
						
							|  |  |  |                         {   if ( nPos < pTmp->GetVirtDrawObj()->GetOrdNumDirect() ) | 
					
						
							|  |  |  |                                 bSub = FALSE; | 
					
						
							|  |  |  |                             else | 
					
						
							| 
									
										
										
										
											2004-06-28 12:41:51 +00:00
										 |  |  |                                 pTmp = pTmp->GetAnchorFrm()->FindFlyFrm(); | 
					
						
							| 
									
										
										
										
											2000-09-18 23:08:29 +00:00
										 |  |  |                         } while ( bSub && pTmp ); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     if ( bSub ) | 
					
						
							|  |  |  |                         Sub( aRegion, pFly->Frm() ); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ( pPage == pEndPage ) | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |             pPage = (SwPageFrm*)pPage->GetNext(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //Weil's besser aussieht noch die DropCaps ausschliessen.
 | 
					
						
							|  |  |  |     SwRect aDropRect; | 
					
						
							|  |  |  |     if ( pStartFrm->IsTxtFrm() ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ( ((SwTxtFrm*)pStartFrm)->GetDropRect( aDropRect ) ) | 
					
						
							|  |  |  |             Sub( aRegion, aDropRect ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ( pEndFrm != pStartFrm && pEndFrm->IsTxtFrm() ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ( ((SwTxtFrm*)pEndFrm)->GetDropRect( aDropRect ) ) | 
					
						
							|  |  |  |             Sub( aRegion, aDropRect ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     rCrsr.Remove( 0, rCrsr.Count() ); | 
					
						
							|  |  |  |     rCrsr.Insert( &aRegion, 0 ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |