1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 #ifndef _SVDPAGE_HXX 25 #define _SVDPAGE_HXX 26 27 #include <vcl/bitmap.hxx> 28 #include <vcl/print.hxx> 29 #include <vcl/gdimtf.hxx> 30 #include <tools/weakbase.hxx> 31 #include <cppuhelper/weakref.hxx> 32 #include <svx/svdtypes.hxx> 33 #include <svx/svdlayer.hxx> 34 #include <svx/sdrcomment.hxx> 35 #include <vector> 36 #include <svx/sdrpageuser.hxx> 37 #include <svx/sdr/contact/viewobjectcontactredirector.hxx> 38 #include <svx/sdrmasterpagedescriptor.hxx> 39 #include "svx/svxdllapi.h" 40 #include <com/sun/star/container/XIndexAccess.hpp> 41 #include <svx/svdobj.hxx> 42 #include <boost/scoped_ptr.hpp> 43 44 ////////////////////////////////////////////////////////////////////////////// 45 // predefines 46 47 namespace sdr { namespace contact { class ViewContact; }} 48 class SdrPage; 49 class SdrModel; 50 class SfxItemPool; 51 class SdrPageView; 52 class SdrLayerAdmin; 53 class SetOfByte; 54 class Color; 55 class SfxStyleSheet; 56 class SvxUnoDrawPagesAccess; 57 58 enum SdrInsertReasonKind {SDRREASON_UNKNOWN, // unbekannt 59 SDRREASON_STREAMING, // einlesen eines Doks 60 SDRREASON_UNDO, // kommt aus dem Undo 61 SDRREASON_COPY, // irgendjemand kopiert... 62 SDRREASON_VIEWCREATE, // vom Anwender interaktiv erzeugt 63 SDRREASON_VIEWCALL}; // Durch SdrView::Group(), ... 64 65 class SdrInsertReason { 66 const SdrObject* pRefObj; 67 SdrInsertReasonKind eReason; 68 public: SdrInsertReason()69 SdrInsertReason(): pRefObj(NULL),eReason(SDRREASON_UNKNOWN) {} SdrInsertReason(SdrInsertReasonKind eR,const SdrObject * pO=NULL)70 SdrInsertReason(SdrInsertReasonKind eR,const SdrObject* pO=NULL): pRefObj(pO),eReason(eR) {} SetReferenceObject(const SdrObject * pO)71 void SetReferenceObject(const SdrObject* pO) { pRefObj=pO; } GetReferenceObject() const72 const SdrObject* GetReferenceObject() const { return pRefObj; } SetReason(SdrInsertReasonKind eR)73 void SetReason(SdrInsertReasonKind eR) { eReason=eR; } GetReason() const74 SdrInsertReasonKind GetReason() const { return eReason; } 75 }; 76 77 ////////////////////////////////////////////////////////////////////////////// 78 // class SdrObjList 79 80 class SVX_DLLPUBLIC SdrObjList 81 { 82 private: 83 typedef ::std::vector<SdrObject*> SdrObjectContainerType; 84 SdrObjectContainerType maList; 85 86 protected: 87 friend class SdrObjListIter; 88 friend class SdrEditView; 89 SdrObjList* pUpList; // Vaterliste 90 SdrModel* pModel; // Diese Liste gehoert zu diesem Model (Layer,ItemPool,Storage). 91 SdrPage* pPage; // Page, in die Liste haengt. Kann auch this sein. 92 SdrObject* pOwnerObj; // OwnerObject, falls Liste eines GruppenObjekts. 93 Rectangle aOutRect; 94 Rectangle aSnapRect; 95 SdrObjListKind eListKind; 96 FASTBOOL bObjOrdNumsDirty; 97 FASTBOOL bRectsDirty; 98 protected: 99 virtual void RecalcRects(); 100 101 private: 102 /// simple ActionChildInserted forwarder to have it on a central place 103 void impChildInserted(SdrObject& rChild) const; 104 public: 105 TYPEINFO(); 106 SdrObjList(SdrModel* pNewModel, SdrPage* pNewPage, SdrObjList* pNewUpList=NULL); 107 SdrObjList(const SdrObjList& rSrcList); 108 virtual ~SdrObjList(); 109 // !!! Diese Methode nur fuer Leute, die ganz genau wissen was sie tun !!! 110 111 // #110094# This should not be needed (!) SetObjOrdNumsDirty()112 void SetObjOrdNumsDirty() { bObjOrdNumsDirty=sal_True; } 113 // pModel, pPage, pUpList und pOwnerObj werden Zuweisungeoperator nicht veraendert! 114 void operator=(const SdrObjList& rSrcList); 115 void CopyObjects(const SdrObjList& rSrcList); 116 // alles Aufraeumen (ohne Undo) 117 void Clear(); GetListKind() const118 SdrObjListKind GetListKind() const { return eListKind; } SetListKind(SdrObjListKind eNewKind)119 void SetListKind(SdrObjListKind eNewKind) { eListKind=eNewKind; } GetUpList() const120 SdrObjList* GetUpList() const { return pUpList; } SetUpList(SdrObjList * pNewUpList)121 void SetUpList(SdrObjList* pNewUpList) { pUpList=pNewUpList; } GetOwnerObj() const122 SdrObject* GetOwnerObj() const { return pOwnerObj; } SetOwnerObj(SdrObject * pNewOwner)123 void SetOwnerObj(SdrObject* pNewOwner) { pOwnerObj=pNewOwner; } 124 virtual SdrPage* GetPage() const; 125 virtual void SetPage(SdrPage* pNewPage); 126 virtual SdrModel* GetModel() const; 127 virtual void SetModel(SdrModel* pNewModel); 128 // Neuberechnung der Objekt-Ordnungsnummern 129 void RecalcObjOrdNums(); IsObjOrdNumsDirty() const130 FASTBOOL IsObjOrdNumsDirty() const { return bObjOrdNumsDirty; } 131 virtual void NbcInsertObject(SdrObject* pObj, sal_uIntPtr nPos=CONTAINER_APPEND 132 , const SdrInsertReason* pReason=NULL 133 ); 134 virtual void InsertObject(SdrObject* pObj, sal_uIntPtr nPos=CONTAINER_APPEND 135 , const SdrInsertReason* pReason=NULL 136 ); 137 // aus Liste entfernen ohne delete 138 virtual SdrObject* NbcRemoveObject(sal_uIntPtr nObjNum); 139 virtual SdrObject* RemoveObject(sal_uIntPtr nObjNum); 140 // Vorhandenes Objekt durch ein anderes ersetzen. 141 // Wie Remove&Insert jedoch performanter, da die Ordnungsnummern 142 // nicht Dirty gesetzt werden muessen. 143 virtual SdrObject* NbcReplaceObject(SdrObject* pNewObj, sal_uIntPtr nObjNum); 144 virtual SdrObject* ReplaceObject(SdrObject* pNewObj, sal_uIntPtr nObjNum); 145 // Die Z-Order eines Objekts veraendern 146 virtual SdrObject* NbcSetObjectOrdNum(sal_uIntPtr nOldObjNum, sal_uIntPtr nNewObjNum); 147 virtual SdrObject* SetObjectOrdNum(sal_uIntPtr nOldObjNum, sal_uIntPtr nNewObjNum); 148 149 virtual void SetRectsDirty(); 150 151 const Rectangle& GetAllObjSnapRect() const; 152 const Rectangle& GetAllObjBoundRect() const; 153 154 // Alle Textobjekte neu formatieren, z.B. bei Druckerwechsel 155 void NbcReformatAllTextObjects(); 156 void ReformatAllTextObjects(); 157 158 /** #103122# reformats all edge objects that are connected to other objects */ 159 void ReformatAllEdgeObjects(); 160 161 // Die Vorlagenattribute der Zeichenobjekte in harte Attribute verwandeln. 162 void BurnInStyleSheetAttributes(); 163 164 sal_uIntPtr GetObjCount() const; 165 SdrObject* GetObj(sal_uIntPtr nNum) const; 166 167 // Gelinkte Seite oder gelinktes Gruppenobjekt 168 virtual FASTBOOL IsReadOnly() const; 169 170 // Zaehlt alle Objekte inkl. Objekte in Objektgruppen, ... 171 sal_uIntPtr CountAllObjects() const; 172 173 // Alle aufgelagerten Teile (z.B. Grafiken) der Liste in den 174 // Speicher laden. 175 void ForceSwapInObjects() const; 176 void ForceSwapOutObjects() const; 177 SwapInAll() const178 void SwapInAll() const { ForceSwapInObjects(); } SwapOutAll() const179 void SwapOutAll() const { ForceSwapOutObjects(); } 180 181 /** Makes the object list flat, i.e. the object list content are 182 then tree leaves 183 184 This method travels recursively over all group objects in this 185 list, extracts the content, inserts it flat to the list and 186 removes the group object afterwards. 187 */ 188 virtual void FlattenGroups(); 189 /** Ungroup the object at the given index 190 191 This method ungroups the content of the group object at the 192 given index, i.e. the content is put flat into the object list 193 (if the object at the given index is no group, this method is 194 a no-op). If the group itself contains group objects, the 195 operation is performed recursively, such that the content of 196 the given object contains no groups afterwards. 197 */ 198 virtual void UnGroupObj( sal_uIntPtr nObjNum ); 199 200 /** Return whether there is an explicit, user defined, object navigation 201 order. When there is one this method returns <TRUE/> and the 202 GetObjectForNavigationPosition() and 203 SdrObject::GetNavigationPosition() methods will return values 204 different from those returne by SdrObject::GetOrdNum() and 205 GetObj(). 206 */ 207 bool HasObjectNavigationOrder (void) const; 208 209 /** Set the navigation position of the given object to the specified 210 value. Note that this changes the navigation position for all 211 objects on or following the old or new position. 212 */ 213 void SetObjectNavigationPosition ( 214 SdrObject& rObject, 215 const sal_uInt32 nNewNavigationPosition); 216 217 /** Return the object for the given navigation position. When there is 218 a user defined navigation order, i.e. mpNavigationOrder is not NULL, 219 then that is used to look up the object. Otherwise the z-order is 220 used by looking up the object in maList. 221 @param nNavigationPosition 222 Valid values include 0 and are smaller than the number of 223 objects as returned by GetObjCount(). 224 @return 225 The returned pointer is NULL for invalid positions. 226 */ 227 SdrObject* GetObjectForNavigationPosition (const sal_uInt32 nNavigationPosition) const; 228 229 /** Restore the navigation order to that defined by the z-order. 230 */ 231 void ClearObjectNavigationOrder (void); 232 233 /** Set the navigation position of all SdrObjects to their position in 234 the mpNavigationOrder list. This method returns immediately when no 235 update is necessary. 236 @return 237 This method returns <TRUE/> when the navigation positions stored 238 in SdrObjects are up to date. 239 It returns <FALSE/> when the navigation positions are not valid, 240 for example because no explicit navigation order has been 241 defined, i.e. HasObjectNavigationOrder() would return <FALSE/>. 242 */ 243 bool RecalcNavigationPositions (void); 244 245 /** Set the navigation order to the one defined by the given list of 246 XShape objects. 247 @param rxOrder 248 When this is an empty reference then the navigation order is 249 reset to the z-order. The preferred way to do this, however, is 250 to call ClearObjectNavigationOrder(). 251 Otherwise this list is expected to contain all the shapes in the 252 called SdrObjList. 253 */ 254 void SetNavigationOrder (const ::com::sun::star::uno::Reference< 255 ::com::sun::star::container::XIndexAccess>& rxOrder); 256 257 private: 258 class WeakSdrObjectContainerType; 259 /// This list, if it exists, defines the navigation order. It it does 260 /// not exist then maList defines the navigation order. 261 ::boost::scoped_ptr<WeakSdrObjectContainerType> mpNavigationOrder; 262 263 /// This flag is <TRUE/> when the mpNavigation list has been changed but 264 /// the indices of the referenced SdrObjects still have their old values. 265 bool mbIsNavigationOrderDirty; 266 267 /** Insert an SdrObject into maList. Do not modify the maList member 268 directly. 269 @param rObject 270 The object to insert into the object list. 271 @param nInsertPosition 272 The given object is inserted before the object at this 273 position. Valid values include 0 (the object is inserted at the 274 head of the list) and the number of objects in the list as 275 returned by GetObjCount() (the object is inserted at the end of 276 the list.) 277 */ 278 void InsertObjectIntoContainer ( 279 SdrObject& rObject, 280 const sal_uInt32 nInsertPosition); 281 282 /** Replace an object in the object list. 283 @param rObject 284 The new object that replaces the one in the list at the 285 specified position. 286 @param nObjectPosition 287 The object at this position in the object list is replaced by 288 the given object. Valid values include 0 and are smaller than 289 the number of objects in the list. 290 */ 291 void ReplaceObjectInContainer ( 292 SdrObject& rObject, 293 const sal_uInt32 nObjectPosition); 294 295 /** Remove an object from the object list. 296 The object list has to contain at least one element. 297 @param nObjectPosition 298 The object at this position is removed from the object list. 299 Valid values include 0 and are smaller than the number of 300 objects in the list. 301 */ 302 void RemoveObjectFromContainer ( 303 const sal_uInt32 nObjectPosition); 304 }; 305 306 /* 307 Eine Sdraw-Seite enthaelt genau eine Objektliste sowie eine Beschreibung 308 der physikalischen Seitendimensionen (Groesse/Raender). Letzteres wird 309 lediglich zum Fangen von Objekten beim Draggen benoetigt. 310 An der Seite lassen sich (ueber SdrObjList) Objekte einfuegen und loeschen, 311 nach vorn und nach hinten stellen. Ausserdem kann die Ordnungszahl eines 312 Objektes abgefragt sowie direkt gesetzt werden. 313 */ 314 315 // Used for all methods which return a page number 316 #define SDRPAGE_NOTFOUND 0xFFFF 317 318 ////////////////////////////////////////////////////////////////////////////// 319 // class SdrPageGridFrame 320 321 // Fuer das Fangraster/Punkgitter im Writer 322 class SdrPageGridFrame 323 { 324 Rectangle aPaper; 325 Rectangle aUserArea; 326 public: SdrPageGridFrame(const Rectangle & rPaper)327 SdrPageGridFrame(const Rectangle& rPaper): aPaper(rPaper), aUserArea(rPaper) {} SdrPageGridFrame(const Rectangle & rPaper,const Rectangle & rUser)328 SdrPageGridFrame(const Rectangle& rPaper, const Rectangle& rUser): aPaper(rPaper), aUserArea(rUser) {} SetPaperRect(const Rectangle & rPaper)329 void SetPaperRect(const Rectangle& rPaper) { aPaper=rPaper; } SetUserArea(const Rectangle & rUser)330 void SetUserArea(const Rectangle& rUser) { aUserArea=rUser; } GetPaperRect() const331 const Rectangle& GetPaperRect() const { return aPaper; } GetUserArea() const332 const Rectangle& GetUserArea() const { return aUserArea; } 333 }; 334 335 class SVX_DLLPUBLIC SdrPageGridFrameList { 336 Container aList; 337 private: 338 SVX_DLLPRIVATE SdrPageGridFrameList(const SdrPageGridFrameList& rSrcList); // never implemented 339 SVX_DLLPRIVATE void operator=(const SdrPageGridFrameList& rSrcList); // never implemented 340 protected: GetObject(sal_uInt16 i) const341 SdrPageGridFrame* GetObject(sal_uInt16 i) const { return (SdrPageGridFrame*)(aList.GetObject(i)); } 342 public: SdrPageGridFrameList()343 SdrPageGridFrameList(): aList(1024,4,4) {} ~SdrPageGridFrameList()344 ~SdrPageGridFrameList() { Clear(); } 345 void Clear(); GetCount() const346 sal_uInt16 GetCount() const { return sal_uInt16(aList.Count()); } Insert(const SdrPageGridFrame & rGF,sal_uInt16 nPos=0xFFFF)347 void Insert(const SdrPageGridFrame& rGF, sal_uInt16 nPos=0xFFFF) { aList.Insert(new SdrPageGridFrame(rGF),nPos); } Delete(sal_uInt16 nPos)348 void Delete(sal_uInt16 nPos) { delete (SdrPageGridFrame*)aList.Remove(nPos); } Move(sal_uInt16 nPos,sal_uInt16 nNewPos)349 void Move(sal_uInt16 nPos, sal_uInt16 nNewPos) { aList.Insert(aList.Remove(nPos),nNewPos); } operator [](sal_uInt16 nPos)350 SdrPageGridFrame& operator[](sal_uInt16 nPos) { return *GetObject(nPos); } operator [](sal_uInt16 nPos) const351 const SdrPageGridFrame& operator[](sal_uInt16 nPos) const { return *GetObject(nPos); } 352 }; 353 354 //////////////////////////////////////////////////////////////////////////////////////////////////// 355 // class SdrPageProperties 356 357 class SVX_DLLPUBLIC SdrPageProperties : public SfxListener 358 { 359 private: 360 // data 361 SdrPage* mpSdrPage; 362 SfxStyleSheet* mpStyleSheet; 363 SfxItemSet* mpProperties; 364 365 // internal helpers 366 void ImpRemoveStyleSheet(); 367 void ImpAddStyleSheet(SfxStyleSheet& rNewStyleSheet); 368 369 // not implemented 370 SdrPageProperties& operator=(const SdrPageProperties& rCandidate); 371 372 public: 373 // construct/destruct 374 SdrPageProperties(SdrPage& rSdrPage); 375 virtual ~SdrPageProperties(); 376 377 // Notify(...) from baseclass SfxListener 378 virtual void Notify(SfxBroadcaster& rBC, const SfxHint& rHint); 379 380 // data read/write 381 const SfxItemSet& GetItemSet() const; 382 void PutItemSet(const SfxItemSet& rSet); 383 void PutItem(const SfxPoolItem& rItem); 384 void ClearItem(const sal_uInt16 nWhich = 0); 385 386 // StyleSheet access 387 void SetStyleSheet(SfxStyleSheet* pStyleSheet); 388 SfxStyleSheet* GetStyleSheet() const; 389 }; 390 391 //////////////////////////////////////////////////////////////////////////////////////////////////// 392 // class SdrPage 393 394 class SVX_DLLPUBLIC SdrPage : public SdrObjList, public tools::WeakBase< SdrPage > 395 { 396 /////////////////////////////////////////////////////////////////////////////// 397 // start PageUser section 398 private: 399 // #111111# PageUser section 400 sdr::PageUserVector maPageUsers; 401 402 public: 403 void AddPageUser(sdr::PageUser& rNewUser); 404 void RemovePageUser(sdr::PageUser& rOldUser); 405 406 /////////////////////////////////////////////////////////////////////////////// 407 // end PageUser section 408 409 /////////////////////////////////////////////////////////////////////////////// 410 // #110094# DrawContact section 411 private: 412 sdr::contact::ViewContact* mpViewContact; 413 protected: 414 virtual sdr::contact::ViewContact* CreateObjectSpecificViewContact(); 415 public: 416 sdr::contact::ViewContact& GetViewContact() const; 417 418 // #110094# DrawContact support: Methods for handling Page changes 419 void ActionChanged() const; 420 421 // #i9076# 422 friend class SdrModel; 423 friend class SvxUnoDrawPagesAccess; 424 425 // this class uses its own UNO wrapper 426 // and thus has to set mxUnoPage 427 friend class ChXChartDocument; 428 429 sal_Int32 nWdt; // Seitengroesse 430 sal_Int32 nHgt; // Seitengroesse 431 sal_Int32 nBordLft; // Seitenrand links 432 sal_Int32 nBordUpp; // Seitenrand oben 433 sal_Int32 nBordRgt; // Seitenrand rechts 434 sal_Int32 nBordLwr; // Seitenrand unten 435 436 // this is a weak reference to a possible living api wrapper for this page 437 ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > mxUnoPage; 438 439 protected: 440 SdrLayerAdmin* pLayerAdmin; 441 private: 442 SdrPageProperties* mpSdrPageProperties; 443 444 public: getSdrPageProperties()445 SdrPageProperties& getSdrPageProperties() { return *mpSdrPageProperties; } getSdrPageProperties() const446 const SdrPageProperties& getSdrPageProperties() const { return *mpSdrPageProperties; } 447 const SdrPageProperties* getCorrectSdrPageProperties() const; 448 449 protected: 450 // new MasterPageDescriptorVector 451 ::sdr::MasterPageDescriptor* mpMasterPageDescriptor; 452 453 SetOfByte aPrefVisiLayers; 454 sal_uInt16 nPageNum; 455 456 // bitfield 457 unsigned mbMaster : 1; // flag if this is a MasterPage 458 unsigned mbInserted : 1; 459 unsigned mbObjectsNotPersistent : 1; 460 unsigned mbSwappingLocked : 1; 461 462 // #i93597# 463 unsigned mbPageBorderOnlyLeftRight : 1; 464 465 virtual ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > createUnoPage(); 466 467 public: 468 TYPEINFO(); 469 SdrPage(SdrModel& rNewModel, bool bMasterPage=false); 470 // Copy-Ctor und Zuweisungeoperator sind nicht getestet! 471 SdrPage(const SdrPage& rSrcPage); 472 virtual ~SdrPage(); 473 // pModel, pPage, pUpList, pOwnerObj und mbInserted werden Zuweisungeoperator nicht veraendert! 474 virtual void operator=(const SdrPage& rSrcPage); 475 virtual SdrPage* Clone() const; 476 virtual SdrPage* Clone(SdrModel* pNewModel) const; IsMasterPage() const477 bool IsMasterPage() const { return mbMaster; } 478 void SetInserted(bool bNew = true); IsInserted() const479 FASTBOOL IsInserted() const { return mbInserted; } 480 virtual void SetChanged(); 481 482 // #i68775# React on PageNum changes (from Model in most cases) 483 void SetPageNum(sal_uInt16 nNew); 484 sal_uInt16 GetPageNum() const; 485 486 // #i93597# Allow page border definition to not be the full rectangle but to 487 // use only the left and right vertical edges (reportdesigner) setPageBorderOnlyLeftRight(bool bNew)488 void setPageBorderOnlyLeftRight(bool bNew) { mbPageBorderOnlyLeftRight = bNew; } getPageBorderOnlyLeftRight() const489 bool getPageBorderOnlyLeftRight() const { return mbPageBorderOnlyLeftRight; } 490 491 virtual void SetSize(const Size& aSiz); 492 virtual Size GetSize() const; 493 virtual void SetOrientation(Orientation eOri); 494 virtual Orientation GetOrientation() const; 495 virtual sal_Int32 GetWdt() const; 496 virtual sal_Int32 GetHgt() const; 497 virtual void SetBorder(sal_Int32 nLft, sal_Int32 nUpp, sal_Int32 nRgt, sal_Int32 Lwr); 498 virtual void SetLftBorder(sal_Int32 nBorder); 499 virtual void SetUppBorder(sal_Int32 nBorder); 500 virtual void SetRgtBorder(sal_Int32 nBorder); 501 virtual void SetLwrBorder(sal_Int32 nBorder); 502 virtual sal_Int32 GetLftBorder() const; 503 virtual sal_Int32 GetUppBorder() const; 504 virtual sal_Int32 GetRgtBorder() const; 505 virtual sal_Int32 GetLwrBorder() const; 506 507 virtual void SetModel(SdrModel* pNewModel); 508 509 // New MasterPage interface TRG_HasMasterPage() const510 sal_Bool TRG_HasMasterPage() const { return (0L != mpMasterPageDescriptor); } 511 void TRG_SetMasterPage(SdrPage& rNew); 512 void TRG_ClearMasterPage(); 513 SdrPage& TRG_GetMasterPage() const; 514 const SetOfByte& TRG_GetMasterPageVisibleLayers() const; 515 void TRG_SetMasterPageVisibleLayers(const SetOfByte& rNew); 516 sdr::contact::ViewContact& TRG_GetMasterPageDescriptorViewContact() const; 517 518 //#if 0 // _SOLAR__PRIVATE 519 protected: 520 void TRG_ImpMasterPageRemoved(const SdrPage& rRemovedPage); 521 //#endif // __PRIVATE 522 public: 523 524 // Aenderungen an den Layern setzen nicht das Modified-Flag ! GetLayerAdmin() const525 const SdrLayerAdmin& GetLayerAdmin() const { return *pLayerAdmin; } GetLayerAdmin()526 SdrLayerAdmin& GetLayerAdmin() { return *pLayerAdmin; } 527 528 // GetBitmap und GetMetafile sind noch nicht implementiert. 529 // Bitmap in Bildschirmaufloesung und -farbtiefe aus den Objekten der 530 // Page erzeugen. GetBitmap(FASTBOOL bTrimBorders=sal_True) const531 Bitmap GetBitmap(FASTBOOL bTrimBorders=sal_True) const { return GetBitmap(aPrefVisiLayers,bTrimBorders); } 532 Bitmap GetBitmap(const SetOfByte& rVisibleLayers, FASTBOOL bTrimBorders=sal_True) const; 533 // Metafile aus den Objekten der Page erzeugen GetMetaFile(FASTBOOL bTrimBorders=sal_True)534 GDIMetaFile GetMetaFile(FASTBOOL bTrimBorders=sal_True) { return GetMetaFile(aPrefVisiLayers,bTrimBorders); } 535 GDIMetaFile GetMetaFile(const SetOfByte& rVisibleLayers, FASTBOOL bTrimBorders=sal_True); 536 537 virtual String GetLayoutName() const; 538 539 // fuer's Raster im Writer, auch fuer AlignObjects wenn 1 Objekt markiert ist 540 // wenn pRect!=NULL, dann die Seiten, die von diesem Rect intersected werden 541 // ansonsten die sichtbaren Seiten. 542 virtual const SdrPageGridFrameList* GetGridFrameList(const SdrPageView* pPV, const Rectangle* pRect) const; IsObjectsNotPersistent() const543 bool IsObjectsNotPersistent() const { return mbObjectsNotPersistent; } SetObjectsNotPersistent(bool b)544 void SetObjectsNotPersistent(bool b) { mbObjectsNotPersistent = b; } 545 // Durch Setzen dieses Flags, kann das Auslagern (Swappen) von 546 // Teilen der Page (z.B. Grafiken) unterbunden werden. 547 // Es werden hierdurch jedoch nicht automatisch alle ausgelagerten 548 // Teile nachgeladen, dies geschieht erst bei konkretem Bedarf oder 549 // durch Aufruf von SwapInAll(). 550 // Fuer die MasterPage(s) der Page muss dies ggf. separat gemacht werden. IsSwappingLocked() const551 bool IsSwappingLocked() const { return mbSwappingLocked; } SetSwappingLocked(bool bLock)552 void SetSwappingLocked(bool bLock) { mbSwappingLocked = bLock; } 553 554 ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > getUnoPage(); 555 556 virtual SfxStyleSheet* GetTextStyleSheetForObject( SdrObject* pObj ) const; 557 558 FASTBOOL HasTransparentObjects( sal_Bool bCheckForAlphaChannel = sal_False ) const; 559 560 /** *deprecated* returns an averaged background color of this page */ 561 // #i75566# GetBackgroundColor -> GetPageBackgroundColor 562 Color GetPageBackgroundColor() const; 563 564 /** *deprecated* returns an averaged background color of this page */ 565 // #i75566# GetBackgroundColor -> GetPageBackgroundColor and bScreenDisplay hint value 566 Color GetPageBackgroundColor( SdrPageView* pView, bool bScreenDisplay = true) const; 567 568 /** this method returns true if the object from the ViewObjectContact should 569 be visible on this page while rendering. 570 bEdit selects if visibility test is for an editing view or a final render, 571 like printing. 572 */ 573 virtual bool checkVisibility( 574 const sdr::contact::ViewObjectContact& rOriginal, 575 const sdr::contact::DisplayInfo& rDisplayInfo, 576 bool bEdit ); 577 578 /** Check if page is the HandoutMasterPage (in SVX, no PK_HANDOUT available) */ 579 bool isHandoutMasterPage() const; 580 581 ////////////////////////////////////////////////////////////////////////////// 582 // sdr::Comment interface 583 private: 584 sdr::CommentVector maComments; 585 586 public: GetCommentCount() const587 sal_uInt32 GetCommentCount() const { return maComments.size(); } 588 const sdr::Comment& GetCommentByIndex(sal_uInt32 nIndex); 589 void AddComment(const sdr::Comment& rNew); 590 void ReplaceCommentByIndex(sal_uInt32 nIndex, const sdr::Comment& rNew); 591 }; 592 593 typedef tools::WeakReference< SdrPage > SdrPageWeakRef; 594 595 ////////////////////////////////////////////////////////////////////////////// 596 // use new redirector instead of pPaintProc 597 598 class SVX_DLLPUBLIC StandardCheckVisisbilityRedirector : public ::sdr::contact::ViewObjectContactRedirector 599 { 600 public: 601 StandardCheckVisisbilityRedirector(); 602 virtual ~StandardCheckVisisbilityRedirector(); 603 604 // all default implementations just call the same methods at the original. To do something 605 // different, overload the method and at least do what the method does. 606 virtual drawinglayer::primitive2d::Primitive2DSequence createRedirectedPrimitive2DSequence( 607 const sdr::contact::ViewObjectContact& rOriginal, 608 const sdr::contact::DisplayInfo& rDisplayInfo); 609 }; 610 611 ////////////////////////////////////////////////////////////////////////////// 612 613 #endif //_SVDPAGE_HXX 614 615