2002-02-04 13:10:18 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: accframe.cxx,v $
|
|
|
|
*
|
2002-07-10 15:53:35 +00:00
|
|
|
* $Revision: 1.16 $
|
2002-02-04 13:10:18 +00:00
|
|
|
*
|
2002-07-10 15:53:35 +00:00
|
|
|
* last change: $Author: mib $ $Date: 2002-07-10 16:53:33 $
|
2002-02-04 13:10:18 +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): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifdef PRECOMPILED
|
|
|
|
#include "core_pch.hxx"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#pragma hdrstop
|
|
|
|
|
2002-04-05 11:18:25 +00:00
|
|
|
|
2002-02-05 14:52:06 +00:00
|
|
|
#include <hintids.hxx>
|
|
|
|
#ifndef _SVX_BRSHITEM_HXX //autogen
|
|
|
|
#include <svx/brshitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FLYFRM_HXX
|
|
|
|
#include <flyfrm.hxx>
|
|
|
|
#endif
|
|
|
|
|
2002-02-04 13:10:18 +00:00
|
|
|
#ifndef _LAYFRM_HXX
|
|
|
|
#include <layfrm.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _ROOTFRM_HXX
|
|
|
|
#include <rootfrm.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TXTFRM_HXX
|
|
|
|
#include <txtfrm.hxx>
|
|
|
|
#endif
|
2002-02-05 14:52:06 +00:00
|
|
|
#ifndef _SECTFRM_HXX
|
|
|
|
#include <sectfrm.hxx>
|
|
|
|
#endif
|
2002-04-05 11:18:25 +00:00
|
|
|
#ifndef _PAGEFRM_HXX
|
|
|
|
#include <pagefrm.hxx>
|
|
|
|
#endif
|
2002-02-05 14:52:06 +00:00
|
|
|
#ifndef _FRMSH_HXX
|
|
|
|
#include <frmsh.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SECTION_HXX
|
|
|
|
#include <section.hxx>
|
|
|
|
#endif
|
2002-02-04 13:10:18 +00:00
|
|
|
#ifndef _VIEWSH_HXX
|
|
|
|
#include <viewsh.hxx>
|
|
|
|
#endif
|
2002-02-05 14:52:06 +00:00
|
|
|
#ifndef _VIEWOPT_HXX
|
|
|
|
#include <viewopt.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _DOC_HXX
|
|
|
|
#include <doc.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FRMATR_HXX
|
|
|
|
#include <frmatr.hxx>
|
|
|
|
#endif
|
2002-04-11 13:04:40 +00:00
|
|
|
#ifndef _PAGEFRM_HXX
|
|
|
|
#include <pagefrm.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGEDESC_HXX
|
|
|
|
#include <pagedesc.hxx>
|
|
|
|
#endif
|
2002-05-15 12:22:47 +00:00
|
|
|
#ifndef _FMTANCHR_HXX
|
|
|
|
#include <fmtanchr.hxx>
|
|
|
|
#endif
|
2002-04-11 13:04:40 +00:00
|
|
|
#ifndef _FLDBAS_HXX
|
|
|
|
#include <fldbas.hxx>
|
|
|
|
#endif
|
2002-05-15 12:22:47 +00:00
|
|
|
#ifndef _DCONTACT_HXX
|
|
|
|
#include <dcontact.hxx>
|
|
|
|
#endif
|
2002-02-04 13:10:18 +00:00
|
|
|
|
2002-02-20 16:55:57 +00:00
|
|
|
#ifndef _ACCMAP_HXX
|
|
|
|
#include <accmap.hxx>
|
|
|
|
#endif
|
2002-04-05 11:18:25 +00:00
|
|
|
#ifndef _ACCFRMOBJSLIST_HXX
|
|
|
|
#include <accfrmobjslist.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _ACCFRMOBJMAP_HXX
|
|
|
|
#include <accfrmobjmap.hxx>
|
|
|
|
#endif
|
2002-02-04 13:10:18 +00:00
|
|
|
#ifndef _ACCFRAME_HXX
|
|
|
|
#include <accframe.hxx>
|
|
|
|
#endif
|
|
|
|
|
2002-04-05 11:18:25 +00:00
|
|
|
|
2002-02-11 11:51:16 +00:00
|
|
|
// Regarding visibilily (or in terms of accessibility: regarding the showing
|
|
|
|
// state): A frame is visible and therfor contained in the tree if its frame
|
|
|
|
// size overlaps with the visible area. The bounding box however is the
|
|
|
|
// frame's paint area.
|
2002-04-11 13:04:40 +00:00
|
|
|
sal_Int32 SwAccessibleFrame::GetChildCount( const SwRect& rVisArea,
|
2002-05-22 10:48:43 +00:00
|
|
|
const SwFrm *pFrm,
|
|
|
|
sal_Bool bInPagePreview )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
|
|
|
sal_Int32 nCount = 0;
|
2002-04-05 11:18:25 +00:00
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
const SwFrmOrObjSList aVisList( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjSList::const_iterator aIter( aVisList.begin() );
|
|
|
|
while( aIter != aVisList.end() )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
const SwFrmOrObj& rLower = *aIter;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-11 13:04:40 +00:00
|
|
|
nCount++;
|
|
|
|
}
|
|
|
|
else if( rLower.GetSwFrm() )
|
|
|
|
{
|
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
nCount += GetChildCount( rVisArea, rLower.GetSwFrm(),
|
|
|
|
bInPagePreview );
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
++aIter;
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return nCount;
|
|
|
|
}
|
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
SwFrmOrObj SwAccessibleFrame::GetChild( const SwRect& rVisArea,
|
2002-05-22 10:48:43 +00:00
|
|
|
const SwFrm *pFrm,
|
|
|
|
sal_Int32& rPos,
|
|
|
|
sal_Bool bInPagePreview )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
SwFrmOrObj aRet;
|
2002-02-05 14:52:06 +00:00
|
|
|
|
|
|
|
if( rPos >= 0 )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
if( SwFrmOrObjMap::IsSortingRequired( pFrm ) )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
// We need a sorted list here
|
|
|
|
const SwFrmOrObjMap aVisMap( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjMap::const_iterator aIter( aVisMap.begin() );
|
|
|
|
while( aIter != aVisMap.end() && !aRet.IsValid() )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
const SwFrmOrObj& rLower = (*aIter).second;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-02-05 14:52:06 +00:00
|
|
|
{
|
|
|
|
if( 0 == rPos )
|
2002-04-05 11:18:25 +00:00
|
|
|
aRet = rLower;
|
2002-02-05 14:52:06 +00:00
|
|
|
else
|
|
|
|
rPos--;
|
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
else if( rLower.GetSwFrm() )
|
2002-02-05 14:52:06 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
aRet = GetChild( rVisArea, rLower.GetSwFrm(), rPos,
|
|
|
|
bInPagePreview );
|
2002-02-05 14:52:06 +00:00
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
++aIter;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// The unsorted list is sorted enough, because it return lower
|
|
|
|
// frames in the correct order.
|
|
|
|
const SwFrmOrObjSList aVisList( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjSList::const_iterator aIter( aVisList.begin() );
|
|
|
|
while( aIter != aVisList.end() && !aRet.IsValid() )
|
|
|
|
{
|
|
|
|
const SwFrmOrObj& rLower = *aIter;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-04-05 11:18:25 +00:00
|
|
|
{
|
|
|
|
if( 0 == rPos )
|
|
|
|
aRet = rLower;
|
|
|
|
else
|
|
|
|
rPos--;
|
|
|
|
}
|
|
|
|
else if( rLower.GetSwFrm() )
|
|
|
|
{
|
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
aRet = GetChild( rVisArea, rLower.GetSwFrm(), rPos,
|
|
|
|
bInPagePreview );
|
2002-04-05 11:18:25 +00:00
|
|
|
}
|
|
|
|
++aIter;
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-05 11:18:25 +00:00
|
|
|
return aRet;
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
sal_Bool SwAccessibleFrame::GetChildIndex( const SwRect& rVisArea,
|
2002-04-05 11:18:25 +00:00
|
|
|
const SwFrm *pFrm,
|
|
|
|
const SwFrmOrObj& rChild,
|
2002-05-22 10:48:43 +00:00
|
|
|
sal_Int32& rPos,
|
|
|
|
sal_Bool bInPagePreview )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
|
|
|
sal_Bool bFound = sal_False;
|
2002-04-05 11:18:25 +00:00
|
|
|
|
|
|
|
if( SwFrmOrObjMap::IsSortingRequired( pFrm ) )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
// We need a sorted list here
|
|
|
|
const SwFrmOrObjMap aVisMap( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjMap::const_iterator aIter( aVisMap.begin() );
|
|
|
|
while( aIter != aVisMap.end() && !bFound )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
const SwFrmOrObj& rLower = (*aIter).second;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
if( rChild == rLower )
|
2002-02-04 13:10:18 +00:00
|
|
|
bFound = sal_True;
|
|
|
|
else
|
|
|
|
rPos++;
|
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
else if( rLower.GetSwFrm() )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
bFound = GetChildIndex( rVisArea, rLower.GetSwFrm(), rChild,
|
|
|
|
rPos, bInPagePreview );
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
++aIter;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// The unsorted list is sorted enough, because it return lower
|
|
|
|
// frames in the correct order.
|
|
|
|
const SwFrmOrObjSList aVisList( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjSList::const_iterator aIter( aVisList.begin() );
|
|
|
|
while( aIter != aVisList.end() && !bFound )
|
|
|
|
{
|
|
|
|
const SwFrmOrObj& rLower = *aIter;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-04-05 11:18:25 +00:00
|
|
|
{
|
|
|
|
if( rChild == rLower )
|
|
|
|
bFound = sal_True;
|
|
|
|
else
|
|
|
|
rPos++;
|
|
|
|
}
|
|
|
|
else if( rLower.GetSwFrm() )
|
|
|
|
{
|
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
bFound = GetChildIndex( rVisArea, rLower.GetSwFrm(), rChild,
|
|
|
|
rPos, bInPagePreview );
|
2002-04-05 11:18:25 +00:00
|
|
|
}
|
|
|
|
++aIter;
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return bFound;
|
|
|
|
}
|
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
SwFrmOrObj SwAccessibleFrame::GetChildAt( const SwRect& rVisArea,
|
2002-05-22 10:48:43 +00:00
|
|
|
const SwFrm *pFrm,
|
|
|
|
const Point& rPos,
|
|
|
|
sal_Bool bInPagePreview )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
SwFrmOrObj aRet;
|
|
|
|
|
|
|
|
if( SwFrmOrObjMap::IsSortingRequired( pFrm ) )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
// We need a sorted list here, and we have to reverse iterate,
|
|
|
|
// because objects in front should be returned.
|
|
|
|
const SwFrmOrObjMap aVisMap( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjMap::const_reverse_iterator aRIter( aVisMap.rbegin() );
|
|
|
|
while( aRIter != aVisMap.rend() && !aRet.IsValid() )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
const SwFrmOrObj& rLower = (*aRIter).second;
|
|
|
|
// A frame is returned if it's frame size is inside the visarea
|
|
|
|
// and the positiion is inside the frame's paint area.
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
if( rLower.GetBounds().IsInside( rPos ) )
|
|
|
|
aRet = rLower;
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
else if( rLower.GetSwFrm() )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
aRet = GetChildAt( rVisArea, rLower.GetSwFrm(), rPos,
|
|
|
|
bInPagePreview );
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
aRIter++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// The unsorted list is sorted enough, because it returns lower
|
|
|
|
// frames in the correct order. Morover, we can iterate forward,
|
|
|
|
// because the lowers don't overlap!
|
|
|
|
const SwFrmOrObjSList aVisList( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjSList::const_iterator aIter( aVisList.begin() );
|
|
|
|
while( aIter != aVisList.end() && !aRet.IsValid() )
|
|
|
|
{
|
|
|
|
const SwFrmOrObj& rLower = *aIter;
|
|
|
|
// A frame is returned if it's frame size is inside the visarea
|
|
|
|
// and the positiion is inside the frame's paint area.
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-04-05 11:18:25 +00:00
|
|
|
{
|
|
|
|
if( rLower.GetBounds().IsInside( rPos ) )
|
|
|
|
aRet = rLower;
|
|
|
|
}
|
|
|
|
else if( rLower.GetSwFrm() )
|
|
|
|
{
|
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
aRet = GetChildAt( rVisArea, rLower.GetSwFrm(), rPos,
|
|
|
|
bInPagePreview );
|
2002-04-05 11:18:25 +00:00
|
|
|
}
|
|
|
|
++aIter;
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-05 11:18:25 +00:00
|
|
|
return aRet;
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
|
|
|
|
2002-05-15 12:22:47 +00:00
|
|
|
void SwAccessibleFrame::GetChildren( const SwRect& rVisArea, const SwFrm *pFrm,
|
2002-05-22 10:48:43 +00:00
|
|
|
::std::list< SwFrmOrObj >& rChildren,
|
|
|
|
sal_Bool bInPagePreview )
|
2002-05-15 12:22:47 +00:00
|
|
|
{
|
|
|
|
if( SwFrmOrObjMap::IsSortingRequired( pFrm ) )
|
|
|
|
{
|
|
|
|
// We need a sorted list here
|
|
|
|
const SwFrmOrObjMap aVisMap( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjMap::const_iterator aIter( aVisMap.begin() );
|
|
|
|
while( aIter != aVisMap.end() )
|
|
|
|
{
|
|
|
|
const SwFrmOrObj& rLower = (*aIter).second;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-05-15 12:22:47 +00:00
|
|
|
{
|
|
|
|
rChildren.push_back( rLower );
|
|
|
|
}
|
|
|
|
else if( rLower.GetSwFrm() )
|
|
|
|
{
|
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
GetChildren( rVisArea, rLower.GetSwFrm(), rChildren,
|
|
|
|
bInPagePreview );
|
2002-05-15 12:22:47 +00:00
|
|
|
}
|
|
|
|
++aIter;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// The unsorted list is sorted enough, because it return lower
|
|
|
|
// frames in the correct order.
|
|
|
|
const SwFrmOrObjSList aVisList( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjSList::const_iterator aIter( aVisList.begin() );
|
|
|
|
while( aIter != aVisList.end() )
|
|
|
|
{
|
|
|
|
const SwFrmOrObj& rLower = *aIter;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-05-15 12:22:47 +00:00
|
|
|
{
|
|
|
|
rChildren.push_back( rLower );
|
|
|
|
}
|
|
|
|
else if( rLower.GetSwFrm() )
|
|
|
|
{
|
|
|
|
// There are no unaccessible SdrObjects that count
|
2002-05-22 10:48:43 +00:00
|
|
|
GetChildren( rVisArea, rLower.GetSwFrm(), rChildren,
|
|
|
|
bInPagePreview );
|
2002-05-15 12:22:47 +00:00
|
|
|
}
|
|
|
|
++aIter;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-02-27 08:32:33 +00:00
|
|
|
void SwAccessibleFrame::MergeLowerBounds( SwRect& rBounds,
|
2002-04-11 13:04:40 +00:00
|
|
|
const SwRect& rVisArea,
|
2002-05-22 10:48:43 +00:00
|
|
|
const SwFrm *pFrm,
|
|
|
|
sal_Bool bInPagePreview )
|
2002-02-27 08:32:33 +00:00
|
|
|
{
|
2002-04-11 13:04:40 +00:00
|
|
|
const SwFrmOrObjSList aVisList( rVisArea, pFrm );
|
|
|
|
SwFrmOrObjSList::const_iterator aIter( aVisList.begin() );
|
|
|
|
while( aIter != aVisList.end() )
|
2002-02-20 16:55:57 +00:00
|
|
|
{
|
2002-04-05 11:18:25 +00:00
|
|
|
const SwFrmOrObj& rLower = *aIter;
|
2002-05-22 10:48:43 +00:00
|
|
|
if( rLower.IsAccessible( bInPagePreview ) )
|
2002-02-20 16:55:57 +00:00
|
|
|
{
|
2002-04-11 13:04:40 +00:00
|
|
|
rBounds.Union( rLower.GetBounds() );
|
2002-02-20 16:55:57 +00:00
|
|
|
}
|
2002-04-11 13:04:40 +00:00
|
|
|
else if( rLower.GetSwFrm() )
|
2002-02-20 16:55:57 +00:00
|
|
|
{
|
2002-05-22 10:48:43 +00:00
|
|
|
MergeLowerBounds( rBounds, rVisArea, rLower.GetSwFrm(),
|
|
|
|
bInPagePreview );
|
2002-02-20 16:55:57 +00:00
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
++aIter;
|
2002-02-20 16:55:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
SwRect SwAccessibleFrame::GetBounds( const SwFrm *pFrm )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
|
|
|
if( !pFrm )
|
|
|
|
pFrm = GetFrm();
|
2002-02-27 08:32:33 +00:00
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
SwFrmOrObj aFrm( pFrm );
|
2002-05-22 10:48:43 +00:00
|
|
|
SwRect aBounds( aFrm.GetBounds().Intersection( maVisArea ) );
|
2002-02-04 13:10:18 +00:00
|
|
|
return aBounds;
|
|
|
|
}
|
|
|
|
|
2002-02-20 16:55:57 +00:00
|
|
|
sal_Bool SwAccessibleFrame::IsEditable( ViewShell *pVSh ) const
|
2002-02-05 14:52:06 +00:00
|
|
|
{
|
|
|
|
const SwFrm *pFrm = GetFrm();
|
|
|
|
if( !pFrm )
|
|
|
|
return sal_False;
|
|
|
|
|
2002-03-18 11:49:59 +00:00
|
|
|
ASSERT( pVSh, "no view shell" );
|
2002-07-10 15:53:35 +00:00
|
|
|
if( pVSh && (pVSh->GetViewOptions()->IsReadonly() ||
|
|
|
|
pVSh->IsPreView()) )
|
2002-02-05 14:52:06 +00:00
|
|
|
return sal_False;
|
|
|
|
|
2002-03-18 11:49:59 +00:00
|
|
|
if( !pFrm->IsRootFrm() && pFrm->IsProtected() )
|
|
|
|
return sal_False;
|
2002-02-05 14:52:06 +00:00
|
|
|
|
2002-03-18 11:49:59 +00:00
|
|
|
return sal_True;
|
2002-02-05 14:52:06 +00:00
|
|
|
}
|
|
|
|
|
2002-02-20 16:55:57 +00:00
|
|
|
sal_Bool SwAccessibleFrame::IsOpaque( ViewShell *pVSh ) const
|
2002-02-05 14:52:06 +00:00
|
|
|
{
|
2002-04-11 13:04:40 +00:00
|
|
|
SwFrmOrObj aFrm( GetFrm() );
|
|
|
|
if( !aFrm.GetSwFrm() )
|
2002-02-05 14:52:06 +00:00
|
|
|
return sal_False;
|
|
|
|
|
|
|
|
ASSERT( pVSh, "no view shell" );
|
|
|
|
if( !pVSh )
|
|
|
|
return sal_False;
|
|
|
|
|
|
|
|
const SwViewOption *pVOpt = pVSh->GetViewOptions();
|
|
|
|
do
|
|
|
|
{
|
2002-04-11 13:04:40 +00:00
|
|
|
const SwFrm *pFrm = aFrm.GetSwFrm();
|
2002-02-05 14:52:06 +00:00
|
|
|
if( pFrm->IsRootFrm() )
|
|
|
|
return sal_True;
|
|
|
|
|
|
|
|
if( pFrm->IsPageFrm() && !pVOpt->IsPageBack() )
|
|
|
|
return sal_False;
|
|
|
|
|
|
|
|
const SvxBrushItem &rBack = pFrm->GetAttrSet()->GetBackground();
|
|
|
|
if( !rBack.GetColor().GetTransparency() ||
|
|
|
|
rBack.GetGraphicPos() != GPOS_NONE )
|
|
|
|
return sal_True;
|
|
|
|
|
|
|
|
if( pFrm->IsSctFrm() )
|
|
|
|
{
|
|
|
|
const SwSection* pSection = ((SwSectionFrm*)pFrm)->GetSection();
|
|
|
|
if( pSection && ( TOX_HEADER_SECTION == pSection->GetType() ||
|
|
|
|
TOX_CONTENT_SECTION == pSection->GetType() ) &&
|
2002-06-20 08:21:18 +00:00
|
|
|
!pVOpt->IsReadonly() &&
|
2002-04-25 13:00:16 +00:00
|
|
|
SwViewOption::IsIndexShadings() )
|
2002-02-05 14:52:06 +00:00
|
|
|
return sal_True;
|
|
|
|
}
|
2002-04-11 13:04:40 +00:00
|
|
|
if( pFrm->IsFlyFrm() )
|
|
|
|
aFrm = static_cast<const SwFlyFrm*>(pFrm)->GetAnchor();
|
2002-02-05 14:52:06 +00:00
|
|
|
else
|
2002-04-11 13:04:40 +00:00
|
|
|
aFrm = pFrm->GetUpper();
|
2002-05-22 10:48:43 +00:00
|
|
|
} while( aFrm.GetSwFrm() && !aFrm.IsAccessible( IsInPagePreview() ) );
|
2002-02-05 14:52:06 +00:00
|
|
|
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
SwAccessibleFrame::SwAccessibleFrame( const SwRect& rVisArea,
|
2002-05-22 10:48:43 +00:00
|
|
|
const SwFrm *pF,
|
|
|
|
sal_Bool bIsPagePreview ) :
|
|
|
|
maVisArea( rVisArea ),
|
|
|
|
mpFrm( pF ),
|
|
|
|
mbIsInPagePreview( bIsPagePreview )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
SwAccessibleFrame::~SwAccessibleFrame()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2002-05-22 10:48:43 +00:00
|
|
|
const SwFrm *SwAccessibleFrame::GetParent( const SwFrmOrObj& rFrmOrObj,
|
|
|
|
sal_Bool bInPagePreview )
|
2002-02-04 13:10:18 +00:00
|
|
|
{
|
2002-04-11 13:04:40 +00:00
|
|
|
SwFrmOrObj aParent;
|
2002-05-15 12:22:47 +00:00
|
|
|
const SwFrm *pFrm = rFrmOrObj.GetSwFrm();
|
|
|
|
if( pFrm )
|
2002-04-05 11:18:25 +00:00
|
|
|
{
|
2002-05-15 12:22:47 +00:00
|
|
|
if( pFrm->IsFlyFrm() )
|
2002-04-05 11:18:25 +00:00
|
|
|
{
|
2002-05-15 12:22:47 +00:00
|
|
|
const SwFlyFrm *pFly = static_cast< const SwFlyFrm *>( pFrm );
|
|
|
|
if( pFly->IsFlyInCntFrm() )
|
|
|
|
{
|
|
|
|
// For FLY_IN_CNTNT the parent is the anchor
|
|
|
|
aParent = pFly->GetAnchor();
|
2002-05-22 10:48:43 +00:00
|
|
|
ASSERT( aParent.IsAccessible( bInPagePreview ),
|
2002-05-15 12:22:47 +00:00
|
|
|
"parent is not accessible" );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// In any other case the parent is the root frm
|
2002-05-22 10:48:43 +00:00
|
|
|
// (in page preview, the page frame)
|
|
|
|
if( bInPagePreview )
|
|
|
|
aParent = pFly->FindPageFrm();
|
|
|
|
else
|
|
|
|
aParent = pFly->FindRootFrm();
|
2002-05-15 12:22:47 +00:00
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2002-05-15 12:22:47 +00:00
|
|
|
SwFrmOrObj aUpper( pFrm->GetUpper() );
|
2002-05-22 10:48:43 +00:00
|
|
|
while( aUpper.GetSwFrm() && !aUpper.IsAccessible(bInPagePreview) )
|
2002-05-15 12:22:47 +00:00
|
|
|
aUpper = aUpper.GetSwFrm()->GetUpper();
|
|
|
|
aParent = aUpper;
|
2002-04-05 11:18:25 +00:00
|
|
|
}
|
|
|
|
}
|
2002-05-15 12:22:47 +00:00
|
|
|
else if( rFrmOrObj.GetSdrObject() )
|
2002-04-05 11:18:25 +00:00
|
|
|
{
|
2002-05-15 12:22:47 +00:00
|
|
|
const SwDrawContact *pContact =
|
|
|
|
static_cast< const SwDrawContact* >(
|
|
|
|
GetUserCall( rFrmOrObj.GetSdrObject() ) );
|
|
|
|
ASSERT( pContact, "sdr contact is missing" );
|
|
|
|
if( pContact )
|
|
|
|
{
|
|
|
|
const SwFrmFmt *pFrmFmt = pContact->GetFmt();
|
|
|
|
ASSERT( pFrmFmt, "frame format is missing" );
|
|
|
|
if( pFrmFmt && FLY_IN_CNTNT == pFrmFmt->GetAnchor().GetAnchorId() )
|
|
|
|
{
|
|
|
|
// For FLY_IN_CNTNT the parent is the anchor
|
|
|
|
aParent = pContact->GetAnchor();
|
2002-05-22 10:48:43 +00:00
|
|
|
ASSERT( aParent.IsAccessible( bInPagePreview ),
|
2002-05-15 12:22:47 +00:00
|
|
|
"parent is not accessible" );
|
|
|
|
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// In any other case the parent is the root frm
|
2002-05-27 14:05:22 +00:00
|
|
|
if( bInPagePreview )
|
|
|
|
aParent = pContact->GetAnchor()->FindPageFrm();
|
|
|
|
else
|
|
|
|
aParent = pContact->GetAnchor()->FindRootFrm();
|
2002-05-15 12:22:47 +00:00
|
|
|
}
|
|
|
|
}
|
2002-04-05 11:18:25 +00:00
|
|
|
}
|
2002-02-04 13:10:18 +00:00
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
return aParent.GetSwFrm();
|
2002-02-04 13:10:18 +00:00
|
|
|
}
|
|
|
|
|
2002-04-11 13:04:40 +00:00
|
|
|
String SwAccessibleFrame::GetFormattedPageNumber() const
|
2002-03-11 10:54:46 +00:00
|
|
|
{
|
2002-04-11 13:04:40 +00:00
|
|
|
sal_uInt16 nPageNum = GetFrm()->GetVirtPageNum();
|
|
|
|
sal_uInt32 nFmt = GetFrm()->FindPageFrm()->GetPageDesc()
|
|
|
|
->GetNumType().GetNumberingType();
|
|
|
|
if( SVX_NUM_NUMBER_NONE == nFmt )
|
|
|
|
nFmt = SVX_NUM_ARABIC;
|
|
|
|
|
|
|
|
String sRet( FormatNumber( nPageNum, nFmt ) );
|
|
|
|
return sRet;
|
2002-03-11 10:54:46 +00:00
|
|
|
}
|