2561 lines
80 KiB
C++
2561 lines
80 KiB
C++
/*************************************************************************
|
||
*
|
||
* $RCSfile: feshview.cxx,v $
|
||
*
|
||
* $Revision: 1.3 $
|
||
*
|
||
* last change: $Author: ama $ $Date: 2002-01-29 10:41:09 $
|
||
*
|
||
* 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
|
||
|
||
#define ITEMID_BOXINFO SID_ATTR_BORDER_INNER
|
||
#include "hintids.hxx"
|
||
|
||
#ifdef WIN
|
||
#define NEEDED_BY_FESHVIEW
|
||
#define _FESHVIEW_ONLY_INLINE_NEEDED
|
||
#endif
|
||
|
||
#ifndef _SVDOUNO_HXX //autogen
|
||
#include <svx/svdouno.hxx>
|
||
#endif
|
||
#ifndef _SVDOOLE2_HXX //autogen
|
||
#include <svx/svdoole2.hxx>
|
||
#endif
|
||
#ifndef _SVDOGRP_HXX //autogen
|
||
#include <svx/svdogrp.hxx>
|
||
#endif
|
||
#ifndef _SVX_FILLITEM_HXX //autogen
|
||
#include <svx/xfillit.hxx>
|
||
#endif
|
||
#ifndef _SVDVMARK_HXX //autogen
|
||
#include <svx/svdvmark.hxx>
|
||
#endif
|
||
#ifndef _XPOLY_HXX //autogen
|
||
#include <svx/xpoly.hxx>
|
||
#endif
|
||
#ifndef _SVDCAPT_HXX //autogen
|
||
#include <svx/svdocapt.hxx>
|
||
#endif
|
||
#ifndef _SFXAPP_HXX //autogen
|
||
#include <sfx2/app.hxx>
|
||
#endif
|
||
#ifndef _SVX_BOXITEM_HXX //autogen
|
||
#include <svx/boxitem.hxx>
|
||
#endif
|
||
#ifndef _SVX_OPAQITEM_HXX //autogen
|
||
#include <svx/opaqitem.hxx>
|
||
#endif
|
||
#ifndef _SVX_PROTITEM_HXX //autogen
|
||
#include <svx/protitem.hxx>
|
||
#endif
|
||
#ifndef _SVDPAGE_HXX //autogen
|
||
#include <svx/svdpage.hxx>
|
||
#endif
|
||
#ifndef _IPOBJ_HXX //autogen
|
||
#include <so3/ipobj.hxx>
|
||
#endif
|
||
|
||
|
||
#ifndef _FRMFMT_HXX //autogen
|
||
#include <frmfmt.hxx>
|
||
#endif
|
||
#ifndef _FRMATR_HXX
|
||
#include <frmatr.hxx>
|
||
#endif
|
||
#ifndef _FMTFSIZE_HXX //autogen
|
||
#include <fmtfsize.hxx>
|
||
#endif
|
||
#ifndef _FMTANCHR_HXX //autogen
|
||
#include <fmtanchr.hxx>
|
||
#endif
|
||
#ifndef _FMTORNT_HXX //autogen
|
||
#include <fmtornt.hxx>
|
||
#endif
|
||
#ifndef _FMTSRND_HXX //autogen
|
||
#include <fmtsrnd.hxx>
|
||
#endif
|
||
#ifndef _FMTCNTNT_HXX //autogen
|
||
#include <fmtcntnt.hxx>
|
||
#endif
|
||
#ifndef _FMTFLCNT_HXX //autogen
|
||
#include <fmtflcnt.hxx>
|
||
#endif
|
||
#ifndef _FMTCNCT_HXX //autogen
|
||
#include <fmtcnct.hxx>
|
||
#endif
|
||
#ifndef _DOCARY_HXX
|
||
#include <docary.hxx>
|
||
#endif
|
||
#ifndef _TBLSEL_HXX //autogen
|
||
#include <tblsel.hxx>
|
||
#endif
|
||
#ifndef _SWTABLE_HXX //autogen
|
||
#include <swtable.hxx>
|
||
#endif
|
||
#include "fesh.hxx"
|
||
#include "rootfrm.hxx"
|
||
#include "pagefrm.hxx"
|
||
#include "sectfrm.hxx"
|
||
#include "doc.hxx"
|
||
#include "dview.hxx"
|
||
#include "dflyobj.hxx"
|
||
#include "dcontact.hxx"
|
||
#include "viewimp.hxx"
|
||
#include "flyfrm.hxx"
|
||
#include "pam.hxx"
|
||
#include "ndole.hxx"
|
||
#include "ndgrf.hxx"
|
||
#include "ndtxt.hxx"
|
||
#include "viewopt.hxx" // fuer GetHTMLMode
|
||
#include "swundo.hxx"
|
||
#include "notxtfrm.hxx"
|
||
#include "txtfrm.hxx"
|
||
#include "txatbase.hxx"
|
||
#include "mdiexp.hxx" // fuer Update der Statuszeile bei drag
|
||
|
||
#define SCROLLVAL 75
|
||
|
||
//Tattergrenze fuer Drawing-SS
|
||
#define MINMOVE ((USHORT)GetOut()->PixelToLogic(Size(Imp()->GetDrawView()->GetMarkHdlSizePixel()/2,0)).Width())
|
||
|
||
SwFlyFrm *GetFlyFromMarked( const SdrMarkList *pLst, ViewShell *pSh )
|
||
{
|
||
if ( !pLst )
|
||
pLst = pSh->HasDrawView() ? &pSh->Imp()->GetDrawView()->GetMarkList():0;
|
||
|
||
if ( pLst && pLst->GetMarkCount() == 1 )
|
||
{
|
||
SdrObject *pO = pLst->GetMark( 0 )->GetObj();
|
||
if ( pO->IsWriterFlyFrame() )
|
||
return ((SwVirtFlyDrawObj*)pO)->GetFlyFrm();
|
||
}
|
||
return 0;
|
||
}
|
||
|
||
void lcl_GrabCursor( SwFEShell* pSh, SwFlyFrm* pOldSelFly)
|
||
{
|
||
const SwFrmFmt *pFlyFmt = pSh->SelFlyGrabCrsr();
|
||
if( pFlyFmt && !pSh->ActionPend() &&
|
||
(!pOldSelFly || pOldSelFly->GetFmt() != pFlyFmt) )
|
||
{
|
||
// dann das evt. gesetzte Macro rufen
|
||
pSh->GetFlyMacroLnk().Call( (void*)pFlyFmt );
|
||
extern BOOL bNoInterrupt; // in swapp.cxx
|
||
// wir in dem Makro ein Dialog gestartet, dann kommt das
|
||
// MouseButtonUp zu diesem und nicht zu uns. Dadurch ist
|
||
// Flag bei uns immer gesetzt und schaltet nie die auf die
|
||
// entsp. Shell um !!!!!!!
|
||
bNoInterrupt = FALSE;
|
||
}
|
||
else if( !pFlyFmt || RES_DRAWFRMFMT == pFlyFmt->Which() )
|
||
pSh->SetCrsr( pSh->Imp()->GetDrawView()->GetAllMarkedRect().TopLeft(), TRUE);
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::SelectObj()
|
||
|*
|
||
|* Ersterstellung MA 16. Nov. 92
|
||
|* Letzte Aenderung MA 22. Oct. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::SelectObj( const Point& rPt, BOOL bAddSelect,
|
||
BOOL bEnterGroup, SdrObject *pObj )
|
||
{
|
||
SET_CURR_SHELL( this );
|
||
StartAction(); //Aktion ist Notwendig, damit nicht mehrere
|
||
//AttrChgdNotify (etwa durch Unmark->MarkListHasChgd)
|
||
//durchkommen
|
||
|
||
ASSERT( Imp()->HasDrawView(), "SelectObj without DrawView?" );
|
||
SwDrawView *pDView = Imp()->GetDrawView();
|
||
const SdrMarkList &rMrkList = pDView->GetMarkList();
|
||
const BOOL bHadSelection = rMrkList.GetMarkCount() ? TRUE : FALSE;
|
||
SwFlyFrm* pOldSelFly = 0;
|
||
const Point aOldPos( pDView->GetAllMarkedRect().TopLeft() );
|
||
|
||
if( bHadSelection )
|
||
{
|
||
//Unmark rufen wenn !bAddSelect oder wenn ein Fly selektiert ist.
|
||
BOOL bUnmark = !bAddSelect;
|
||
|
||
if ( rMrkList.GetMarkCount() == 1 )
|
||
{
|
||
//Wenn ein Fly selektiert ist, so muss er erst deselektiert werden.
|
||
pOldSelFly = ::GetFlyFromMarked( &rMrkList, this );
|
||
if ( pOldSelFly )
|
||
{
|
||
const USHORT nType = GetCntType();
|
||
if( nType != CNT_TXT ||
|
||
( pOldSelFly->GetFmt()->GetProtect().IsCntntProtected()
|
||
&& !IsReadOnlyAvailable() ))
|
||
{
|
||
//Wenn ein Fly deselektiert wird, der Grafik, Ole o.ae.
|
||
//enthaelt, so muss der Crsr aus diesem entfernt werden.
|
||
//Desgleichen wenn ein Fly mit geschuetztem Inhalt deselektiert
|
||
//wird. Der Einfachheit halber wire der Crsr 'grad so neben die
|
||
//linke obere Ecke gesetzt.
|
||
Point aPt( pOldSelFly->Frm().Pos() );
|
||
aPt.X() -= 1;
|
||
BOOL bUnLockView = !IsViewLocked();
|
||
LockView( TRUE );
|
||
SetCrsr( aPt, TRUE );
|
||
if( bUnLockView )
|
||
LockView( FALSE );
|
||
}
|
||
if ( nType & CNT_GRF &&
|
||
((SwNoTxtFrm*)pOldSelFly->Lower())->HasAnimation() )
|
||
{
|
||
GetWin()->Invalidate( pOldSelFly->Frm().SVRect() );
|
||
}
|
||
bUnmark = TRUE;
|
||
}
|
||
#ifdef USED
|
||
else
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( 0 )->GetObj();
|
||
SwFrmFmt *pFrmFmt = FindFrmFmt( pObj );
|
||
if( pFrmFmt &&
|
||
FLY_IN_CNTNT == pFrmFmt->GetAnchor().GetAnchorId() )
|
||
bUnmark = TRUE;
|
||
}
|
||
#endif
|
||
}
|
||
if ( bUnmark )
|
||
pDView->UnmarkAll();
|
||
}
|
||
else
|
||
{
|
||
KillPams();
|
||
ClearMark();
|
||
}
|
||
|
||
if ( pObj )
|
||
pDView->MarkObj( pObj, Imp()->GetPageView(), bAddSelect, bEnterGroup );
|
||
else
|
||
pDView->MarkObj( rPt, MINMOVE, bAddSelect, bEnterGroup );
|
||
|
||
const FASTBOOL bRet = 0 != rMrkList.GetMarkCount();
|
||
|
||
if ( rMrkList.GetMarkCount() > 1 )
|
||
{
|
||
//Ganz dumm ist es, wenn Zeichenobjekte Selektiert waren und
|
||
//nun ein Fly hinzuselektiert wird.
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
BOOL bForget = pObj->IsWriterFlyFrame();
|
||
if( bForget )
|
||
{
|
||
pDView->UnmarkAll();
|
||
if ( pObj )
|
||
pDView->MarkObj( pObj, Imp()->GetPageView(), bAddSelect, bEnterGroup );
|
||
else
|
||
pDView->MarkObj( rPt, MINMOVE );
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
|
||
if ( bRet )
|
||
{
|
||
::lcl_GrabCursor(this, pOldSelFly);
|
||
if ( GetCntType() & CNT_GRF )
|
||
{
|
||
const SwFlyFrm *pTmp = GetFlyFromMarked( &rMrkList, this );
|
||
ASSERT( pTmp, "Graphic without Fly" );
|
||
if ( ((SwNoTxtFrm*)pTmp->Lower())->HasAnimation() )
|
||
((SwNoTxtFrm*)pTmp->Lower())->StopAnimation( GetOut() );
|
||
}
|
||
}
|
||
else if ( !pOldSelFly && bHadSelection )
|
||
SetCrsr( aOldPos, TRUE);
|
||
|
||
if( bRet || !bHadSelection )
|
||
CallChgLnk();
|
||
|
||
// update der Statuszeile
|
||
::FrameNotify( this, bRet ? FLY_DRAG_START : FLY_DRAG_END );
|
||
|
||
EndAction();
|
||
return bRet;
|
||
}
|
||
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::GetSelFrmType()
|
||
|*
|
||
|* Ersterstellung MA 12. Jan. 93
|
||
|* Letzte Aenderung JP 19.03.96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
USHORT SwFEShell::GetSelFrmType() const
|
||
{
|
||
const SdrMarkList* pMrkList;
|
||
if( !Imp()->GetDrawView() ||
|
||
0 == (pMrkList = &Imp()->GetDrawView()->GetMarkList()) ||
|
||
!pMrkList->GetMarkCount())
|
||
return FRMTYPE_NONE;
|
||
|
||
const SwFlyFrm *pFly = ::GetFlyFromMarked( pMrkList, (ViewShell*)this );
|
||
|
||
if ( pFly )
|
||
{
|
||
if( pFly->IsFlyLayFrm() )
|
||
return FRMTYPE_FLY_FREE;
|
||
else if( pFly->IsFlyAtCntFrm() )
|
||
return FRMTYPE_FLY_ATCNT;
|
||
ASSERT( pFly->IsFlyInCntFrm(), "Neuer Rahmentyp?" );
|
||
return FRMTYPE_FLY_INCNT;
|
||
}
|
||
return FRMTYPE_DRAWOBJ;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::Scroll()
|
||
|*
|
||
|* Ersterstellung MA 20. Dec. 94
|
||
|* Letzte Aenderung MA 27. Jul. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::Scroll( const Point &rPt )
|
||
{
|
||
const SwRect aRect( rPt, rPt );
|
||
if ( IsScrollMDI( this, aRect ) &&
|
||
(!Imp()->GetDrawView()->GetMarkList().GetMarkCount() ||
|
||
Imp()->IsDragPossible( rPt )) )
|
||
{
|
||
SwSaveHdl aSave( Imp() );
|
||
ScrollMDI( this, aRect, SCROLLVAL, SCROLLVAL );
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::SetDragMode()
|
||
|*
|
||
|* Ersterstellung MA 30. Jan. 95
|
||
|* Letzte Aenderung MA 30. Jan. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::SetDragMode( UINT16 eDragMode )
|
||
{
|
||
if ( Imp()->HasDrawView() )
|
||
Imp()->GetDrawView()->SetDragMode( (SdrDragMode)eDragMode );
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::BeginDrag()
|
||
|*
|
||
|* Ersterstellung MS 10.06.92
|
||
|* Letzte Aenderung MA 13. Mar. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
long SwFEShell::BeginDrag( const Point* pPt, BOOL )
|
||
{
|
||
SdrView *pView = Imp()->GetDrawView();
|
||
if ( pView && pView->HasMarkedObj() )
|
||
{
|
||
delete pChainFrom; delete pChainTo; pChainFrom = pChainTo = 0;
|
||
SdrHdl* pHdl = pView->HitHandle( *pPt, *GetWin() );
|
||
pView->BegDragObj( *pPt, GetWin(), pHdl );
|
||
::FrameNotify( this, FLY_DRAG );
|
||
return 1;
|
||
}
|
||
return 0;
|
||
}
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::Drag()
|
||
|*
|
||
|* Ersterstellung MS 10.06.92
|
||
|* Letzte Aenderung MA 13. Mar. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
long SwFEShell::Drag( const Point *pPt, BOOL )
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "Drag without DrawView?" );
|
||
if ( Imp()->GetDrawView()->IsDragObj() )
|
||
{
|
||
Scroll( *pPt );
|
||
|
||
#ifdef USED
|
||
JP 31.01.96: der Wunsch ist, das Orthogonale Resizen nur vom Benutzer
|
||
vorgegeben werden kann. (beschlossen und verkuendet: ST/WP/..)
|
||
//OLE wird immer proportional resized.
|
||
if ( !Imp()->GetDrawView()->IsMoveOnlyDragObj( TRUE ) &&
|
||
GetCntType() == CNT_OLE )
|
||
Imp()->GetDrawView()->SetOrtho( TRUE );
|
||
#endif
|
||
|
||
Imp()->GetDrawView()->MovDragObj( *pPt );
|
||
Imp()->GetDrawView()->ShowDragAnchor();
|
||
::FrameNotify( this, FLY_DRAG );
|
||
return 1;
|
||
}
|
||
return 0;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::EndDrag()
|
||
|*
|
||
|* Ersterstellung MS 10.06.92
|
||
|* Letzte Aenderung MA 13. Mar. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
long SwFEShell::EndDrag( const Point *, BOOL )
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "EndDrag without DrawView?" );
|
||
SdrView *pView = Imp()->GetDrawView();
|
||
if ( pView->IsDragObj() )
|
||
{
|
||
//Start-/EndActions nur an der ViewShell aufsetzen
|
||
ViewShell *pSh = this;
|
||
do {
|
||
pSh->StartAction();
|
||
} while ( this != (pSh = (ViewShell*)pSh->GetNext()) );
|
||
|
||
StartUndo( UNDO_START );
|
||
|
||
//#50778# Bug im Draging: Im StartAction wird ein HideShowXor gerufen.
|
||
//Im EndDragObj() wird dies unsinniger und faelschlicherweise wieder
|
||
//Rueckgaengig gemacht. Um Konsistenz herzustellen muessen wir das
|
||
//Xor also wieder zur Anzeige bringen.
|
||
|
||
// Reanimation from the hack #50778 to fix bug #97057
|
||
// May be not the best solution, but the one with lowest risc at the moment.
|
||
pView->ShowShownXor( GetOut() );
|
||
|
||
pView->EndDragObj();
|
||
// JP 18.08.95: DrawUndo-Action auf FlyFrames werden nicht gespeichert
|
||
// Die Fly aendern das Flag
|
||
GetDoc()->SetNoDrawUndoObj( FALSE );
|
||
ChgAnchor( 0, TRUE );
|
||
|
||
EndUndo( UNDO_END );
|
||
|
||
do {
|
||
pSh->EndAction();
|
||
if( pSh->IsA( TYPE( SwCrsrShell ) ) )
|
||
((SwCrsrShell*)pSh)->CallChgLnk();
|
||
} while ( this != (pSh = (ViewShell*)pSh->GetNext()) );
|
||
|
||
GetDoc()->SetModified();
|
||
::FrameNotify( this, FLY_DRAG );
|
||
return 1;
|
||
}
|
||
return 0;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::BreakDrag()
|
||
|*
|
||
|* Ersterstellung OM 02. Okt. 95
|
||
|* Letzte Aenderung OM 02. Okt. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::BreakDrag()
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "BreakDrag without DrawView?" );
|
||
if ( Imp()->GetDrawView()->IsDragObj() )
|
||
Imp()->GetDrawView()->BrkDragObj();
|
||
SetChainMarker();
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::SelFlyGrabCrsr()
|
||
|*
|
||
|* Beschreibung Wenn ein Fly selektiert ist, zieht er den Crsr in
|
||
|* den ersten CntntFrm
|
||
|* Ersterstellung MA 11. Dec. 92
|
||
|* Letzte Aenderung MA 07. Oct. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
const SwFrmFmt* SwFEShell::SelFlyGrabCrsr()
|
||
{
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
SwFlyFrm *pFly = ::GetFlyFromMarked( &rMrkList, this );
|
||
|
||
if( pFly )
|
||
{
|
||
pFly->GetAnchor()->Calc();
|
||
SwCntntFrm *pCFrm = pFly->ContainsCntnt();
|
||
if ( pCFrm )
|
||
{
|
||
SwCntntNode *pCNode = pCFrm->GetNode();
|
||
SwPaM *pCrsr = GetCrsr();
|
||
|
||
pCrsr->GetPoint()->nNode = *pCNode;
|
||
pCrsr->GetPoint()->nContent.Assign( pCNode, 0 );
|
||
|
||
SwRect& rChrRect = (SwRect&)GetCharRect();
|
||
rChrRect = pFly->Prt();
|
||
rChrRect.Pos() += pFly->Frm().Pos();
|
||
GetCrsrDocPos() = rChrRect.Pos();
|
||
}
|
||
return pFly->GetFmt();
|
||
}
|
||
}
|
||
return 0;
|
||
}
|
||
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::SelectionToTop(), SelectionToBottom()
|
||
|*
|
||
|* Beschreibung Selektion nach oben/unten (Z-Order)
|
||
|*
|
||
|* Ersterstellung MA 05. Nov. 92
|
||
|* Letzte Aenderung MA 03. Jun. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void lcl_NotifyNeighbours( const SdrMarkList *pLst )
|
||
{
|
||
//Die Regeln fuer die Ausweichmanoever haben sich veraendert.
|
||
//1. Die Umgebung des Fly und aller innenliegenden muss benachrichtigt
|
||
// werden.
|
||
//2. Der Inhalt des Rahmen selbst muss benachrichtigt werden.
|
||
//3. Rahmen die dem Rahmen ausweichen bzw. wichen muessen benachrichtigt werden.
|
||
//4. Auch Zeichenobjekte koennen Rahmen verdraengen
|
||
|
||
for( USHORT j = 0; j < pLst->GetMarkCount(); ++j )
|
||
{
|
||
SwPageFrm *pPage;
|
||
BOOL bCheckNeighbours = FALSE;
|
||
SwHoriOrient aHori;
|
||
SwRect aRect;
|
||
SdrObject *pO = pLst->GetMark( 0 )->GetObj();
|
||
if ( pO->IsWriterFlyFrame() )
|
||
{
|
||
SwFlyFrm *pFly = ((SwVirtFlyDrawObj*)pO)->GetFlyFrm();
|
||
|
||
const SwFmtHoriOrient &rHori = pFly->GetFmt()->GetHoriOrient();
|
||
aHori = rHori.GetHoriOrient();
|
||
if( HORI_NONE != aHori && HORI_CENTER != aHori &&
|
||
pFly->IsFlyAtCntFrm() )
|
||
{
|
||
bCheckNeighbours = TRUE;
|
||
pFly->InvalidatePos();
|
||
pFly->Frm().Pos().Y() += 1;
|
||
}
|
||
|
||
pPage = pFly->FindPageFrm();
|
||
aRect = pFly->Frm();
|
||
}
|
||
else
|
||
{
|
||
SwFrm *pAnch = ( (SwDrawContact*)GetUserCall(pO) )->GetAnchor();
|
||
if( !pAnch )
|
||
continue;
|
||
pPage = pAnch->FindPageFrm();
|
||
aRect = GetBoundRect( pO );
|
||
}
|
||
|
||
USHORT nCount = pPage->GetSortedObjs() ? pPage->GetSortedObjs()->Count() : 0;
|
||
for ( USHORT i = 0; i < nCount; ++i )
|
||
{
|
||
SdrObject *pO = (*pPage->GetSortedObjs())[i];
|
||
if ( !pO->IsWriterFlyFrame() )
|
||
continue;
|
||
|
||
SwVirtFlyDrawObj *pObj = (SwVirtFlyDrawObj*)pO;
|
||
|
||
SwFlyFrm *pAct = pObj->GetFlyFrm();
|
||
SwRect aTmpCalcPnt( pAct->Prt() );
|
||
aTmpCalcPnt += pAct->Frm().Pos();
|
||
if ( aRect.IsOver( aTmpCalcPnt ) )
|
||
{
|
||
SwCntntFrm *pCnt = pAct->ContainsCntnt();
|
||
while ( pCnt )
|
||
{
|
||
aTmpCalcPnt = pCnt->Prt();
|
||
aTmpCalcPnt += pCnt->Frm().Pos();
|
||
if ( aRect.IsOver( aTmpCalcPnt ) )
|
||
((SwFrm*)pCnt)->Prepare( PREP_FLY_ATTR_CHG );
|
||
pCnt = pCnt->GetNextCntntFrm();
|
||
}
|
||
}
|
||
if ( bCheckNeighbours && pAct->IsFlyAtCntFrm() )
|
||
{
|
||
const SwFmtHoriOrient &rH = pAct->GetFmt()->GetHoriOrient();
|
||
if ( rH.GetHoriOrient() == aHori &&
|
||
pAct->Frm().Top() <= aRect.Bottom() &&
|
||
pAct->Frm().Bottom() >= aRect.Top() )
|
||
{
|
||
pAct->InvalidatePos();
|
||
pAct->Frm().Pos().Y() += 1;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
void SwFEShell::SelectionToTop( BOOL bTop )
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "SelectionToTop without DrawView?" );
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
ASSERT( rMrkList.GetMarkCount(), "Kein Object Selektiert." );
|
||
|
||
SwFlyFrm *pFly = ::GetFlyFromMarked( &rMrkList, this );
|
||
if ( pFly && pFly->IsFlyInCntFrm() )
|
||
return;
|
||
|
||
StartAllAction();
|
||
if ( bTop )
|
||
Imp()->GetDrawView()->PutMarkedToTop();
|
||
else
|
||
Imp()->GetDrawView()->MovMarkedToTop();
|
||
::lcl_NotifyNeighbours( &rMrkList );
|
||
GetDoc()->SetModified();
|
||
EndAllAction();
|
||
}
|
||
|
||
void SwFEShell::SelectionToBottom( BOOL bBottom )
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "SelectionToBottom without DrawView?" );
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
ASSERT( rMrkList.GetMarkCount(), "Kein Object Selektiert." );
|
||
|
||
SwFlyFrm *pFly = ::GetFlyFromMarked( &rMrkList, this );
|
||
if ( pFly && pFly->IsFlyInCntFrm() )
|
||
return;
|
||
|
||
StartAllAction();
|
||
if ( bBottom )
|
||
Imp()->GetDrawView()->PutMarkedToBtm();
|
||
else
|
||
Imp()->GetDrawView()->MovMarkedToBtm();
|
||
::lcl_NotifyNeighbours( &rMrkList );
|
||
GetDoc()->SetModified();
|
||
EndAllAction();
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::GetLayerId()
|
||
|*
|
||
|* Beschreibung Objekt ueber/unter dem Dokument?
|
||
|* 2 Controls, 1 Heaven, 0 Hell, -1 Uneindeutig
|
||
|* Ersterstellung MA 20. Dec. 94
|
||
|* Letzte Aenderung MA 20. Dec. 94
|
||
|*
|
||
*************************************************************************/
|
||
|
||
short SwFEShell::GetLayerId() const
|
||
{
|
||
short nRet = SHRT_MAX;
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
const SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
if ( nRet == SHRT_MAX )
|
||
nRet = pObj->GetLayer();
|
||
else if ( nRet != pObj->GetLayer() )
|
||
{
|
||
nRet = -1;
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
if ( nRet == SHRT_MAX )
|
||
nRet = -1;
|
||
return nRet;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::SelectionToHeaven(), SelectionToHell()
|
||
|*
|
||
|* Beschreibung Objekt ueber/unter dem Dokument
|
||
|* Ersterstellung MA 20. Dec. 94
|
||
|* Letzte Aenderung AMA 04. Jun. 98
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::ChangeOpaque( BYTE nLayerId )
|
||
{
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
const BYTE nControls = GetDoc()->GetControlsId();
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
if ( pObj->GetLayer() != nLayerId && pObj->GetLayer() != nControls )
|
||
{
|
||
pObj->SetLayer( nLayerId );
|
||
InvalidateWindows( SwRect( pObj->GetBoundRect() ) );
|
||
if ( pObj->IsWriterFlyFrame() )
|
||
{
|
||
SwFmt *pFmt = ((SwVirtFlyDrawObj*)pObj)->GetFlyFrm()->GetFmt();
|
||
SvxOpaqueItem aOpa( pFmt->GetOpaque() );
|
||
aOpa.SetValue( nLayerId == GetDoc()->GetHellId() );
|
||
pFmt->SetAttr( aOpa );
|
||
}
|
||
}
|
||
}
|
||
GetDoc()->SetModified();
|
||
}
|
||
}
|
||
|
||
void SwFEShell::SelectionToHeaven()
|
||
{
|
||
ChangeOpaque( GetDoc()->GetHeavenId() );
|
||
}
|
||
|
||
void SwFEShell::SelectionToHell()
|
||
{
|
||
ChangeOpaque( GetDoc()->GetHellId() );
|
||
}
|
||
|
||
#if 0
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::FlipHellAndHeaven()
|
||
|*
|
||
|* Beschreibung Alle Zeichenobjekte aus der Hoelle in den Himmel
|
||
|* und umgekehrt.
|
||
|* Ersterstellung MA 12. Jan. 95
|
||
|* Letzte Aenderung AMA 04. Jun. 98
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::FlipHellAndHeaven()
|
||
{
|
||
SwDoc *pDoc = GetDoc();
|
||
if ( pDoc->GetDrawModel() )
|
||
{
|
||
SdrPage* pPage = pDoc->GetDrawModel()->GetPage( 0 );
|
||
SdrLayerID nHeaven = (SdrLayerID)pDoc->GetHeavenId();
|
||
SdrLayerID nHell = (SdrLayerID)pDoc->GetHellId();
|
||
SdrLayerID nControls = (SdrLayerID)pDoc->GetControlsId();
|
||
BOOL bChanged = FALSE;
|
||
for ( USHORT i = 0; i < pPage->GetObjCount(); ++i )
|
||
{
|
||
SdrObject *pObj = pPage->GetObj( i );
|
||
if ( !pObj->IsWriterFlyFrame() && nControls != pObj->GetLayer() )
|
||
{
|
||
pObj->SetLayer( nHeaven == pObj->GetLayer() ? nHell : nHeaven );
|
||
bChanged = TRUE;
|
||
}
|
||
}
|
||
if( bChanged )
|
||
{
|
||
InvalidateWindows( pDoc->GetRootFrm()->Frm() );
|
||
GetDoc()->SetModified();
|
||
}
|
||
}
|
||
}
|
||
#endif
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::IsObjSelected(), IsFrmSelected()
|
||
|*
|
||
|* Ersterstellung MA 16. Nov. 92
|
||
|* Letzte Aenderung MA 17. Jan. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
USHORT SwFEShell::IsObjSelected() const
|
||
{
|
||
if ( IsFrmSelected() || !Imp()->HasDrawView() )
|
||
return 0;
|
||
else
|
||
return USHORT( Imp()->GetDrawView()->GetMarkList().GetMarkCount() );
|
||
}
|
||
|
||
BOOL SwFEShell::IsFrmSelected() const
|
||
{
|
||
if ( !Imp()->HasDrawView() )
|
||
return FALSE;
|
||
else
|
||
return 0 != ::GetFlyFromMarked( &Imp()->GetDrawView()->GetMarkList(),
|
||
(ViewShell*)this );
|
||
}
|
||
|
||
Rectangle *SwFEShell::IsAnchorAtPos( const Point &rPt ) const
|
||
{
|
||
if ( !Imp()->HasDrawView() )
|
||
return 0;
|
||
else
|
||
return Imp()->GetDrawView()->IsAnchorAtPos( rPt );
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::EndTextEdit()
|
||
|*
|
||
|* Ersterstellung MA 19. Feb. 96
|
||
|* Letzte Aenderung MA 19. Feb. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::EndTextEdit()
|
||
{
|
||
//Beenden des TextEditModus. Wenn gewuenscht (default wenn das Objekt
|
||
//keinen Text mehr enthaelt und keine Attribute traegt) wird das
|
||
//Objekt gel<65>scht. Alle anderen markierten Objekte bleiben erhalten.
|
||
|
||
ASSERT( Imp()->HasDrawView() && Imp()->GetDrawView()->IsTextEdit(),
|
||
"EndTextEdit an no Object" );
|
||
|
||
StartAllAction();
|
||
SdrView *pView = Imp()->GetDrawView();
|
||
SdrObject *pObj = pView->GetTextEditObject();
|
||
SdrObjUserCall* pUserCall;
|
||
if( 0 != ( pUserCall = GetUserCall(pObj) ) )
|
||
{
|
||
pUserCall->Changed( *pObj, SDRUSERCALL_RESIZE,
|
||
pObj->GetBoundRect() );
|
||
}
|
||
if ( !pObj->GetUpGroup() )
|
||
{
|
||
if ( SDRENDTEXTEDIT_SHOULDBEDELETED == pView->EndTextEdit( TRUE ) )
|
||
{
|
||
if ( pView->GetMarkList().GetMarkCount() > 1 )
|
||
{
|
||
{
|
||
SdrMarkList aSave( pView->GetMarkList() );
|
||
aSave.DeleteMark( aSave.FindObject( pObj ) );
|
||
if ( aSave.GetMarkCount() )
|
||
{
|
||
pView->UnmarkAll();
|
||
pView->MarkObj( pObj, Imp()->GetPageView() );
|
||
}
|
||
DelSelectedObj();
|
||
if ( aSave.GetMarkCount() )
|
||
{
|
||
for ( USHORT i = 0; i < aSave.GetMarkCount(); ++i )
|
||
pView->MarkObj( aSave.GetMark( i )->GetObj(),
|
||
Imp()->GetPageView() );
|
||
}
|
||
}
|
||
}
|
||
else
|
||
DelSelectedObj();
|
||
}
|
||
}
|
||
else
|
||
pView->EndTextEdit();
|
||
EndAllAction();
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::IsInsideSelectedObj()
|
||
|*
|
||
|* Ersterstellung MA 16. Nov. 92
|
||
|* Letzte Aenderung MA 08. Nov. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
int SwFEShell::IsInsideSelectedObj( const Point &rPt )
|
||
{
|
||
if( Imp()->HasDrawView() )
|
||
{
|
||
SwDrawView *pDView = Imp()->GetDrawView();
|
||
|
||
if( pDView->GetMarkList().GetMarkCount() &&
|
||
pDView->IsMarkedObjHit( rPt ) )
|
||
{
|
||
return SDRHIT_OBJECT;
|
||
}
|
||
}
|
||
return SDRHIT_NONE;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::IsObjSelectable()
|
||
|*
|
||
|* Ersterstellung MA 16. Nov. 92
|
||
|* Letzte Aenderung MA 02. Feb. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
int SwFEShell::IsObjSelectable( const Point& rPt )
|
||
{
|
||
SET_CURR_SHELL(this);
|
||
#ifdef OLD
|
||
if( Imp()->HasDrawView() )
|
||
return Imp()->GetDrawView()->PickSomething( rPt, MINMOVE );
|
||
return 0;
|
||
#else
|
||
SwDrawView *pDView = Imp()->GetDrawView();
|
||
BOOL bRet = FALSE;
|
||
if( pDView )
|
||
{
|
||
SdrObject* pObj;
|
||
SdrPageView* pPV;
|
||
USHORT nOld = pDView->GetHitTolerancePixel();
|
||
pDView->SetHitTolerancePixel( pDView->GetMarkHdlSizePixel()/2 );
|
||
|
||
bRet = pDView->PickObj( rPt, pObj, pPV, SDRSEARCH_PICKMARKABLE );
|
||
pDView->SetHitTolerancePixel( nOld );
|
||
}
|
||
return bRet ? 1 : 0;
|
||
#endif
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::GotoFly()
|
||
|*
|
||
|* Beschreibung Wenn ein Fly selektiert ist, gehen wir von dessen
|
||
|* TopLeft aus, andernfalls von der Mitte des aktuellen CharRects.
|
||
|* Ersterstellung OK 11.03.94 10:12
|
||
|* Letzte Aenderung MA 29. Jul. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::GotoFly( BOOL bNext, FlyCntType eType )
|
||
{
|
||
if( !Imp()->HasDrawView() )
|
||
return FALSE;
|
||
else
|
||
{
|
||
const SwFlyFrm *pBest = 0,
|
||
*pTop = 0;
|
||
|
||
const long nTmp = bNext ? LONG_MAX : 0;
|
||
Point aBestPos( nTmp, nTmp );
|
||
Point aTopPos( nTmp, nTmp );
|
||
Point aCurPos;
|
||
Point aPos;
|
||
BOOL bRet = FALSE;
|
||
|
||
// Sonderfall, wenn der Cursor in einem Fly steht dann soll dieser
|
||
// selektiert werden !
|
||
pBest = GetCurrFrm( FALSE )->FindFlyFrm();
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
|
||
if( !pBest || rMrkList.GetMarkCount() == 1 )
|
||
{
|
||
// Ausgangspunkt bestimmen.
|
||
SwFlyFrm *pFly = ::GetFlyFromMarked( &rMrkList, this );
|
||
if( pFly )
|
||
aPos = pFly->Frm().Pos();
|
||
else
|
||
aPos = GetCharRect().Center();
|
||
|
||
SdrPage* pPage = GetDoc()->GetDrawModel()->GetPage( 0 );
|
||
const ULONG nObjs = pPage->GetObjCount();
|
||
for( ULONG nObj = 0; nObj < nObjs; ++nObj )
|
||
{
|
||
SdrObject *pO = pPage->GetObj( nObj );
|
||
if ( !pO->IsWriterFlyFrame() )
|
||
continue;
|
||
|
||
SwVirtFlyDrawObj *pObj = (SwVirtFlyDrawObj*)pO;
|
||
|
||
SwFlyFrm *pFly = pObj->GetFlyFrm();
|
||
|
||
switch ( eType )
|
||
{
|
||
case FLYCNTTYPE_FRM:
|
||
if ( pFly->Lower() && pFly->Lower()->IsNoTxtFrm() )
|
||
continue;
|
||
break;
|
||
case FLYCNTTYPE_GRF:
|
||
if ( pFly->Lower() &&
|
||
(pFly->Lower()->IsLayoutFrm() ||
|
||
!((SwCntntFrm*)pFly->Lower())->GetNode()->GetGrfNode()))
|
||
continue;
|
||
break;
|
||
case FLYCNTTYPE_OLE:
|
||
if ( pFly->Lower() &&
|
||
(pFly->Lower()->IsLayoutFrm() ||
|
||
!((SwCntntFrm*)pFly->Lower())->GetNode()->GetOLENode()))
|
||
continue;
|
||
break;
|
||
}
|
||
|
||
aCurPos = pFly->Frm().Pos();
|
||
|
||
// Sonderfall wenn ein anderes Obj auf selber Y steht.
|
||
if( aCurPos != aPos && // nur wenn ich es nicht selber bin
|
||
aCurPos.Y() == aPos.Y() && // ist die Y Position gleich
|
||
(bNext? (aCurPos.X() > aPos.X()) : // liegt neben mir
|
||
(aCurPos.X() < aPos.X())) ) // " reverse
|
||
{
|
||
aBestPos = Point( nTmp, nTmp );
|
||
for( ULONG i = 0; i < nObjs; ++i )
|
||
{
|
||
SdrObject *pO = pPage->GetObj( i );
|
||
if ( !pO->IsWriterFlyFrame() )
|
||
continue;
|
||
|
||
SwVirtFlyDrawObj *pObj = (SwVirtFlyDrawObj*)pO;
|
||
|
||
aCurPos = pObj->GetFlyFrm()->Frm().Pos();
|
||
|
||
if( aCurPos != aPos && aCurPos.Y() == aPos.Y() &&
|
||
(bNext? (aCurPos.X() > aPos.X()) : // liegt neben mir
|
||
(aCurPos.X() < aPos.X())) && // " reverse
|
||
(bNext? (aCurPos.X() < aBestPos.X()) : // besser als Beste
|
||
(aCurPos.X() > aBestPos.X())) ) // " reverse
|
||
{
|
||
aBestPos = aCurPos;
|
||
pBest = pObj->GetFlyFrm();
|
||
}
|
||
}
|
||
break;
|
||
}
|
||
|
||
if( (bNext? (aPos.Y() < aCurPos.Y()) : // nur unter mir
|
||
(aPos.Y() > aCurPos.Y())) && // " reverse
|
||
(bNext? (aBestPos.Y() > aCurPos.Y()) : // naeher drunter
|
||
(aBestPos.Y() < aCurPos.Y())) || // " reverse
|
||
(aBestPos.Y() == aCurPos.Y() &&
|
||
(bNext? (aBestPos.X() > aCurPos.X()) : // weiter links
|
||
(aBestPos.X() < aCurPos.X())))) // " reverse
|
||
|
||
{
|
||
aBestPos = aCurPos;
|
||
pBest = pObj->GetFlyFrm();
|
||
}
|
||
|
||
if( (bNext? (aTopPos.Y() > aCurPos.Y()) : // hoeher als Beste
|
||
(aTopPos.Y() < aCurPos.Y())) || // " reverse
|
||
(aTopPos.Y() == aCurPos.Y() &&
|
||
(bNext? (aTopPos.X() > aCurPos.X()) : // weiter links
|
||
(aTopPos.X() < aCurPos.X())))) // " reverse
|
||
{
|
||
aTopPos = aCurPos;
|
||
pTop = pObj->GetFlyFrm();
|
||
}
|
||
}
|
||
// leider nichts gefunden
|
||
if( (bNext? (aBestPos.X() == LONG_MAX) : (aBestPos.X() == 0)) )
|
||
pBest = pTop;
|
||
}
|
||
|
||
if( pBest )
|
||
{
|
||
SelectObj( pBest->Frm().Pos(), FALSE, FALSE, (SdrObject*)pBest->GetVirtDrawObj() );
|
||
if( !ActionPend() )
|
||
MakeVisible( pBest->Frm() );
|
||
CallChgLnk();
|
||
bRet = TRUE;
|
||
}
|
||
return bRet;
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::GotoObj()
|
||
|*
|
||
|* Beschreibung Wenn ein Obj selektiert ist, gehen wir von dessen
|
||
|* TopLeft aus, andernfalls von der Mitte des aktuellen CharRects.
|
||
|* Ersterstellung MA 01. Jun. 95
|
||
|* Letzte Aenderung MA 30. Apr. 96
|
||
|*
|
||
*************************************************************************/
|
||
/* -----------------23.09.98 10:29-------------------
|
||
* Beinhaltet das Objekt ein Control oder Gruppen,
|
||
* die nur aus Controls bestehen
|
||
* --------------------------------------------------*/
|
||
FASTBOOL lcl_IsControlGroup( const SdrObject *pObj )
|
||
{
|
||
BOOL bRet = FALSE;
|
||
if(pObj->ISA(SdrUnoObj))
|
||
bRet = TRUE;
|
||
else if( pObj->ISA( SdrObjGroup ) )
|
||
{
|
||
bRet = TRUE;
|
||
const SdrObjList *pLst = ((SdrObjGroup*)pObj)->GetSubList();
|
||
for ( USHORT i = 0; i < pLst->GetObjCount(); ++i )
|
||
if( !::lcl_IsControlGroup( pLst->GetObj( i ) ) )
|
||
return FALSE;
|
||
}
|
||
return bRet;
|
||
}
|
||
|
||
|
||
BOOL SwFEShell::GotoObj( BOOL bNext, DrawObjType eType )
|
||
{
|
||
if( !Imp()->HasDrawView() )
|
||
return FALSE;
|
||
else
|
||
{
|
||
const SdrObject *pBest = 0,
|
||
*pTop = 0;
|
||
|
||
const long nTmp = bNext ? LONG_MAX : 0;
|
||
Point aBestPos( nTmp, nTmp );
|
||
Point aTopPos( nTmp, nTmp );
|
||
Point aCurPos;
|
||
Point aPos;
|
||
BOOL bRet = FALSE;
|
||
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
|
||
// Ausgangspunkt bestimmen.
|
||
if ( rMrkList.GetMarkCount() )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark(0)->GetObj();
|
||
aPos = pObj->GetSnapRect().TopLeft();
|
||
}
|
||
else
|
||
aPos = GetCharRect().Center();
|
||
|
||
SdrPage* pPage = GetDoc()->GetDrawModel()->GetPage( 0 );
|
||
const ULONG nObjs = pPage->GetObjCount();
|
||
for( ULONG nObj = 0; nObj < nObjs; ++nObj )
|
||
{
|
||
SdrObject *pObj = pPage->GetObj( nObj );
|
||
|
||
if ( pObj->IsWriterFlyFrame() ||
|
||
eType == DRAW_SIMPLE && lcl_IsControlGroup( pObj ) ||
|
||
eType == DRAW_CONTROL && !lcl_IsControlGroup( pObj ))
|
||
continue;
|
||
|
||
aCurPos = pObj->GetBoundRect().TopLeft();
|
||
|
||
// Sonderfall wenn ein anderes Obj auf selber Y steht.
|
||
if( aCurPos != aPos && // nur wenn ich es nicht selber bin
|
||
aCurPos.Y() == aPos.Y() && // ist die Y Position gleich
|
||
(bNext? (aCurPos.X() > aPos.X()) : // liegt neben mir
|
||
(aCurPos.X() < aPos.X())) ) // " reverse
|
||
{
|
||
aBestPos = Point( nTmp, nTmp );
|
||
for( ULONG i = 0; i < nObjs; ++i )
|
||
{
|
||
SdrObject *pObj = pPage->GetObj( i );
|
||
if ( pObj->IsWriterFlyFrame() )
|
||
continue;
|
||
|
||
aCurPos = pObj->GetBoundRect().TopLeft();
|
||
|
||
if( aCurPos != aPos && aCurPos.Y() == aPos.Y() &&
|
||
(bNext? (aCurPos.X() > aPos.X()) : // liegt neben mir
|
||
(aCurPos.X() < aPos.X())) && // " reverse
|
||
(bNext? (aCurPos.X() < aBestPos.X()) : // besser als Beste
|
||
(aCurPos.X() > aBestPos.X())) ) // " reverse
|
||
{
|
||
aBestPos = aCurPos;
|
||
pBest = pObj;
|
||
}
|
||
}
|
||
break;
|
||
}
|
||
|
||
if( (bNext? (aPos.Y() < aCurPos.Y()) : // nur unter mir
|
||
(aPos.Y() > aCurPos.Y())) && // " reverse
|
||
(bNext? (aBestPos.Y() > aCurPos.Y()) : // naeher drunter
|
||
(aBestPos.Y() < aCurPos.Y())) || // " reverse
|
||
(aBestPos.Y() == aCurPos.Y() &&
|
||
(bNext? (aBestPos.X() > aCurPos.X()) : // weiter links
|
||
(aBestPos.X() < aCurPos.X())))) // " reverse
|
||
|
||
{
|
||
aBestPos = aCurPos;
|
||
pBest = pObj;
|
||
}
|
||
|
||
if( (bNext? (aTopPos.Y() > aCurPos.Y()) : // hoeher als Beste
|
||
(aTopPos.Y() < aCurPos.Y())) || // " reverse
|
||
(aTopPos.Y() == aCurPos.Y() &&
|
||
(bNext? (aTopPos.X() > aCurPos.X()) : // weiter links
|
||
(aTopPos.X() < aCurPos.X())))) // " reverse
|
||
{
|
||
aTopPos = aCurPos;
|
||
pTop = pObj;
|
||
}
|
||
}
|
||
// leider nichts gefunden
|
||
if( (bNext? (aBestPos.X() == LONG_MAX) : (aBestPos.X() == 0)) )
|
||
pBest = pTop;
|
||
|
||
if( pBest )
|
||
{
|
||
SelectObj( Point(), FALSE, FALSE, (SdrObject*)pBest );
|
||
if( !ActionPend() )
|
||
MakeVisible( pBest->GetBoundRect() );
|
||
CallChgLnk();
|
||
bRet = TRUE;
|
||
}
|
||
return bRet;
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::ControlCount(), GotoControl()
|
||
|*
|
||
|* Ersterstellung MA 22. Jul. 96
|
||
|* Letzte Aenderung MA 22. Jul. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
ULONG SwFEShell::ControlCount() const
|
||
{
|
||
INT32 nRet = 0;
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
SdrPage* pPage = GetDoc()->GetDrawModel()->GetPage( 0 );
|
||
const ULONG nObjs = pPage->GetObjCount();
|
||
for( ULONG nObj = 0; nObj < nObjs; ++nObj )
|
||
{
|
||
if ( pPage->GetObj( nObj )->ISA( SdrUnoObj ) )
|
||
++nRet;
|
||
}
|
||
}
|
||
return nRet;
|
||
}
|
||
|
||
BOOL SwFEShell::GotoControl( ULONG nIndex )
|
||
{
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
ULONG nIdx = 0;
|
||
SdrPage* pPage = GetDoc()->GetDrawModel()->GetPage( 0 );
|
||
const ULONG nObjs = pPage->GetObjCount();
|
||
for( ULONG nObj = 0; nObj < nObjs; ++nObj )
|
||
{
|
||
SdrObject *pObj = pPage->GetObj( nObj );
|
||
if ( pObj->ISA( SdrUnoObj ) )
|
||
{
|
||
if ( nIdx == nIndex )
|
||
{
|
||
SelectObj( Point(), FALSE, FALSE, pObj );
|
||
if( !ActionPend() )
|
||
MakeVisible( pObj->GetBoundRect() );
|
||
CallChgLnk();
|
||
return TRUE;
|
||
}
|
||
++nIdx;
|
||
}
|
||
}
|
||
}
|
||
return FALSE;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::BeginCreate()
|
||
|*
|
||
|* Ersterstellung MA 20. Dec. 94
|
||
|* Letzte Aenderung MA 21. Mar. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::BeginCreate( UINT16 eSdrObjectKind, const Point &rPos )
|
||
{
|
||
BOOL bRet = FALSE;
|
||
|
||
if ( !Imp()->HasDrawView() )
|
||
Imp()->MakeDrawView();
|
||
|
||
if ( GetPageNumber( rPos ) )
|
||
{
|
||
Imp()->GetDrawView()->SetCurrentObj( eSdrObjectKind );
|
||
if ( eSdrObjectKind == OBJ_CAPTION )
|
||
bRet = Imp()->GetDrawView()->BegCreateCaptionObj(
|
||
rPos, Size( lMinBorder - MINFLY, lMinBorder - MINFLY ),
|
||
GetOut() );
|
||
else
|
||
bRet = Imp()->GetDrawView()->BegCreateObj( rPos, GetOut() );
|
||
}
|
||
if ( bRet )
|
||
::FrameNotify( this, FLY_DRAG_START );
|
||
return bRet;
|
||
}
|
||
|
||
BOOL SwFEShell::BeginCreate( UINT16 eSdrObjectKind, UINT32 eObjInventor,
|
||
const Point &rPos )
|
||
{
|
||
BOOL bRet = FALSE;
|
||
|
||
if ( !Imp()->HasDrawView() )
|
||
Imp()->MakeDrawView();
|
||
|
||
if ( GetPageNumber( rPos ) )
|
||
{
|
||
Imp()->GetDrawView()->SetCurrentObj( eSdrObjectKind, eObjInventor );
|
||
bRet = Imp()->GetDrawView()->BegCreateObj( rPos, GetOut() );
|
||
}
|
||
if ( bRet )
|
||
::FrameNotify( this, FLY_DRAG_START );
|
||
return bRet;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::MoveCreate()
|
||
|*
|
||
|* Ersterstellung MA 20. Dec. 94
|
||
|* Letzte Aenderung MA 24. Jan. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::MoveCreate( const Point &rPos )
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "MoveCreate without DrawView?" );
|
||
if ( GetPageNumber( rPos ) )
|
||
{
|
||
Scroll( rPos );
|
||
Imp()->GetDrawView()->MovCreateObj( rPos );
|
||
::FrameNotify( this, FLY_DRAG );
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::EndCreate(), ImpEndCreate()
|
||
|*
|
||
|* Ersterstellung MA 20. Dec. 94
|
||
|* Letzte Aenderung MA 14. Oct. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::EndCreate( UINT16 eSdrCreateCmd )
|
||
{
|
||
// JP 18.08.95: Damit das Undo-Object aus der DrawEngine nicht bei uns
|
||
// gespeichert wird, (wir erzeugen ein eigenes Undo-Object!) hier kurz
|
||
// das Undo abschalten
|
||
ASSERT( Imp()->HasDrawView(), "EndCreate without DrawView?" );
|
||
if( !Imp()->GetDrawView()->IsGroupEntered() )
|
||
GetDoc()->SetNoDrawUndoObj( TRUE );
|
||
FASTBOOL bCreate = Imp()->GetDrawView()->EndCreateObj(
|
||
SdrCreateCmd( eSdrCreateCmd ) );
|
||
GetDoc()->SetNoDrawUndoObj( FALSE );
|
||
|
||
if ( !bCreate )
|
||
{
|
||
::FrameNotify( this, FLY_DRAG_END );
|
||
return FALSE;
|
||
}
|
||
|
||
if ( (SdrCreateCmd)eSdrCreateCmd == SDRCREATE_NEXTPOINT )
|
||
{
|
||
::FrameNotify( this, FLY_DRAG );
|
||
return TRUE;
|
||
}
|
||
return ImpEndCreate();
|
||
}
|
||
|
||
|
||
BOOL SwFEShell::ImpEndCreate()
|
||
{
|
||
ASSERT( Imp()->GetDrawView()->GetMarkList().GetMarkCount() == 1,
|
||
"Neues Object nicht selektiert." );
|
||
|
||
SdrObject& rSdrObj = *Imp()->GetDrawView()->GetMarkList().GetMark(0)->GetObj();
|
||
|
||
if( rSdrObj.GetSnapRect().IsEmpty() )
|
||
{
|
||
//JP 10.04.95: das Object vergessen wir lieber, fuerht nur
|
||
// zu Problemen
|
||
Imp()->GetDrawView()->DeleteMarked();
|
||
Imp()->GetDrawView()->UnmarkAll();
|
||
::FrameNotify( this, FLY_DRAG_END );
|
||
return FALSE;
|
||
}
|
||
|
||
if( rSdrObj.GetUpGroup() )
|
||
{
|
||
Point aTmpPos( rSdrObj.GetRelativePos() + rSdrObj.GetAnchorPos() );
|
||
Point aNewAnchor( rSdrObj.GetUpGroup()->GetAnchorPos() );
|
||
rSdrObj.NbcSetRelativePos( aTmpPos - aNewAnchor );
|
||
rSdrObj.NbcSetAnchorPos( aNewAnchor );
|
||
// Imp()->GetDrawView()->UnmarkAll();
|
||
::FrameNotify( this, FLY_DRAG );
|
||
return TRUE;
|
||
}
|
||
|
||
StartAllAction();
|
||
|
||
Imp()->GetDrawView()->UnmarkAll();
|
||
|
||
SwPaM* pCrsr = GetCrsr();
|
||
|
||
const Rectangle &rBound = rSdrObj.GetSnapRect();
|
||
const Point aPt( rBound.TopLeft() );
|
||
|
||
//Fremde Identifier sollen in den Default laufen.
|
||
//Ueberschneidungen sind moeglich!!
|
||
UINT16 nIdent = SdrInventor == rSdrObj.GetObjInventor()
|
||
? rSdrObj.GetObjIdentifier()
|
||
: 0xFFFF;
|
||
|
||
//Default fuer Controls ist Zeichengebunden, Absatzgebunden sonst.
|
||
SwFmtAnchor aAnch;
|
||
const SwFrm *pAnch = 0;
|
||
FASTBOOL bCharBound = FALSE;
|
||
if( rSdrObj.ISA( SdrUnoObj ) )
|
||
{
|
||
SwPosition aPos( GetDoc()->GetNodes() );
|
||
SwCrsrMoveState aState( MV_SETONLYTEXT );
|
||
Point aPoint( aPt.X(), aPt.Y() + rBound.GetHeight()/2 );
|
||
GetDoc()->GetRootFrm()->GetCrsrOfst( &aPos, aPoint, &aState );
|
||
|
||
//JP 22.01.99: Zeichenbindung ist im ReadnOnly-Inhalt nicht erlaubt
|
||
if( !aPos.nNode.GetNode().IsProtect() )
|
||
{
|
||
pAnch = aPos.nNode.GetNode().GetCntntNode()->GetFrm( &aPoint, &aPos );
|
||
SwRect aTmp;
|
||
pAnch->GetCharRect( aTmp, aPos );
|
||
|
||
//Der Crsr darf nicht zu weit entfernt sein.
|
||
bCharBound = TRUE;
|
||
Rectangle aRect( aTmp.SVRect() );
|
||
aRect.Left() -= MM50*2;
|
||
aRect.Top() -= MM50*2;
|
||
aRect.Right() += MM50*2;
|
||
aRect.Bottom()+= MM50*2;
|
||
|
||
if( !aRect.IsOver( rBound ) && !::GetHtmlMode( GetDoc()->GetDocShell() ))
|
||
bCharBound = FALSE;
|
||
|
||
//Bindung in Kopf-/Fusszeilen ist ebenfalls nicht erlaubt.
|
||
if( bCharBound )
|
||
bCharBound = !GetDoc()->IsInHeaderFooter( aPos.nNode );
|
||
|
||
if( bCharBound )
|
||
{
|
||
aAnch.SetType( FLY_IN_CNTNT );
|
||
aAnch.SetAnchor( &aPos );
|
||
}
|
||
}
|
||
}
|
||
|
||
if( !bCharBound )
|
||
{
|
||
BOOL bBodyOnly = OBJ_NONE != nIdent, bAtPage = FALSE;
|
||
const SwFrm *pPage = 0;
|
||
SwCrsrMoveState aState( MV_SETONLYTEXT );
|
||
Point aPoint( aPt );
|
||
SwPosition aPos( GetDoc()->GetNodes() );
|
||
GetLayout()->GetCrsrOfst( &aPos, aPoint, &aState );
|
||
|
||
//JP 22.01.99: nicht in ReadnOnly-Inhalt setzen
|
||
if( aPos.nNode.GetNode().IsProtect() )
|
||
// dann darf er nur seitengebunden sein. Oder sollte man
|
||
// die naechste nicht READONLY Position suchen?
|
||
bAtPage = TRUE;
|
||
|
||
pAnch = aPos.nNode.GetNode().GetCntntNode()->GetFrm( &aPoint, 0, FALSE );
|
||
|
||
if( !bAtPage )
|
||
{
|
||
const SwFlyFrm *pTmp = pAnch->FindFlyFrm();
|
||
if( pTmp )
|
||
{
|
||
const SwFrm* pTmpFrm = pAnch;
|
||
SwRect aBound( rBound );
|
||
while( pTmp )
|
||
{
|
||
if( pTmp->Frm().IsInside( aBound ) )
|
||
{
|
||
if( !bBodyOnly || !pTmp->FindFooterOrHeader() )
|
||
pPage = pTmpFrm;
|
||
break;
|
||
}
|
||
pTmp = pTmp->GetAnchor()
|
||
? pTmp->GetAnchor()->FindFlyFrm()
|
||
: 0;
|
||
pTmpFrm = pTmp;
|
||
}
|
||
}
|
||
|
||
if( !pPage )
|
||
pPage = pAnch->FindPageFrm();
|
||
|
||
// immer ueber FindAnchor gehen, damit der Frame immer an den
|
||
// davorgehen gebunden wird. Beim GetCrsOfst kann man auch zum
|
||
// nachfolgenden kommen. DAS IST FALSCH
|
||
pAnch = ::FindAnchor( pPage, aPt, bBodyOnly );
|
||
aPos.nNode = *((SwCntntFrm*)pAnch)->GetNode();
|
||
|
||
//JP 22.01.99: nicht in ReadnOnly-Inhalt setzen
|
||
if( aPos.nNode.GetNode().IsProtect() )
|
||
// dann darf er nur seitengebunden sein. Oder sollte man
|
||
// die naechste nicht READONLY Position suchen?
|
||
bAtPage = TRUE;
|
||
else
|
||
{
|
||
aAnch.SetType( FLY_AT_CNTNT );
|
||
aAnch.SetAnchor( &aPos );
|
||
}
|
||
}
|
||
|
||
if( bAtPage )
|
||
{
|
||
pPage = pAnch->FindPageFrm();
|
||
|
||
aAnch.SetType( FLY_PAGE );
|
||
aAnch.SetPageNum( pPage->GetPhyPageNum() );
|
||
pAnch = pPage; // die Page wird jetzt zum Anker
|
||
}
|
||
}
|
||
|
||
SfxItemSet aSet( GetDoc()->GetAttrPool(), RES_FRM_SIZE, RES_FRM_SIZE,
|
||
RES_SURROUND, RES_ANCHOR, 0 );
|
||
aSet.Put( aAnch );
|
||
|
||
if( OBJ_NONE == nIdent )
|
||
{
|
||
//Bei OBJ_NONE wird ein Fly eingefuegt.
|
||
const long nWidth = rBound.Right() - rBound.Left();
|
||
const long nHeight= rBound.Bottom() - rBound.Top();
|
||
aSet.Put( SwFmtFrmSize( ATT_MIN_SIZE, Max( nWidth, long(MINFLY) ),
|
||
Max( nHeight, long(MINFLY) )));
|
||
|
||
SwFmtHoriOrient aHori( rBound.Left() -
|
||
pAnch->Frm().Left(), HORI_NONE, FRAME );
|
||
SwTwips nYOffset = rBound.Top() - pAnch->Frm().Top();
|
||
if( pAnch->IsTxtFrm() && ((SwTxtFrm*)pAnch)->IsFollow() )
|
||
{
|
||
SwTxtFrm* pTmp = (SwTxtFrm*)pAnch;
|
||
do {
|
||
pTmp = pTmp->FindMaster();
|
||
ASSERT( pTmp, "Where's my Master?" );
|
||
nYOffset += pTmp->Prt().Height();
|
||
} while ( pTmp->IsFollow() );
|
||
}
|
||
SwFmtVertOrient aVert( nYOffset, VERT_NONE, FRAME );
|
||
aSet.Put( SwFmtSurround( SURROUND_PARALLEL ) );
|
||
aSet.Put( aHori );
|
||
aSet.Put( aVert );
|
||
|
||
//Schnell noch das Rechteck merken
|
||
const SwRect aFlyRect( rBound );
|
||
|
||
//Erzeugtes Object wegwerfen, so kann der Fly am elegentesten
|
||
//ueber vorhandene SS erzeugt werden.
|
||
GetDoc()->SetNoDrawUndoObj( TRUE ); // siehe oben
|
||
SdrPage *pPg = GetDoc()->MakeDrawModel()->GetPage( 0 );
|
||
if( !pPg )
|
||
{
|
||
pPg = GetDoc()->GetDrawModel()->AllocPage( FALSE );
|
||
GetDoc()->GetDrawModel()->InsertPage( pPg );
|
||
}
|
||
pPg->RecalcObjOrdNums();
|
||
delete pPg->RemoveObject( rSdrObj.GetOrdNumDirect() );
|
||
GetDoc()->SetNoDrawUndoObj( FALSE );
|
||
|
||
SwFlyFrm* pFlyFrm;
|
||
if( NewFlyFrm( aSet, TRUE ) &&
|
||
::GetHtmlMode( GetDoc()->GetDocShell() ) &&
|
||
0 != ( pFlyFrm = FindFlyFrm() ))
|
||
{
|
||
SfxItemSet aHtmlSet( GetDoc()->GetAttrPool(), RES_VERT_ORIENT, RES_HORI_ORIENT );
|
||
//Horizontale Ausrichtung:
|
||
const FASTBOOL bLeftFrm = aFlyRect.Left() <
|
||
pAnch->Frm().Left() + pAnch->Prt().Left(),
|
||
bLeftPrt = aFlyRect.Left() + aFlyRect.Width() <
|
||
pAnch->Frm().Left() + pAnch->Prt().Width()/2;
|
||
if( bLeftFrm || bLeftPrt )
|
||
{
|
||
aHori.SetHoriOrient( HORI_LEFT );
|
||
aHori.SetRelationOrient( bLeftFrm ? FRAME : PRTAREA );
|
||
}
|
||
else
|
||
{
|
||
const FASTBOOL bRightFrm = aFlyRect.Left() >
|
||
pAnch->Frm().Left() + pAnch->Prt().Width();
|
||
aHori.SetHoriOrient( HORI_RIGHT );
|
||
aHori.SetRelationOrient( bRightFrm ? FRAME : PRTAREA );
|
||
}
|
||
aHtmlSet.Put( aHori );
|
||
aVert.SetVertOrient( VERT_TOP );
|
||
aVert.SetRelationOrient( PRTAREA );
|
||
aHtmlSet.Put( aVert );
|
||
|
||
GetDoc()->SetAttr( aHtmlSet, *pFlyFrm->GetFmt() );
|
||
}
|
||
}
|
||
else
|
||
{
|
||
Point aRelNullPt;
|
||
|
||
if( OBJ_CAPTION == nIdent )
|
||
aRelNullPt = ((SdrCaptionObj&)rSdrObj).GetTailPos();
|
||
else
|
||
aRelNullPt = rBound.TopLeft();
|
||
|
||
aSet.Put( aAnch );
|
||
aSet.Put( SwFmtSurround( SURROUND_THROUGHT ) );
|
||
SwDrawFrmFmt* pFmt = (SwDrawFrmFmt*)GetDoc()->MakeLayoutFmt( RND_DRAW_OBJECT, 0, &aSet );
|
||
|
||
SwDrawContact *pContact = new SwDrawContact( pFmt, &rSdrObj );
|
||
if( bCharBound )
|
||
{
|
||
ASSERT( aAnch.GetAnchorId() == FLY_IN_CNTNT, "wrong AnchorType" );
|
||
SwTxtNode *pNd = aAnch.GetCntntAnchor()->nNode.GetNode().GetTxtNode();
|
||
pNd->Insert( SwFmtFlyCnt( pFmt ),
|
||
aAnch.GetCntntAnchor()->nContent.GetIndex(), 0 );
|
||
SwFmtVertOrient aVert( pFmt->GetVertOrient() );
|
||
aVert.SetVertOrient( VERT_LINE_CENTER );
|
||
pFmt->SetAttr( aVert );
|
||
}
|
||
if( pAnch->IsTxtFrm() && ((SwTxtFrm*)pAnch)->IsFollow() )
|
||
{
|
||
SwTxtFrm* pTmp = (SwTxtFrm*)pAnch;
|
||
do {
|
||
pTmp = pTmp->FindMaster();
|
||
ASSERT( pTmp, "Where's my Master?" );
|
||
} while( pTmp->IsFollow() );
|
||
pAnch = pTmp;
|
||
}
|
||
rSdrObj.NbcSetRelativePos( aRelNullPt - pAnch->Frm().Pos() );
|
||
rSdrObj.NbcSetAnchorPos( pAnch->Frm().Pos() );
|
||
pContact->ConnectToLayout();
|
||
|
||
Imp()->GetDrawView()->MarkObj( &rSdrObj, Imp()->GetPageView(),
|
||
FALSE, FALSE );
|
||
}
|
||
|
||
GetDoc()->SetModified();
|
||
|
||
KillPams();
|
||
EndAllActionAndCall();
|
||
return TRUE;
|
||
}
|
||
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::BreakCreate()
|
||
|*
|
||
|* Ersterstellung MA 20. Dec. 94
|
||
|* Letzte Aenderung MA 09. Jan. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::BreakCreate()
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "BreakCreate without DrawView?" );
|
||
Imp()->GetDrawView()->BrkCreateObj();
|
||
::FrameNotify( this, FLY_DRAG_END );
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::IsDrawCreate()
|
||
|*
|
||
|* Ersterstellung OM 16. Mar. 95
|
||
|* Letzte Aenderung OM 16. Mar. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::IsDrawCreate() const
|
||
{
|
||
return Imp()->HasDrawView() ? Imp()->GetDrawView()->IsCreateObj() : FALSE;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::BeginMark()
|
||
|*
|
||
|* Ersterstellung OM 07. Feb. 95
|
||
|* Letzte Aenderung OM 07. Feb. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::BeginMark( const Point &rPos )
|
||
{
|
||
if ( !Imp()->HasDrawView() )
|
||
Imp()->MakeDrawView();
|
||
|
||
if ( GetPageNumber( rPos ) )
|
||
{
|
||
SwDrawView* pDView = Imp()->GetDrawView();
|
||
|
||
if (pDView->HasMarkablePoints())
|
||
return pDView->BegMarkPoints( rPos, (OutputDevice*) NULL );
|
||
else
|
||
return pDView->BegMarkObj( rPos, (OutputDevice*) NULL );
|
||
}
|
||
else
|
||
return FALSE;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::MoveMark()
|
||
|*
|
||
|* Ersterstellung OM 07. Feb. 95
|
||
|* Letzte Aenderung OM 07. Feb. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::MoveMark( const Point &rPos )
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "MoveMark without DrawView?" );
|
||
|
||
if ( GetPageNumber( rPos ) )
|
||
{
|
||
Scroll( rPos );
|
||
SwDrawView* pDView = Imp()->GetDrawView();
|
||
// Imp()->GetDrawView()->MovMarkObj( rPos );
|
||
|
||
if (pDView->IsInsObjPoint())
|
||
pDView->MovInsObjPoint( rPos );
|
||
else if (pDView->IsMarkPoints())
|
||
pDView->MovMarkPoints( rPos );
|
||
else
|
||
pDView->MovAction( rPos );
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::EndMark()
|
||
|*
|
||
|* Ersterstellung OM 07. Feb. 95
|
||
|* Letzte Aenderung MA 08. Feb. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::EndMark()
|
||
{
|
||
BOOL bRet = FALSE;
|
||
ASSERT( Imp()->HasDrawView(), "EndMark without DrawView?" );
|
||
|
||
if (Imp()->GetDrawView()->IsMarkObj())
|
||
{
|
||
bRet = Imp()->GetDrawView()->EndMarkObj();
|
||
|
||
if ( bRet )
|
||
{
|
||
BOOL bShowHdl = FALSE;
|
||
SwDrawView* pDView = Imp()->GetDrawView();
|
||
//Rahmen werden auf diese Art nicht Selektiert, es sein denn es
|
||
//ist nur ein Rahmen.
|
||
SdrMarkList &rMrkList = (SdrMarkList&)pDView->GetMarkList();
|
||
SwFlyFrm* pOldSelFly = ::GetFlyFromMarked( &rMrkList, this );
|
||
|
||
if ( rMrkList.GetMarkCount() > 1 )
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
if( pObj->IsWriterFlyFrame() )
|
||
{
|
||
if ( !bShowHdl )
|
||
{
|
||
pDView->HideMarkHdl( GetOut() );
|
||
bShowHdl = TRUE;
|
||
}
|
||
rMrkList.DeleteMarkNum( i );
|
||
--i; //keinen auslassen.
|
||
}
|
||
}
|
||
|
||
if( bShowHdl )
|
||
{
|
||
pDView->MarkListHasChanged();
|
||
pDView->AdjustMarkHdl();
|
||
pDView->ShowMarkHdl( GetOut() );
|
||
}
|
||
|
||
if ( rMrkList.GetMarkCount() )
|
||
::lcl_GrabCursor(this, pOldSelFly);
|
||
else
|
||
bRet = FALSE;
|
||
}
|
||
if ( bRet )
|
||
::FrameNotify( this, FLY_DRAG_START );
|
||
}
|
||
else
|
||
{
|
||
if (Imp()->GetDrawView()->IsMarkPoints())
|
||
bRet = Imp()->GetDrawView()->EndMarkPoints();
|
||
}
|
||
|
||
SetChainMarker();
|
||
return bRet;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::BreakSelect()
|
||
|*
|
||
|* Ersterstellung OM 07. Feb. 95
|
||
|* Letzte Aenderung OM 07. Feb. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::BreakMark()
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "BreakMark without DrawView?" );
|
||
Imp()->GetDrawView()->BrkMarkObj();
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::GetAnchorId()
|
||
|*
|
||
|* Ersterstellung MA 30. Jan. 95
|
||
|* Letzte Aenderung MA 30. Jan. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
short SwFEShell::GetAnchorId() const
|
||
{
|
||
short nRet = SHRT_MAX;
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
if ( pObj->IsWriterFlyFrame() )
|
||
{
|
||
nRet = -1;
|
||
break;
|
||
}
|
||
SwDrawContact *pContact = (SwDrawContact*)GetUserCall(pObj);
|
||
short nId = pContact->GetFmt()->GetAnchor().GetAnchorId();
|
||
if ( nRet == SHRT_MAX )
|
||
nRet = nId;
|
||
else if ( nRet != nId )
|
||
{
|
||
nRet = -1;
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
if ( nRet == SHRT_MAX )
|
||
nRet = -1;
|
||
return nRet;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::ChgAnchor()
|
||
|*
|
||
|* Ersterstellung MA 10. Jan. 95
|
||
|* Letzte Aenderung MA 30. May. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::ChgAnchor( int eAnchorId, BOOL bSameOnly, BOOL bPosCorr )
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "ChgAnchor without DrawView?" );
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
if( rMrkList.GetMarkCount() &&
|
||
!rMrkList.GetMark( 0 )->GetObj()->GetUpGroup() )
|
||
{
|
||
StartAllAction();
|
||
|
||
if( GetDoc()->ChgAnchor( rMrkList, eAnchorId, bSameOnly, bPosCorr ))
|
||
Imp()->GetDrawView()->UnmarkAll();
|
||
|
||
EndAllAction();
|
||
|
||
::FrameNotify( this, FLY_DRAG );
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::DelSelectedObj()
|
||
|*
|
||
|* Ersterstellung MA 03. Nov. 92
|
||
|* Letzte Aenderung MA 14. Nov. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::DelSelectedObj()
|
||
{
|
||
ASSERT( Imp()->HasDrawView(), "DelSelectedObj(), no DrawView available" );
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
StartAllAction();
|
||
Imp()->GetDrawView()->DeleteMarked();
|
||
EndAllAction();
|
||
::FrameNotify( this, FLY_DRAG_END );
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::GetObjSize(), GetAnchorObjDiff()
|
||
|*
|
||
|* Beschreibung Fuer die Statuszeile zum Erfragen der aktuellen
|
||
|* Verhaeltnisse
|
||
|* Ersterstellung MA 25. Apr. 95
|
||
|* Letzte Aenderung MA 25. Apr. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
Size SwFEShell::GetObjSize() const
|
||
{
|
||
Rectangle aRect;
|
||
if ( Imp()->HasDrawView() )
|
||
{
|
||
if ( Imp()->GetDrawView()->IsAction() )
|
||
Imp()->GetDrawView()->TakeActionRect( aRect );
|
||
else
|
||
aRect = Imp()->GetDrawView()->GetAllMarkedRect();
|
||
}
|
||
return aRect.GetSize();
|
||
}
|
||
|
||
Point SwFEShell::GetAnchorObjDiff() const
|
||
{
|
||
const SdrView *pView = Imp()->GetDrawView();
|
||
ASSERT( pView, "GetAnchorObjDiff without DrawView?" );
|
||
|
||
Rectangle aRect;
|
||
if ( Imp()->GetDrawView()->IsAction() )
|
||
Imp()->GetDrawView()->TakeActionRect( aRect );
|
||
else
|
||
aRect = Imp()->GetDrawView()->GetAllMarkedRect();
|
||
|
||
Point aRet( aRect.TopLeft() );
|
||
|
||
if ( IsFrmSelected() )
|
||
{
|
||
SwFlyFrm *pFly = FindFlyFrm();
|
||
aRet -= pFly->GetAnchor()->Frm().Pos();
|
||
}
|
||
else
|
||
{
|
||
const SdrObject *pObj = pView->GetMarkList().GetMarkCount() == 1 ?
|
||
pView->GetMarkList().GetMark(0)->GetObj() : 0;
|
||
if ( pObj )
|
||
aRet -= pObj->GetAnchorPos();
|
||
}
|
||
|
||
return aRet;
|
||
}
|
||
|
||
Point SwFEShell::GetObjAbsPos() const
|
||
{
|
||
ASSERT( Imp()->GetDrawView(), "GetObjAbsPos() without DrawView?" );
|
||
return Imp()->GetDrawView()->GetDragStat().GetActionRect().TopLeft();
|
||
}
|
||
|
||
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::IsGroupSelected()
|
||
|*
|
||
|* Ersterstellung MA 30. Jan. 95
|
||
|* Letzte Aenderung MA 30. May. 96
|
||
|*
|
||
*************************************************************************/
|
||
|
||
BOOL SwFEShell::IsGroupSelected()
|
||
{
|
||
if ( IsObjSelected() )
|
||
{
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
if ( pObj->IsA( TYPE(SdrObjGroup) ) &&
|
||
FLY_IN_CNTNT != ((SwDrawContact*)GetUserCall(pObj))->
|
||
GetFmt()->GetAnchor().GetAnchorId() )
|
||
return TRUE;
|
||
}
|
||
}
|
||
return FALSE;
|
||
}
|
||
|
||
BOOL SwFEShell::IsGroupAllowed() const
|
||
{
|
||
BOOL bRet;
|
||
if ( IsObjSelected() > 1 )
|
||
{
|
||
bRet = TRUE;
|
||
const SdrObject* pUpGroup;
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for ( USHORT i = 0; bRet && i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
const SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
if( i )
|
||
bRet = pObj->GetUpGroup() == pUpGroup;
|
||
else
|
||
pUpGroup = pObj->GetUpGroup();
|
||
|
||
if( FLY_IN_CNTNT == ::FindFrmFmt( (SdrObject*)pObj )->GetAnchor().GetAnchorId() )
|
||
bRet = FALSE;
|
||
}
|
||
}
|
||
else
|
||
bRet = FALSE;
|
||
return bRet;
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::GroupSelection()
|
||
|*
|
||
|* Beschreibung Die Gruppe bekommt den Anker und das Contactobjekt
|
||
|* des ersten in der Selektion
|
||
|* Ersterstellung MA 30. Jan. 95
|
||
|* Letzte Aenderung MA 23. Apr. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::GroupSelection()
|
||
{
|
||
if ( IsGroupAllowed() )
|
||
{
|
||
StartAllAction();
|
||
StartUndo( UNDO_START );
|
||
|
||
GetDoc()->GroupSelection( *Imp()->GetDrawView() );
|
||
ChgAnchor( 0, TRUE );
|
||
|
||
EndUndo( UNDO_END );
|
||
EndAllAction();
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::UnGroupSelection()
|
||
|*
|
||
|* Beschreibung Die Einzelobjekte bekommen eine Kopie vom Anker und
|
||
|* Contactobjekt der Gruppe.
|
||
|* Ersterstellung MA 30. Jan. 95
|
||
|* Letzte Aenderung MA 01. Feb. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::UnGroupSelection()
|
||
{
|
||
if ( IsGroupSelected() )
|
||
{
|
||
StartAllAction();
|
||
StartUndo( UNDO_START );
|
||
|
||
GetDoc()->UnGroupSelection( *Imp()->GetDrawView() );
|
||
ChgAnchor( 0, TRUE );
|
||
|
||
EndUndo( UNDO_END );
|
||
EndAllAction();
|
||
}
|
||
}
|
||
|
||
/*************************************************************************
|
||
|*
|
||
|* SwFEShell::MirrorSelection()
|
||
|*
|
||
|* Ersterstellung MA 06. Aug. 95
|
||
|* Letzte Aenderung MA 06. Aug. 95
|
||
|*
|
||
*************************************************************************/
|
||
|
||
void SwFEShell::MirrorSelection( BOOL bHorizontal )
|
||
{
|
||
SdrView *pView = Imp()->GetDrawView();
|
||
if ( IsObjSelected() && pView->IsMirrorAllowed() )
|
||
{
|
||
if ( bHorizontal )
|
||
pView->MirrorAllMarkedHorizontal();
|
||
else
|
||
pView->MirrorAllMarkedVertical();
|
||
}
|
||
}
|
||
|
||
// springe zum benannten Rahmen (Grafik/OLE)
|
||
|
||
BOOL SwFEShell::GotoFly( const String& rName, FlyCntType eType, BOOL bSelFrm )
|
||
{
|
||
BOOL bRet = FALSE;
|
||
static BYTE __READONLY_DATA aChkArr[ 4 ] = {
|
||
/* FLYCNTTYPE_ALL */ 0,
|
||
/* FLYCNTTYPE_FRM */ ND_TEXTNODE,
|
||
/* FLYCNTTYPE_GRF */ ND_GRFNODE,
|
||
/* FLYCNTTYPE_OLE */ ND_OLENODE
|
||
};
|
||
|
||
const SwFlyFrmFmt* pFlyFmt = pDoc->FindFlyByName( rName, aChkArr[ eType]);
|
||
if( pFlyFmt )
|
||
{
|
||
SET_CURR_SHELL( this );
|
||
|
||
SwClientIter aIter( *(SwModify*)pFlyFmt );
|
||
SwFlyFrm* pFrm = (SwFlyFrm*)aIter.First( TYPE( SwFlyFrm ));
|
||
if( pFrm )
|
||
{
|
||
ASSERT( pFrm->IsFlyFrm(), "Wrong FrmType" );
|
||
if( bSelFrm )
|
||
{
|
||
SelectObj( pFrm->Frm().Pos(), FALSE, FALSE, ((SwFlyFrm*)pFrm)->GetVirtDrawObj() );
|
||
if( !ActionPend() )
|
||
MakeVisible( pFrm->Frm() );
|
||
}
|
||
else
|
||
{
|
||
pFrm->GetAnchor()->Calc();
|
||
SwCntntFrm *pCFrm = pFrm->ContainsCntnt();
|
||
if ( pCFrm )
|
||
{
|
||
SwCntntNode *pCNode = pCFrm->GetNode();
|
||
ClearMark();
|
||
SwPaM* pCrsr = GetCrsr();
|
||
|
||
pCrsr->GetPoint()->nNode = *pCNode;
|
||
pCrsr->GetPoint()->nContent.Assign( pCNode, 0 );
|
||
|
||
SwRect& rChrRect = (SwRect&)GetCharRect();
|
||
rChrRect = pFrm->Prt();
|
||
rChrRect.Pos() += pFrm->Frm().Pos();
|
||
GetCrsrDocPos() = rChrRect.Pos();
|
||
}
|
||
}
|
||
bRet = TRUE;
|
||
}
|
||
}
|
||
return bRet;
|
||
}
|
||
|
||
USHORT SwFEShell::GetFlyCount(FlyCntType eType ) const
|
||
{
|
||
return GetDoc()->GetFlyCount(eType);
|
||
}
|
||
|
||
|
||
const SwFrmFmt* SwFEShell::GetFlyNum(USHORT nIdx, FlyCntType eType ) const
|
||
{
|
||
return GetDoc()->GetFlyNum(nIdx, eType );
|
||
}
|
||
|
||
// zeige das akt. selektierte "Object" an
|
||
void SwFEShell::MakeSelVisible()
|
||
{
|
||
if( Imp()->HasDrawView() &&
|
||
Imp()->GetDrawView()->GetMarkList().GetMarkCount() )
|
||
{
|
||
MakeVisible( Imp()->GetDrawView()->GetAllMarkedRect() );
|
||
}
|
||
else
|
||
SwCrsrShell::MakeSelVisible();
|
||
}
|
||
|
||
|
||
//Welcher Schutz ist am selektierten Objekt gesetzt?
|
||
BYTE SwFEShell::IsSelObjProtected( FlyProtectType eType ) const
|
||
{
|
||
int nChk = 0;
|
||
BOOL bParent = eType & FLYPROTECT_PARENT;
|
||
if( Imp()->HasDrawView() )
|
||
{
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for( ULONG i = rMrkList.GetMarkCount(); i; )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( --i )->GetObj();
|
||
if( !bParent )
|
||
{
|
||
nChk |= ( pObj->IsMoveProtect() ? FLYPROTECT_POS : 0 ) |
|
||
( pObj->IsResizeProtect()? FLYPROTECT_SIZE : 0 );
|
||
|
||
if( FLYPROTECT_CONTENT & eType && pObj->IsWriterFlyFrame() )
|
||
{
|
||
SwFlyFrm *pFly = ((SwVirtFlyDrawObj*)pObj)->GetFlyFrm();
|
||
if ( pFly->GetFmt()->GetProtect().IsCntntProtected() )
|
||
nChk |= FLYPROTECT_CONTENT;
|
||
|
||
if ( pFly->Lower() && pFly->Lower()->IsNoTxtFrm() )
|
||
{
|
||
SwOLENode *pNd = ((SwCntntFrm*)pFly->Lower())->GetNode()->GetOLENode();
|
||
if ( pNd )
|
||
{
|
||
SvInPlaceObjectRef aRef = pNd->GetOLEObj().GetOleRef();
|
||
if ( aRef.Is() &&
|
||
SVOBJ_MISCSTATUS_NOTRESIZEABLE & aRef->GetMiscStatus() )
|
||
{
|
||
nChk |= FLYPROTECT_SIZE;
|
||
nChk |= FLYPROTECT_FIXED;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
nChk &= eType;
|
||
if( nChk == eType )
|
||
return eType;
|
||
}
|
||
SwFrm* pAnch;
|
||
if( pObj->IsWriterFlyFrame() )
|
||
pAnch = ( (SwVirtFlyDrawObj*)pObj )->GetFlyFrm()->GetAnchor();
|
||
else
|
||
{
|
||
SwDrawContact* pTmp = (SwDrawContact*)GetUserCall(pObj);
|
||
pAnch = pTmp ? pTmp->GetAnchor() : NULL;
|
||
}
|
||
if( pAnch && pAnch->IsProtected() )
|
||
return eType;
|
||
}
|
||
}
|
||
return nChk;
|
||
}
|
||
|
||
BOOL SwFEShell::GetObjAttr( SfxItemSet &rSet ) const
|
||
{
|
||
if ( !IsObjSelected() )
|
||
return FALSE;
|
||
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
SwDrawContact *pContact = (SwDrawContact*)GetUserCall(pObj);
|
||
if ( i )
|
||
rSet.MergeValues( pContact->GetFmt()->GetAttrSet() );
|
||
else
|
||
rSet.Put( pContact->GetFmt()->GetAttrSet() );
|
||
}
|
||
return TRUE;
|
||
}
|
||
|
||
BOOL SwFEShell::SetObjAttr( const SfxItemSet& rSet )
|
||
{
|
||
SET_CURR_SHELL( this );
|
||
|
||
if ( !rSet.Count() )
|
||
{ ASSERT( !this, "SetObjAttr, empty set." );
|
||
return FALSE;
|
||
}
|
||
|
||
StartAllAction();
|
||
StartUndo( UNDO_INSATTR );
|
||
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
SwDrawContact *pContact = (SwDrawContact*)GetUserCall(pObj);
|
||
GetDoc()->SetAttr( rSet, *pContact->GetFmt() );
|
||
}
|
||
|
||
EndUndo( UNDO_INSATTR );
|
||
EndAllActionAndCall();
|
||
GetDoc()->SetModified();
|
||
return TRUE;
|
||
}
|
||
|
||
BOOL SwFEShell::IsAlignPossible() const
|
||
{
|
||
USHORT nCnt;
|
||
if ( 0 < (nCnt = IsObjSelected()) )
|
||
{
|
||
BOOL bRet = TRUE;
|
||
if ( nCnt == 1 )
|
||
{
|
||
SdrObject *pO = Imp()->GetDrawView()->GetMarkList().GetMark(0)->GetObj();
|
||
SwDrawContact *pC = (SwDrawContact*)GetUserCall(pO);
|
||
if (pC->GetFmt()->GetAnchor().GetAnchorId() == FLY_AT_CNTNT)
|
||
bRet = FALSE;
|
||
else
|
||
bRet = pC->GetAnchor() ? pC->GetAnchor()->IsInDocBody() : FALSE;
|
||
}
|
||
if ( bRet )
|
||
return Imp()->GetDrawView()->IsAlignPossible();
|
||
}
|
||
return FALSE;
|
||
}
|
||
|
||
|
||
//Temporaerer Fix bis SS von JOE da ist
|
||
void SwFEShell::CheckUnboundObjects()
|
||
{
|
||
SET_CURR_SHELL( this );
|
||
|
||
const SdrMarkList &rMrkList = Imp()->GetDrawView()->GetMarkList();
|
||
for ( USHORT i = 0; i < rMrkList.GetMarkCount(); ++i )
|
||
{
|
||
SdrObject *pObj = rMrkList.GetMark( i )->GetObj();
|
||
if ( !GetUserCall(pObj) )
|
||
{
|
||
const Rectangle &rBound = pObj->GetSnapRect();
|
||
const Point aPt( rBound.TopLeft() );
|
||
const SwFrm *pPage = GetLayout()->Lower();
|
||
const SwFrm *pLast = pPage;
|
||
while ( pPage && !pPage->Frm().IsInside( aPt ) )
|
||
{
|
||
if ( aPt.Y() > pPage->Frm().Bottom() )
|
||
pLast = pPage;
|
||
pPage = pPage->GetNext();
|
||
}
|
||
if ( !pPage )
|
||
pPage = pLast;
|
||
ASSERT( pPage, "Page not found." );
|
||
|
||
//Fremde Identifier sollen in den Default laufen.
|
||
//Ueberschneidungen sind moeglich!!
|
||
UINT16 nIdent =
|
||
Imp()->GetDrawView()->GetCurrentObjInventor() == SdrInventor ?
|
||
Imp()->GetDrawView()->GetCurrentObjIdentifier() : 0xFFFF;
|
||
|
||
SwFmtAnchor aAnch;
|
||
const SwFrm *pAnch = 0;
|
||
{
|
||
pAnch = ::FindAnchor( pPage, aPt, TRUE );
|
||
SwPosition aPos( *((SwCntntFrm*)pAnch)->GetNode() );
|
||
aAnch.SetType( FLY_AT_CNTNT );
|
||
aAnch.SetAnchor( &aPos );
|
||
((SwRect&)GetCharRect()).Pos() = aPt;
|
||
}
|
||
|
||
//Erst hier die Action, damit das GetCharRect aktuelle Werte liefert.
|
||
StartAllAction();
|
||
|
||
SfxItemSet aSet( GetAttrPool(), RES_FRM_SIZE, RES_FRM_SIZE,
|
||
RES_SURROUND, RES_ANCHOR, 0 );
|
||
aSet.Put( aAnch );
|
||
|
||
Point aRelNullPt;
|
||
|
||
if( OBJ_CAPTION == nIdent )
|
||
aRelNullPt = ((SdrCaptionObj*)pObj)->GetTailPos();
|
||
else
|
||
aRelNullPt = rBound.TopLeft();
|
||
|
||
aSet.Put( aAnch );
|
||
aSet.Put( SwFmtSurround( SURROUND_THROUGHT ) );
|
||
SwFrmFmt* pFmt = GetDoc()->MakeLayoutFmt(
|
||
RND_DRAW_OBJECT, 0, &aSet );
|
||
|
||
SwDrawContact *pContact = new SwDrawContact(
|
||
(SwDrawFrmFmt*)pFmt, pObj );
|
||
pObj->NbcSetRelativePos( aRelNullPt - pAnch->Frm().Pos() );
|
||
pObj->NbcSetAnchorPos ( pAnch->Frm().Pos() );
|
||
pContact->ConnectToLayout();
|
||
|
||
EndAllAction();
|
||
}
|
||
}
|
||
}
|
||
|
||
void SwFEShell::SetCalcFieldValueHdl(Outliner* pOutliner)
|
||
{
|
||
GetDoc()->SetCalcFieldValueHdl(pOutliner);
|
||
}
|
||
|
||
|
||
|
||
int SwFEShell::Chainable( SwRect &rRect, const SwFrmFmt &rSource,
|
||
const Point &rPt ) const
|
||
{
|
||
rRect.Clear();
|
||
|
||
//Die Source darf noch keinen Follow haben.
|
||
const SwFmtChain &rChain = rSource.GetChain();
|
||
if ( rChain.GetNext() )
|
||
return SW_CHAIN_SOURCE_CHAINED;
|
||
|
||
if( Imp()->HasDrawView() )
|
||
{
|
||
SdrObject* pObj;
|
||
SdrPageView* pPView;
|
||
SwDrawView *pDView = (SwDrawView*)Imp()->GetDrawView();
|
||
const USHORT nOld = pDView->GetHitTolerancePixel();
|
||
pDView->SetHitTolerancePixel( 0 );
|
||
if( pDView->PickObj( rPt, pObj, pPView, SDRSEARCH_PICKMARKABLE ) &&
|
||
pObj->IsWriterFlyFrame() )
|
||
{
|
||
SwFlyFrm *pFly = ((SwVirtFlyDrawObj*)pObj)->GetFlyFrm();
|
||
rRect = pFly->Frm();
|
||
|
||
//Ziel darf natuerlich nicht gleich Source sein und es
|
||
//darf keine geschlossene Kette entstehen.
|
||
SwFrmFmt *pFmt = pFly->GetFmt();
|
||
return GetDoc()->Chainable(rSource, *pFmt);
|
||
}
|
||
pDView->SetHitTolerancePixel( nOld );
|
||
}
|
||
return SW_CHAIN_NOT_FOUND;
|
||
}
|
||
|
||
int SwFEShell::Chain( SwFrmFmt &rSource, const Point &rPt )
|
||
{
|
||
SwRect aDummy;
|
||
int nErr = Chainable( aDummy, rSource, rPt );
|
||
if ( !nErr )
|
||
{
|
||
StartAllAction();
|
||
SdrObject* pObj;
|
||
SdrPageView* pPView;
|
||
SwDrawView *pDView = (SwDrawView*)Imp()->GetDrawView();
|
||
const USHORT nOld = pDView->GetHitTolerancePixel();
|
||
pDView->SetHitTolerancePixel( 0 );
|
||
pDView->PickObj( rPt, pObj, pPView, SDRSEARCH_PICKMARKABLE );
|
||
pDView->SetHitTolerancePixel( nOld );
|
||
SwFlyFrm *pFly = ((SwVirtFlyDrawObj*)pObj)->GetFlyFrm();
|
||
|
||
SwFlyFrmFmt *pFmt = (SwFlyFrmFmt*)pFly->GetFmt();
|
||
GetDoc()->Chain(rSource, *pFmt);
|
||
EndAllAction();
|
||
SetChainMarker();
|
||
}
|
||
return nErr;
|
||
}
|
||
|
||
void SwFEShell::Unchain( SwFrmFmt &rFmt )
|
||
{
|
||
StartAllAction();
|
||
GetDoc()->Unchain(rFmt);
|
||
EndAllAction();
|
||
}
|
||
|
||
|
||
void SwFEShell::HideChainMarker()
|
||
{
|
||
if ( pChainFrom )
|
||
pChainFrom->Hide();
|
||
if ( pChainTo )
|
||
pChainTo->Hide();
|
||
}
|
||
|
||
void SwFEShell::SetChainMarker()
|
||
{
|
||
FASTBOOL bDelFrom = TRUE,
|
||
bDelTo = TRUE;
|
||
if ( IsFrmSelected() )
|
||
{
|
||
SwFlyFrm *pFly = FindFlyFrm();
|
||
|
||
XPolygon aPoly(3);
|
||
if ( pFly->GetPrevLink() )
|
||
{
|
||
bDelFrom = FALSE;
|
||
const SwFrm *pPre = pFly->GetPrevLink();
|
||
aPoly[0] = Point( pPre->Frm().Right(), pPre->Frm().Bottom());
|
||
aPoly[1] = pFly->Frm().Pos();
|
||
if ( !pChainFrom )
|
||
pChainFrom = new SdrViewUserMarker( GetDrawView() );
|
||
pChainFrom->SetPolyLine( TRUE );
|
||
pChainFrom->SetXPolygon( aPoly );
|
||
pChainFrom->Show();
|
||
}
|
||
if ( pFly->GetNextLink() )
|
||
{
|
||
bDelTo = FALSE;
|
||
const SwFlyFrm *pNxt = pFly->GetNextLink();
|
||
aPoly[0] = Point( pFly->Frm().Right(), pFly->Frm().Bottom());
|
||
aPoly[1] = pNxt->Frm().Pos();
|
||
if ( !pChainTo )
|
||
pChainTo = new SdrViewUserMarker( GetDrawView() );
|
||
pChainTo->SetXPolygon( aPoly );
|
||
pChainTo->SetPolyLine( TRUE );
|
||
pChainTo->Show();
|
||
}
|
||
}
|
||
if ( bDelFrom )
|
||
delete pChainFrom, pChainFrom = 0;
|
||
if ( bDelTo )
|
||
delete pChainTo, pChainTo = 0;
|
||
}
|
||
|
||
long SwFEShell::GetSectionWidth( SwFmt& rFmt ) const
|
||
{
|
||
SwFrm *pFrm = GetCurrFrm();
|
||
// Steht der Cursor z.Z. in einem SectionFrm?
|
||
if( pFrm && pFrm->IsInSct() )
|
||
{
|
||
SwSectionFrm* pSect = pFrm->FindSctFrm();
|
||
do
|
||
{
|
||
// Ist es der Gewuenschte?
|
||
if( pSect->GetRegisteredIn() == &rFmt )
|
||
return pSect->Frm().Width();
|
||
// fuer geschachtelte Bereiche
|
||
pSect = pSect->GetUpper()->FindSctFrm();
|
||
}
|
||
while( pSect );
|
||
}
|
||
SwClientIter aIter( rFmt );
|
||
SwClient *pLast = aIter.GoStart();
|
||
while ( pLast )
|
||
{
|
||
if ( pLast->IsA( TYPE(SwFrm) ) )
|
||
{
|
||
SwSectionFrm* pSct = (SwSectionFrm*)pLast;
|
||
if( !pSct->IsFollow() )
|
||
return pSct->Frm().Width();
|
||
}
|
||
pLast = aIter++;
|
||
}
|
||
return 0;
|
||
}
|
||
|
||
|