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 // MARKER(update_precomp.py): autogen include statement, do not remove 25 #include "precompiled_sw.hxx" 26 27 28 #include <string> // HACK: prevent conflict between STLPORT and Workshop headers 29 #include <stdlib.h> 30 #include <hintids.hxx> 31 #include <rtl/logfile.hxx> 32 #include <vcl/graph.hxx> 33 #include <vcl/inputctx.hxx> 34 #include <basic/sbxobj.hxx> 35 #include <svl/eitem.hxx> 36 #include <unotools/undoopt.hxx> 37 #include <unotools/lingucfg.hxx> 38 #include <unotools/useroptions.hxx> 39 #include <sfx2/dispatch.hxx> 40 #include <sfx2/request.hxx> 41 #include <sfx2/docfile.hxx> 42 #include <sfx2/printer.hxx> 43 #include <sfx2/app.hxx> 44 #include <svx/ruler.hxx> 45 #include <editeng/protitem.hxx> 46 #include <svx/fmshell.hxx> 47 #include <svx/extrusionbar.hxx> 48 #include <svx/fontworkbar.hxx> 49 #include <unotxvw.hxx> 50 #include <cmdid.h> 51 #include <swhints.hxx> 52 #include <swmodule.hxx> 53 #include <inputwin.hxx> 54 #include <chartins.hxx> 55 #include <uivwimp.hxx> 56 #include <uitool.hxx> 57 #include <edtwin.hxx> 58 #include <textsh.hxx> 59 #include <listsh.hxx> 60 #include <tabsh.hxx> 61 #include <grfsh.hxx> 62 #include <mediash.hxx> 63 #include <docsh.hxx> 64 #include <frmsh.hxx> 65 #include <olesh.hxx> 66 #include <drawsh.hxx> 67 #include <drawbase.hxx> 68 #include <drformsh.hxx> 69 #include <drwtxtsh.hxx> 70 #include <beziersh.hxx> 71 #include <globdoc.hxx> 72 #include <scroll.hxx> 73 #include <navipi.hxx> 74 #include <gloshdl.hxx> 75 #include <usrpref.hxx> 76 #include <srcview.hxx> 77 #include <doc.hxx> 78 #include <IDocumentUndoRedo.hxx> 79 #include <drawdoc.hxx> 80 #include <wdocsh.hxx> 81 #include <wview.hxx> 82 #include <workctrl.hxx> 83 #include <wrtsh.hxx> 84 #include <barcfg.hxx> 85 #include <pview.hxx> 86 #include <swdtflvr.hxx> 87 #include <view.hrc> 88 #include <globdoc.hrc> 89 #include <frmui.hrc> 90 #include <cfgitems.hxx> 91 #include <prtopt.hxx> 92 #include <linguistic/lngprops.hxx> 93 #include <editeng/unolingu.hxx> 94 //#include <sfx2/app.hxx> 95 #include <com/sun/star/frame/FrameSearchFlag.hpp> 96 #include <com/sun/star/scanner/ScannerContext.hpp> 97 #include <com/sun/star/scanner/XScannerManager.hpp> 98 #include <toolkit/helper/vclunohelper.hxx> 99 #include <rtl/ustrbuf.hxx> 100 #include <xmloff/xmluconv.hxx> 101 102 #include "formatclipboard.hxx" 103 #include <PostItMgr.hxx> 104 #include <annotsh.hxx> 105 106 #include <fldbas.hxx> 107 108 #include <unomid.h> 109 110 #include <com/sun/star/document/XDocumentProperties.hpp> 111 #include <com/sun/star/document/XDocumentPropertiesSupplier.hpp> 112 113 114 using namespace ::com::sun::star; 115 using namespace ::com::sun::star::uno; 116 using namespace ::com::sun::star::lang; 117 using namespace ::com::sun::star::scanner; 118 using ::rtl::OUString; 119 using ::rtl::OUStringBuffer; 120 121 122 extern sal_Bool bNoInterrupt; // in mainwn.cxx 123 124 #define SWVIEWFLAGS ( SFX_VIEW_CAN_PRINT| \ 125 SFX_VIEW_HAS_PRINTOPTIONS) 126 127 /*-------------------------------------------------------------------- 128 Beschreibung: Statics 129 --------------------------------------------------------------------*/ 130 131 int bDocSzUpdated = 1; 132 133 SvxSearchItem* SwView::pSrchItem = 0; 134 135 sal_uInt16 SwView::nInsertCtrlState = FN_INSERT_TABLE; 136 sal_uInt16 SwView::nWebInsertCtrlState = FN_INSERT_TABLE; 137 sal_uInt16 SwView::nInsertObjectCtrlState = SID_INSERT_DIAGRAM; 138 139 sal_Bool SwView::bExtra = sal_False; 140 sal_Bool SwView::bFound = sal_False; 141 sal_Bool SwView::bJustOpened = sal_False; 142 143 144 SvxSearchDialog* SwView::pSrchDlg = 0; 145 SearchAttrItemList* SwView::pSrchList = 0; 146 SearchAttrItemList* SwView::pReplList = 0; 147 148 DBG_NAME(viewhdl) 149 150 /*-------------------------------------------------------------------- 151 Beschreibung: 152 --------------------------------------------------------------------*/ 153 154 inline SfxDispatcher &SwView::GetDispatcher() 155 { 156 return *GetViewFrame()->GetDispatcher(); 157 } 158 159 /*-------------------------------------------------------------------- 160 Beschreibung: 161 --------------------------------------------------------------------*/ 162 163 void SwView::ImpSetVerb( int nSelType ) 164 { 165 sal_Bool bResetVerbs = bVerbsActive; 166 if ( !GetViewFrame()->GetFrame().IsInPlace() && 167 (nsSelectionType::SEL_OLE|nsSelectionType::SEL_GRF) & nSelType ) 168 { 169 if ( !pWrtShell->IsSelObjProtected(FLYPROTECT_CONTENT) ) 170 { 171 if ( nSelType & nsSelectionType::SEL_OLE ) 172 { 173 SetVerbs( GetWrtShell().GetOLEObject()->getSupportedVerbs() ); 174 bVerbsActive = sal_True; 175 bResetVerbs = sal_False; 176 } 177 } 178 } 179 if ( bResetVerbs ) 180 { 181 SetVerbs( Sequence< embed::VerbDescriptor >() ); 182 bVerbsActive = sal_False; 183 } 184 } 185 186 /*-------------------------------------------------------------------- 187 Description: 188 called by the SwEditWin when it gets the focus 189 --------------------------------------------------------------------*/ 190 191 void SwView::GotFocus() const 192 { 193 // if we got the focus, and the form shell *is* on the top of the dispatcher 194 // stack, then we need to rebuild the stack (the form shell doesn't belong to 195 // the top then) 196 const SfxDispatcher& rDispatcher = const_cast< SwView* >( this )->GetDispatcher(); 197 SfxShell* pTopShell = rDispatcher.GetShell( 0 ); 198 FmFormShell* pAsFormShell = PTR_CAST( FmFormShell, pTopShell ); 199 if ( pAsFormShell ) 200 { 201 pAsFormShell->ForgetActiveControl(); 202 const_cast< SwView* >( this )->AttrChangedNotify( pWrtShell ); 203 } 204 else if ( mpPostItMgr ) 205 { 206 SwAnnotationShell* pAsAnnotationShell = PTR_CAST( SwAnnotationShell, pTopShell ); 207 if ( pAsAnnotationShell ) 208 { 209 mpPostItMgr->SetActiveSidebarWin(0); 210 const_cast< SwView* >( this )->AttrChangedNotify( pWrtShell ); 211 } 212 } 213 if( GetWrtShellPtr() ) 214 { 215 SwWrtShell& rWrtShell = GetWrtShell(); 216 rWrtShell.GetDoc()->SetCurrentViewShell( GetWrtShellPtr() ); 217 rWrtShell.GetDoc()->set( IDocumentSettingAccess::BROWSE_MODE, 218 rWrtShell.GetViewOptions()->getBrowseMode() ); 219 } 220 } 221 222 /*-------------------------------------------------------------------- 223 Description: 224 called by the FormShell when a form control is focused. This is 225 a request to put the form shell on the top of the dispatcher 226 stack 227 --------------------------------------------------------------------*/ 228 229 IMPL_LINK( SwView, FormControlActivated, FmFormShell*, EMPTYARG ) 230 { 231 // if a form control has been activated, and the form shell is not on the top 232 // of the dispatcher stack, then we need to activate it 233 const SfxDispatcher& rDispatcher = GetDispatcher(); 234 const SfxShell* pTopShell = rDispatcher.GetShell( 0 ); 235 const FmFormShell* pAsFormShell = PTR_CAST( FmFormShell, pTopShell ); 236 if ( !pAsFormShell ) 237 { 238 // if we're editing text currently, cancel this 239 SdrView *pSdrView = pWrtShell ? pWrtShell->GetDrawView() : NULL; 240 if ( pSdrView && pSdrView->IsTextEdit() ) 241 pSdrView->SdrEndTextEdit( sal_True ); 242 243 const_cast< SwView* >( this )->AttrChangedNotify( pWrtShell ); 244 } 245 246 return 0L; 247 } 248 249 void SwView::SelectShell() 250 { 251 //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 252 // 253 // Achtung: SelectShell fuer die WebView mitpflegen 254 // 255 //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 256 257 if(bInDtor) 258 return; 259 // Entscheidung, ob UpdateTable gerufen werden muss 260 sal_Bool bUpdateTable = sal_False; 261 const SwFrmFmt* pCurTableFmt = pWrtShell->GetTableFmt(); 262 if(pCurTableFmt && pCurTableFmt != pLastTableFormat) 263 { 264 bUpdateTable = sal_True; // kann erst spaeter ausgefuehrt werden 265 } 266 pLastTableFormat = pCurTableFmt; 267 268 //SEL_TBL und SEL_TBL_CELLS koennen verodert sein! 269 int nNewSelectionType = (pWrtShell->GetSelectionType() 270 & ~nsSelectionType::SEL_TBL_CELLS); 271 272 if ( pFormShell && pFormShell->IsActiveControl() ) 273 nNewSelectionType |= nsSelectionType::SEL_FOC_FRM_CTRL; 274 275 if ( nNewSelectionType == nSelectionType ) 276 { 277 GetViewFrame()->GetBindings().InvalidateAll( sal_False ); 278 if ( nSelectionType & nsSelectionType::SEL_OLE || 279 nSelectionType & nsSelectionType::SEL_GRF ) 280 //Fuer Grafiken und OLE kann sich natuerlich das Verb aendern! 281 ImpSetVerb( nNewSelectionType ); 282 } 283 else 284 { 285 286 SfxDispatcher &rDispatcher = GetDispatcher(); 287 SwToolbarConfigItem *pBarCfg = SW_MOD()->GetToolbarConfig(); 288 289 // DELETEZ(pxSelectionObj); //Selektionsobjekt loeschen 290 if ( pShell ) 291 { 292 rDispatcher.Flush(); // alle gecachten Shells wirklich loeschen 293 294 //Zur alten Selektion merken welche Toolbar sichtbar war 295 sal_uInt16 nId = static_cast< sal_uInt16 >( rDispatcher.GetObjectBarId( SFX_OBJECTBAR_OBJECT )); 296 if ( nId ) 297 pBarCfg->SetTopToolbar( nSelectionType, nId ); 298 299 SfxShell *pSfxShell; 300 for ( sal_uInt16 i = 0; sal_True; ++i ) 301 { 302 pSfxShell = rDispatcher.GetShell( i ); 303 if ( pSfxShell->ISA( SwBaseShell ) 304 || pSfxShell->ISA( SwDrawTextShell ) 305 || pSfxShell->ISA( svx::ExtrusionBar ) 306 || pSfxShell->ISA( svx::FontworkBar ) 307 || pSfxShell->ISA( SwAnnotationShell ) 308 ) 309 { 310 rDispatcher.Pop( *pSfxShell, SFX_SHELL_POP_DELETE ); 311 } 312 else if ( pSfxShell->ISA( FmFormShell ) ) 313 { 314 rDispatcher.Pop( *pSfxShell ); 315 } 316 else 317 break; 318 } 319 } 320 321 sal_Bool bInitFormShell = sal_False; 322 if (!pFormShell) 323 { 324 bInitFormShell = sal_True; 325 pFormShell = new FmFormShell( this ); 326 pFormShell->SetControlActivationHandler( LINK( this, SwView, FormControlActivated ) ); 327 StartListening(*pFormShell); 328 } 329 330 sal_Bool bSetExtInpCntxt = sal_False; 331 nSelectionType = nNewSelectionType; 332 ShellModes eShellMode; 333 334 if ( !( nSelectionType & nsSelectionType::SEL_FOC_FRM_CTRL ) ) 335 rDispatcher.Push( *pFormShell ); 336 337 if ( nSelectionType & nsSelectionType::SEL_OLE ) 338 { 339 eShellMode = SHELL_MODE_OBJECT; 340 pShell = new SwOleShell( *this ); 341 rDispatcher.Push( *pShell ); 342 } 343 else if ( nSelectionType & nsSelectionType::SEL_FRM 344 || nSelectionType & nsSelectionType::SEL_GRF) 345 { 346 eShellMode = SHELL_MODE_FRAME; 347 pShell = new SwFrameShell( *this ); 348 rDispatcher.Push( *pShell ); 349 if(nSelectionType & nsSelectionType::SEL_GRF ) 350 { 351 eShellMode = SHELL_MODE_GRAPHIC; 352 pShell = new SwGrfShell( *this ); 353 rDispatcher.Push( *pShell ); 354 } 355 } 356 else if ( nSelectionType & nsSelectionType::SEL_DRW ) 357 { 358 eShellMode = SHELL_MODE_DRAW; 359 pShell = new SwDrawShell( *this ); 360 rDispatcher.Push( *pShell ); 361 362 if ( nSelectionType & nsSelectionType::SEL_BEZ ) 363 { 364 eShellMode = SHELL_MODE_BEZIER; 365 pShell = new SwBezierShell( *this ); 366 rDispatcher.Push( *pShell ); 367 } 368 else if( nSelectionType & nsSelectionType::SEL_MEDIA ) 369 { 370 eShellMode = SHELL_MODE_MEDIA; 371 pShell = new SwMediaShell( *this ); 372 rDispatcher.Push( *pShell ); 373 } 374 375 if (nSelectionType & nsSelectionType::SEL_EXTRUDED_CUSTOMSHAPE) 376 { 377 eShellMode = SHELL_MODE_EXTRUDED_CUSTOMSHAPE; 378 pShell = new svx::ExtrusionBar(this); 379 rDispatcher.Push( *pShell ); 380 } 381 if (nSelectionType & nsSelectionType::SEL_FONTWORK) 382 { 383 eShellMode = SHELL_MODE_FONTWORK; 384 pShell = new svx::FontworkBar(this); 385 rDispatcher.Push( *pShell ); 386 } 387 } 388 else if ( nSelectionType & nsSelectionType::SEL_DRW_FORM ) 389 { 390 eShellMode = SHELL_MODE_DRAW_FORM; 391 pShell = new SwDrawFormShell( *this ); 392 393 rDispatcher.Push( *pShell ); 394 } 395 else if ( nSelectionType & nsSelectionType::SEL_DRW_TXT ) 396 { 397 bSetExtInpCntxt = sal_True; 398 eShellMode = SHELL_MODE_DRAWTEXT; 399 rDispatcher.Push( *(new SwBaseShell( *this )) ); 400 pShell = new SwDrawTextShell( *this ); 401 rDispatcher.Push( *pShell ); 402 } 403 else if ( nSelectionType & nsSelectionType::SEL_POSTIT ) 404 { 405 eShellMode = SHELL_MODE_POSTIT; 406 pShell = new SwAnnotationShell( *this ); 407 rDispatcher.Push( *pShell ); 408 } 409 else 410 { 411 bSetExtInpCntxt = sal_True; 412 eShellMode = SHELL_MODE_TEXT; 413 sal_uInt32 nHelpId = 0; 414 if ( nSelectionType & nsSelectionType::SEL_NUM ) 415 { 416 eShellMode = SHELL_MODE_LIST_TEXT; 417 pShell = new SwListShell( *this ); 418 nHelpId = pShell->GetHelpId(); 419 rDispatcher.Push( *pShell ); 420 } 421 pShell = new SwTextShell(*this); 422 if(nHelpId) 423 pShell->SetHelpId(nHelpId); 424 rDispatcher.Push( *pShell ); 425 if ( nSelectionType & nsSelectionType::SEL_TBL ) 426 { 427 eShellMode = eShellMode == SHELL_MODE_LIST_TEXT ? SHELL_MODE_TABLE_LIST_TEXT 428 : SHELL_MODE_TABLE_TEXT; 429 pShell = new SwTableShell( *this ); 430 rDispatcher.Push( *pShell ); 431 } 432 } 433 434 if ( nSelectionType & nsSelectionType::SEL_FOC_FRM_CTRL ) 435 rDispatcher.Push( *pFormShell ); 436 437 pViewImpl->SetShellMode(eShellMode); 438 ImpSetVerb( nSelectionType ); 439 440 if( !GetDocShell()->IsReadOnly() ) 441 { 442 if( bSetExtInpCntxt && GetWrtShell().HasReadonlySel() ) 443 bSetExtInpCntxt = sal_False; 444 445 InputContext aCntxt( GetEditWin().GetInputContext() ); 446 aCntxt.SetOptions( bSetExtInpCntxt 447 ? (aCntxt.GetOptions() | 448 ( INPUTCONTEXT_TEXT | 449 INPUTCONTEXT_EXTTEXTINPUT )) 450 : (aCntxt.GetOptions() & ~ 451 ( INPUTCONTEXT_TEXT | 452 INPUTCONTEXT_EXTTEXTINPUT )) ); 453 GetEditWin().SetInputContext( aCntxt ); 454 } 455 456 //Zur neuen Selektion die Toolbar aktivieren, die auch beim letzten Mal 457 //aktiviert war 458 //Vorher muss ein Flush() sein, betrifft aber lt. MBA nicht das UI und ist 459 //kein Performance-Problem 460 // TODO/LATER: maybe now the Flush() command is superfluous?! 461 rDispatcher.Flush(); 462 463 Point aPnt = GetEditWin().OutputToScreenPixel(GetEditWin().GetPointerPosPixel()); 464 aPnt = GetEditWin().PixelToLogic(aPnt); 465 GetEditWin().UpdatePointer(aPnt); 466 467 SdrView* pDView = GetWrtShell().GetDrawView(); 468 if ( bInitFormShell && pDView ) 469 pFormShell->SetView(PTR_CAST(FmFormView, pDView)); 470 471 } 472 //Guenstiger Zeitpunkt fuer die Kommunikation mit OLE-Objekten? 473 if ( GetDocShell()->GetDoc()->IsOLEPrtNotifyPending() ) 474 GetDocShell()->GetDoc()->PrtOLENotify( sal_False ); 475 476 //jetzt das Tabellen-Update 477 if(bUpdateTable) 478 pWrtShell->UpdateTable(); 479 480 GetViewImpl()->GetUNOObject_Impl()->NotifySelChanged(); 481 } 482 483 //Zusammenspiel: AttrChangedNotify() und TimeoutHdl. 484 //Falls noch Actions offen sind keine Aktualisierung, da der 485 //Cursor auf der Core-Seite im Wald stehen kann. 486 //Da wir aber keine Stati mehr liefern koennen und wollen locken wir 487 //stattdessen den Dispatcher. 488 489 490 491 extern "C" 492 { 493 int lcl_CmpIds( const void *pFirst, const void *pSecond) 494 { 495 return (*(sal_uInt16*)pFirst) - (*(sal_uInt16*)pSecond); 496 } 497 } 498 499 500 501 IMPL_LINK( SwView, AttrChangedNotify, SwWrtShell *, EMPTYARG ) 502 { 503 if ( GetEditWin().IsChainMode() ) 504 GetEditWin().SetChainMode( sal_False ); 505 506 //Opt: Nicht wenn PaintLocked. Beim Unlock wird dafuer nocheinmal ein 507 //Notify ausgeloest. 508 if( !pWrtShell->IsPaintLocked() && !bNoInterrupt && 509 GetDocShell()->IsReadOnly() ) 510 _CheckReadonlyState(); 511 512 // JP 19.01.99: Cursor in Readonly Bereichen 513 if( !pWrtShell->IsPaintLocked() && !bNoInterrupt ) 514 _CheckReadonlySelection(); 515 516 if( !bAttrChgNotified ) 517 { 518 if ( pWrtShell->BasicActionPend() || bNoInterrupt || 519 GetDispatcher().IsLocked() || //do not confuse the SFX 520 GetViewFrame()->GetBindings().IsInUpdate() )//do not confuse the SFX 521 { 522 bAttrChgNotified = sal_True; 523 aTimer.Start(); 524 525 const SfxPoolItem *pItem; 526 if ( SFX_ITEM_SET != GetObjectShell()->GetMedium()->GetItemSet()-> 527 GetItemState( SID_HIDDEN, sal_False, &pItem ) || 528 !((SfxBoolItem*)pItem)->GetValue() ) 529 { 530 GetViewFrame()->GetBindings().ENTERREGISTRATIONS(); 531 bAttrChgNotifiedWithRegistrations = sal_True; 532 } 533 534 } 535 else 536 SelectShell(); 537 538 } 539 540 //#i6193#, change ui if cursor is at a SwPostItField 541 if (mpPostItMgr) 542 { 543 mpPostItMgr->SetShadowState( pWrtShell->GetPostItFieldAtCursor() ); 544 } 545 546 return 0; 547 } 548 549 550 551 IMPL_LINK( SwView, TimeoutHdl, Timer *, EMPTYARG ) 552 { 553 DBG_PROFSTART(viewhdl); 554 555 if( pWrtShell->BasicActionPend() || bNoInterrupt ) 556 { 557 aTimer.Start(); 558 DBG_PROFSTOP(viewhdl); 559 return 0; 560 } 561 562 if ( bAttrChgNotifiedWithRegistrations ) 563 { 564 GetViewFrame()->GetBindings().LEAVEREGISTRATIONS(); 565 bAttrChgNotifiedWithRegistrations = sal_False; 566 } 567 568 _CheckReadonlyState(); 569 _CheckReadonlySelection(); 570 571 sal_Bool bOldUndo = pWrtShell->DoesUndo(); 572 pWrtShell->DoUndo( sal_False ); 573 SelectShell(); 574 pWrtShell->DoUndo( bOldUndo ); 575 bAttrChgNotified = sal_False; 576 GetViewImpl()->GetUNOObject_Impl()->NotifySelChanged(); 577 578 DBG_PROFSTOP(viewhdl); 579 return 0; 580 } 581 582 void SwView::_CheckReadonlyState() 583 { 584 SfxDispatcher &rDis = GetDispatcher(); 585 //Um erkennen zu koennen ob bereits disabled ist! 586 SfxItemState eStateRO, eStateProtAll; 587 const SfxPoolItem *pItem; 588 // JP 29.04.97: von einem nur uns bekannten Slot den Status abfragen. 589 // Ansonsten kennen andere den Slot; wie z.B. die BasidIde 590 eStateRO = rDis.QueryState( FN_INSERT_BOOKMARK, pItem ); 591 eStateProtAll = rDis.QueryState( FN_EDIT_REGION, pItem ); 592 sal_Bool bChgd = sal_False; 593 594 if ( !pWrtShell->IsCrsrReadonly() ) 595 { 596 static sal_uInt16 aROIds[] = 597 { 598 SID_DELETE, FN_BACKSPACE, FN_SHIFT_BACKSPACE, 599 SID_UNDO, 600 SID_REDO, SID_REPEAT, SID_PASTE, 601 SID_PASTE_UNFORMATTED, 602 SID_PASTE_SPECIAL, SID_SBA_BRW_INSERT, 603 SID_BACKGROUND_COLOR, FN_INSERT_BOOKMARK, 604 SID_CHARMAP, FN_INSERT_SOFT_HYPHEN, 605 FN_INSERT_HARDHYPHEN, FN_INSERT_HARD_SPACE, FN_INSERT_BREAK, 606 FN_INSERT_LINEBREAK, FN_INSERT_COLUMN_BREAK, FN_INSERT_BREAK_DLG, 607 FN_DELETE_SENT, FN_DELETE_BACK_SENT, FN_DELETE_WORD, 608 FN_DELETE_BACK_WORD, FN_DELETE_LINE, FN_DELETE_BACK_LINE, 609 FN_DELETE_PARA, FN_DELETE_BACK_PARA, FN_DELETE_WHOLE_LINE, 610 FN_CALCULATE, FN_FORMAT_RESET, 611 FN_POSTIT, FN_JAVAEDIT, SID_ATTR_PARA_ADJUST_LEFT, 612 SID_ATTR_PARA_ADJUST_RIGHT, SID_ATTR_PARA_ADJUST_CENTER,SID_ATTR_PARA_ADJUST_BLOCK, 613 SID_ATTR_PARA_LINESPACE_10, SID_ATTR_PARA_LINESPACE_15, SID_ATTR_PARA_LINESPACE_20, 614 SID_ATTR_CHAR_FONT, SID_ATTR_CHAR_FONTHEIGHT, SID_ATTR_CHAR_COLOR_BACKGROUND, 615 SID_ATTR_CHAR_COLOR_BACKGROUND_EXT, SID_ATTR_CHAR_COLOR_EXT, 616 SID_ATTR_CHAR_COLOR, SID_ATTR_CHAR_WEIGHT, SID_ATTR_CHAR_POSTURE, 617 SID_ATTR_CHAR_OVERLINE, 618 SID_ATTR_CHAR_UNDERLINE, SID_ATTR_FLASH, SID_ATTR_CHAR_STRIKEOUT, 619 FN_UNDERLINE_DOUBLE, SID_ATTR_CHAR_CONTOUR, SID_ATTR_CHAR_SHADOWED, 620 SID_ATTR_CHAR_AUTOKERN, SID_ATTR_CHAR_ESCAPEMENT, FN_SET_SUPER_SCRIPT, 621 FN_SET_SUB_SCRIPT, SID_ATTR_CHAR_CASEMAP, SID_ATTR_CHAR_LANGUAGE, 622 SID_ATTR_CHAR_KERNING, SID_CHAR_DLG, SID_ATTR_CHAR_WORDLINEMODE, 623 FN_GROW_FONT_SIZE, FN_SHRINK_FONT_SIZE, FN_TXTATR_INET, 624 FN_FORMAT_DROPCAPS, SID_ATTR_PARA_ADJUST, SID_ATTR_PARA_LINESPACE, 625 SID_ATTR_PARA_SPLIT, SID_ATTR_PARA_KEEP, SID_ATTR_PARA_WIDOWS, 626 SID_ATTR_PARA_ORPHANS, 627 SID_ATTR_PARA_MODEL, SID_PARA_DLG, 628 FN_SELECT_PARA, SID_DEC_INDENT, 629 SID_INC_INDENT 630 }; 631 static sal_Bool bFirst = sal_True; 632 if ( bFirst ) 633 { 634 qsort( (void*)aROIds, sizeof(aROIds)/sizeof(sal_uInt16), sizeof(sal_uInt16), lcl_CmpIds ); 635 bFirst = sal_False; 636 } 637 if ( SFX_ITEM_DISABLED == eStateRO ) 638 { 639 rDis.SetSlotFilter( sal_Bool(2), sizeof(aROIds)/sizeof(sal_uInt16), aROIds ); 640 bChgd = sal_True; 641 } 642 } 643 else if( pWrtShell->IsAllProtect() ) 644 { 645 if ( SFX_ITEM_DISABLED == eStateProtAll ) 646 { 647 static sal_uInt16 aAllProtIds[] = { SID_SAVEDOC, FN_EDIT_REGION }; 648 static sal_Bool bAllProtFirst = sal_True; 649 if ( bAllProtFirst ) 650 { 651 qsort( (void*)aAllProtIds, sizeof(aAllProtIds)/sizeof(sal_uInt16), sizeof(sal_uInt16), lcl_CmpIds ); 652 bAllProtFirst = sal_False; 653 } 654 rDis.SetSlotFilter( sal_Bool(2), 655 sizeof(aAllProtIds)/sizeof(sal_uInt16), 656 aAllProtIds ); 657 bChgd = sal_True; 658 } 659 } 660 else if ( SFX_ITEM_DISABLED != eStateRO || 661 SFX_ITEM_DISABLED != eStateProtAll ) 662 { 663 bChgd = sal_True; 664 rDis.SetSlotFilter(); 665 } 666 if ( bChgd ) 667 GetViewFrame()->GetBindings().InvalidateAll(sal_True); 668 } 669 670 void SwView::_CheckReadonlySelection() 671 { 672 sal_uInt32 nDisableFlags = 0; 673 SfxDispatcher &rDis = GetDispatcher(); 674 675 if( pWrtShell->HasReadonlySel() && 676 ( !pWrtShell->GetDrawView() || 677 !pWrtShell->GetDrawView()->GetMarkedObjectList().GetMarkCount() )) 678 nDisableFlags |= SW_DISABLE_ON_PROTECTED_CURSOR; 679 680 if( (SW_DISABLE_ON_PROTECTED_CURSOR & nDisableFlags ) != 681 (SW_DISABLE_ON_PROTECTED_CURSOR & rDis.GetDisableFlags() ) ) 682 { 683 // zusaetzlich am Window den InputContext umsetzen, damit in 684 // japanischen / chinesischen Versionen die externe Eingabe 685 // ab-/angeschaltet wird. Das aber nur wenn auch die richtige 686 // Shell auf dem Stack steht. 687 switch( pViewImpl->GetShellMode() ) 688 { 689 case SHELL_MODE_TEXT: 690 case SHELL_MODE_LIST_TEXT: 691 case SHELL_MODE_TABLE_TEXT: 692 case SHELL_MODE_TABLE_LIST_TEXT: 693 { 694 //JP 22.01.99: temporaere Loesung!!! Sollte bei jeder Cursorbewegung 695 // den Font von der akt. Einfuegeposition setzen, also ausserhalb 696 // dieses if's. Aber TH wertet den Font zur Zeit nicht aus und 697 // das besorgen erscheint mir hier zu teuer zu sein. 698 // Ausserdem haben wir keinen Font, sondern nur Attribute aus denen 699 // die Textformatierung dann den richtigen Font zusammen baut. 700 701 InputContext aCntxt( GetEditWin().GetInputContext() ); 702 aCntxt.SetOptions( SW_DISABLE_ON_PROTECTED_CURSOR & nDisableFlags 703 ? (aCntxt.GetOptions() & ~ 704 ( INPUTCONTEXT_TEXT | 705 INPUTCONTEXT_EXTTEXTINPUT )) 706 : (aCntxt.GetOptions() | 707 ( INPUTCONTEXT_TEXT | 708 INPUTCONTEXT_EXTTEXTINPUT )) ); 709 GetEditWin().SetInputContext( aCntxt ); 710 } 711 break; 712 default: 713 ; 714 } 715 716 } 717 718 if( nDisableFlags != rDis.GetDisableFlags() ) 719 { 720 rDis.SetDisableFlags( nDisableFlags ); 721 GetViewFrame()->GetBindings().InvalidateAll( sal_True ); 722 } 723 } 724 725 726 SwView::SwView( SfxViewFrame *_pFrame, SfxViewShell* pOldSh ) 727 : SfxViewShell( _pFrame, SWVIEWFLAGS ), 728 aPageStr( SW_RES( STR_PAGE )), 729 nNewPage(USHRT_MAX), 730 nOldPageNum(0), 731 pNumRuleNodeFromDoc(0), // #i23726# 732 pEditWin( new SwEditWin( &_pFrame->GetWindow(), *this ) ), 733 pWrtShell(0), 734 pShell(0), 735 pFormShell(0), 736 pHScrollbar(0), 737 pVScrollbar(0), 738 pScrollFill(new ScrollBarBox( &_pFrame->GetWindow(), _pFrame->GetFrame().GetParentFrame() ? 0 : WB_SIZEABLE )), 739 pHRuler( new SvxRuler(&GetViewFrame()->GetWindow(), pEditWin, 740 SVXRULER_SUPPORT_TABS | 741 SVXRULER_SUPPORT_PARAGRAPH_MARGINS | 742 SVXRULER_SUPPORT_BORDERS | 743 SVXRULER_SUPPORT_NEGATIVE_MARGINS| 744 SVXRULER_SUPPORT_REDUCED_METRIC, 745 GetViewFrame()->GetBindings(), 746 WB_STDRULER | WB_EXTRAFIELD | WB_BORDER)), 747 pVRuler(new SvxRuler(&GetViewFrame()->GetWindow(), pEditWin, 748 SVXRULER_SUPPORT_TABS | SVXRULER_SUPPORT_PARAGRAPH_MARGINS_VERTICAL| 749 SVXRULER_SUPPORT_BORDERS | SVXRULER_SUPPORT_REDUCED_METRIC, 750 GetViewFrame()->GetBindings(), 751 WB_VSCROLL | WB_EXTRAFIELD | WB_BORDER )), 752 pTogglePageBtn(0), 753 pPageUpBtn(0), 754 pPageDownBtn(0), 755 pNaviBtn(0), 756 pGlosHdl(0), 757 pDrawActual(0), 758 pLastTableFormat(0), 759 pFormatClipboard(new SwFormatClipboard()), 760 mpPostItMgr(0), 761 nSelectionType( INT_MAX ), 762 nPageCnt(0), 763 nDrawSfxId( USHRT_MAX ), 764 nFormSfxId( USHRT_MAX ), 765 nLastPasteDestination( 0xFFFF ), 766 nLeftBorderDistance( 0 ), 767 nRightBorderDistance( 0 ), 768 bInMailMerge(sal_False), 769 bInDtor(sal_False), 770 bOldShellWasPagePreView(sal_False), 771 bIsPreviewDoubleClick(sal_False) 772 { 773 // OD 18.12.2002 #103492# - According to discussion with MBA and further 774 // investigations, no old SfxViewShell will be set as parameter <pOldSh>, 775 // if function "New Window" is performed to open an additional view beside 776 // an already existing one. 777 // If the view is switch from one to another, the 'old' view is given by 778 // parameter <pOldSh>. 779 780 RTL_LOGFILE_CONTEXT_AUTHOR( aLog, "SW", "JP93722", "SwView::SwView" ); 781 782 bCenterCrsr = bTopCrsr = bAllwaysShowSel = bTabColFromDoc = bTabRowFromDoc = 783 bSetTabColFromDoc = bSetTabRowFromDoc = bAttrChgNotified = bAttrChgNotifiedWithRegistrations = 784 bVerbsActive = bDrawRotate = bInOuterResizePixel = bInInnerResizePixel = 785 bPasteState = bPasteSpecialState = bMakeSelectionVisible = sal_False; 786 787 bShowAtResize = bDrawSelMode = bDocSzUpdated = sal_True; 788 789 _CreateScrollbar( sal_True ); 790 _CreateScrollbar( sal_False ); 791 792 pViewImpl = new SwView_Impl(this); 793 SetName(C2S("View")); 794 SetWindow( pEditWin ); 795 796 aTimer.SetTimeout( 120 ); 797 798 SwDocShell* pDocSh = PTR_CAST( SwDocShell, _pFrame->GetObjectShell() ); 799 sal_Bool bOldModifyFlag = pDocSh->IsEnableSetModified(); 800 if(bOldModifyFlag) 801 pDocSh->EnableSetModified( sal_False ); 802 ASSERT( pDocSh, "View ohne DocShell." ); 803 SwWebDocShell* pWebDShell = PTR_CAST( SwWebDocShell, pDocSh ); 804 805 const SwMasterUsrPref *pUsrPref = SW_MOD()->GetUsrPref(0 != pWebDShell); 806 SwViewOption aUsrPref( *pUsrPref); 807 808 //! get lingu options without loading lingu DLL 809 SvtLinguOptions aLinguOpt; 810 SvtLinguConfig().GetOptions( aLinguOpt ); 811 aUsrPref.SetOnlineSpell( aLinguOpt.bIsSpellAuto ); 812 813 sal_Bool bOldShellWasSrcView = sal_False; 814 815 // OD 18.12.2002 #103492# - determine, if there is an existing view for 816 // document 817 SfxViewShell* pExistingSh = 0; 818 if ( pOldSh ) 819 { 820 pExistingSh = pOldSh; 821 // determine type of existing view 822 if( pExistingSh->IsA( TYPE( SwPagePreView ) ) ) 823 { 824 sSwViewData = ((SwPagePreView*)pExistingSh)->GetPrevSwViewData(); 825 sNewCrsrPos = ((SwPagePreView*)pExistingSh)->GetNewCrsrPos(); 826 nNewPage = ((SwPagePreView*)pExistingSh)->GetNewPage(); 827 bOldShellWasPagePreView = sal_True; 828 bIsPreviewDoubleClick = sNewCrsrPos.Len() > 0 || nNewPage != USHRT_MAX; 829 } 830 else if( pExistingSh->IsA( TYPE( SwSrcView ) ) ) 831 bOldShellWasSrcView = sal_True; 832 } 833 834 RTL_LOGFILE_CONTEXT_TRACE( aLog, "before create WrtShell" ); 835 if(PTR_CAST( SwView, pExistingSh)) 836 { 837 pWrtShell = new SwWrtShell( *((SwView*)pExistingSh)->pWrtShell, 838 pEditWin, *this); 839 } 840 else if( dynamic_cast<SwWrtShell*>( pDocSh->GetDoc()->GetCurrentViewShell() ) ) 841 { 842 pWrtShell = new SwWrtShell( *(SwWrtShell*)pDocSh->GetDoc()->GetCurrentViewShell(), 843 pEditWin, *this); 844 } 845 else 846 { 847 SwDoc& rDoc = *((SwDocShell*)pDocSh)->GetDoc(); 848 849 if( !bOldShellWasSrcView && pWebDShell && !bOldShellWasPagePreView ) 850 aUsrPref.setBrowseMode( sal_True ); 851 else if( rDoc.IsLoaded() ) 852 aUsrPref.setBrowseMode( rDoc.get(IDocumentSettingAccess::BROWSE_MODE) ); 853 854 //Fuer den BrowseMode wollen wir keinen Factor uebernehmen. 855 if( aUsrPref.getBrowseMode() && aUsrPref.GetZoomType() != SVX_ZOOM_PERCENT ) 856 { 857 aUsrPref.SetZoomType( SVX_ZOOM_PERCENT ); 858 aUsrPref.SetZoom( 100 ); 859 } 860 if(pDocSh->IsPreview()) 861 { 862 aUsrPref.SetZoomType( SVX_ZOOM_WHOLEPAGE ); 863 aUsrPref.SetViewLayoutBookMode( false ); 864 aUsrPref.SetViewLayoutColumns( 1 ); 865 } 866 pWrtShell = new SwWrtShell( rDoc, pEditWin, *this, &aUsrPref ); 867 //#97610# creating an SwView from a SwPagePreView needs to 868 // add the ViewShell to the ring of the other ViewShell(s) 869 if(bOldShellWasPagePreView) 870 { 871 ViewShell& rPreviewViewShell = *((SwPagePreView*)pExistingSh)->GetViewShell(); 872 pWrtShell->MoveTo(&rPreviewViewShell); 873 //#95521# to update the field command et.al. if necessary 874 const SwViewOption* pPreViewOpt = rPreviewViewShell.GetViewOptions(); 875 if( pPreViewOpt->IsFldName() != aUsrPref.IsFldName() || 876 pPreViewOpt->IsShowHiddenField() != aUsrPref.IsShowHiddenField() || 877 pPreViewOpt->IsShowHiddenPara() != aUsrPref.IsShowHiddenPara() || 878 pPreViewOpt->IsShowHiddenChar() != aUsrPref.IsShowHiddenChar() ) 879 rPreviewViewShell.ApplyViewOptions(aUsrPref); 880 // OD 09.01.2003 #106334# - reset design mode at draw view for form 881 // shell, if needed. 882 if ( ((SwPagePreView*)pExistingSh)->ResetFormDesignMode() && 883 pWrtShell->HasDrawView() ) 884 { 885 SdrView* pDrawView = pWrtShell->GetDrawView(); 886 pDrawView->SetDesignMode( ((SwPagePreView*)pExistingSh)->FormDesignModeToReset() ); 887 } 888 } 889 } 890 RTL_LOGFILE_CONTEXT_TRACE( aLog, "after create WrtShell" ); 891 892 // --> OD 2005-02-11 #i38810# - assure that modified state of document 893 // isn't reset, if document is already modified. 894 const bool bIsDocModified = pWrtShell->GetDoc()->IsModified(); 895 // <-- 896 897 // JP 05.02.99: Bug 61495 - damit unter anderem das HLineal im 898 // ReadonlyFall nicht angezeigt wird 899 aUsrPref.SetReadonly( pWrtShell->GetViewOptions()->IsReadonly() ); 900 901 //Kein Margin fuer OLE! 902 Size aBrwsBorder; 903 if( SFX_CREATE_MODE_EMBEDDED != pDocSh->GetCreateMode() ) 904 aBrwsBorder = GetMargin(); 905 906 pWrtShell->SetBrowseBorder( aBrwsBorder ); 907 908 // Im CTOR duerfen keine Shell wechsel erfolgen, die muessen ueber 909 // den Timer "zwischen gespeichert" werden. Sonst raeumt der SFX 910 // sie wieder vom Stack! 911 sal_Bool bOld = bNoInterrupt; 912 bNoInterrupt = sal_True; 913 914 pHRuler->SetActive( sal_True ); 915 pVRuler->SetActive( sal_True ); 916 917 SfxViewFrame* pViewFrame = GetViewFrame(); 918 if( pViewFrame->GetFrame().GetParentFrame()) 919 { 920 aUsrPref.SetViewHRuler(sal_False); 921 aUsrPref.SetViewVRuler(sal_False); 922 } 923 924 StartListening( *pViewFrame, sal_True ); 925 StartListening( *pDocSh, sal_True ); 926 927 // Vom HLineal den ZOOM-Faktor einstellen 928 Fraction aZoomFract( aUsrPref.GetZoom(), 100 ); 929 pHRuler->SetZoom( aZoomFract ); 930 pVRuler->SetZoom( aZoomFract ); 931 pHRuler->SetDoubleClickHdl(LINK( this, SwView, ExecRulerClick )); 932 FieldUnit eMetric = pUsrPref->GetHScrollMetric(); 933 pHRuler->SetUnit( eMetric ); 934 eMetric = pUsrPref->GetVScrollMetric(); 935 pVRuler->SetUnit( eMetric ); 936 937 // DocShell setzen 938 pDocSh->SetView( this ); 939 SW_MOD()->SetView( this ); 940 941 mpPostItMgr = new SwPostItMgr(this); 942 943 // Die DocSize erfragen und verarbeiten. Ueber die Handler konnte 944 // die Shell nicht gefunden werden, weil die Shell innerhalb CTOR-Phase 945 // nicht in der SFX-Verwaltung bekannt ist. 946 DocSzChgd( pWrtShell->GetDocSize() ); 947 948 // AttrChangedNotify Link setzen 949 pWrtShell->SetChgLnk(LINK(this, SwView, AttrChangedNotify)); 950 951 if( pDocSh->GetCreateMode() == SFX_CREATE_MODE_EMBEDDED && 952 //TODO/LATER: why a cast here? 953 //!((SvEmbeddedObject *)pDocSh)->GetVisArea().IsEmpty() ) 954 //SetVisArea( ((SvEmbeddedObject *)pDocSh)->GetVisArea(),sal_False); 955 !pDocSh->GetVisArea(ASPECT_CONTENT).IsEmpty() ) 956 SetVisArea( pDocSh->GetVisArea(ASPECT_CONTENT),sal_False); 957 958 pWrtShell->DoUndo( 0 != SW_MOD()->GetUndoOptions().GetUndoCount() ); 959 960 const sal_Bool bBrowse = pWrtShell->GetViewOptions()->getBrowseMode(); 961 // Disable "multiple window" 962 SetNewWindowAllowed(!bBrowse); 963 // End of disabled multiple window 964 965 ShowVScrollbar(aUsrPref.IsViewVScrollBar()); 966 ShowHScrollbar(aUsrPref.IsViewHScrollBar()); 967 pHScrollbar->SetAuto(bBrowse); 968 if( aUsrPref.IsViewHRuler() ) 969 CreateTab(); 970 if( aUsrPref.IsViewVRuler() ) 971 CreateVLineal(); 972 973 pWrtShell->SetUIOptions( aUsrPref ); 974 pWrtShell->SetReadOnlyAvailable( aUsrPref.IsCursorInProtectedArea() ); 975 pWrtShell->ApplyAccessiblityOptions(SW_MOD()->GetAccessibilityOptions()); 976 977 if( pWrtShell->GetDoc()->IsUpdateExpFld() ) 978 { 979 SET_CURR_SHELL( pWrtShell ); 980 pWrtShell->StartAction(); 981 pWrtShell->CalcLayout(); 982 pWrtShell->GetDoc()->UpdateFlds(NULL, false); 983 pWrtShell->EndAction(); 984 pWrtShell->GetDoc()->SetUpdateExpFldStat( sal_False ); 985 } 986 987 // ggfs. alle Verzeichnisse updaten: 988 if( pWrtShell->GetDoc()->IsUpdateTOX() ) 989 { 990 SfxRequest aSfxRequest( FN_UPDATE_TOX, SFX_CALLMODE_SLOT, GetPool() ); 991 Execute( aSfxRequest ); 992 pWrtShell->GetDoc()->SetUpdateTOX( sal_False ); // wieder zurueck setzen 993 pWrtShell->SttEndDoc(sal_True); 994 } 995 996 // kein ResetModified, wenn es schone eine View auf dieses Doc gibt 997 SfxViewFrame* pVFrame = GetViewFrame(); 998 SfxViewFrame* pFirst = SfxViewFrame::GetFirst(pDocSh); 999 // zur Zeit(360) wird die View erst nach dem Ctor eingetragen 1000 // der folgende Ausdruck funktioniert auch, wenn sich das aendert 1001 //JP 27.07.98: wenn per Undo nicht mehr die Modifizierung aufhebar ist, 1002 // so setze das Modified NICHT zurueck. 1003 // --> OD 2005-02-11 #i38810# - no reset of modified state, if document 1004 // was already modified. 1005 if (!pWrtShell->GetDoc()->GetIDocumentUndoRedo().IsUndoNoResetModified() && 1006 ( !pFirst || pFirst == pVFrame ) && 1007 !bIsDocModified ) 1008 // <-- 1009 { 1010 pWrtShell->ResetModified(); 1011 } 1012 1013 bNoInterrupt = bOld; 1014 1015 // wird ein GlobalDoc neu angelegt, soll auch der Navigator erzeugt werden 1016 if( pDocSh->IsA(SwGlobalDocShell::StaticType()) && 1017 !pVFrame->GetChildWindow( SID_NAVIGATOR )) 1018 { 1019 SfxBoolItem aNavi(SID_NAVIGATOR, sal_True); 1020 GetDispatcher().Execute(SID_NAVIGATOR, SFX_CALLMODE_ASYNCHRON, &aNavi, 0L); 1021 } 1022 1023 1024 uno::Reference< frame::XFrame > xFrame = pVFrame->GetFrame().GetFrameInterface(); 1025 1026 uno::Reference< frame::XFrame > xBeamerFrame = xFrame->findFrame( 1027 OUString::createFromAscii("_beamer"), frame::FrameSearchFlag::CHILDREN); 1028 if(xBeamerFrame.is()) 1029 { 1030 SwDBData aData = pWrtShell->GetDBData(); 1031 SW_MOD()->ShowDBObj( *this, aData ); 1032 } 1033 1034 // has anybody calls the attrchanged handler in the constructor? 1035 if( bAttrChgNotifiedWithRegistrations ) 1036 { 1037 GetViewFrame()->GetBindings().LEAVEREGISTRATIONS(); 1038 if( aTimer.IsActive() ) 1039 aTimer.Stop(); 1040 } 1041 1042 aTimer.SetTimeoutHdl(LINK(this, SwView, TimeoutHdl)); 1043 bAttrChgNotified = bAttrChgNotifiedWithRegistrations = sal_False; 1044 if(bOldModifyFlag) 1045 pDocSh->EnableSetModified( sal_True ); 1046 InvalidateBorder(); 1047 } 1048 1049 SwView::~SwView() 1050 { 1051 delete mpPostItMgr; 1052 // --> OD 2009-03-10 #i100035# 1053 mpPostItMgr = 0; 1054 // <-- 1055 1056 bInDtor = sal_True; 1057 pEditWin->Hide(); // damit kein Paint Aerger machen kann! 1058 // An der SwDocShell den Pointer auf die View ruecksetzen 1059 SwDocShell* pDocSh = GetDocShell(); 1060 if( pDocSh && pDocSh->GetView() == this ) 1061 pDocSh->SetView( 0 ); 1062 if ( SW_MOD()->GetView() == this ) 1063 SW_MOD()->SetView( 0 ); 1064 1065 if( aTimer.IsActive() && bAttrChgNotifiedWithRegistrations ) 1066 GetViewFrame()->GetBindings().LEAVEREGISTRATIONS(); 1067 1068 //JP 27.11.00: Bug 80631 - the last view must end the text edit 1069 SdrView *pSdrView = pWrtShell ? pWrtShell->GetDrawView() : 0; 1070 if( pSdrView && pSdrView->IsTextEdit() ) 1071 pSdrView->SdrEndTextEdit( sal_True ); 1072 1073 SetWindow( 0 ); 1074 1075 pViewImpl->Invalidate(); 1076 EndListening(*GetViewFrame()); 1077 EndListening(*GetDocShell()); 1078 delete pScrollFill; 1079 delete pWrtShell; 1080 pWrtShell = 0; // Auf 0 setzen, damit folgende DToren nicht drauf zugreifen 1081 pShell = 0; 1082 delete pHScrollbar; 1083 delete pVScrollbar; 1084 delete pHRuler; 1085 delete pVRuler; 1086 delete pTogglePageBtn; 1087 delete pPageUpBtn; 1088 delete pNaviBtn; 1089 delete pPageDownBtn; 1090 delete pGlosHdl; 1091 delete pViewImpl; 1092 delete pEditWin; 1093 delete pFormatClipboard; 1094 } 1095 1096 SwDocShell* SwView::GetDocShell() 1097 { 1098 SfxObjectShell* pDocShell = GetViewFrame()->GetObjectShell(); 1099 return PTR_CAST(SwDocShell, pDocShell); 1100 } 1101 1102 /*-------------------------------------------------------------------- 1103 Beschreibung: CursorPos merken 1104 --------------------------------------------------------------------*/ 1105 1106 1107 void SwView::WriteUserData( String &rUserData, sal_Bool bBrowse ) 1108 { 1109 //Das Browse-Flag wird vom Sfx durchgereicht, wenn Dokumente gebrowsed 1110 //werden (nicht zu verwechseln mit dem BrowseMode). 1111 //Die dann gespeicherten Daten sind nicht persistent!! 1112 1113 const SwRect& rRect = pWrtShell->GetCharRect(); 1114 const Rectangle& rVis = GetVisArea(); 1115 1116 rUserData = String::CreateFromInt32( rRect.Left() ); 1117 rUserData += ';'; 1118 rUserData += String::CreateFromInt32( rRect.Top() ); 1119 rUserData += ';'; 1120 rUserData += String::CreateFromInt32( pWrtShell->GetViewOptions()->GetZoom() ); 1121 rUserData += ';'; 1122 rUserData += String::CreateFromInt32( rVis.Left() ); 1123 rUserData += ';'; 1124 rUserData += String::CreateFromInt32( rVis.Top() ); 1125 rUserData += ';'; 1126 rUserData += String::CreateFromInt32( bBrowse ? LONG_MIN : rVis.Right()); 1127 rUserData += ';'; 1128 rUserData += String::CreateFromInt32( bBrowse ? LONG_MIN : rVis.Bottom()); 1129 rUserData += ';'; 1130 rUserData += String::CreateFromInt32( 1131 (sal_uInt16)pWrtShell->GetViewOptions()->GetZoomType());//eZoom; 1132 rUserData += ';'; 1133 rUserData += FRMTYPE_NONE == pWrtShell->GetSelFrmType() ? '0' : '1'; 1134 } 1135 /*-------------------------------------------------------------------- 1136 Beschreibung: CursorPos setzen 1137 --------------------------------------------------------------------*/ 1138 //#i43146# go to the last editing position when opening own files 1139 bool lcl_IsOwnDocument( SwView& rView ) 1140 { 1141 uno::Reference<document::XDocumentPropertiesSupplier> xDPS( 1142 rView.GetDocShell()->GetModel(), uno::UNO_QUERY_THROW); 1143 uno::Reference<document::XDocumentProperties> xDocProps 1144 = xDPS->getDocumentProperties(); 1145 String Created = xDocProps->getAuthor(); 1146 String Changed = xDocProps->getModifiedBy(); 1147 String FullName = SW_MOD()->GetUserOptions().GetFullName(); 1148 return (FullName.Len() && 1149 (Changed.Len() && Changed == FullName )) || 1150 (!Changed.Len() && Created.Len() && Created == FullName ); 1151 } 1152 1153 1154 void SwView::ReadUserData( const String &rUserData, sal_Bool bBrowse ) 1155 { 1156 if ( rUserData.GetTokenCount() > 1 && 1157 //Fuer Dokumente ohne Layout nur im OnlineLayout oder beim 1158 //Forward/Backward 1159 (!pWrtShell->IsNewLayout() || pWrtShell->GetViewOptions()->getBrowseMode() || bBrowse) ) 1160 { 1161 //#i43146# go to the last editing position when opening own files 1162 bool bIsOwnDocument = lcl_IsOwnDocument( *this ); 1163 1164 SET_CURR_SHELL(pWrtShell); 1165 1166 sal_uInt16 nPos = 0; 1167 1168 // Nein, es ist *keine* gute Idee GetToken gleich im Point-Konstr. 1169 // aufzurufen, denn welcher Parameter wird zuerst ausgewertet? 1170 long nX = rUserData.GetToken( 0, ';', nPos ).ToInt32(), 1171 nY = rUserData.GetToken( 0, ';', nPos ).ToInt32(); 1172 Point aCrsrPos( nX, nY ); 1173 1174 sal_uInt16 nZoomFactor = 1175 static_cast< sal_uInt16 >( rUserData.GetToken(0, ';', nPos ).ToInt32() ); 1176 1177 long nLeft = rUserData.GetToken(0, ';', nPos ).ToInt32(), 1178 nTop = rUserData.GetToken(0, ';', nPos ).ToInt32(), 1179 nRight = rUserData.GetToken(0, ';', nPos ).ToInt32(), 1180 nBottom= rUserData.GetToken(0, ';', nPos ).ToInt32(); 1181 1182 const long nAdd = pWrtShell->GetViewOptions()->getBrowseMode() ? DOCUMENTBORDER : DOCUMENTBORDER*2; 1183 if ( nBottom <= (pWrtShell->GetDocSize().Height()+nAdd) ) 1184 { 1185 pWrtShell->EnableSmooth( sal_False ); 1186 1187 const Rectangle aVis( nLeft, nTop, nRight, nBottom ); 1188 1189 sal_uInt16 nOff = 0; 1190 SvxZoomType eZoom; 1191 if( !pWrtShell->GetViewOptions()->getBrowseMode() ) 1192 eZoom = (SvxZoomType) (sal_uInt16)rUserData.GetToken(nOff, ';', nPos ).ToInt32(); 1193 else 1194 { 1195 eZoom = SVX_ZOOM_PERCENT; 1196 ++nOff; 1197 } 1198 1199 sal_Bool bSelectObj = (0 != rUserData.GetToken( nOff, ';', nPos ).ToInt32()) 1200 && pWrtShell->IsObjSelectable( aCrsrPos ); 1201 1202 //#i33307# restore editing position 1203 pViewImpl->SetRestorePosition(aCrsrPos, bSelectObj); 1204 // OD 11.02.2003 #100556# - set flag value to avoid macro execution. 1205 bool bSavedFlagValue = pWrtShell->IsMacroExecAllowed(); 1206 pWrtShell->SetMacroExecAllowed( false ); 1207 //!!! pb (11.08.2004): #i32536# 1208 // os: changed: The user data has to be read if the view is switched back from page preview 1209 //#i43146# go to the last editing position when opening own files 1210 if(bOldShellWasPagePreView || bIsOwnDocument) 1211 { 1212 pWrtShell->SwCrsrShell::SetCrsr( aCrsrPos, !bSelectObj ); 1213 if( bSelectObj ) 1214 { 1215 pWrtShell->SelectObj( aCrsrPos ); 1216 pWrtShell->EnterSelFrmMode( &aCrsrPos ); 1217 } 1218 } 1219 1220 // OD 11.02.2003 #100556# - reset flag value 1221 pWrtShell->SetMacroExecAllowed( bSavedFlagValue ); 1222 1223 // OD 08.04.2003 #108693# - set visible area before applying 1224 // information from print preview. Otherwise, the applied information 1225 // is lost. 1226 //!!! pb (11.08.2004): #i32536# 1227 // os: changed: The user data has to be read if the view is switched back from page preview 1228 //#i43146# go to the last editing position when opening own files 1229 if(bOldShellWasPagePreView || bIsOwnDocument ) 1230 { 1231 if ( bBrowse ) 1232 SetVisArea( aVis.TopLeft() ); 1233 else 1234 SetVisArea( aVis ); 1235 } 1236 1237 //apply information from print preview - if available 1238 if( sNewCrsrPos.Len() ) 1239 { 1240 long nXTmp = sNewCrsrPos.GetToken( 0, ';' ).ToInt32(), 1241 nYTmp = sNewCrsrPos.GetToken( 1, ';' ).ToInt32(); 1242 Point aCrsrPos2( nXTmp, nYTmp ); 1243 bSelectObj = pWrtShell->IsObjSelectable( aCrsrPos2 ); 1244 1245 pWrtShell->SwCrsrShell::SetCrsr( aCrsrPos2, sal_False ); 1246 if( bSelectObj ) 1247 { 1248 pWrtShell->SelectObj( aCrsrPos2 ); 1249 pWrtShell->EnterSelFrmMode( &aCrsrPos2 ); 1250 } 1251 pWrtShell->MakeSelVisible(); 1252 sNewCrsrPos.Erase(); 1253 } 1254 else if(USHRT_MAX != nNewPage) 1255 { 1256 pWrtShell->GotoPage(nNewPage, sal_True); 1257 nNewPage = USHRT_MAX; 1258 } 1259 1260 SelectShell(); 1261 1262 pWrtShell->StartAction(); 1263 const SwViewOption* pVOpt = pWrtShell->GetViewOptions(); 1264 if( pVOpt->GetZoom() != nZoomFactor || pVOpt->GetZoomType() != eZoom ) 1265 SetZoom( eZoom, nZoomFactor); 1266 1267 pWrtShell->LockView( sal_True ); 1268 pWrtShell->EndAction(); 1269 pWrtShell->LockView( sal_False ); 1270 pWrtShell->EnableSmooth( sal_True ); 1271 } 1272 } 1273 } 1274 1275 void SwView::ReadUserDataSequence ( const uno::Sequence < beans::PropertyValue >& rSequence, sal_Bool bBrowse ) 1276 { 1277 if(GetDocShell()->IsPreview()||bIsPreviewDoubleClick) 1278 return; 1279 //#i43146# go to the last editing position when opening own files 1280 bool bIsOwnDocument = lcl_IsOwnDocument( *this ); 1281 sal_Int32 nLength = rSequence.getLength(); 1282 if (nLength && (!pWrtShell->IsNewLayout() || pWrtShell->GetViewOptions()->getBrowseMode() || bBrowse) ) 1283 { 1284 SET_CURR_SHELL(pWrtShell); 1285 const beans::PropertyValue *pValue = rSequence.getConstArray(); 1286 const SwRect& rRect = pWrtShell->GetCharRect(); 1287 const Rectangle &rVis = GetVisArea(); 1288 const SwViewOption* pVOpt = pWrtShell->GetViewOptions(); 1289 1290 long nX = rRect.Left(), nY = rRect.Top(), nLeft = rVis.Left(), nTop = rVis.Top(); 1291 long nRight = bBrowse ? LONG_MIN : rVis.Right(), nBottom = bBrowse ? LONG_MIN : rVis.Bottom(); 1292 sal_Int16 nZoomType = static_cast< sal_Int16 >(pVOpt->GetZoomType()); 1293 sal_Int16 nZoomFactor = static_cast < sal_Int16 > (pVOpt->GetZoom()); 1294 bool bViewLayoutBookMode = pVOpt->IsViewLayoutBookMode(); 1295 sal_Int16 nViewLayoutColumns = pVOpt->GetViewLayoutColumns(); 1296 1297 sal_Bool bSelectedFrame = ( pWrtShell->GetSelFrmType() != FRMTYPE_NONE ), 1298 bGotViewLeft = sal_False, bGotViewTop = sal_False, bGotVisibleLeft = sal_False, 1299 bGotVisibleTop = sal_False, bGotVisibleRight = sal_False, 1300 bGotVisibleBottom = sal_False, bGotZoomType = sal_False, 1301 bGotZoomFactor = sal_False, bGotIsSelectedFrame = sal_False, 1302 bGotViewLayoutColumns = sal_False, bGotViewLayoutBookMode = sal_False; 1303 1304 for (sal_Int16 i = 0 ; i < nLength; i++) 1305 { 1306 if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "ViewLeft" ) ) ) 1307 { 1308 pValue->Value >>= nX; 1309 nX = MM100_TO_TWIP( nX ); 1310 bGotViewLeft = sal_True; 1311 } 1312 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "ViewTop" ) ) ) 1313 { 1314 pValue->Value >>= nY; 1315 nY = MM100_TO_TWIP( nY ); 1316 bGotViewTop = sal_True; 1317 } 1318 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "VisibleLeft" ) ) ) 1319 { 1320 pValue->Value >>= nLeft; 1321 nLeft = MM100_TO_TWIP( nLeft ); 1322 bGotVisibleLeft = sal_True; 1323 } 1324 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "VisibleTop" ) ) ) 1325 { 1326 pValue->Value >>= nTop; 1327 nTop = MM100_TO_TWIP( nTop ); 1328 bGotVisibleTop = sal_True; 1329 } 1330 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "VisibleRight" ) ) ) 1331 { 1332 pValue->Value >>= nRight; 1333 nRight = MM100_TO_TWIP( nRight ); 1334 bGotVisibleRight = sal_True; 1335 } 1336 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "VisibleBottom" ) ) ) 1337 { 1338 pValue->Value >>= nBottom; 1339 nBottom = MM100_TO_TWIP( nBottom ); 1340 bGotVisibleBottom = sal_True; 1341 } 1342 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "ZoomType" ) ) ) 1343 { 1344 pValue->Value >>= nZoomType; 1345 bGotZoomType = sal_True; 1346 } 1347 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "ZoomFactor" ) ) ) 1348 { 1349 pValue->Value >>= nZoomFactor; 1350 bGotZoomFactor = sal_True; 1351 } 1352 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "ViewLayoutColumns" ) ) ) 1353 { 1354 pValue->Value >>= nViewLayoutColumns; 1355 bGotViewLayoutColumns = sal_True; 1356 } 1357 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "ViewLayoutBookMode" ) ) ) 1358 { 1359 bViewLayoutBookMode = * (sal_Bool *) pValue->Value.getValue(); 1360 bGotViewLayoutBookMode = sal_True; 1361 } 1362 else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "IsSelectedFrame" ) ) ) 1363 { 1364 pValue->Value >>= bSelectedFrame; 1365 bGotIsSelectedFrame = sal_True; 1366 } 1367 pValue++; 1368 } 1369 if (bGotVisibleBottom) 1370 { 1371 Point aCrsrPos( nX, nY ); 1372 const long nAdd = pWrtShell->GetViewOptions()->getBrowseMode() ? DOCUMENTBORDER : DOCUMENTBORDER*2; 1373 if (nBottom <= (pWrtShell->GetDocSize().Height()+nAdd) ) 1374 { 1375 pWrtShell->EnableSmooth( sal_False ); 1376 const Rectangle aVis( nLeft, nTop, nRight, nBottom ); 1377 1378 sal_uInt16 nOff = 0; 1379 SvxZoomType eZoom; 1380 if ( !pWrtShell->GetViewOptions()->getBrowseMode() ) 1381 eZoom = static_cast < SvxZoomType > ( nZoomType ); 1382 else 1383 { 1384 eZoom = SVX_ZOOM_PERCENT; 1385 ++nOff; 1386 } 1387 if (bGotIsSelectedFrame) 1388 { 1389 sal_Bool bSelectObj = (sal_False != bSelectedFrame ) 1390 && pWrtShell->IsObjSelectable( aCrsrPos ); 1391 1392 // OD 11.02.2003 #100556# - set flag value to avoid macro execution. 1393 bool bSavedFlagValue = pWrtShell->IsMacroExecAllowed(); 1394 pWrtShell->SetMacroExecAllowed( false ); 1395 //!!! pb (11.08.2004): #i32536# 1396 // os: changed: The user data has to be read if the view is switched back from page preview 1397 //#i43146# go to the last editing position when opening own files 1398 //#i33307# restore editing position 1399 pViewImpl->SetRestorePosition(aCrsrPos, bSelectObj); 1400 if(bOldShellWasPagePreView|| bIsOwnDocument) 1401 { 1402 pWrtShell->SwCrsrShell::SetCrsr( aCrsrPos, !bSelectObj ); 1403 if( bSelectObj ) 1404 { 1405 pWrtShell->SelectObj( aCrsrPos ); 1406 pWrtShell->EnterSelFrmMode( &aCrsrPos ); 1407 } 1408 } 1409 1410 // OD 11.02.2003 #100556# - reset flag value 1411 pWrtShell->SetMacroExecAllowed( bSavedFlagValue ); 1412 } 1413 SelectShell(); 1414 1415 // Set ViewLayoutSettings 1416 const bool bSetViewLayoutSettings = bGotViewLayoutColumns && bGotViewLayoutBookMode && 1417 ( pVOpt->GetViewLayoutColumns() != nViewLayoutColumns || pVOpt->IsViewLayoutBookMode() != bViewLayoutBookMode ); 1418 1419 const bool bSetViewSettings = bGotZoomType && bGotZoomFactor && 1420 ( pVOpt->GetZoom() != nZoomFactor || pVOpt->GetZoomType() != eZoom ); 1421 1422 // In case we have a 'fixed' view layout of 2 or more columns, 1423 // we have to apply the view options *before* starting the action. 1424 // Otherwsie the SetZoom function cannot work correctly, because 1425 // the view layout hasn't been calculated. 1426 const bool bZoomNeedsViewLayout = bSetViewLayoutSettings && 1427 1 < nViewLayoutColumns && 1428 bSetViewSettings && 1429 eZoom != SVX_ZOOM_PERCENT; 1430 1431 1432 if ( !bZoomNeedsViewLayout ) 1433 pWrtShell->StartAction(); 1434 1435 if ( bSetViewLayoutSettings ) 1436 SetViewLayout( nViewLayoutColumns, bViewLayoutBookMode, sal_True ); 1437 1438 if ( bZoomNeedsViewLayout ) 1439 pWrtShell->StartAction(); 1440 1441 if ( bSetViewSettings ) 1442 SetZoom( eZoom, nZoomFactor, sal_True ); 1443 1444 //!!! pb (11.08.2004): #i32536# 1445 // os: changed: The user data has to be read if the view is switched back from page preview 1446 //#i43146# go to the last editing position when opening own files 1447 if(bOldShellWasPagePreView||bIsOwnDocument) 1448 { 1449 if ( bBrowse && bGotVisibleLeft && bGotVisibleTop ) 1450 { 1451 Point aTopLeft(aVis.TopLeft()); 1452 //#i76699# make sure the document is still centered 1453 const SwTwips lBorder = IsDocumentBorder() ? DOCUMENTBORDER : 2 * DOCUMENTBORDER; 1454 SwTwips nEditWidth = GetEditWin().GetOutputSize().Width(); 1455 if(nEditWidth > (aDocSz.Width() + lBorder )) 1456 aTopLeft.X() = ( aDocSz.Width() + lBorder - nEditWidth ) / 2; 1457 else 1458 { 1459 //check if the values are possible 1460 long nXMax = pHScrollbar->GetRangeMax() - pHScrollbar->GetVisibleSize(); 1461 if( aTopLeft.X() > nXMax ) 1462 aTopLeft.X() = nXMax < 0 ? 0 : nXMax; 1463 } 1464 SetVisArea( aTopLeft ); 1465 } 1466 else if (bGotVisibleLeft && bGotVisibleTop && bGotVisibleRight && bGotVisibleBottom ) 1467 SetVisArea( aVis ); 1468 } 1469 1470 pWrtShell->LockView( sal_True ); 1471 pWrtShell->EndAction(); 1472 pWrtShell->LockView( sal_False ); 1473 pWrtShell->EnableSmooth( sal_True ); 1474 } 1475 } 1476 } 1477 } 1478 #define NUM_VIEW_SETTINGS 12 1479 void SwView::WriteUserDataSequence ( uno::Sequence < beans::PropertyValue >& rSequence, sal_Bool bBrowse ) 1480 { 1481 const SwRect& rRect = pWrtShell->GetCharRect(); 1482 const Rectangle& rVis = GetVisArea(); 1483 Any aAny; 1484 1485 rSequence.realloc ( NUM_VIEW_SETTINGS ); 1486 sal_Int16 nIndex = 0; 1487 beans::PropertyValue *pValue = rSequence.getArray(); 1488 1489 sal_uInt16 nViewID( GetViewFrame()->GetCurViewId()); 1490 pValue->Name = rtl::OUString ( RTL_CONSTASCII_USTRINGPARAM( "ViewId" ) ); 1491 OUStringBuffer sBuffer ( OUString(RTL_CONSTASCII_USTRINGPARAM( "view" ) ) ); 1492 SvXMLUnitConverter::convertNumber(sBuffer, static_cast<sal_Int32>(nViewID)); 1493 pValue->Value <<= sBuffer.makeStringAndClear(); 1494 pValue++;nIndex++; 1495 1496 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "ViewLeft" ) ); 1497 pValue->Value <<= TWIP_TO_MM100 ( rRect.Left() ); 1498 pValue++;nIndex++; 1499 1500 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "ViewTop" ) ); 1501 pValue->Value <<= TWIP_TO_MM100 ( rRect.Top() ); 1502 pValue++;nIndex++; 1503 1504 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "VisibleLeft" ) ); 1505 pValue->Value <<= TWIP_TO_MM100 ( rVis.Left() ); 1506 pValue++;nIndex++; 1507 1508 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "VisibleTop" ) ); 1509 pValue->Value <<= TWIP_TO_MM100 ( rVis.Top() ); 1510 pValue++;nIndex++; 1511 1512 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "VisibleRight" ) ); 1513 pValue->Value <<= TWIP_TO_MM100 ( bBrowse ? LONG_MIN : rVis.Right() ); 1514 pValue++;nIndex++; 1515 1516 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "VisibleBottom" ) ); 1517 pValue->Value <<= TWIP_TO_MM100 ( bBrowse ? LONG_MIN : rVis.Bottom() ); 1518 pValue++;nIndex++; 1519 1520 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "ZoomType" ) ); 1521 const sal_Int16 nZoomType = static_cast< sal_Int16 >(pWrtShell->GetViewOptions()->GetZoomType()); 1522 pValue->Value <<= nZoomType; 1523 pValue++;nIndex++; 1524 1525 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "ViewLayoutColumns" ) ); 1526 const sal_Int16 nViewLayoutColumns = static_cast< sal_Int16 >(pWrtShell->GetViewOptions()->GetViewLayoutColumns()); 1527 pValue->Value <<= nViewLayoutColumns; 1528 pValue++;nIndex++; 1529 1530 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "ViewLayoutBookMode" ) ); 1531 const sal_Bool bIsViewLayoutBookMode = pWrtShell->GetViewOptions()->IsViewLayoutBookMode(); 1532 pValue->Value.setValue( &bIsViewLayoutBookMode, ::getBooleanCppuType() ); 1533 pValue++;nIndex++; 1534 1535 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "ZoomFactor" ) ); 1536 pValue->Value <<= static_cast < sal_Int16 > (pWrtShell->GetViewOptions()->GetZoom()); 1537 pValue++;nIndex++; 1538 1539 pValue->Name = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "IsSelectedFrame" ) ); 1540 const sal_Bool bIsSelected = FRMTYPE_NONE == pWrtShell->GetSelFrmType() ? sal_False : sal_True; 1541 pValue->Value.setValue ( &bIsSelected, ::getBooleanCppuType() ); 1542 nIndex++; 1543 1544 if ( nIndex < NUM_VIEW_SETTINGS ) 1545 rSequence.realloc ( nIndex ); 1546 } 1547 #undef NUM_VIEW_SETTINGS 1548 1549 1550 1551 void SwView::ShowCursor( FASTBOOL bOn ) 1552 { 1553 //JP 10.10.2001: Bug 90461 - don't scroll the cursor into the visible area 1554 sal_Bool bUnlockView = !pWrtShell->IsViewLocked(); 1555 pWrtShell->LockView( sal_True ); //lock visible section 1556 1557 if( !bOn ) 1558 pWrtShell->HideCrsr(); 1559 else if( !pWrtShell->IsFrmSelected() && !pWrtShell->IsObjSelected() ) 1560 pWrtShell->ShowCrsr(); 1561 1562 if( bUnlockView ) 1563 pWrtShell->LockView( sal_False ); 1564 } 1565 1566 1567 1568 ErrCode SwView::DoVerb( long nVerb ) 1569 { 1570 if ( !GetViewFrame()->GetFrame().IsInPlace() ) 1571 { 1572 SwWrtShell &rSh = GetWrtShell(); 1573 const int nSel = rSh.GetSelectionType(); 1574 if ( nSel & nsSelectionType::SEL_OLE ) 1575 rSh.LaunchOLEObj( nVerb ); 1576 } 1577 return ERRCODE_NONE; 1578 } 1579 1580 /*-----------------17.02.98 13:33------------------- 1581 nur sal_True fuer eine Textselektion zurueck geben 1582 --------------------------------------------------*/ 1583 sal_Bool SwView::HasSelection( sal_Bool bText ) const 1584 { 1585 return bText ? GetWrtShell().SwCrsrShell::HasSelection() 1586 : GetWrtShell().HasSelection(); 1587 } 1588 1589 /*-----------------09/16/97 09:50am----------------- 1590 1591 --------------------------------------------------*/ 1592 1593 String SwView::GetSelectionText( sal_Bool bCompleteWrds ) 1594 { 1595 return GetSelectionTextParam( bCompleteWrds, sal_True ); 1596 } 1597 1598 /*-----------------09/16/97 09:50am----------------- 1599 1600 --------------------------------------------------*/ 1601 String SwView::GetSelectionTextParam( sal_Bool bCompleteWrds, 1602 sal_Bool bEraseTrail ) 1603 { 1604 String sReturn; 1605 if( bCompleteWrds && !GetWrtShell().HasSelection() ) 1606 GetWrtShell().SelWrd(); 1607 1608 GetWrtShell().GetSelectedText( sReturn ); 1609 if( bEraseTrail ) 1610 sReturn.EraseTrailingChars(); 1611 return sReturn; 1612 } 1613 1614 /*-------------------------------------------------------------------- 1615 Beschreibung: 1616 --------------------------------------------------------------------*/ 1617 1618 1619 1620 SwGlossaryHdl* SwView::GetGlosHdl() 1621 { 1622 if(!pGlosHdl) 1623 pGlosHdl = new SwGlossaryHdl(GetViewFrame(), pWrtShell); 1624 return pGlosHdl; 1625 } 1626 1627 /*-----------------05.09.96 15.50------------------- 1628 1629 --------------------------------------------------*/ 1630 1631 1632 1633 void SwView::Notify( SfxBroadcaster& rBC, const SfxHint& rHint ) 1634 { 1635 sal_Bool bCallBase = sal_True; 1636 if ( rHint.ISA(SfxSimpleHint) ) 1637 { 1638 sal_uInt32 nId = ((SfxSimpleHint&)rHint).GetId(); 1639 switch ( nId ) 1640 { 1641 // --> OD 2005-03-03 #i43775# - sub shells will be destroyed by the 1642 // dispatcher, if the view frame is dying. Thus, reset member <pShell>. 1643 case SFX_HINT_DYING: 1644 { 1645 if ( &rBC == GetViewFrame() ) 1646 { 1647 ResetSubShell(); 1648 } 1649 } 1650 break; 1651 // <-- 1652 case SFX_HINT_MODECHANGED: 1653 { 1654 // Modalmodus-Umschaltung? 1655 sal_Bool bModal = GetDocShell()->IsInModalMode(); 1656 pHRuler->SetActive( !bModal ); 1657 pVRuler->SetActive( !bModal ); 1658 } 1659 1660 /* kein break hier */ 1661 1662 case SFX_HINT_TITLECHANGED: 1663 if ( GetDocShell()->IsReadOnly() != GetWrtShell().GetViewOptions()->IsReadonly() ) 1664 { 1665 SwWrtShell &rSh = GetWrtShell(); 1666 rSh.SetReadonlyOption( GetDocShell()->IsReadOnly() ); 1667 1668 if ( rSh.GetViewOptions()->IsViewVRuler() ) 1669 CreateVLineal(); 1670 else 1671 KillVLineal(); 1672 if ( rSh.GetViewOptions()->IsViewHRuler() ) 1673 CreateTab(); 1674 else 1675 KillTab(); 1676 bool bReadonly = GetDocShell()->IsReadOnly(); 1677 //#i76332# if document is to be opened in alive-mode then this has to be regarded while switching from readonly-mode to edit-mode 1678 if( !bReadonly ) 1679 { 1680 SwDrawModel* pDrawModel = 0; 1681 1682 if ( 0 != ( pDrawModel = GetDocShell()->GetDoc()->GetDrawModel() ) ) 1683 { 1684 if( !pDrawModel->GetOpenInDesignMode() ) 1685 break;// don't touch the design mode 1686 } 1687 } 1688 SfxBoolItem aItem( SID_FM_DESIGN_MODE, !bReadonly); 1689 GetDispatcher().Execute( SID_FM_DESIGN_MODE, SFX_CALLMODE_ASYNCHRON, 1690 &aItem, 0L ); 1691 } 1692 break; 1693 1694 case SW_BROADCAST_DRAWVIEWS_CREATED: 1695 { 1696 bCallBase = sal_False; 1697 if ( GetFormShell() ) 1698 { 1699 GetFormShell()->SetView( 1700 PTR_CAST(FmFormView, GetWrtShell().GetDrawView()) ); 1701 SfxBoolItem aItem( SID_FM_DESIGN_MODE, !GetDocShell()->IsReadOnly()); 1702 GetDispatcher().Execute( SID_FM_DESIGN_MODE, SFX_CALLMODE_SYNCHRON, 1703 &aItem, 0L ); 1704 } 1705 } 1706 break; 1707 } 1708 } 1709 else if(rHint.ISA(FmDesignModeChangedHint)) 1710 { 1711 sal_Bool bDesignMode = ((FmDesignModeChangedHint&)rHint).GetDesignMode(); 1712 if (!bDesignMode && GetDrawFuncPtr()) 1713 { 1714 GetDrawFuncPtr()->Deactivate(); 1715 SetDrawFuncPtr(NULL); 1716 LeaveDrawCreate(); 1717 AttrChangedNotify(pWrtShell); 1718 } 1719 } 1720 1721 if ( bCallBase ) 1722 SfxViewShell::Notify(rBC, rHint); 1723 } 1724 1725 /*-----------------02.12.96 12:36------------------- 1726 1727 --------------------------------------------------*/ 1728 #if defined WNT || defined UNX 1729 1730 void SwView::ScannerEventHdl( const EventObject& /*rEventObject*/ ) 1731 { 1732 uno::Reference< XScannerManager > xScanMgr = SW_MOD()->GetScannerManager(); 1733 if( xScanMgr.is() ) 1734 { 1735 const ScannerContext aContext( xScanMgr->getAvailableScanners().getConstArray()[ 0 ] ); 1736 const ScanError eError = xScanMgr->getError( aContext ); 1737 1738 if( ScanError_ScanErrorNone == eError ) 1739 { 1740 const uno::Reference< awt::XBitmap > xBitmap( xScanMgr->getBitmap( aContext ) ); 1741 1742 if( xBitmap.is() ) 1743 { 1744 const BitmapEx aScanBmp( VCLUnoHelper::GetBitmap( xBitmap ) ); 1745 1746 if( !!aScanBmp ) 1747 { 1748 Graphic aGrf(aScanBmp); 1749 pWrtShell->Insert( aEmptyStr, aEmptyStr, aGrf ); 1750 } 1751 } 1752 } 1753 } 1754 SfxBindings& rBind = GetViewFrame()->GetBindings(); 1755 rBind.Invalidate( SID_TWAIN_SELECT ); 1756 rBind.Invalidate( SID_TWAIN_TRANSFER ); 1757 } 1758 #endif 1759 1760 /*-----------------04.03.97 15:07------------------- 1761 1762 --------------------------------------------------*/ 1763 1764 1765 void SwView::StopShellTimer() 1766 { 1767 if(aTimer.IsActive()) 1768 { 1769 aTimer.Stop(); 1770 if ( bAttrChgNotifiedWithRegistrations ) 1771 { 1772 GetViewFrame()->GetBindings().LEAVEREGISTRATIONS(); 1773 bAttrChgNotifiedWithRegistrations = sal_False; 1774 } 1775 SelectShell(); 1776 bAttrChgNotified = sal_False; 1777 } 1778 } 1779 1780 /*-----------------09/03/97 04:12pm----------------- 1781 1782 --------------------------------------------------*/ 1783 sal_uInt16 SwView::PrepareClose( sal_Bool bUI, sal_Bool bForBrowsing ) 1784 { 1785 SfxViewFrame* pVFrame = GetViewFrame(); 1786 pVFrame->SetChildWindow( SwInputChild::GetChildWindowId(), sal_False ); 1787 if( pVFrame->GetDispatcher()->IsLocked() ) 1788 pVFrame->GetDispatcher()->Lock(sal_False); 1789 1790 sal_uInt16 nRet; 1791 if ( pFormShell && 1792 sal_True != (nRet = pFormShell->PrepareClose( bUI, bForBrowsing )) ) 1793 1794 { 1795 return nRet; 1796 } 1797 return SfxViewShell::PrepareClose( bUI, bForBrowsing ); 1798 } 1799 1800 1801 1802 // status methods for clipboard. 1803 // Status changes now notified from the clipboard. 1804 sal_Bool SwView::IsPasteAllowed() 1805 { 1806 sal_uInt16 nPasteDestination = SwTransferable::GetSotDestination( *pWrtShell ); 1807 if( nLastPasteDestination != nPasteDestination ) 1808 { 1809 TransferableDataHelper aDataHelper( 1810 TransferableDataHelper::CreateFromSystemClipboard( 1811 &GetEditWin()) ); 1812 if( aDataHelper.GetXTransferable().is() ) 1813 { 1814 bPasteState = SwTransferable::IsPaste( *pWrtShell, aDataHelper ); 1815 bPasteSpecialState = SwTransferable::IsPasteSpecial( 1816 *pWrtShell, aDataHelper ); 1817 } 1818 else 1819 bPasteState = bPasteSpecialState = sal_False; 1820 1821 if( 0xFFFF == nLastPasteDestination ) // the init value 1822 pViewImpl->AddClipboardListener(); 1823 nLastPasteDestination = nPasteDestination; 1824 } 1825 return bPasteState; 1826 } 1827 1828 sal_Bool SwView::IsPasteSpecialAllowed() 1829 { 1830 if ( pFormShell && pFormShell->IsActiveControl() ) 1831 return sal_False; 1832 1833 sal_uInt16 nPasteDestination = SwTransferable::GetSotDestination( *pWrtShell ); 1834 if( nLastPasteDestination != nPasteDestination ) 1835 { 1836 TransferableDataHelper aDataHelper( 1837 TransferableDataHelper::CreateFromSystemClipboard( 1838 &GetEditWin()) ); 1839 if( aDataHelper.GetXTransferable().is() ) 1840 { 1841 bPasteState = SwTransferable::IsPaste( *pWrtShell, aDataHelper ); 1842 bPasteSpecialState = SwTransferable::IsPasteSpecial( 1843 *pWrtShell, aDataHelper ); 1844 } 1845 else 1846 bPasteState = bPasteSpecialState = sal_False; 1847 1848 if( 0xFFFF == nLastPasteDestination ) // the init value 1849 pViewImpl->AddClipboardListener(); 1850 } 1851 return bPasteSpecialState; 1852 } 1853 /* -----------------------------12.07.01 13:25-------------------------------- 1854 1855 ---------------------------------------------------------------------------*/ 1856 void SwView::NotifyDBChanged() 1857 { 1858 GetViewImpl()->GetUNOObject_Impl()->NotifyDBChanged(); 1859 } 1860 1861 /*-------------------------------------------------------------------- 1862 Beschreibung: Drucken 1863 --------------------------------------------------------------------*/ 1864 1865 /* -----------------------------28.10.02 13:25-------------------------------- 1866 1867 ---------------------------------------------------------------------------*/ 1868 SfxObjectShellLock & SwView::GetTmpSelectionDoc() 1869 { 1870 return GetViewImpl()->GetTmpSelectionDoc(); 1871 } 1872 /* -----------------------------31.10.02 13:25-------------------------------- 1873 1874 ---------------------------------------------------------------------------*/ 1875 SfxObjectShellLock & SwView::GetOrCreateTmpSelectionDoc() 1876 { 1877 SfxObjectShellLock &rxTmpDoc = GetViewImpl()->GetTmpSelectionDoc(); 1878 if (!rxTmpDoc.Is()) 1879 { 1880 SwXTextView *pImpl = GetViewImpl()->GetUNOObject_Impl(); 1881 rxTmpDoc = pImpl->BuildTmpSelectionDoc(); 1882 } 1883 return rxTmpDoc; 1884 } 1885 /* -----------------3/31/2003 12:39PM---------------- 1886 1887 --------------------------------------------------*/ 1888 void SwView::AddTransferable(SwTransferable& rTransferable) 1889 { 1890 GetViewImpl()->AddTransferable(rTransferable); 1891 } 1892 1893 /* --------------------------------------------------*/ 1894 1895 namespace sw { 1896 1897 void InitPrintOptionsFromApplication(SwPrintData & o_rData, bool const bWeb) 1898 { 1899 o_rData = *SW_MOD()->GetPrtOptions(bWeb); 1900 } 1901 1902 } // namespace sw 1903 1904