/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: svdpage.cxx,v $ * $Revision: 1.67 $ * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_svx.hxx" #include // HACK #include #include #include #include #include #ifndef _STRING_H #define _STRING_H #endif #include #include #include #include #include #include // fuer SwapInAll() #include // Zum kopieren der Konnektoren #include // Sonderbehandlung OLE beim SdrExchangeFormat #include "svditer.hxx" #include #include #include #include #include #include #include #include #include #include // FRound #include #include #include #include using namespace ::com::sun::star; namespace { void DumpObjectList (const ::std::vector& rContainer) { ::std::vector::const_iterator iObject (rContainer.begin()); ::std::vector::const_iterator iEnd (rContainer.end()); for (int nIndex=0 ; iObject!=iEnd; ++iObject,++nIndex) { const SdrObject* pObject = iObject->get(); OSL_TRACE("%d : %x, %s", nIndex, pObject, ::rtl::OUStringToOString(pObject->GetName(),RTL_TEXTENCODING_UTF8).getStr()); } } } class SdrObjList::WeakSdrObjectContainerType : public ::std::vector { public: WeakSdrObjectContainerType (const sal_Int32 nInitialSize) : ::std::vector(nInitialSize) {}; }; static const sal_Int32 InitialObjectContainerCapacity (64); DBG_NAME(SdrObjList) TYPEINIT0(SdrObjList); SdrObjList::SdrObjList(SdrModel* pNewModel, SdrPage* pNewPage, SdrObjList* pNewUpList): maList(), mpNavigationOrder(), mbIsNavigationOrderDirty(false) { DBG_CTOR(SdrObjList,NULL); maList.reserve(InitialObjectContainerCapacity); pModel=pNewModel; pPage=pNewPage; pUpList=pNewUpList; bObjOrdNumsDirty=FALSE; bRectsDirty=FALSE; pOwnerObj=NULL; eListKind=SDROBJLIST_UNKNOWN; } SdrObjList::SdrObjList(const SdrObjList& rSrcList): maList(), mpNavigationOrder(), mbIsNavigationOrderDirty(false) { DBG_CTOR(SdrObjList,NULL); maList.reserve(InitialObjectContainerCapacity); pModel=NULL; pPage=NULL; pUpList=NULL; bObjOrdNumsDirty=FALSE; bRectsDirty=FALSE; pOwnerObj=NULL; eListKind=SDROBJLIST_UNKNOWN; *this=rSrcList; } SdrObjList::~SdrObjList() { DBG_DTOR(SdrObjList,NULL); // #111111# // To avoid that the Clear() method will broadcast changes when in destruction // which would call virtual methos (not allowed in destructor), the model is set // to NULL here. pModel = 0L; Clear(); // Containerinhalt loeschen! } void SdrObjList::operator=(const SdrObjList& rSrcList) { Clear(); eListKind=rSrcList.eListKind; CopyObjects(rSrcList); } void SdrObjList::CopyObjects(const SdrObjList& rSrcList) { Clear(); bObjOrdNumsDirty=FALSE; bRectsDirty =FALSE; ULONG nCloneErrCnt=0; ULONG nAnz=rSrcList.GetObjCount(); SdrInsertReason aReason(SDRREASON_COPY); ULONG no; for (no=0; noClone(pPage,pModel); SdrObject* pDO = pSO->Clone(); pDO->SetModel(pModel); pDO->SetPage(pPage); if (pDO!=NULL) { NbcInsertObject(pDO,CONTAINER_APPEND,&aReason); } else { nCloneErrCnt++; } } // und nun zu den Konnektoren // Die neuen Objekte werden auf die der rSrcList abgebildet // und so die Objektverbindungen hergestellt. // Aehnliche Implementation an folgenden Stellen: // void SdrObjList::CopyObjects(const SdrObjList& rSrcList) // SdrModel* SdrExchangeView::GetMarkedObjModel() const // FASTBOOL SdrExchangeView::Paste(const SdrModel& rMod,...) // void SdrEditView::CopyMarked() if (nCloneErrCnt==0) { for (no=0; noGetConnectedNode(TRUE); SdrObject* pSrcNode2=pSrcEdge->GetConnectedNode(FALSE); if (pSrcNode1!=NULL && pSrcNode1->GetObjList()!=pSrcEdge->GetObjList()) pSrcNode1=NULL; // Listenuebergreifend if (pSrcNode2!=NULL && pSrcNode2->GetObjList()!=pSrcEdge->GetObjList()) pSrcNode2=NULL; // ist (noch) nicht if (pSrcNode1!=NULL || pSrcNode2!=NULL) { SdrObject* pEdgeObjTmp=GetObj(no); SdrEdgeObj* pDstEdge=PTR_CAST(SdrEdgeObj,pEdgeObjTmp); if (pDstEdge!=NULL) { if (pSrcNode1!=NULL) { ULONG nDstNode1=pSrcNode1->GetOrdNum(); SdrObject* pDstNode1=GetObj(nDstNode1); if (pDstNode1!=NULL) { // Sonst grober Fehler! pDstEdge->ConnectToNode(TRUE,pDstNode1); } else { DBG_ERROR("SdrObjList::operator=(): pDstNode1==NULL!"); } } if (pSrcNode2!=NULL) { ULONG nDstNode2=pSrcNode2->GetOrdNum(); SdrObject* pDstNode2=GetObj(nDstNode2); if (pDstNode2!=NULL) { // Node war sonst wohl nicht markiert pDstEdge->ConnectToNode(FALSE,pDstNode2); } else { DBG_ERROR("SdrObjList::operator=(): pDstNode2==NULL!"); } } } else { DBG_ERROR("SdrObjList::operator=(): pDstEdge==NULL!"); } } } } } else { #ifdef DBG_UTIL ByteString aStr("SdrObjList::operator=(): Fehler beim Clonen "); if(nCloneErrCnt == 1) { aStr += "eines Zeichenobjekts."; } else { aStr += "von "; aStr += ByteString::CreateFromInt32( nCloneErrCnt ); aStr += " Zeichenobjekten."; } aStr += " Objektverbindungen werden nicht mitkopiert."; DBG_ERROR(aStr.GetBuffer()); #endif } } void SdrObjList::Clear() { sal_Bool bObjectsRemoved(sal_False); while( ! maList.empty()) { // remove last object from list SdrObject* pObj = maList.back(); RemoveObjectFromContainer(maList.size()-1); // flushViewObjectContacts() is done since SdrObject::Free is not guaranteed // to delete the object and thus refresh visualisations pObj->GetViewContact().flushViewObjectContacts(true); bObjectsRemoved = sal_True; // sent remove hint (after removal, see RemoveObject()) if(pModel) { SdrHint aHint(*pObj); aHint.SetKind(HINT_OBJREMOVED); aHint.SetPage(pPage); pModel->Broadcast(aHint); } // delete the object itself SdrObject::Free( pObj ); } if(pModel && bObjectsRemoved) { pModel->SetChanged(); } } SdrPage* SdrObjList::GetPage() const { return pPage; } void SdrObjList::SetPage(SdrPage* pNewPage) { if (pPage!=pNewPage) { pPage=pNewPage; ULONG nAnz=GetObjCount(); for (ULONG no=0; noSetPage(pPage); } } } SdrModel* SdrObjList::GetModel() const { return pModel; } void SdrObjList::SetModel(SdrModel* pNewModel) { if (pModel!=pNewModel) { pModel=pNewModel; ULONG nAnz=GetObjCount(); for (ULONG i=0; iSetModel(pModel); } } } void SdrObjList::RecalcObjOrdNums() { ULONG nAnz=GetObjCount(); for (ULONG no=0; noSetOrdNum(no); } bObjOrdNumsDirty=FALSE; } void SdrObjList::RecalcRects() { aOutRect=Rectangle(); aSnapRect=aOutRect; ULONG nAnz=GetObjCount(); ULONG i; for (i=0; iGetCurrentBoundRect(); aSnapRect=pObj->GetSnapRect(); } else { aOutRect.Union(pObj->GetCurrentBoundRect()); aSnapRect.Union(pObj->GetSnapRect()); } } } void SdrObjList::SetRectsDirty() { bRectsDirty=TRUE; if (pUpList!=NULL) pUpList->SetRectsDirty(); } void SdrObjList::impChildInserted(SdrObject& rChild) const { sdr::contact::ViewContact* pParent = rChild.GetViewContact().GetParentContact(); if(pParent) { pParent->ActionChildInserted(rChild.GetViewContact()); } } void SdrObjList::NbcInsertObject(SdrObject* pObj, ULONG nPos, const SdrInsertReason* /*pReason*/) { DBG_ASSERT(pObj!=NULL,"SdrObjList::NbcInsertObject(NULL)"); if (pObj!=NULL) { DBG_ASSERT(!pObj->IsInserted(),"ZObjekt hat bereits Inserted-Status"); ULONG nAnz=GetObjCount(); if (nPos>nAnz) nPos=nAnz; InsertObjectIntoContainer(*pObj,nPos); if (nPosSetOrdNum(nPos); pObj->SetObjList(this); pObj->SetPage(pPage); // #110094# Inform the parent about change to allow invalidations at // evtl. existing parent visualisations impChildInserted(*pObj); if (!bRectsDirty) { aOutRect.Union(pObj->GetCurrentBoundRect()); aSnapRect.Union(pObj->GetSnapRect()); } pObj->SetInserted(TRUE); // Ruft u.a. den UserCall } } void SdrObjList::InsertObject(SdrObject* pObj, ULONG nPos, const SdrInsertReason* pReason) { DBG_ASSERT(pObj!=NULL,"SdrObjList::InsertObject(NULL)"); if(pObj) { // #69055# if anchor is used, reset it before grouping if(GetOwnerObj()) { const Point& rAnchorPos = pObj->GetAnchorPos(); if(rAnchorPos.X() || rAnchorPos.Y()) pObj->NbcSetAnchorPos(Point()); } // do insert to new group NbcInsertObject(pObj, nPos, pReason); // Falls das Objekt in eine Gruppe eingefuegt wird // und nicht mit seinen Bruedern ueberlappt, muss es // einen eigenen Redraw bekommen if(pOwnerObj) { // only repaint here pOwnerObj->ActionChanged(); } if(pModel) { // Hier muss ein anderer Broadcast her! // Repaint ab Objekt Nummer ... (Achtung: GroupObj) if(pObj->GetPage()) { SdrHint aHint(*pObj); aHint.SetKind(HINT_OBJINSERTED); pModel->Broadcast(aHint); } pModel->SetChanged(); } } } SdrObject* SdrObjList::NbcRemoveObject(ULONG nObjNum) { if (nObjNum >= maList.size()) { OSL_ASSERT(nObjNumGetViewContact().flushViewObjectContacts(true); DBG_ASSERT(pObj!=NULL,"Object zum Removen nicht gefunden"); if (pObj!=NULL) { DBG_ASSERT(pObj->IsInserted(),"ZObjekt hat keinen Inserted-Status"); pObj->SetInserted(FALSE); // Ruft u.a. den UserCall pObj->SetObjList(NULL); pObj->SetPage(NULL); if (!bObjOrdNumsDirty) { // Optimierung fuer den Fall, dass das letzte Obj rausgenommen wird if (nObjNum!=ULONG(nAnz-1)) { bObjOrdNumsDirty=TRUE; } } SetRectsDirty(); } return pObj; } SdrObject* SdrObjList::RemoveObject(ULONG nObjNum) { if (nObjNum >= maList.size()) { OSL_ASSERT(nObjNumGetViewContact().flushViewObjectContacts(true); DBG_ASSERT(pObj->IsInserted(),"ZObjekt hat keinen Inserted-Status"); if (pModel!=NULL) { // Hier muss ein anderer Broadcast her! if (pObj->GetPage()!=NULL) { SdrHint aHint(*pObj); aHint.SetKind(HINT_OBJREMOVED); pModel->Broadcast(aHint); } pModel->SetChanged(); } pObj->SetInserted(FALSE); // Ruft u.a. den UserCall pObj->SetObjList(NULL); pObj->SetPage(NULL); if (!bObjOrdNumsDirty) { // Optimierung fuer den Fall, dass das letzte Obj rausgenommen wird if (nObjNum!=ULONG(nAnz-1)) { bObjOrdNumsDirty=TRUE; } } SetRectsDirty(); if(pOwnerObj && !GetObjCount()) { // empty group created; it needs to be repainted since it's // visualisation changes pOwnerObj->ActionChanged(); } } return pObj; } SdrObject* SdrObjList::NbcReplaceObject(SdrObject* pNewObj, ULONG nObjNum) { if (nObjNum >= maList.size() || pNewObj == NULL) { OSL_ASSERT(nObjNumIsInserted(),"SdrObjList::ReplaceObject: ZObjekt hat keinen Inserted-Status"); pObj->SetInserted(FALSE); pObj->SetObjList(NULL); pObj->SetPage(NULL); ReplaceObjectInContainer(*pNewObj,nObjNum); // flushViewObjectContacts() clears the VOC's and those invalidate pObj->GetViewContact().flushViewObjectContacts(true); pNewObj->SetOrdNum(nObjNum); pNewObj->SetObjList(this); pNewObj->SetPage(pPage); // #110094# Inform the parent about change to allow invalidations at // evtl. existing parent visualisations impChildInserted(*pNewObj); pNewObj->SetInserted(TRUE); SetRectsDirty(); } return pObj; } SdrObject* SdrObjList::ReplaceObject(SdrObject* pNewObj, ULONG nObjNum) { if (nObjNum >= maList.size()) { OSL_ASSERT(nObjNumIsInserted(),"SdrObjList::ReplaceObject: ZObjekt hat keinen Inserted-Status"); if (pModel!=NULL) { // Hier muss ein anderer Broadcast her! if (pObj->GetPage()!=NULL) { SdrHint aHint(*pObj); aHint.SetKind(HINT_OBJREMOVED); pModel->Broadcast(aHint); } } pObj->SetInserted(FALSE); pObj->SetObjList(NULL); pObj->SetPage(NULL); ReplaceObjectInContainer(*pNewObj,nObjNum); // flushViewObjectContacts() clears the VOC's and those invalidate pObj->GetViewContact().flushViewObjectContacts(true); pNewObj->SetOrdNum(nObjNum); pNewObj->SetObjList(this); pNewObj->SetPage(pPage); // #110094# Inform the parent about change to allow invalidations at // evtl. existing parent visualisations impChildInserted(*pNewObj); pNewObj->SetInserted(TRUE); if (pModel!=NULL) { // Hier muss ein anderer Broadcast her! if (pNewObj->GetPage()!=NULL) { SdrHint aHint(*pNewObj); aHint.SetKind(HINT_OBJINSERTED); pModel->Broadcast(aHint); } pModel->SetChanged(); } SetRectsDirty(); } return pObj; } SdrObject* SdrObjList::NbcSetObjectOrdNum(ULONG nOldObjNum, ULONG nNewObjNum) { if (nOldObjNum >= maList.size() || nNewObjNum >= maList.size()) { OSL_ASSERT(nOldObjNumIsInserted(),"SdrObjList::NbcSetObjectOrdNum: ZObjekt hat keinen Inserted-Status"); RemoveObjectFromContainer(nOldObjNum); InsertObjectIntoContainer(*pObj,nNewObjNum); // #110094# No need to delete visualisation data since same object // gets inserted again. Also a single ActionChanged is enough pObj->ActionChanged(); pObj->SetOrdNum(nNewObjNum); bObjOrdNumsDirty=TRUE; } return pObj; } SdrObject* SdrObjList::SetObjectOrdNum(ULONG nOldObjNum, ULONG nNewObjNum) { if (nOldObjNum >= maList.size() || nNewObjNum >= maList.size()) { OSL_ASSERT(nOldObjNumIsInserted(),"SdrObjList::SetObjectOrdNum: ZObjekt hat keinen Inserted-Status"); RemoveObjectFromContainer(nOldObjNum); InsertObjectIntoContainer(*pObj,nNewObjNum); // #110094#No need to delete visualisation data since same object // gets inserted again. Also a single ActionChanged is enough pObj->ActionChanged(); pObj->SetOrdNum(nNewObjNum); bObjOrdNumsDirty=TRUE; if (pModel!=NULL) { // Hier muss ein anderer Broadcast her! if (pObj->GetPage()!=NULL) pModel->Broadcast(SdrHint(*pObj)); pModel->SetChanged(); } } return pObj; } const Rectangle& SdrObjList::GetAllObjSnapRect() const { if (bRectsDirty) { ((SdrObjList*)this)->RecalcRects(); ((SdrObjList*)this)->bRectsDirty=FALSE; } return aSnapRect; } const Rectangle& SdrObjList::GetAllObjBoundRect() const { if (bRectsDirty) { ((SdrObjList*)this)->RecalcRects(); ((SdrObjList*)this)->bRectsDirty=FALSE; } return aOutRect; } SdrObject* SdrObjList::CheckHit(const Point& rPnt, USHORT nTol, const SetOfByte* pVisiLayer, FASTBOOL bBackward) const { SdrObject* pHit=NULL; Rectangle R(rPnt.X()-nTol,rPnt.Y()-nTol,rPnt.X()+nTol,rPnt.Y()+nTol); if (R.IsOver(GetAllObjBoundRect())) { ULONG nObjAnz=GetObjCount(); ULONG nObjNum=bBackward ? 0 : nObjAnz; while (pHit==NULL && (bBackward ? nObjNum0)) { if (!bBackward) nObjNum--; SdrObject* pObj=GetObj(nObjNum); if (R.IsOver(pObj->GetCurrentBoundRect())) { SdrObjList* pSubList=pObj->GetSubList(); if (pSubList!=NULL || pVisiLayer==NULL) { // Gruppenobjekte beruecksichtigen sichtbare Layer selbst pHit=pObj->CheckHit(rPnt,nTol,pVisiLayer/*,bBackward*/); } else { // Ansonsten nur wenn Layer sichtbar SdrLayerID nLayer=pObj->GetLayer(); if (pVisiLayer->IsSet(nLayer)) { pHit=pObj->CheckHit(rPnt,nTol,pVisiLayer/*,bBackward*/); } } } if (bBackward) nObjNum++; } } return pHit; } void SdrObjList::NbcReformatAllTextObjects() { ULONG nAnz=GetObjCount(); ULONG nNum=0; Printer* pPrinter = NULL; if (pModel) { if (pModel->GetRefDevice() && pModel->GetRefDevice()->GetOutDevType() == OUTDEV_PRINTER) { // Kein RefDevice oder RefDevice kein Printer pPrinter = (Printer*) pModel->GetRefDevice(); } } while (nNumGetObjInventor() == SdrInventor && pObj->GetObjIdentifier() == OBJ_OLE2 && !( (SdrOle2Obj*) pObj )->IsEmpty() ) { //const SvInPlaceObjectRef& xObjRef = ((SdrOle2Obj*) pObj)->GetObjRef(); //TODO/LATER: PrinterChangeNotification needed //if( xObjRef.Is() && ( xObjRef->GetMiscStatus() & SVOBJ_MISCSTATUS_RESIZEONPRINTERCHANGE ) ) // xObjRef->OnDocumentPrinterChanged(pPrinter); } pObj->NbcReformatText(); nAnz=GetObjCount(); // ReformatText may delete an object nNum++; } } void SdrObjList::ReformatAllTextObjects() { NbcReformatAllTextObjects(); } /** steps over all available objects and reformats all edge objects that are connected to other objects so that they may reposition itselfs. #103122# */ void SdrObjList::ReformatAllEdgeObjects() { const sal_uInt32 nCount=GetObjCount(); sal_uInt32 nObj; for( nObj = 0; nObj < nCount; nObj++ ) { SdrObject* pObj = GetObj(nObj); if( pObj->ISA(SdrEdgeObj) ) static_cast(pObj)->Reformat(); } } void SdrObjList::BurnInStyleSheetAttributes() { for(sal_uInt32 a(0L); a < GetObjCount(); a++) { GetObj(a)->BurnInStyleSheetAttributes(); } } FASTBOOL SdrObjList::ImpGetFillColor(SdrObject* pObj, Color& rCol) const { return GetDraftFillColor(pObj->GetMergedItemSet(), rCol); } FASTBOOL SdrObjList::GetFillColor(const Point& rPnt, const SetOfByte& rVisLayers, /*FASTBOOL bLayerSorted,*/ Color& rCol) const { if (pModel==NULL) return FALSE; FASTBOOL bRet=FALSE; FASTBOOL bMaster=pPage!=NULL ? pPage->IsMasterPage() : FALSE; for (ULONG no=GetObjCount(); !bRet && no>0; ) { no--; SdrObject* pObj=GetObj(no); SdrObjList* pOL=pObj->GetSubList(); if (pOL!=NULL) { // Aha, Gruppenobjekt bRet=pOL->GetFillColor(rPnt,rVisLayers,/*bLayerSorted,*/rCol); } else { SdrTextObj* pTextObj=PTR_CAST(SdrTextObj,pObj); // #108867# Exclude zero master page object (i.e. background // shape) from color query if (pTextObj!=NULL && pObj->IsClosedObj() && rVisLayers.IsSet(pObj->GetLayer()) && (!bMaster || (!pObj->IsNotVisibleAsMaster() && no!=0)) && pObj->GetCurrentBoundRect().IsInside(rPnt) && !pTextObj->IsHideContour() && pObj->IsHit(rPnt,0,NULL)) { // Nachfolgend extra Funktion um Stack zu sparen, // da diese Methode hier rekursiv ist. bRet=ImpGetFillColor(pObj,rCol); } } } return bRet; } ULONG SdrObjList::GetObjCount() const { return maList.size(); } SdrObject* SdrObjList::GetObj(ULONG nNum) const { if (nNum >= maList.size()) { OSL_ASSERT(nNumIsReadOnly(); return bRet; } ULONG SdrObjList::CountAllObjects() const { ULONG nCnt=GetObjCount(); ULONG nAnz=nCnt; for (USHORT nNum=0; nNumGetSubList(); if (pSubOL!=NULL) { nCnt+=pSubOL->CountAllObjects(); } } return nCnt; } void SdrObjList::ForceSwapInObjects() const { ULONG nObjAnz=GetObjCount(); for (ULONG nObjNum=nObjAnz; nObjNum>0;) { SdrObject* pObj=GetObj(--nObjNum); SdrGrafObj* pGrafObj=PTR_CAST(SdrGrafObj,pObj); if (pGrafObj!=NULL) { pGrafObj->ForceSwapIn(); } SdrObjList* pOL=pObj->GetSubList(); if (pOL!=NULL) { pOL->ForceSwapInObjects(); } } } void SdrObjList::ForceSwapOutObjects() const { ULONG nObjAnz=GetObjCount(); for (ULONG nObjNum=nObjAnz; nObjNum>0;) { SdrObject* pObj=GetObj(--nObjNum); SdrGrafObj* pGrafObj=PTR_CAST(SdrGrafObj,pObj); if (pGrafObj!=NULL) { pGrafObj->ForceSwapOut(); } SdrObjList* pOL=pObj->GetSubList(); if (pOL!=NULL) { pOL->ForceSwapOutObjects(); } } } void SdrObjList::FlattenGroups() { sal_Int32 nObj = GetObjCount(); sal_Int32 i; for( i=nObj-1; i>=0; --i) UnGroupObj(i); } void SdrObjList::UnGroupObj( ULONG nObjNum ) { // if the given object is no group, this method is a noop SdrObject* pUngroupObj = GetObj( nObjNum ); if( pUngroupObj ) { SdrObjList* pSrcLst = pUngroupObj->GetSubList(); //sal_Int32 nCount( 0 ); if( pUngroupObj->ISA( SdrObjGroup ) && pSrcLst ) { SdrObjGroup* pUngroupGroup = static_cast< SdrObjGroup* > (pUngroupObj); // ungroup recursively (has to be head recursion, // otherwise our indices will get trashed when doing it in // the loop) pSrcLst->FlattenGroups(); // the position at which we insert the members of rUngroupGroup sal_Int32 nInsertPos( pUngroupGroup->GetOrdNum() ); SdrObject* pObj; sal_Int32 i, nAnz = pSrcLst->GetObjCount(); for( i=0; iRemoveObject(0); SdrInsertReason aReason(SDRREASON_VIEWCALL, pUngroupGroup); InsertObject(pObj, nInsertPos, &aReason); ++nInsertPos; } RemoveObject(nInsertPos); } } #ifdef DBG_UTIL else DBG_ERROR("SdrObjList::UnGroupObj: object index invalid"); #endif } bool SdrObjList::HasObjectNavigationOrder (void) const { return mpNavigationOrder.get() != NULL; } void SdrObjList::SetObjectNavigationPosition ( SdrObject& rObject, const sal_uInt32 nNewPosition) { // When the navigation order container has not yet been created then // create one now. It is initialized with the z-order taken from // maList. if (mpNavigationOrder.get() == NULL) { mpNavigationOrder.reset(new WeakSdrObjectContainerType(maList.size())); ::std::copy( maList.begin(), maList.end(), mpNavigationOrder->begin()); } OSL_ASSERT(mpNavigationOrder.get()!=NULL); OSL_ASSERT( mpNavigationOrder->size() == maList.size()); SdrObjectWeakRef aReference (&rObject); // Look up the object whose navigation position is to be changed. WeakSdrObjectContainerType::iterator iObject (::std::find( mpNavigationOrder->begin(), mpNavigationOrder->end(), aReference)); if (iObject == mpNavigationOrder->end()) { // The given object is not a member of the navigation order. return; } // Move the object to its new position. const sal_uInt32 nOldPosition = ::std::distance(mpNavigationOrder->begin(), iObject); if (nOldPosition != nNewPosition) { mpNavigationOrder->erase(iObject); sal_uInt32 nInsertPosition (nNewPosition); // Adapt insertion position for the just erased object. if (nNewPosition >= nOldPosition) nInsertPosition -= 1; if (nInsertPosition >= mpNavigationOrder->size()) mpNavigationOrder->push_back(aReference); else mpNavigationOrder->insert(mpNavigationOrder->begin()+nInsertPosition, aReference); mbIsNavigationOrderDirty = true; // The navigation order is written out to file so mark the model as modified. if (pModel != NULL) pModel->SetChanged(); } } SdrObject* SdrObjList::GetObjectForNavigationPosition (const sal_uInt32 nNavigationPosition) const { if (HasObjectNavigationOrder()) { // There is a user defined navigation order. Make sure the object // index is correct and look up the object in mpNavigationOrder. if (nNavigationPosition >= mpNavigationOrder->size()) { OSL_ASSERT(nNavigationPosition < mpNavigationOrder->size()); } else return (*mpNavigationOrder)[nNavigationPosition].get(); } else { // There is no user defined navigation order. Use the z-order // instead. if (nNavigationPosition >= maList.size()) { OSL_ASSERT(nNavigationPosition < maList.size()); } else return maList[nNavigationPosition]; } return NULL; } void SdrObjList::ClearObjectNavigationOrder (void) { mpNavigationOrder.reset(); mbIsNavigationOrderDirty = true; } bool SdrObjList::RecalcNavigationPositions (void) { bool bUpToDate (false); if (mbIsNavigationOrderDirty) { if (mpNavigationOrder.get() != NULL) { mbIsNavigationOrderDirty = false; WeakSdrObjectContainerType::iterator iObject; WeakSdrObjectContainerType::const_iterator iEnd (mpNavigationOrder->end()); sal_uInt32 nIndex (0); for (iObject=mpNavigationOrder->begin(); iObject!=iEnd; ++iObject,++nIndex) (*iObject)->SetNavigationPosition(nIndex); bUpToDate = true; } } return mpNavigationOrder.get() != NULL; } void SdrObjList::SetNavigationOrder (const uno::Reference& rxOrder) { if (rxOrder.is()) { const sal_Int32 nCount = rxOrder->getCount(); if ((sal_uInt32)nCount != maList.size()) return; if (mpNavigationOrder.get() == NULL) mpNavigationOrder.reset(new WeakSdrObjectContainerType(nCount)); for (sal_Int32 nIndex=0; nIndex xShape (rxOrder->getByIndex(nIndex), uno::UNO_QUERY); SdrObject* pObject = SdrObject::getSdrObjectFromXShape(xShape); if (pObject == NULL) break; (*mpNavigationOrder)[nIndex] = pObject; } mbIsNavigationOrderDirty = true; } else ClearObjectNavigationOrder(); } void SdrObjList::InsertObjectIntoContainer ( SdrObject& rObject, const sal_uInt32 nInsertPosition) { OSL_ASSERT(nInsertPosition<=maList.size()); // Update the navigation positions. if (HasObjectNavigationOrder()) { // The new object does not have a user defined position so append it // to the list. rObject.SetNavigationPosition(mpNavigationOrder->size()); mpNavigationOrder->push_back(&rObject); } // Insert object into object list. Because the insert() method requires // a valid iterator as insertion position, we have to use push_back() to // insert at the end of the list. if (nInsertPosition >= maList.size()) maList.push_back(&rObject); else maList.insert(maList.begin()+nInsertPosition, &rObject); bObjOrdNumsDirty=TRUE; } void SdrObjList::ReplaceObjectInContainer ( SdrObject& rNewObject, const sal_uInt32 nObjectPosition) { if (nObjectPosition >= maList.size()) { OSL_ASSERT(nObjectPositionbegin(), mpNavigationOrder->end(), aReference)); if (iObject != mpNavigationOrder->end()) mpNavigationOrder->erase(iObject); mpNavigationOrder->push_back(&rNewObject); mbIsNavigationOrderDirty = true; } maList[nObjectPosition] = &rNewObject; bObjOrdNumsDirty=TRUE; } void SdrObjList::RemoveObjectFromContainer ( const sal_uInt32 nObjectPosition) { if (nObjectPosition >= maList.size()) { OSL_ASSERT(nObjectPositionbegin(), mpNavigationOrder->end(), aReference)); if (iObject != mpNavigationOrder->end()) mpNavigationOrder->erase(iObject); mbIsNavigationOrderDirty = true; } maList.erase(maList.begin()+nObjectPosition); bObjOrdNumsDirty=TRUE; } //////////////////////////////////////////////////////////////////////////////////////////////////// void SdrPageGridFrameList::Clear() { USHORT nAnz=GetCount(); for (USHORT i=0; impViewContact = ((SdrPage*)this)->CreateObjectSpecificViewContact(); } return *mpViewContact; } //////////////////////////////////////////////////////////////////////////////////////////////////// TYPEINIT1(SdrPage,SdrObjList); DBG_NAME(SdrPage) SdrPage::SdrPage(SdrModel& rNewModel, bool bMasterPage) : SdrObjList(&rNewModel, this), mpViewContact(0L), nWdt(10L), nHgt(10L), nBordLft(0L), nBordUpp(0L), nBordRgt(0L), nBordLwr(0L), pLayerAdmin(new SdrLayerAdmin(&rNewModel.GetLayerAdmin())), pBackgroundObj(0L), mpMasterPageDescriptor(0L), nPageNum(0L), mbMaster(bMasterPage), mbInserted(false), mbObjectsNotPersistent(false), mbSwappingLocked(false), mbPageBorderOnlyLeftRight(false) { DBG_CTOR(SdrPage,NULL); aPrefVisiLayers.SetAll(); eListKind = (bMasterPage) ? SDROBJLIST_MASTERPAGE : SDROBJLIST_DRAWPAGE; } SdrPage::SdrPage(const SdrPage& rSrcPage) : SdrObjList(rSrcPage.pModel, this), tools::WeakBase< SdrPage >(), mpViewContact(0L), nWdt(rSrcPage.nWdt), nHgt(rSrcPage.nHgt), nBordLft(rSrcPage.nBordLft), nBordUpp(rSrcPage.nBordUpp), nBordRgt(rSrcPage.nBordRgt), nBordLwr(rSrcPage.nBordLwr), pLayerAdmin(new SdrLayerAdmin(rSrcPage.pModel->GetLayerAdmin())), pBackgroundObj(0L), mpMasterPageDescriptor(0L), nPageNum(rSrcPage.nPageNum), mbMaster(rSrcPage.mbMaster), mbInserted(false), mbObjectsNotPersistent(rSrcPage.mbObjectsNotPersistent), mbSwappingLocked(rSrcPage.mbSwappingLocked), mbPageBorderOnlyLeftRight(rSrcPage.mbPageBorderOnlyLeftRight) { DBG_CTOR(SdrPage,NULL); aPrefVisiLayers.SetAll(); eListKind = (mbMaster) ? SDROBJLIST_MASTERPAGE : SDROBJLIST_DRAWPAGE; // copy things from source // Warning: this leads to slicing (see issue 93186) and has to be // removed as soon as possible. *this = rSrcPage; // be careful and correct eListKind, a member of SdrObjList which // will be changed by the SdrOIbjList::operator= before... eListKind = (mbMaster) ? SDROBJLIST_MASTERPAGE : SDROBJLIST_DRAWPAGE; // The previous assignment to *this may have resulted in a call to // createUnoPage at a partially initialized (sliced) SdrPage object. // Due to the vtable being not yet fully set-up at this stage, // createUnoPage() may have been called at the wrong class. // To force a call to the right createUnoPage() at a later time when the // new object is full constructed mxUnoPage is disposed now. uno::Reference xComponent (mxUnoPage, uno::UNO_QUERY); if (xComponent.is()) { mxUnoPage = NULL; xComponent->dispose(); } } SdrPage::~SdrPage() { if( mxUnoPage.is() ) try { uno::Reference< lang::XComponent > xPageComponent( mxUnoPage, uno::UNO_QUERY_THROW ); mxUnoPage.clear(); xPageComponent->dispose(); } catch( const uno::Exception& ) { DBG_UNHANDLED_EXCEPTION(); } // #111111# // tell all the registered PageUsers that the page is in destruction // This causes some (all?) PageUsers to remove themselves from the list // of page users. Therefore we have to use a copy of the list for the // iteration. ::sdr::PageUserVector aListCopy (maPageUsers.begin(), maPageUsers.end()); for(::sdr::PageUserVector::iterator aIterator = aListCopy.begin(); aIterator != aListCopy.end(); aIterator++) { sdr::PageUser* pPageUser = *aIterator; DBG_ASSERT(pPageUser, "SdrPage::~SdrPage: corrupt PageUser list (!)"); pPageUser->PageInDestruction(*this); } // #111111# // Clear the vector. This means that user do not need to call RemovePageUser() // when they get called from PageInDestruction(). maPageUsers.clear(); SdrObject::Free( pBackgroundObj ); delete pLayerAdmin; TRG_ClearMasterPage(); // #110094# if(mpViewContact) { delete mpViewContact; mpViewContact = 0L; } DBG_DTOR(SdrPage,NULL); } void SdrPage::operator=(const SdrPage& rSrcPage) { if(mpViewContact) { delete mpViewContact; mpViewContact = 0L; } SdrObject::Free( pBackgroundObj ); // Joe also sets some parameters for the class this one // is derived from. SdrObjList does the same bad handling of // copy constructor and operator=, so i better let it stand here. pPage = this; // copy all the local parameters to make this instance // a valid copy od source page before copying and inserting // the contained objects mbMaster = rSrcPage.mbMaster; mbSwappingLocked = rSrcPage.mbSwappingLocked; mbPageBorderOnlyLeftRight = rSrcPage.mbPageBorderOnlyLeftRight; aPrefVisiLayers = rSrcPage.aPrefVisiLayers; nWdt = rSrcPage.nWdt; nHgt = rSrcPage.nHgt; nBordLft = rSrcPage.nBordLft; nBordUpp = rSrcPage.nBordUpp; nBordRgt = rSrcPage.nBordRgt; nBordLwr = rSrcPage.nBordLwr; nPageNum = rSrcPage.nPageNum; if(rSrcPage.TRG_HasMasterPage()) { TRG_SetMasterPage(rSrcPage.TRG_GetMasterPage()); TRG_SetMasterPageVisibleLayers(rSrcPage.TRG_GetMasterPageVisibleLayers()); } else { TRG_ClearMasterPage(); } //aMasters = rSrcPage.aMasters; mbObjectsNotPersistent = rSrcPage.mbObjectsNotPersistent; if(rSrcPage.pBackgroundObj) { pBackgroundObj = rSrcPage.pBackgroundObj->Clone(); pBackgroundObj->SetPage( this ); pBackgroundObj->SetModel( pModel ); // #i62000# for single-page MPBGO, force no line pBackgroundObj->SetMergedItem(XLineStyleItem(XLINE_NONE)); } // Now copy the contained obejcts (by cloning them) SdrObjList::operator=(rSrcPage); } SdrPage* SdrPage::Clone() const { return Clone(NULL); } SdrPage* SdrPage::Clone(SdrModel* pNewModel) const { if (pNewModel==NULL) pNewModel=pModel; SdrPage* pPage2=new SdrPage(*pNewModel); *pPage2=*this; return pPage2; } void SdrPage::SetSize(const Size& aSiz) { bool bChanged(false); if(aSiz.Width() != nWdt) { nWdt = aSiz.Width(); bChanged = true; } if(aSiz.Height() != nHgt) { nHgt = aSiz.Height(); bChanged = true; } if(bChanged) { SetChanged(); } } Size SdrPage::GetSize() const { return Size(nWdt,nHgt); } INT32 SdrPage::GetWdt() const { return nWdt; } void SdrPage::SetOrientation(Orientation eOri) { // Quadratisch ist und bleibt immer Portrait Size aSiz(GetSize()); if (aSiz.Width()!=aSiz.Height()) { if ((eOri==ORIENTATION_PORTRAIT) == (aSiz.Width()>aSiz.Height())) { SetSize(Size(aSiz.Height(),aSiz.Width())); } } } Orientation SdrPage::GetOrientation() const { // Quadratisch ist Portrait Orientation eRet=ORIENTATION_PORTRAIT; Size aSiz(GetSize()); if (aSiz.Width()>aSiz.Height()) eRet=ORIENTATION_LANDSCAPE; return eRet; } INT32 SdrPage::GetHgt() const { return nHgt; } void SdrPage::SetBorder(INT32 nLft, INT32 nUpp, INT32 nRgt, INT32 nLwr) { bool bChanged(false); if(nBordLft != nLft) { nBordLft = nLft; bChanged = true; } if(nBordUpp != nUpp) { nBordUpp = nUpp; bChanged = true; } if(nBordRgt != nRgt) { nBordRgt = nRgt; bChanged = true; } if(nBordLwr != nLwr) { nBordLwr = nLwr; bChanged = true; } if(bChanged) { SetChanged(); } } void SdrPage::SetLftBorder(INT32 nBorder) { if(nBordLft != nBorder) { nBordLft = nBorder; SetChanged(); } } void SdrPage::SetUppBorder(INT32 nBorder) { if(nBordUpp != nBorder) { nBordUpp = nBorder; SetChanged(); } } void SdrPage::SetRgtBorder(INT32 nBorder) { if(nBordRgt != nBorder) { nBordRgt=nBorder; SetChanged(); } } void SdrPage::SetLwrBorder(INT32 nBorder) { if(nBordLwr != nBorder) { nBordLwr=nBorder; SetChanged(); } } INT32 SdrPage::GetLftBorder() const { return nBordLft; } INT32 SdrPage::GetUppBorder() const { return nBordUpp; } INT32 SdrPage::GetRgtBorder() const { return nBordRgt; } INT32 SdrPage::GetLwrBorder() const { return nBordLwr; } void SdrPage::SetModel(SdrModel* pNewModel) { SdrModel* pOldModel=pModel; SdrObjList::SetModel(pNewModel); if (pNewModel!=pOldModel) { if (pNewModel!=NULL) { pLayerAdmin->SetParent(&pNewModel->GetLayerAdmin()); } else { pLayerAdmin->SetParent(NULL); } pLayerAdmin->SetModel(pNewModel); if( pBackgroundObj ) pBackgroundObj->SetModel( pNewModel ); } // update listeners at possible api wrapper object if( pOldModel != pNewModel ) { if( mxUnoPage.is() ) { SvxDrawPage* pPage2 = SvxDrawPage::getImplementation( mxUnoPage ); if( pPage2 ) pPage2->ChangeModel( pNewModel ); } } } //////////////////////////////////////////////////////////////////////////////////////////////////// // #i68775# React on PageNum changes (from Model in most cases) void SdrPage::SetPageNum(sal_uInt16 nNew) { if(nNew != nPageNum) { // change nPageNum = nNew; // notify visualisations, also notifies e.g. buffered MasterPages ActionChanged(); } } USHORT SdrPage::GetPageNum() const { if (!mbInserted) return 0; if (mbMaster) { if (pModel && pModel->IsMPgNumsDirty()) ((SdrModel*)pModel)->RecalcPageNums(TRUE); } else { if (pModel && pModel->IsPagNumsDirty()) ((SdrModel*)pModel)->RecalcPageNums(FALSE); } return nPageNum; } void SdrPage::SetChanged() { // #110094#-11 // For test purposes, use the new ViewContact for change // notification now. ActionChanged(); if( pModel ) { pModel->SetChanged(); } } //////////////////////////////////////////////////////////////////////////////////////////////////// // MasterPage interface void SdrPage::TRG_SetMasterPage(SdrPage& rNew) { if(mpMasterPageDescriptor && &(mpMasterPageDescriptor->GetUsedPage()) == &rNew) return; if(mpMasterPageDescriptor) TRG_ClearMasterPage(); mpMasterPageDescriptor = new ::sdr::MasterPageDescriptor(*this, rNew); GetViewContact().ActionChanged(); } void SdrPage::TRG_ClearMasterPage() { if(mpMasterPageDescriptor) { SetChanged(); // the flushViewObjectContacts() will do needed invalidates by deleting the involved VOCs mpMasterPageDescriptor->GetUsedPage().GetViewContact().flushViewObjectContacts(true); delete mpMasterPageDescriptor; mpMasterPageDescriptor = 0L; } } SdrPage& SdrPage::TRG_GetMasterPage() const { DBG_ASSERT(mpMasterPageDescriptor != 0L, "TRG_GetMasterPage(): No MasterPage available. Use TRG_HasMasterPage() before access (!)"); return mpMasterPageDescriptor->GetUsedPage(); } const SetOfByte& SdrPage::TRG_GetMasterPageVisibleLayers() const { DBG_ASSERT(mpMasterPageDescriptor != 0L, "TRG_GetMasterPageVisibleLayers(): No MasterPage available. Use TRG_HasMasterPage() before access (!)"); return mpMasterPageDescriptor->GetVisibleLayers(); } void SdrPage::TRG_SetMasterPageVisibleLayers(const SetOfByte& rNew) { DBG_ASSERT(mpMasterPageDescriptor != 0L, "TRG_SetMasterPageVisibleLayers(): No MasterPage available. Use TRG_HasMasterPage() before access (!)"); mpMasterPageDescriptor->SetVisibleLayers(rNew); } sdr::contact::ViewContact& SdrPage::TRG_GetMasterPageDescriptorViewContact() const { DBG_ASSERT(mpMasterPageDescriptor != 0L, "TRG_GetMasterPageDescriptorViewContact(): No MasterPage available. Use TRG_HasMasterPage() before access (!)"); return mpMasterPageDescriptor->GetViewContact(); } // #115423# used from SdrModel::RemoveMasterPage void SdrPage::TRG_ImpMasterPageRemoved(const SdrPage& rRemovedPage) { if(TRG_HasMasterPage()) { if(&TRG_GetMasterPage() == &rRemovedPage) { TRG_ClearMasterPage(); } } } // MasterPage interface //////////////////////////////////////////////////////////////////////////////////////////////////// FASTBOOL SdrPage::ImplGetFillColor(const Point& rPnt, const SetOfByte& rVisLayers, /* FASTBOOL bLayerSorted,*/ Color& rCol, FASTBOOL bSkipBackgroundShape) const { if (pModel==NULL) return FALSE; FASTBOOL bRet=SdrObjList::GetFillColor(rPnt,rVisLayers,/*bLayerSorted,*/rCol); if (!bRet && !mbMaster) { // nun zu den Masterpages if(TRG_HasMasterPage()) { SetOfByte aSet(rVisLayers); aSet &= TRG_GetMasterPageVisibleLayers(); SdrPage& rMasterPage = TRG_GetMasterPage(); // #108867# Don't fall back to background shape on // master pages. This is later handled by // GetBackgroundColor, and is necessary to cater for // the silly ordering: 1. shapes, 2. master page // shapes, 3. page background, 4. master page // background. bRet = rMasterPage.ImplGetFillColor(rPnt, aSet, rCol, TRUE); } } // #108867# Only now determine background color from background shapes if( !bRet && !bSkipBackgroundShape ) { rCol = GetPageBackgroundColor(); return TRUE; } return bRet; } //////////////////////////////////////////////////////////////////////////////////////////////////// FASTBOOL SdrPage::GetFillColor(const Point& rPnt, const SetOfByte& rVisLayers, /*FASTBOOL bLayerSorted,*/ Color& rCol) const { // #108867# Wrapper for ImplGetFillColor. Used to properly set the // bSkipBackgroundShape parameter. Never skip background shape on // first level of recursion return ImplGetFillColor(rPnt,rVisLayers,/*bLayerSorted,*/rCol,FALSE); } //////////////////////////////////////////////////////////////////////////////////////////////////// const SdrPageGridFrameList* SdrPage::GetGridFrameList(const SdrPageView* /*pPV*/, const Rectangle* /*pRect*/) const { return NULL; } XubString SdrPage::GetLayoutName() const { // Die wollte Dieter haben. return String(); } void SdrPage::SetBackgroundObj( SdrObject* pObj ) { if ( pObj ) { pObj->SetPage( this ); pObj->SetModel( pModel ); pObj->SetLayer( 1 ); // Nothing known about the backgroundlayer... // #i62000# for single-page MPBGO, force no line pObj->SetMergedItem(XLineStyleItem(XLINE_NONE)); } SdrObject::Free( pBackgroundObj ); pBackgroundObj = pObj; } void SdrPage::SetInserted( bool bIns ) { if( mbInserted != bIns ) { mbInserted = bIns; SdrObjListIter aIter( *this, IM_FLAT ); while ( aIter.IsMore() ) { SdrObject* pObj = aIter.Next(); if ( pObj->ISA(SdrOle2Obj) ) { if( mbInserted ) ( (SdrOle2Obj*) pObj)->Connect(); else ( (SdrOle2Obj*) pObj)->Disconnect(); } } } } uno::Reference< uno::XInterface > SdrPage::getUnoPage() { // try weak reference first if( !mxUnoPage.is() ) { // create one mxUnoPage = createUnoPage(); } return mxUnoPage; } uno::Reference< uno::XInterface > SdrPage::createUnoPage() { ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > xInt = static_cast( new SvxFmDrawPage( this ) ); return xInt; } SfxStyleSheet* SdrPage::GetTextStyleSheetForObject( SdrObject* pObj ) const { return pObj->GetStyleSheet(); } FASTBOOL SdrPage::HasTransparentObjects( BOOL bCheckForAlphaChannel ) const { FASTBOOL bRet = FALSE; for( ULONG n = 0, nCount = GetObjCount(); ( n < nCount ) && !bRet; n++ ) if( GetObj( n )->IsTransparent( bCheckForAlphaChannel ) ) bRet = TRUE; return bRet; } /** returns an averaged background color of this page */ // #i75566# GetBackgroundColor -> GetPageBackgroundColor and bScreenDisplay hint value Color SdrPage::GetPageBackgroundColor( SdrPageView* pView, bool bScreenDisplay ) const { Color aColor; if(bScreenDisplay && (!pView || pView->GetApplicationDocumentColor() == COL_AUTO)) { svtools::ColorConfig aColorConfig; aColor = aColorConfig.GetColorValue( svtools::DOCCOLOR ).nColor; } else { aColor = pView->GetApplicationDocumentColor(); } // first, see if we have a background object SdrObject* pBackgroundObj2 = NULL; if( IsMasterPage() ) { if( GetObjCount() ) pBackgroundObj2 = GetObj( 0 ); } else { pBackgroundObj2 = GetBackgroundObj(); if( NULL == pBackgroundObj2 ) { // if not, see if we have a masterpage and get that background object if(TRG_HasMasterPage()) { SdrPage& rMasterPage = TRG_GetMasterPage(); if(rMasterPage.GetObjCount()) { pBackgroundObj2 = rMasterPage.GetObj( 0 ); } } } } if( pBackgroundObj2 ) { const SfxItemSet& rSet = pBackgroundObj2->GetMergedItemSet(); GetDraftFillColor( rSet, aColor ); } return aColor; } /** *deprecated, use GetBackgroundColor with SdrPageView */ Color SdrPage::GetPageBackgroundColor() const // #i75566# GetBackgroundColor -> GetPageBackgroundColor { return GetPageBackgroundColor( NULL, true ); } /** this method returns true if the object from the ViewObjectContact should be visible on this page while rendering. bEdit selects if visibility test is for an editing view or a final render, like printing. */ bool SdrPage::checkVisibility( const sdr::contact::ViewObjectContact& /*rOriginal*/, const sdr::contact::DisplayInfo& /*rDisplayInfo*/, bool /*bEdit*/) { // this will be handled in the application if needed return true; } // #110094# DrawContact support: Methods for handling Page changes void SdrPage::ActionChanged() const { // Do necessary ViewContact actions GetViewContact().ActionChanged(); // #i48535# also handle MasterPage change if(TRG_HasMasterPage()) { TRG_GetMasterPageDescriptorViewContact().ActionChanged(); } } // NYI: Dummy implementations for declarations in svdpage.hxx Bitmap SdrPage::GetBitmap(const SetOfByte& /*rVisibleLayers*/, FASTBOOL /*bTrimBorders*/) const { DBG_ASSERT(0, "SdrPage::GetBitmap(): not yet implemented."); return Bitmap(); } GDIMetaFile SdrPage::GetMetaFile(const SetOfByte& /*rVisibleLayers*/, FASTBOOL /*bTrimBorders*/) { DBG_ASSERT(0, "SdrPage::GetMetaFile(): not yet implemented."); return GDIMetaFile(); } ////////////////////////////////////////////////////////////////////////////// // sdr::Comment interface const sdr::Comment& SdrPage::GetCommentByIndex(sal_uInt32 nIndex) { DBG_ASSERT(nIndex < maComments.size(), "SdrPage::GetCommentByIndex: Access out of range (!)"); return maComments[nIndex]; } void SdrPage::AddComment(const sdr::Comment& rNew) { maComments.push_back(rNew); ::std::sort(maComments.begin(), maComments.end()); } void SdrPage::ReplaceCommentByIndex(sal_uInt32 nIndex, const sdr::Comment& rNew) { DBG_ASSERT(nIndex < maComments.size(), "SdrPage::GetCommentByIndex: Access out of range (!)"); if(maComments[nIndex] != rNew) { maComments[nIndex] = rNew; ::std::sort(maComments.begin(), maComments.end()); } } ////////////////////////////////////////////////////////////////////////////// // use new redirector instead of pPaintProc StandardCheckVisisbilityRedirector::StandardCheckVisisbilityRedirector() : ViewObjectContactRedirector() { } StandardCheckVisisbilityRedirector::~StandardCheckVisisbilityRedirector() { } drawinglayer::primitive2d::Primitive2DSequence StandardCheckVisisbilityRedirector::createRedirectedPrimitive2DSequence( const sdr::contact::ViewObjectContact& rOriginal, const sdr::contact::DisplayInfo& rDisplayInfo) { SdrObject* pObject = rOriginal.GetViewContact().TryToGetSdrObject(); if(pObject) { if(pObject->GetPage()) { if(pObject->GetPage()->checkVisibility(rOriginal, rDisplayInfo, false)) { return ::sdr::contact::ViewObjectContactRedirector::createRedirectedPrimitive2DSequence(rOriginal, rDisplayInfo); } } return drawinglayer::primitive2d::Primitive2DSequence(); } else { // not an object, maybe a page return ::sdr::contact::ViewObjectContactRedirector::createRedirectedPrimitive2DSequence(rOriginal, rDisplayInfo); } } ////////////////////////////////////////////////////////////////////////////// // eof