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 #ifndef SW_VIEWSH_HXX 24 #define SW_VIEWSH_HXX 25 26 #include <com/sun/star/embed/XClassifiedObject.hpp> 27 #include <com/sun/star/embed/XEmbeddedObject.hpp> 28 #include <tools/rtti.hxx> 29 #include <svl/svarray.hxx> 30 #include "swdllapi.h" 31 #include <swtypes.hxx> 32 #include <ring.hxx> 33 #include <swrect.hxx> 34 #include <errhdl.hxx> 35 #include <boost/shared_ptr.hpp>// swmod 080115 36 #include <vcl/mapmod.hxx> 37 #include <vcl/print.hxx> 38 39 namespace com { namespace sun { namespace star { namespace accessibility { 40 class XAccessible; } } } } 41 42 class SfxObjectShellRef; 43 class SwDoc; 44 class IDocumentSettingAccess; 45 class IDocumentDeviceAccess; 46 class IDocumentMarkAccess; 47 class IDocumentDrawModelAccess; 48 class IDocumentRedlineAccess; 49 class IDocumentLayoutAccess; 50 class IDocumentFieldsAccess; 51 class IDocumentContentOperations; 52 class IDocumentStylePoolAccess; 53 class IDocumentStatistics; 54 class IDocumentUndoRedo; 55 // --> OD 2007-11-14 #i83479# 56 class IDocumentListItems; 57 class IDocumentOutlineNodes; 58 // <-- 59 class SfxPrinter; 60 class SfxProgress; 61 class SwRootFrm; 62 class SwNodes; 63 class SdrView; 64 class SfxItemPool; 65 class SfxViewShell; 66 class SwViewOption; 67 class SwViewImp; 68 class SwPrintData; 69 class SwPagePreViewPrtData; 70 class Window; 71 class OutputDevice; 72 class SwLayIdle; 73 struct ShellResource; 74 class SwRegionRects; 75 class SwFrm; 76 class SvtAccessibilityOptions; 77 class SwPagePreviewLayout; 78 class SwTxtFrm; 79 class BitmapEx; 80 81 struct SwAccessibilityOptions; 82 class Region; 83 class SwPostItMgr; 84 class SdrPaintWindow; 85 class SwAccessibleMap; 86 87 namespace vcl 88 { 89 class OldStylePrintAdaptor; 90 } 91 92 93 //JP 19.07.98: - Bug 52312 94 // define fuer Flags, die im CTOR oder den darunter liegenden Schichten 95 // benoetigt werden. 96 // Zur Zeit wird fuer die DrawPage das PreView Flag benoetigt 97 #define VSHELLFLAG_ISPREVIEW ((long)0x1) 98 #define VSHELLFLAG_SHARELAYOUT ((long)0x2)//swmod 080125 flag 99 typedef boost::shared_ptr<SwRootFrm> SwRootFrmPtr; 100 101 class SW_DLLPUBLIC ViewShell : public Ring 102 { 103 friend void SetOutDev( ViewShell *pSh, OutputDevice *pOut ); 104 friend void SetOutDevAndWin( ViewShell *pSh, OutputDevice *pOut, 105 Window *pWin, sal_uInt16 nZoom ); 106 107 friend class SwViewImp; 108 friend class SwLayIdle; 109 110 // OD 12.12.2002 #103492# - for setting visible area for page preview paint 111 friend class SwPagePreviewLayout; 112 113 // setting the SwVisArea is used to get a clean formatting before printing 114 friend void SetSwVisArea( ViewShell*, const SwRect& /*, sal_Bool bPDFExport = sal_False */ ); 115 116 // --> PB 2007-05-30 #146850# 117 static BitmapEx* pReplaceBmp; // replaced display of still loaded images 118 static BitmapEx* pErrorBmp; // error display of missed images 119 // <-- 120 121 static sal_Bool bLstAct; // sal_True wenn Das EndAction der letzten Shell 122 // laeuft; also die EndActions der 123 // anderen Shells auf das Dokument 124 // abgearbeitet sind. 125 126 Point aPrtOffst; //Ofst fuer den Printer, 127 //nicht bedruckbarer Rand. 128 Size aBrowseBorder; //Rand fuer Framedokumente 129 SwRect aInvalidRect; 130 131 SfxViewShell *pSfxViewShell; 132 SwViewImp *pImp; //Core-Interna der ViewShell. 133 //Der Pointer ist niemals 0. 134 135 Window *pWin; // = 0 during printing or pdf export 136 OutputDevice *pOut; // Window, Printer, VirtDev, ... 137 OutputDevice* mpTmpRef; // Temporariy reference device. Is used 138 // during (printer depending) prospect 139 // and page preview printing 140 // (because a scaling has to be set at 141 // the original printer) 142 143 SwViewOption *pOpt; 144 SwAccessibilityOptions* pAccOptions; 145 146 147 sal_Bool bDocSizeChgd :1; //Fuer DocChgNotify(): Neue DocGroesse bei 148 //EndAction an das DocMDI melden. 149 sal_Bool bPaintWorks :1; //Normal Painten wenn sal_True, 150 //Paint merken wenn sal_False 151 sal_Bool bPaintInProgress :1; //Kein zweifaches Paint durchlassen. 152 sal_Bool bViewLocked :1; //Lockt den sichtbaren Bereich, 153 //MakeVisible laeuft dann in's leere. 154 sal_Bool bInEndAction :1; //Fiese unstaende vermeiden, siehe viewsh.cxx 155 sal_Bool bPreView :1; //Ist sal_True wenns eine PreView-ViewShell ist. 156 sal_Bool bFrameView :1; //sal_True wenn es ein (HTML-)Frame ist. 157 sal_Bool bEnableSmooth :1; //Disable des SmoothScroll z.B. fuer 158 //Drag der Scrollbars. 159 sal_Bool bEndActionByVirDev:1; //Paints aus der EndAction immer ueber virtuelles 160 161 //Device (etwa beim Browsen) 162 163 // OD 2004-06-01 #i26791# - boolean, indicating that class in in constructor 164 bool mbInConstructor:1; 165 166 // #i74769# 167 SdrPaintWindow* mpTargetPaintWindow; 168 OutputDevice* mpBufferedOut; 169 170 SwRootFrmPtr pLayout; //swmod 080116 171 172 //Initialisierung, wird von den verschiedenen Konstruktoren gerufen. 173 SW_DLLPRIVATE void Init( const SwViewOption *pNewOpt ); 174 175 inline void ResetInvalidRect(); 176 177 SW_DLLPRIVATE void Reformat(); //Invalidert das ges. Layout (ApplyViewOption) 178 179 SW_DLLPRIVATE void PaintDesktop( const SwRect & ); // sammeln der Werte fuers 180 // Malen der Wiese und rufen 181 // PaintDesktop gesplittet, dieser Teil wird auch von PreViewPage benutzt 182 SW_DLLPRIVATE void _PaintDesktop( const SwRegionRects &rRegion ); 183 184 SW_DLLPRIVATE sal_Bool CheckInvalidForPaint( const SwRect & );//Direkt Paint oder lieber 185 //eine Aktion ausloesen. 186 187 SW_DLLPRIVATE void PrepareForPrint( const SwPrintData &rOptions ); 188 189 SW_DLLPRIVATE void ImplApplyViewOptions( const SwViewOption &rOpt ); 190 191 protected: 192 static ShellResource* pShellRes; // Resourcen fuer die Shell 193 static Window* pCareWindow; // diesem Fenster ausweichen 194 195 SwRect aVisArea; //Die moderne Ausfuerung der VisArea 196 SwDoc *pDoc; //Das Dokument, niemals 0 197 198 sal_uInt16 nStartAction; //ist != 0 wenn mindestens eine ::com::sun::star::chaos::Action laeuft 199 sal_uInt16 nLockPaint; //ist != 0 wenn das Paint gelocked ist. 200 201 public: 202 TYPEINFO(); 203 204 SwViewImp *Imp() { return pImp; } 205 const SwViewImp *Imp() const { return pImp; } 206 207 const SwNodes& GetNodes() const; 208 209 //Nach Druckerwechsel, vom Doc 210 void InitPrt( OutputDevice *pOutDev ); 211 212 //Klammerung von zusammengehoerenden Aktionen. 213 inline void StartAction(); 214 void ImplStartAction(); 215 inline void EndAction( const sal_Bool bIdleEnd = sal_False ); 216 void ImplEndAction( const sal_Bool bIdleEnd = sal_False ); 217 sal_uInt16 ActionCount() const { return nStartAction; } 218 sal_Bool ActionPend() const { return nStartAction != 0; } 219 sal_Bool IsInEndAction() const { return bInEndAction; } 220 221 void SetEndActionByVirDev( sal_Bool b ) { bEndActionByVirDev = b; } 222 sal_Bool IsEndActionByVirDev() { return bEndActionByVirDev; } 223 224 // Per UNO wird am RootFrame fuer alle shells der ActionCount kurzfristig 225 // auf Null gesetzt und wieder restauriert 226 void SetRestoreActions(sal_uInt16 nSet); 227 sal_uInt16 GetRestoreActions() const; 228 229 inline sal_Bool HasInvalidRect() const { return aInvalidRect.HasArea(); } 230 void ChgHyphenation() { Reformat(); } 231 void ChgNumberDigits(); 232 233 sal_Bool AddPaintRect( const SwRect &rRect ); 234 235 void InvalidateWindows( const SwRect &rRect ); 236 237 ////////////////////////////////////////////////////////////////////////////// 238 // #i72754# set of Pre/PostPaints with lock counter and initial target OutDev 239 protected: 240 sal_uInt32 mnPrePostPaintCount; 241 OutputDevice* mpPrePostOutDev; 242 MapMode maPrePostMapMode; 243 public: 244 void PrePaint(); 245 void DLPrePaint2(const Region& rRegion); 246 void DLPostPaint2(bool bPaintFormLayer); 247 const MapMode& getPrePostMapMode() const { return maPrePostMapMode; } 248 ////////////////////////////////////////////////////////////////////////////// 249 250 virtual void Paint(const Rectangle &rRect); 251 sal_Bool IsPaintInProgress() const { return bPaintInProgress; } 252 bool IsDrawingLayerPaintInProgress() const { return 0 != mnPrePostPaintCount; } 253 254 //Benachrichtung, dass sich der sichtbare Bereich geaendert hat. 255 //VisArea wird neu gesetzt, anschliessend wird gescrollt. 256 //Das uebergebene Rect liegt auf Pixelgrenzen, 257 //um Pixelfehler beim Scrollen zu vermeiden. 258 virtual void VisPortChgd( const SwRect & ); 259 sal_Bool SmoothScroll( long lXDiff, long lYDiff, const Rectangle* );//Browser 260 void EnableSmooth( sal_Bool b ) { bEnableSmooth = b; } 261 262 const SwRect& VisArea() const { return aVisArea; } 263 //Es wird, wenn notwendig, soweit gescrollt, dass das 264 //uebergebene Rect im sichtbaren Ausschnitt liegt. 265 void MakeVisible( const SwRect & ); 266 267 //Bei naechster Gelegenheit die neue Dokuemntgroesse an das UI weiterreichen. 268 void SizeChgNotify(); 269 void UISizeNotify(); //Das weiterreichen der aktuellen groesse. 270 271 Point GetPagePos( sal_uInt16 nPageNum ) const; 272 273 sal_uInt16 GetNumPages(); //Anzahl der aktuellen Seiten Layout erfragen. 274 sal_Bool IsDummyPage( sal_uInt16 nPageNum ) const; // An empty page? 275 276 //Invalidierung der ersten Sichtbaren Seite fuer alle Shells im Ring. 277 void SetFirstVisPageInvalid(); 278 279 SwRootFrm *GetLayout() const;//swmod 080116 280 sal_Bool IsNewLayout() const; //Wurde das Layout geladen oder neu 281 //erzeugt? 282 283 Size GetDocSize() const;// erfrage die Groesse des Dokuments 284 285 void CalcLayout(); //Durchformatierung des Layouts erzwingen. 286 287 sal_uInt16 GetPageCount() const; 288 289 const Size GetPageSize( sal_uInt16 nPageNum, bool bSkipEmptyPages ) const; 290 291 inline SwDoc *GetDoc() const { return pDoc; } //niemals 0. 292 293 /** Provides access to the document setting interface 294 */ 295 const IDocumentSettingAccess* getIDocumentSettingAccess() const; 296 IDocumentSettingAccess* getIDocumentSettingAccess(); 297 298 /** Provides access to the document device interface 299 */ 300 const IDocumentDeviceAccess* getIDocumentDeviceAccess() const; 301 IDocumentDeviceAccess* getIDocumentDeviceAccess(); 302 303 /** Provides access to the document bookmark interface 304 */ 305 const IDocumentMarkAccess* getIDocumentMarkAccess() const; 306 IDocumentMarkAccess* getIDocumentMarkAccess(); 307 308 /** Provides access to the document draw model interface 309 */ 310 const IDocumentDrawModelAccess* getIDocumentDrawModelAccess() const; 311 IDocumentDrawModelAccess* getIDocumentDrawModelAccess(); 312 313 /** Provides access to the document redline interface 314 */ 315 const IDocumentRedlineAccess* getIDocumentRedlineAccess() const; 316 IDocumentRedlineAccess* getIDocumentRedlineAccess(); 317 318 /** Provides access to the document layout interface 319 */ 320 const IDocumentLayoutAccess* getIDocumentLayoutAccess() const; 321 IDocumentLayoutAccess* getIDocumentLayoutAccess(); 322 323 /** Provides access to the document fields administration interface 324 */ 325 const IDocumentFieldsAccess* getIDocumentFieldsAccess() const; 326 327 /** Provides access to the content operations interface 328 */ 329 IDocumentContentOperations* getIDocumentContentOperations(); 330 331 /** Provides access to the document style pool interface 332 */ 333 IDocumentStylePoolAccess* getIDocumentStylePoolAccess(); 334 335 /** Provides access to the document statistics interface 336 */ 337 const IDocumentStatistics* getIDocumentStatistics() const; 338 339 /** Provides access to the document undo/redo interface 340 */ 341 IDocumentUndoRedo const& GetIDocumentUndoRedo() const; 342 IDocumentUndoRedo & GetIDocumentUndoRedo(); 343 344 // --> OD 2007-11-14 #i83479# 345 const IDocumentListItems* getIDocumentListItemsAccess() const; 346 const IDocumentOutlineNodes* getIDocumentOutlineNodesAccess() const; 347 // <-- 348 349 // 1. GetRefDev: Either the printer or the virtual device from the doc 350 // 2. GetWin: Available if we not printing 351 // 3. GetOut: Printer, Window or Virtual device 352 OutputDevice& GetRefDev() const; 353 inline Window* GetWin() const { return pWin; } 354 inline OutputDevice* GetOut() const { return pOut; } 355 void SetWin(Window* win) { pWin = win; } 356 static inline sal_Bool IsLstEndAction() { return ViewShell::bLstAct; } 357 358 //Andern alle PageDescriptoren 359 void ChgAllPageOrientation( sal_uInt16 eOri ); 360 void ChgAllPageSize( Size &rSz ); 361 362 // printing of one page. 363 // bIsPDFExport == true is: do PDF Export (no printing!) 364 sal_Bool PrintOrPDFExport( OutputDevice *pOutDev, 365 SwPrintData const& rPrintData, 366 sal_Int32 nRenderer /* offset in vector of pages to print */ ); 367 368 // printing of one brochure page 369 void PrintProspect( OutputDevice *pOutDev, const SwPrintData &rPrintData, 370 sal_Int32 nRenderer /* offset in vector of page pairs for prospect printing */ ); 371 372 // printing for OLE 2.0 373 static void PrtOle2( SwDoc *pDoc, const SwViewOption *pOpt, const SwPrintData& rOptions, 374 OutputDevice* pOleOut, const Rectangle& rRect ); 375 376 /// fill temporary doc with selected text for Print or PDF export 377 SwDoc * FillPrtDoc( SwDoc* pPrtDoc, const SfxPrinter* pPrt ); 378 379 //Wird intern fuer die Shell gerufen die Druckt. Formatiert die Seiten. 380 void CalcPagesForPrint( sal_uInt16 nMax ); 381 382 //All about fields. 383 void UpdateFlds(sal_Bool bCloseDB = sal_False); 384 sal_Bool IsAnyFieldInDoc() const; 385 // update all charts, for that exists any table 386 void UpdateAllCharts(); 387 sal_Bool HasCharts() const; 388 389 // 390 // DOCUMENT COMPATIBILITY FLAGS START 391 // 392 393 // Sollen Absatzabstaende addiert oder maximiert werden? 394 void SetParaSpaceMax( bool bNew ); 395 396 // Sollen Absatzabstaende addiert oder maximiert werden? 397 void SetParaSpaceMaxAtPages( bool bNew ); 398 399 // compatible behaviour of tabs 400 void SetTabCompat( bool bNew ); 401 402 // font metric attribute "External Leading" should be considered 403 void SetAddExtLeading( bool bNew ); 404 405 // formatting by virtual device or printer 406 void SetUseVirDev( bool nNew ); 407 408 // OD 2004-02-16 #106629# - adding paragraph and table spacing at bottom 409 // of table cells 410 void SetAddParaSpacingToTableCells( bool _bAddParaSpacingToTableCells ); 411 412 // OD 06.01.2004 #i11859# - former formatting of text lines with 413 // proportional line spacing or not 414 void SetUseFormerLineSpacing( bool _bUseFormerLineSpacing ); 415 416 // OD 2004-03-12 #i11860# - former object positioning 417 void SetUseFormerObjectPositioning( bool _bUseFormerObjPos ); 418 419 // OD 2004-05-05 #i28701# 420 void SetConsiderWrapOnObjPos( bool _bConsiderWrapOnObjPos ); 421 422 // --> FME #108724# 423 void SetUseFormerTextWrapping( bool _bUseFormerTextWrapping ); 424 425 // -> PB 2007-06-11 #i45491# 426 void SetDoNotJustifyLinesWithManualBreak( bool _bDoNotJustifyLinesWithManualBreak ); 427 // <-- 428 429 // 430 // DOCUMENT COMPATIBILITY FLAGS END 431 // 432 433 //Ruft den Idle-Formatierer des Layouts 434 void LayoutIdle(); 435 436 inline const SwViewOption *GetViewOptions() const { return pOpt; } 437 virtual void ApplyViewOptions( const SwViewOption &rOpt ); 438 void SetUIOptions( const SwViewOption &rOpt ); 439 void SetReadonlyOption(sal_Bool bSet); // Readonly-Bit d. ViewOptions setzen 440 void SetPDFExportOption(sal_Bool bSet); // set/reset PDF export mode 441 void SetPrtFormatOption(sal_Bool bSet); // PrtFormat-Bit d. ViewOptions setzen 442 void SetReadonlySelectionOption(sal_Bool bSet);//change the selection mode in readonly docs 443 444 const SwAccessibilityOptions* GetAccessibilityOptions() const { return pAccOptions;} 445 446 static void SetShellRes( ShellResource* pRes ) { pShellRes = pRes; } 447 static ShellResource* GetShellRes(); 448 449 static void SetCareWin( Window* pNew ); 450 static Window* GetCareWin(ViewShell& rVSh) 451 { return pCareWindow ? pCareWindow : CareChildWin(rVSh); } 452 static Window* CareChildWin(ViewShell& rVSh); 453 454 inline SfxViewShell *GetSfxViewShell() { return pSfxViewShell; } 455 inline void SetSfxViewShell(SfxViewShell *pNew) { pSfxViewShell = pNew; } 456 457 // Selektion der Draw ::com::sun::star::script::Engine geaendert 458 virtual void DrawSelChanged(); 459 460 // OD 12.12.2002 #103492# 461 SwPagePreviewLayout* PagePreviewLayout(); 462 463 /** adjust view options for page preview 464 465 OD 09.01.2003 #i6467# 466 Because page preview should show the document as it is printed - 467 page preview is print preview -, the view options are adjusted to the 468 same as for printing. 469 470 @param _rPrintOptions 471 input parameter - constant reference to print options, to which the 472 view option will be adjusted. 473 */ 474 void AdjustOptionsForPagePreview( SwPrintData const& rPrintOptions ); 475 476 sal_Bool IsViewLocked() const { return bViewLocked; } 477 void LockView( sal_Bool b ) { bViewLocked = b; } 478 479 inline void LockPaint(); 480 void ImplLockPaint(); 481 inline void UnlockPaint( sal_Bool bVirDev = sal_False ); 482 void ImplUnlockPaint( sal_Bool bVirDev ); 483 sal_Bool IsPaintLocked() const { return nLockPaint != 0; } 484 485 // Abfragen/Erzeugen DrawView + PageView 486 sal_Bool HasDrawView() const; 487 void MakeDrawView(); 488 489 //DrawView darf u.U. am UI benutzt werden. 490 SdrView *GetDrawView(); 491 const SdrView *GetDrawView() const { return ((ViewShell*)this)->GetDrawView(); } 492 493 //sorge dafuer, das auf jedenfall die MarkListe aktuell ist (Bug 57153) 494 SdrView *GetDrawViewWithValidMarkList(); 495 496 // erfrage den Attribut Pool 497 inline const SfxItemPool& GetAttrPool() const; 498 SfxItemPool& GetAttrPool(); 499 500 sal_Bool IsPreView() const { return bPreView; } 501 502 sal_Bool IsFrameView() const { return bFrameView; } 503 void SetFrameView( const Size& rBrowseBorder ) 504 { bFrameView = sal_True; aBrowseBorder = rBrowseBorder; } 505 506 //Nimmt die notwendigen Invalidierungen vor, 507 //wenn sich der BrowdseModus aendert, bBrowseChgd == sal_True 508 //oder, im BrowseModus, wenn sich die Groessenverhaeltnisse 509 //aendern (bBrowseChgd == sal_False) 510 void CheckBrowseView( sal_Bool bBrowseChgd ); 511 512 const Size& GetBrowseBorder() const; 513 sal_Int32 GetBrowseWidth() const; 514 void SetBrowseBorder( const Size& rNew ); 515 516 ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > CreateAccessible(); 517 518 // OD 15.01.2003 #103492# - change method signature due to new page preview 519 // functionality. 520 ::com::sun::star::uno::Reference< 521 ::com::sun::star::accessibility::XAccessible > 522 CreateAccessiblePreview(); 523 524 void ShowPreViewSelection( sal_uInt16 nSelPage ); 525 void InvalidateAccessibleFocus(); 526 527 //apply Accessiblity options 528 void ApplyAccessiblityOptions(SvtAccessibilityOptions& rAccessibilityOptions); 529 530 /** invalidate CONTENT_FLOWS_FROM/_TO relation for paragraphs 531 532 OD 2005-12-01 #i27138# 533 534 @author OD 535 536 @param _pFromTxtFrm 537 input parameter - paragraph frame, for which the relation CONTENT_FLOWS_FROM 538 has to be invalidated. 539 If NULL, no CONTENT_FLOWS_FROM relation has to be invalidated 540 541 @param _pToTxtFrm 542 input parameter - paragraph frame, for which the relation CONTENT_FLOWS_TO 543 has to be invalidated. 544 If NULL, no CONTENT_FLOWS_TO relation has to be invalidated 545 */ 546 void InvalidateAccessibleParaFlowRelation( const SwTxtFrm* _pFromTxtFrm, 547 const SwTxtFrm* _pToTxtFrm ); 548 549 /** invalidate text selection for paragraphs 550 551 OD 2005-12-12 #i27301# 552 553 @author OD 554 */ 555 void InvalidateAccessibleParaTextSelection(); 556 557 /** invalidate attributes for paragraphs and paragraph's characters 558 559 OD 2009-01-06 #i88069# 560 OD 2010-02-16 #i104008# - usage also for changes of the attributes of 561 paragraph's characters. 562 563 @author OD 564 565 @param rTxtFrm 566 input parameter - paragraph frame, whose attributes have changed 567 */ 568 void InvalidateAccessibleParaAttrs( const SwTxtFrm& rTxtFrm ); 569 570 SwAccessibleMap* GetAccessibleMap(); 571 572 ViewShell( ViewShell&, Window *pWin = 0, OutputDevice *pOut = 0, 573 long nFlags = 0 ); 574 ViewShell( SwDoc& rDoc, Window *pWin, 575 const SwViewOption *pOpt = 0, OutputDevice *pOut = 0, 576 long nFlags = 0 ); 577 virtual ~ViewShell(); 578 579 // --> FME 2004-06-15 #i12836# enhanced pdf export 580 sal_Int32 GetPageNumAndSetOffsetForPDF( OutputDevice& rOut, const SwRect& rRect ) const; 581 // <-- 582 583 inline bool IsInConstructor() const { return mbInConstructor; } 584 585 // --> PB 2007-05-30 #146850# 586 static const BitmapEx& GetReplacementBitmap( bool bIsErrorState ); 587 static void DeleteReplacementBitmaps(); 588 // <-- 589 590 const SwPostItMgr* GetPostItMgr() const { return (const_cast<ViewShell*>(this))->GetPostItMgr(); } 591 SwPostItMgr* GetPostItMgr(); 592 }; 593 594 //---- class CurrShell verwaltet den globalen ShellPointer ------------------- 595 596 class CurrShell 597 { 598 public: 599 ViewShell *pPrev; 600 SwRootFrm *pRoot; 601 602 CurrShell( ViewShell *pNew ); 603 ~CurrShell(); 604 }; 605 606 inline void ViewShell::ResetInvalidRect() 607 { 608 aInvalidRect.Clear(); 609 } 610 611 inline void ViewShell::StartAction() 612 { 613 if ( !nStartAction++ ) 614 ImplStartAction(); 615 } 616 inline void ViewShell::EndAction( const sal_Bool bIdleEnd ) 617 { 618 if( 0 == (nStartAction - 1) ) 619 ImplEndAction( bIdleEnd ); 620 --nStartAction; 621 } 622 623 inline void ViewShell::LockPaint() 624 { 625 if ( !nLockPaint++ ) 626 ImplLockPaint(); 627 } 628 inline void ViewShell::UnlockPaint( sal_Bool bVirDev ) 629 { 630 if ( 0 == --nLockPaint ) 631 ImplUnlockPaint( bVirDev ); 632 } 633 inline const SfxItemPool& ViewShell::GetAttrPool() const 634 { 635 return ((ViewShell*)this)->GetAttrPool(); 636 } 637 638 639 640 #endif // SW_VIEWSH_HXX 641