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_sd.hxx"
26 #include <sfx2/dispatch.hxx>
27 #ifndef _MSGBOX_HXX //autogen
28 #include <vcl/msgbox.hxx>
29 #endif
30 #include <svx/svdpagv.hxx>
31 #include <sfx2/request.hxx>
32 #include <svl/style.hxx>
33 #include <editeng/outliner.hxx>
34 #ifndef _VIEW3D_HXX //autogen
35 #include <svx/view3d.hxx>
36 #endif
37 #ifndef _SVXIDS_HRC //autogen
38 #include <svx/svxids.hrc>
39 #endif
40 #include <svx/svdotext.hxx>
41 #include <svx/svdograf.hxx>
42 #include <svx/svdogrp.hxx>
43 #include <svx/svdorect.hxx>
44 #include <svl/poolitem.hxx>
45 #include <editeng/eeitem.hxx>
46 #include <editeng/bulitem.hxx>
47 #include <svl/itempool.hxx>
48 #include <editeng/numitem.hxx>
49 #include <svl/whiter.hxx>
50
51 #include <sfx2/viewfrm.hxx>
52 #include <sfx2/objface.hxx>
53 #include "stlsheet.hxx"
54
55 #include <svx/svdoutl.hxx>
56 #undef BMP_OLEOBJ
57 #include <svx/svdstr.hrc>
58 #include <svx/dialmgr.hxx>
59
60 #include "glob.hrc"
61 #include "strings.hrc"
62 #include "View.hxx"
63 #include "sdattr.hxx"
64 #include "drawview.hxx"
65 #include "drawdoc.hxx"
66 #include "DrawDocShell.hxx"
67 #include "sdpage.hxx"
68 #include "DrawViewShell.hxx"
69 #include "pres.hxx"
70 #include "sdresid.hxx"
71 #include "Window.hxx"
72 #include "unchss.hxx"
73 #ifndef SD_FRAME_VIEW
74 #include "FrameView.hxx"
75 #endif
76 #include "anminfo.hxx"
77 #include "slideshow.hxx"
78 #include <vcl/virdev.hxx>
79 #include <svx/sdrpaintwindow.hxx>
80 #include <svx/sdr/contact/viewobjectcontact.hxx>
81 #include <svx/sdr/contact/viewcontact.hxx>
82 #include <svx/sdr/contact/displayinfo.hxx>
83
84 #include "undo/undomanager.hxx"
85
86 using namespace ::com::sun::star;
87
88 namespace sd {
89
90 TYPEINIT1(DrawView, View);
91
92 /*************************************************************************
93 |*
94 |* Konstruktor
95 |* zeigt die erste Seite des Dokuments auf Position 0,0 an;
96 |* falls noch keine Seite vorhanden ist, wird eine erzeugt
97 |*
98 \************************************************************************/
99
DrawView(DrawDocShell * pDocSh,OutputDevice * pOutDev,DrawViewShell * pShell)100 DrawView::DrawView( DrawDocShell* pDocSh, OutputDevice* pOutDev, DrawViewShell* pShell)
101 : ::sd::View(pDocSh->GetDoc(), pOutDev, pShell)
102 , mpDocShell(pDocSh)
103 , mpDrawViewShell(pShell)
104 , mpVDev(NULL)
105 , mnPOCHSmph(0)
106 {
107 SetCurrentObj(OBJ_RECT, SdrInventor);
108 }
109
110 /*************************************************************************
111 |*
112 |* Destruktor
113 |*
114 \************************************************************************/
115
~DrawView()116 DrawView::~DrawView()
117 {
118 delete mpVDev;
119 }
120
121 /*************************************************************************
122 |*
123 |* virtuelle Methode von SdrView, wird bei Selektionsaenderung gerufen
124 |*
125 \************************************************************************/
126
MarkListHasChanged()127 void DrawView::MarkListHasChanged()
128 {
129 ::sd::View::MarkListHasChanged();
130
131 if (mpDrawViewShell)
132 mpDrawViewShell->SelectionHasChanged();
133 }
134
135 /*************************************************************************
136 |*
137 |* virtuelle Methode von SdrView, wird bei Modelaenderung gerufen
138 |*
139 \************************************************************************/
140
ModelHasChanged()141 void DrawView::ModelHasChanged()
142 {
143 ::sd::View::ModelHasChanged();
144
145 // den Gestalter zur Neudarstellung zwingen
146 SfxStyleSheetBasePool* pSSPool = mpDoc->GetStyleSheetPool();
147 pSSPool->Broadcast(SfxStyleSheetPoolHint(SFX_STYLESHEETPOOL_CHANGES));
148
149 if( mpDrawViewShell )
150 mpDrawViewShell->ModelHasChanged();
151
152 }
153
154 /*************************************************************************
155 |*
156 |* Attribute auf Titel- und Gliederungtext und Hintergrundrechteck einer
157 |* Masterpage in Vorlagen umlenken, sonst an Basisklasse weitergeben
158 |*
159 \************************************************************************/
160
SetAttributes(const SfxItemSet & rSet,sal_Bool bReplaceAll)161 sal_Bool DrawView::SetAttributes(const SfxItemSet& rSet,
162 sal_Bool bReplaceAll)
163 {
164 sal_Bool bOk = sal_False;
165
166 // wird eine Masterpage bearbeitet?
167 if ( mpDrawViewShell && mpDrawViewShell->GetEditMode() == EM_MASTERPAGE )
168 {
169 SfxStyleSheetBasePool* pStShPool = mpDoc->GetStyleSheetPool();
170 SdPage& rPage = *mpDrawViewShell->getCurrentPage();
171 String aLayoutName = rPage.GetName();
172 SdrTextObj* pEditObject = static_cast< SdrTextObj* >( GetTextEditObject() );
173
174 if (pEditObject)
175 {
176 // Textedit
177 String aTemplateName(aLayoutName);
178
179 sal_uInt32 nInv = pEditObject->GetObjInventor();
180
181 if (nInv == SdrInventor)
182 {
183 sal_uInt16 eObjKind = pEditObject->GetObjIdentifier();
184 PresObjKind ePresObjKind = rPage.GetPresObjKind(pEditObject);
185
186 if ( ePresObjKind == PRESOBJ_TITLE ||
187 ePresObjKind == PRESOBJ_NOTES )
188 {
189 // Presentation object (except outline)
190 SfxStyleSheet* pSheet = rPage.GetStyleSheetForPresObj( ePresObjKind );
191 DBG_ASSERT(pSheet, "StyleSheet nicht gefunden");
192
193 SfxItemSet aTempSet( pSheet->GetItemSet() );
194 aTempSet.Put( rSet );
195 aTempSet.ClearInvalidItems();
196
197 // Undo-Action
198 StyleSheetUndoAction* pAction = new StyleSheetUndoAction(mpDoc, pSheet, &aTempSet);
199 mpDocSh->GetUndoManager()->AddUndoAction(pAction);
200
201 pSheet->GetItemSet().Put(aTempSet);
202 pSheet->Broadcast(SfxSimpleHint(SFX_HINT_DATACHANGED));
203 bOk = sal_True;
204 }
205 else if (eObjKind == OBJ_OUTLINETEXT)
206 {
207 // Presentation object outline
208 OutlinerView* pOV = GetTextEditOutlinerView();
209 ::Outliner* pOutliner = pOV->GetOutliner();
210 List* pList = (List*)pOV->CreateSelectionList();
211 aTemplateName += String(SdResId(STR_LAYOUT_OUTLINE));
212
213 pOutliner->SetUpdateMode(sal_False);
214 mpDocSh->SetWaitCursor( sal_True );
215
216 // Platzhalter durch Vorlagennamen ersetzen
217 String aComment(SdResId(STR_UNDO_CHANGE_PRES_OBJECT));
218 xub_StrLen nPos = aComment.Search( (sal_Unicode)'$' );
219 aComment.Erase(nPos, 1);
220 aComment.Insert( String((SdResId(STR_PSEUDOSHEET_OUTLINE))), nPos);
221 mpDocSh->GetUndoManager()->EnterListAction( aComment, String() );
222
223 Paragraph* pPara = (Paragraph*)pList->Last();
224 while (pPara)
225 {
226 sal_uLong nParaPos = pOutliner->GetAbsPos( pPara );
227 sal_Int16 nDepth = pOutliner->GetDepth( nParaPos );
228 String aName(rPage.GetLayoutName());
229 aName += (sal_Unicode)(' ');
230 aName += String::CreateFromInt32( (nDepth <= 0) ? 1 : nDepth + 1 );
231 SfxStyleSheet* pSheet = (SfxStyleSheet*)pStShPool->Find(aName, SD_STYLE_FAMILY_MASTERPAGE);
232 DBG_ASSERT(pSheet, "StyleSheet nicht gefunden");
233
234 SfxItemSet aTempSet( pSheet->GetItemSet() );
235 aTempSet.Put( rSet );
236 aTempSet.ClearInvalidItems();
237
238 if( nDepth > 0 && aTempSet.GetItemState( EE_PARA_NUMBULLET ) == SFX_ITEM_ON )
239 {
240 // no SvxNumBulletItem in outline level 1 to 8!
241 aTempSet.ClearItem( EE_PARA_NUMBULLET );
242 }
243
244 // Undo-Action
245 StyleSheetUndoAction* pAction = new StyleSheetUndoAction(mpDoc, pSheet, &aTempSet);
246 mpDocSh->GetUndoManager()->AddUndoAction(pAction);
247
248 pSheet->GetItemSet().Put(aTempSet);
249 pSheet->Broadcast(SfxSimpleHint(SFX_HINT_DATACHANGED));
250
251 // now also broadcast any child sheets
252 sal_Int16 nChild;
253 for( nChild = nDepth + 1; nChild < 9; nChild++ )
254 {
255 String aSheetName(rPage.GetLayoutName());
256 aSheetName += (sal_Unicode)(' ');
257 aSheetName += String::CreateFromInt32( nChild <= 0 ? 1 : nChild + 1 );
258 SfxStyleSheet* pOutlSheet = static_cast< SfxStyleSheet* >(pStShPool->Find(aSheetName, SD_STYLE_FAMILY_MASTERPAGE));
259
260 if( pOutlSheet )
261 pOutlSheet->Broadcast(SfxSimpleHint(SFX_HINT_DATACHANGED));
262 }
263
264 pPara = (Paragraph*)pList->Prev();
265
266 if( !pPara && nDepth > 0 && rSet.GetItemState( EE_PARA_NUMBULLET ) == SFX_ITEM_ON &&
267 pOutliner->GetDepth( pOutliner->GetAbsPos( (Paragraph*) pList->First() ) ) > 0 )
268 pPara = pOutliner->GetParagraph( 0 ); // Put NumBulletItem in outline level 1
269 }
270
271 mpDocSh->SetWaitCursor( sal_False );
272 pOV->GetOutliner()->SetUpdateMode(sal_True);
273
274 mpDocSh->GetUndoManager()->LeaveListAction();
275
276 delete pList;
277 bOk = sal_True;
278 }
279 else
280 {
281 bOk = ::sd::View::SetAttributes(rSet, bReplaceAll);
282 }
283 }
284 }
285 else
286 {
287 // Selection
288 const SdrMarkList& rList = GetMarkedObjectList();
289 sal_uLong nMarkCount = rList.GetMarkCount();
290 for (sal_uLong nMark = 0; nMark < nMarkCount; nMark++)
291 {
292 SdrObject* pObject = rList.GetMark(nMark)->GetMarkedSdrObj();
293 sal_uInt32 nInv = pObject->GetObjInventor();
294
295 if (nInv == SdrInventor)
296 {
297 sal_uInt16 eObjKind = pObject->GetObjIdentifier();
298 PresObjKind ePresObjKind = rPage.GetPresObjKind(pObject);
299 String aTemplateName(aLayoutName);
300
301 if (ePresObjKind == PRESOBJ_TITLE ||
302 ePresObjKind == PRESOBJ_NOTES)
303 {
304 // Presentation object (except outline)
305 SfxStyleSheet* pSheet = rPage.GetStyleSheetForPresObj( ePresObjKind );
306 DBG_ASSERT(pSheet, "StyleSheet not found");
307
308 SfxItemSet aTempSet( pSheet->GetItemSet() );
309 aTempSet.Put( rSet );
310 aTempSet.ClearInvalidItems();
311
312 // Undo-Action
313 StyleSheetUndoAction* pAction = new StyleSheetUndoAction(mpDoc, pSheet, &aTempSet);
314 mpDocSh->GetUndoManager()->AddUndoAction(pAction);
315
316 pSheet->GetItemSet().Put(aTempSet,false);
317 pSheet->Broadcast(SfxSimpleHint(SFX_HINT_DATACHANGED));
318 bOk = sal_True;
319 }
320 else if (eObjKind == OBJ_OUTLINETEXT)
321 {
322 // Presentation object outline
323 aTemplateName += String(SdResId(STR_LAYOUT_OUTLINE));
324 for (sal_uInt16 nLevel = 9; nLevel > 0; nLevel--)
325 {
326 String aName(rPage.GetLayoutName());
327 aName += (sal_Unicode)(' ');
328 aName += String::CreateFromInt32( (sal_Int32)nLevel );
329 SfxStyleSheet* pSheet = (SfxStyleSheet*)pStShPool->
330 Find(aName, SD_STYLE_FAMILY_MASTERPAGE);
331 DBG_ASSERT(pSheet, "StyleSheet nicht gefunden");
332
333 SfxItemSet aTempSet( pSheet->GetItemSet() );
334
335 if( nLevel > 1 )
336 {
337 // for all levels over 1, clear all items that will be
338 // hard set to level 1
339 SfxWhichIter aWhichIter(rSet);
340 sal_uInt16 nWhich(aWhichIter.FirstWhich());
341 while( nWhich )
342 {
343 if( SFX_ITEM_ON == rSet.GetItemState( nWhich ) )
344 aTempSet.ClearItem( nWhich );
345 nWhich = aWhichIter.NextWhich();
346 }
347
348 }
349 else
350 {
351 // put the items hard into level one
352 aTempSet.Put( rSet );
353 }
354
355 aTempSet.ClearInvalidItems();
356
357 // Undo-Action
358 StyleSheetUndoAction* pAction = new StyleSheetUndoAction(mpDoc, pSheet, &aTempSet);
359 mpDocSh->GetUndoManager()->AddUndoAction(pAction);
360
361 pSheet->GetItemSet().Set(aTempSet,false);
362 pSheet->Broadcast(SfxSimpleHint(SFX_HINT_DATACHANGED));
363 }
364
365 // remove all hard set items from shape that are now set in style
366 SfxWhichIter aWhichIter(rSet);
367 sal_uInt16 nWhich(aWhichIter.FirstWhich());
368 while( nWhich )
369 {
370 if( SFX_ITEM_ON == rSet.GetItemState( nWhich ) )
371 pObject->ClearMergedItem( nWhich );
372 nWhich = aWhichIter.NextWhich();
373 }
374
375 bOk = sal_True;
376 }
377 }
378 }
379
380 if(!bOk)
381 bOk = ::sd::View::SetAttributes(rSet, bReplaceAll);
382 }
383 }
384 else // nicht auf der Masterpage
385 {
386 bOk = ::sd::View::SetAttributes(rSet, bReplaceAll);
387 }
388
389 return (bOk);
390 }
391
392 /*************************************************************************
393 |*
394 |* Notify fuer Aenderung der Seitenanordnung
395 |*
396 \************************************************************************/
397
Notify(SfxBroadcaster & rBC,const SfxHint & rHint)398 void DrawView::Notify(SfxBroadcaster& rBC, const SfxHint& rHint)
399 {
400 if ( mpDrawViewShell && rHint.ISA(SdrHint) )
401 {
402 SdrHintKind eHintKind = ( (SdrHint&) rHint).GetKind();
403
404 if ( mnPOCHSmph == 0 && eHintKind == HINT_PAGEORDERCHG )
405 {
406 mpDrawViewShell->ResetActualPage();
407 }
408 else if ( eHintKind == HINT_LAYERCHG || eHintKind == HINT_LAYERORDERCHG )
409 {
410 mpDrawViewShell->ResetActualLayer();
411 }
412
413 // #94278# switch to that page when it's not a master page
414 if(HINT_SWITCHTOPAGE == eHintKind)
415 {
416 const SdrPage* pPage = ((const SdrHint&)rHint).GetPage();
417
418 if(pPage && !pPage->IsMasterPage())
419 {
420 if(mpDrawViewShell->GetActualPage() != pPage)
421 {
422 sal_uInt16 nPageNum = (pPage->GetPageNum() - 1) / 2; // Sdr --> Sd
423 mpDrawViewShell->SwitchPage(nPageNum);
424 }
425 }
426 }
427 }
428
429 ::sd::View::Notify(rBC, rHint);
430 }
431
432 /*************************************************************************
433 |*
434 |* PageOrderChangedHint blockieren/freigeben
435 |*
436 \************************************************************************/
437
BlockPageOrderChangedHint(sal_Bool bBlock)438 void DrawView::BlockPageOrderChangedHint(sal_Bool bBlock)
439 {
440 if (bBlock)
441 mnPOCHSmph++;
442 else
443 {
444 DBG_ASSERT(mnPOCHSmph, "Zaehlerunterlauf");
445 mnPOCHSmph--;
446 }
447 }
448
449 /*************************************************************************
450 |*
451 |* StyleSheet-Setzen auf der Masterpage abfangen, wenn Praesentationsobjekte
452 |* selektiert sind
453 |*
454 \************************************************************************/
455
SetStyleSheet(SfxStyleSheet * pStyleSheet,sal_Bool bDontRemoveHardAttr)456 sal_Bool DrawView::SetStyleSheet(SfxStyleSheet* pStyleSheet, sal_Bool bDontRemoveHardAttr)
457 {
458 sal_Bool bResult = sal_True;
459
460 // wird eine Masterpage bearbeitet?
461 if (mpDrawViewShell && mpDrawViewShell->GetEditMode() == EM_MASTERPAGE)
462 {
463 if (IsPresObjSelected(sal_False, sal_True))
464 {
465
466 InfoBox(mpDrawViewShell->GetActiveWindow(),
467 String(SdResId(STR_ACTION_NOTPOSSIBLE))).Execute();
468 bResult = sal_False;
469 }
470 else
471 {
472 bResult = ::sd::View::SetStyleSheet(pStyleSheet, bDontRemoveHardAttr);
473 }
474 }
475 else
476 {
477 bResult = ::sd::View::SetStyleSheet(pStyleSheet, bDontRemoveHardAttr);
478 }
479 return bResult;
480 }
481
482 /*************************************************************************
483 |*
484 |* Paint-Methode: das Ereignis wird an die View weitergeleitet
485 |*
486 \************************************************************************/
487
CompleteRedraw(OutputDevice * pOutDev,const Region & rReg,sdr::contact::ViewObjectContactRedirector * pRedirector)488 void DrawView::CompleteRedraw(OutputDevice* pOutDev, const Region& rReg, sdr::contact::ViewObjectContactRedirector* pRedirector /*=0L*/)
489 {
490 if( mpVDev )
491 {
492 delete mpVDev;
493 mpVDev = NULL;
494 }
495
496 sal_Bool bStandardPaint = sal_True;
497
498 SdDrawDocument* pDoc = mpDocShell->GetDoc();
499 if( pDoc && pDoc->GetDocumentType() == DOCUMENT_TYPE_IMPRESS)
500 {
501 rtl::Reference< sd::SlideShow > xSlideshow( SlideShow::GetSlideShow( pDoc ) );
502 if(xSlideshow.is() && xSlideshow->isRunning())
503 {
504 OutputDevice* pShowWindow = ( OutputDevice* )xSlideshow->getShowWindow();
505 if( (pShowWindow == pOutDev) || (xSlideshow->getAnimationMode() == ANIMATIONMODE_PREVIEW) )
506 {
507 if( pShowWindow == pOutDev )
508 PresPaint(rReg);
509 bStandardPaint = sal_False;
510 }
511 }
512 }
513
514 if(bStandardPaint)
515 {
516 ::sd::View::CompleteRedraw(pOutDev, rReg, pRedirector);
517 }
518 }
519
520 /*************************************************************************
521 |*
522 |* Paint-Event during running slide show
523 |*
524 \************************************************************************/
525
PresPaint(const Region & rRegion)526 void DrawView::PresPaint(const Region& rRegion)
527 {
528 if(mpViewSh)
529 {
530 rtl::Reference< SlideShow > xSlideshow( SlideShow::GetSlideShow( GetDoc() ) );
531 if( xSlideshow.is() && xSlideshow->isRunning() )
532 xSlideshow->paint( rRegion.GetBoundRect() );
533 }
534 }
535
536 /*************************************************************************
537 |* entscheidet, ob ein Objekt markiert werden kann (z. B. noch nicht
538 |* erschienene Animationsobjekte in der Diashow)
539 \************************************************************************/
540
IsObjMarkable(SdrObject * pObj,SdrPageView * pPV) const541 sal_Bool DrawView::IsObjMarkable(SdrObject* pObj, SdrPageView* pPV) const
542 {
543 return FmFormView::IsObjMarkable(pObj, pPV);;
544 }
545
546 /*************************************************************************
547 |*
548 |* Uebergebenen Bereich sichtbar machen (es wird ggf. gescrollt)
549 |*
550 \************************************************************************/
551
MakeVisible(const Rectangle & rRect,::Window & rWin)552 void DrawView::MakeVisible(const Rectangle& rRect, ::Window& rWin)
553 {
554 if (!rRect.IsEmpty())
555 {
556 mpDrawViewShell->MakeVisible(rRect, rWin);
557 }
558 }
559 /*************************************************************************
560 |*
561 |* Seite wird gehided
562 |*
563 \************************************************************************/
564
HideSdrPage()565 void DrawView::HideSdrPage()
566 {
567 if (mpDrawViewShell)
568 {
569 mpDrawViewShell->HidePage();
570 }
571
572 ::sd::View::HideSdrPage();
573 }
574
DeleteMarked()575 void DrawView::DeleteMarked()
576 {
577 OSL_TRACE( "DrawView::DeleteMarked() - enter" );
578
579 sd::UndoManager* pUndoManager = mpDoc->GetUndoManager();
580 DBG_ASSERT( pUndoManager, "sd::DrawView::DeleteMarked(), ui action without undo manager!?" );
581
582 if( pUndoManager )
583 {
584 String aUndo( SVX_RES(STR_EditDelete) );
585 String aSearchString(RTL_CONSTASCII_USTRINGPARAM("%1"));
586 aUndo.SearchAndReplace(aSearchString, GetDescriptionOfMarkedObjects());
587 pUndoManager->EnterListAction(aUndo, aUndo);
588 }
589
590 SdPage* pPage = 0;
591 bool bResetLayout = false;
592
593 const sal_uLong nMarkCount = GetMarkedObjectList().GetMarkCount();
594 if( nMarkCount )
595 {
596 SdrMarkList aList( GetMarkedObjectList() );
597 for (sal_uLong nMark = 0; nMark < nMarkCount; nMark++)
598 {
599 SdrObject* pObj = aList.GetMark(nMark)->GetMarkedSdrObj();
600 if( pObj && !pObj->IsEmptyPresObj() && pObj->GetUserCall() )
601 {
602 pPage = static_cast< SdPage* >( pObj->GetPage() );
603 PresObjKind ePresObjKind;
604 if( pPage && ((ePresObjKind = pPage->GetPresObjKind(pObj)) != PRESOBJ_NONE))
605 {
606 switch( ePresObjKind )
607 {
608 case PRESOBJ_GRAPHIC:
609 case PRESOBJ_OBJECT:
610 case PRESOBJ_CHART:
611 case PRESOBJ_ORGCHART:
612 case PRESOBJ_TABLE:
613 case PRESOBJ_CALC:
614 case PRESOBJ_IMAGE:
615 case PRESOBJ_MEDIA:
616 ePresObjKind = PRESOBJ_OUTLINE;
617 break;
618 default:
619 break;
620 }
621 SdrTextObj* pTextObj = dynamic_cast< SdrTextObj* >( pObj );
622 bool bVertical = pTextObj && pTextObj->IsVerticalWriting();
623 Rectangle aRect( pObj->GetLogicRect() );
624 SdrObject* pNewObj = pPage->InsertAutoLayoutShape( 0, ePresObjKind, bVertical, aRect, true );
625
626 // Move the new PresObj to the position before the
627 // object it will replace.
628 pUndoManager->AddUndoAction(
629 mpDoc->GetSdrUndoFactory().CreateUndoObjectOrdNum(
630 *pNewObj,
631 pNewObj->GetOrdNum(),
632 pObj->GetOrdNum()));
633 pPage->SetObjectOrdNum( pNewObj->GetOrdNum(), pObj->GetOrdNum() );
634
635 bResetLayout = true;
636
637 OSL_TRACE( "DrawView::InsertAutoLayoutShape() - InsertAutoLayoutShape" );
638 }
639 }
640 }
641 }
642
643 ::sd::View::DeleteMarked();
644
645 if( pPage && bResetLayout )
646 pPage->SetAutoLayout( pPage->GetAutoLayout() );
647
648 if( pUndoManager )
649 pUndoManager->LeaveListAction();
650
651 OSL_TRACE( "DrawView::InsertAutoLayoutShape() - leave" );
652 }
653
654 } // end of namespace sd
655