xref: /AOO41X/main/sd/source/ui/func/futext.cxx (revision 8daba9aafd3bcac106a1790a27e74b9f891d4e2a)
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 
27 
28 #include "futext.hxx"
29 #include <editeng/eeitem.hxx>
30 #include <editeng/editerr.hxx>
31 #include <svx/dlgutil.hxx>
32 #include <svx/svxerr.hxx>
33 #include <tools/urlobj.hxx>
34 #include <vcl/help.hxx>
35 #include <editeng/editstat.hxx>
36 #include <svl/aeitem.hxx>
37 #include <svl/intitem.hxx>
38 #include <svx/svdotext.hxx>
39 #include <svx/svdogrp.hxx>
40 #include <svx/sidebar/ContextChangeEventMultiplexer.hxx>
41 #include <editeng/flditem.hxx>
42 #include <svl/style.hxx>
43 #include <svx/svdpagv.hxx>
44 #include <sfx2/viewfrm.hxx>
45 #include <sfx2/dispatch.hxx>
46 #include <sfx2/bindings.hxx>
47 #include <sfx2/request.hxx>
48 #include <editeng/editeng.hxx>
49 #include <svx/svdoutl.hxx>
50 #include <svx/svxids.hrc>
51 #include <sfx2/docfile.hxx>
52 #include <sfx2/sidebar/EnumContext.hxx>
53 #include <comphelper/processfactory.hxx>
54 #include <editeng/outlobj.hxx>
55 #include <svtools/langtab.hxx>
56 
57 // #104122#
58 #include <editeng/frmdiritem.hxx>
59 
60 #include <svx/svdetc.hxx>
61 #include <editeng/editview.hxx>
62 
63 #include "sdresid.hxx"
64 #include "app.hrc"
65 #include "res_bmp.hrc"
66 #include "ViewShell.hxx"
67 #include "ViewShellBase.hxx"
68 #include "View.hxx"
69 #include "Outliner.hxx"
70 #include "Window.hxx"
71 #include "drawdoc.hxx"
72 #include "sdpage.hxx"
73 #include "sdmod.hxx"
74 #include "FrameView.hxx"
75 #include "ToolBarManager.hxx"
76 #include "DrawDocShell.hxx"
77 #include "glob.hrc"
78 #include "pres.hxx"
79 #include "optsitem.hxx"
80 
81 using ::rtl::OUString;
82 using namespace ::com::sun::star;
83 using namespace ::com::sun::star::uno;
84 using namespace ::com::sun::star::lang;
85 using namespace ::com::sun::star::linguistic2;
86 
87 namespace sd {
88 
89 static sal_uInt16 SidArray[] = {
90     SID_STYLE_FAMILY2,                //    5542
91     SID_STYLE_FAMILY5,                //    5545
92     SID_CUT,                          //    5710
93     SID_COPY,                         //    5711
94     SID_ATTR_TABSTOP,                 //   10002
95     SID_ATTR_CHAR_FONT,               //   10007
96     SID_ATTR_CHAR_POSTURE,            //   10008
97     SID_ATTR_CHAR_WEIGHT,             //   10009
98     SID_ATTR_CHAR_UNDERLINE,          //   10014
99     SID_ATTR_CHAR_FONTHEIGHT,         //   10015
100     SID_ATTR_CHAR_COLOR,              //   10017
101     SID_ATTR_PARA_ADJUST_LEFT,        //   10028
102     SID_ATTR_PARA_ADJUST_RIGHT,       //   10029
103     SID_ATTR_PARA_ADJUST_CENTER,      //   10030
104     SID_ATTR_PARA_ADJUST_BLOCK,       //   10031
105     SID_ATTR_PARA_LINESPACE_10,       //   10034
106     SID_ATTR_PARA_LINESPACE_15,       //   10035
107     SID_ATTR_PARA_LINESPACE_20,       //   10036
108     SID_ATTR_PARA_LRSPACE,            //   10043
109     SID_OUTLINE_UP,                   //   10150
110     SID_OUTLINE_DOWN,                 //   10151
111     SID_OUTLINE_LEFT,                 //   10152
112     SID_OUTLINE_RIGHT,                //   10153
113     SID_FORMTEXT_STYLE,               //   10257
114     SID_SET_SUPER_SCRIPT,             //   10294
115     SID_SET_SUB_SCRIPT,               //   10295
116     SID_HYPERLINK_GETLINK,            //   10361
117     SID_CHARMAP,                      //   10503
118     SID_TEXTDIRECTION_LEFT_TO_RIGHT,  //   10907
119     SID_TEXTDIRECTION_TOP_TO_BOTTOM,  //   10908
120     SID_ATTR_PARA_LEFT_TO_RIGHT,      //   10950
121     SID_ATTR_PARA_RIGHT_TO_LEFT,      //   10951
122     FN_NUM_BULLET_ON,                 //   20138
123     SID_PARASPACE_INCREASE,           //   27346
124     SID_PARASPACE_DECREASE,           //   27347
125                             0 };
126 
127 TYPEINIT1( FuText, FuConstruct );
128 
129 
130 static sal_Bool bTestText = 0;
131 
132 /*************************************************************************
133 |*
134 |* Basisklasse fuer Textfunktionen
135 |*
136 \************************************************************************/
137 
138 FuText::FuText( ViewShell* pViewSh, ::sd::Window* pWin, ::sd::View* pView, SdDrawDocument* pDoc, SfxRequest& rReq )
139 : FuConstruct(pViewSh, pWin, pView, pDoc, rReq)
140 , bFirstObjCreated(sal_False)
141 , rRequest (rReq)
142 {
143 }
144 
145 FunctionReference FuText::Create( ViewShell* pViewSh, ::sd::Window* pWin, ::sd::View* pView, SdDrawDocument* pDoc, SfxRequest& rReq )
146 {
147     FunctionReference xFunc( new FuText( pViewSh, pWin, pView, pDoc, rReq ) );
148     return xFunc;
149 }
150 
151 /*************************************************************************
152 |*
153 |* Destruktor
154 |*
155 \************************************************************************/
156 
157 void FuText::disposing()
158 {
159     if(mpView)
160     {
161         if(mpView->SdrEndTextEdit(sal_False) == SDRENDTEXTEDIT_DELETED)
162             mxTextObj.reset( 0 );
163 
164         // die RequestHandler der benutzten Outliner zuruecksetzen auf den
165         // Handler am Dokument
166         ::Outliner* pOutliner = mpView->GetTextEditOutliner();
167 
168         if (pOutliner)
169             pOutliner->SetStyleSheetPool(static_cast<SfxStyleSheetPool*>(mpDoc->GetStyleSheetPool()));
170     }
171 }
172 
173 /*************************************************************************
174 |*
175 |* Execute functionality of this class:
176 |*
177 |* #71422: Start the functionality of this class in this method
178 |* and not in the ctor.
179 |* If you construct an object of this class and you put the
180 |* address of this object to pFuActual you've got a problem,
181 |* because some methods inside DoExecute use the pFuActual-Pointer.
182 |* If the code inside DoExecute is executed inside the ctor,
183 |* the value of pFuActual is not right. And the value will not
184 |* be right until the ctor finished !!!
185 |*
186 \************************************************************************/
187 void FuText::DoExecute( SfxRequest& )
188 {
189     mpViewShell->GetViewShellBase().GetToolBarManager()->SetToolBarShell(
190         ToolBarManager::TBG_FUNCTION,
191         RID_DRAW_TEXT_TOOLBOX);
192 
193     mpView->SetCurrentObj(OBJ_TEXT);
194     mpView->SetEditMode(SDREDITMODE_EDIT);
195 
196     MouseEvent aMEvt(mpWindow->GetPointerPosPixel());
197 
198     if (nSlotId == SID_TEXTEDIT)
199     {
200         // Try to select an object
201         SdrPageView* pPV = mpView->GetSdrPageView();
202         SdrViewEvent aVEvt;
203         mpView->PickAnything(aMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
204         mpView->MarkObj(aVEvt.pRootObj, pPV);
205 
206         mxTextObj.reset( dynamic_cast< SdrTextObj* >( aVEvt.pObj ) );
207     }
208     else if (mpView->AreObjectsMarked())
209     {
210         const SdrMarkList& rMarkList = mpView->GetMarkedObjectList();
211 
212         if (rMarkList.GetMarkCount() == 1)
213         {
214             SdrObject* pObj = rMarkList.GetMark(0)->GetMarkedSdrObj();
215             mxTextObj.reset( dynamic_cast< SdrTextObj* >( pObj ) );
216         }
217     }
218 
219     // check for table
220     if (mpView->AreObjectsMarked())
221     {
222         const SdrMarkList& rMarkList = mpView->GetMarkedObjectList();
223 
224         if (rMarkList.GetMarkCount() == 1)
225         {
226             SdrObject* pObj = rMarkList.GetMark(0)->GetMarkedSdrObj();
227             if( pObj && (pObj->GetObjInventor() == SdrInventor ) && (pObj->GetObjIdentifier() == OBJ_TABLE) )
228             {
229                 mpViewShell->GetViewShellBase().GetToolBarManager()->AddToolBarShell( ToolBarManager::TBG_FUNCTION, RID_DRAW_TABLE_TOOLBOX );
230             }
231         }
232     }
233 
234     sal_Bool bQuickDrag = sal_True;
235 
236     const SfxItemSet* pArgs = rRequest.GetArgs();
237 
238     if (pArgs
239 
240         // #98198# test for type before using
241         && SID_TEXTEDIT == nSlotId
242         && SFX_ITEM_SET == pArgs->GetItemState(SID_TEXTEDIT)
243 
244         && (sal_uInt16)((SfxUInt16Item&)pArgs->Get(SID_TEXTEDIT)).GetValue() == 2)
245     {
246         // Selection by doubleclick -> don't allow QuickDrag
247         bQuickDrag = sal_False;
248     }
249 
250     SetInEditMode(aMEvt, bQuickDrag);
251 }
252 
253 /*************************************************************************
254 |*
255 |* MouseButtonDown-event
256 |*
257 \************************************************************************/
258 
259 sal_Bool FuText::MouseButtonDown(const MouseEvent& rMEvt)
260 {
261     bMBDown = sal_True;
262 
263     sal_Bool bReturn = FuDraw::MouseButtonDown(rMEvt);
264 
265     /* af: (de)Select object before showing the context menu.
266     // Fuer PopupMenu (vorher DrawViewShell)
267     if ((rMEvt.GetButtons() == MOUSE_RIGHT) && rMEvt.GetClicks() == 1 &&
268         mpView->IsTextEdit())
269     {
270         return (sal_True);
271     }
272         */
273 
274     mpView->SetMarkHdlWhenTextEdit(sal_True);
275     SdrViewEvent aVEvt;
276     SdrHitKind eHit = mpView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
277 
278     if (eHit == SDRHIT_TEXTEDIT)
279     {
280         // Text getroffen -> Event von SdrView auswerten lassen
281         if (mpView->MouseButtonDown(rMEvt, mpWindow))
282             return (sal_True);
283     }
284 
285     if (rMEvt.GetClicks() == 1)
286     {
287         if (mpView->IsTextEdit() && eHit != SDRHIT_MARKEDOBJECT && eHit != SDRHIT_HANDLE)
288         {
289             // Texteingabe beenden
290             if(mpView->SdrEndTextEdit() == SDRENDTEXTEDIT_DELETED)
291             {
292                 // Bugfix von MBA: bei Doppelclick auf der Wiese im Modus Text wird
293                 // beim zweiten Click eHit = SDRHIT_TEXTEDITOBJ erhalten, weil ja der
294                 // zweite Click auf das im ersten Click angelegte TextObject geht.
295                 // Dieses wird aber in SdrEndTextEdit entfernt, weil es leer ist. Es
296                 // befindet sich aber noch in der Mark-Liste und der Aufruf MarkObj
297                 // weiter unten greift dann auf das tote Object zu.
298                 // Als einfacher Fix wird nach SdrEndTextEdit noch einmal eHit ermittelt,
299                 // was dann SDRHIT_NONE liefert.
300                 mxTextObj.reset( NULL );
301                 eHit = mpView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
302             }
303 
304             mpView->SetCurrentObj(OBJ_TEXT);
305             mpView->SetEditMode(SDREDITMODE_EDIT);
306         }
307 
308         if (rMEvt.IsLeft() || rMEvt.IsRight())
309         {
310             mpWindow->CaptureMouse();
311             SdrObject* pObj;
312             SdrPageView* pPV = mpView->GetSdrPageView();
313 
314             if (eHit == SDRHIT_TEXTEDIT)
315             {
316                 SetInEditMode(rMEvt, sal_False);
317             }
318             else
319             {
320                 sal_Bool bMacro = sal_False;
321 
322                 if (bMacro && mpView->PickObj(aMDPos,mpView->getHitTolLog(),pObj,pPV,SDRSEARCH_PICKMACRO))
323                 {
324                     // Makro
325                     sal_uInt16 nHitLog = sal_uInt16 ( mpWindow->PixelToLogic(Size(HITPIX,0)).Width() );
326                     mpView->BegMacroObj(aMDPos,nHitLog,pObj,pPV,mpWindow);
327                 }
328                 else
329                 {
330                     if (eHit != SDRHIT_HANDLE)
331                     {
332                         // Selektion aufheben
333                         if (!rMEvt.IsShift() && eHit == SDRHIT_TEXTEDITOBJ)
334                         {
335                             mpView->UnmarkAll();
336                             mpView->SetDragMode(SDRDRAG_MOVE);
337                         }
338                     }
339 
340                     if ( aVEvt.eEvent == SDREVENT_EXECUTEURL                   ||
341                          eHit == SDRHIT_HANDLE                                 ||
342                          eHit == SDRHIT_MARKEDOBJECT                           ||
343                          eHit == SDRHIT_TEXTEDITOBJ                            ||
344                          ( eHit == SDRHIT_UNMARKEDOBJECT && bFirstObjCreated &&
345                            !bPermanent ) )
346                     {
347                         /**********************************************************
348                         * Handle, markiertes oder unmarkiertes Objekt getroffen
349                         **********************************************************/
350                         if (eHit == SDRHIT_TEXTEDITOBJ)
351                         {
352                             /******************************************************
353                             * Text eines unmarkierten Objekts getroffen:
354                             * Objekt wird selektiert und in EditMode versetzt
355                             ******************************************************/
356                             mpView->MarkObj(aVEvt.pRootObj, pPV);
357 
358                             if (aVEvt.pObj && aVEvt.pObj->ISA(SdrTextObj))
359                             {
360                                 mxTextObj.reset( static_cast<SdrTextObj*>(aVEvt.pObj) );
361                             }
362 
363                             SetInEditMode(rMEvt, sal_True);
364                         }
365                         else if (aVEvt.eEvent == SDREVENT_EXECUTEURL && !rMEvt.IsMod2())
366                         {
367                             /******************************************************
368                             * URL ausfuehren
369                             ******************************************************/
370                             mpWindow->ReleaseMouse();
371                             SfxStringItem aStrItem(SID_FILE_NAME, aVEvt.pURLField->GetURL());
372                             SfxStringItem aReferer(SID_REFERER, mpDocSh->GetMedium()->GetName());
373                             SfxBoolItem aBrowseItem( SID_BROWSE, sal_True );
374                             SfxViewFrame* pFrame = mpViewShell->GetViewFrame();
375                             mpWindow->ReleaseMouse();
376 
377                             if (rMEvt.IsMod1())
378                             {
379                                 // Im neuen Frame oeffnen
380                                 pFrame->GetDispatcher()->Execute(SID_OPENDOC, SFX_CALLMODE_ASYNCHRON | SFX_CALLMODE_RECORD,
381                                             &aStrItem, &aBrowseItem, &aReferer, 0L);
382                             }
383                             else
384                             {
385                                 // Im aktuellen Frame oeffnen
386                                 SfxFrameItem aFrameItem(SID_DOCFRAME, pFrame);
387                                 pFrame->GetDispatcher()->Execute(SID_OPENDOC, SFX_CALLMODE_ASYNCHRON | SFX_CALLMODE_RECORD,
388                                             &aStrItem, &aFrameItem, &aBrowseItem, &aReferer, 0L);
389                             }
390                         }
391                         else
392                         {
393                             /******************************************************
394                             * Objekt oder Handle draggen
395                             ******************************************************/
396 
397                             // #i78748#
398                             // do the EndTextEdit first, it will delete the handles and force a
399                             // recreation. This will make aVEvt.pHdl to point to a deleted handle,
400                             // thus it is necessary to reset it and to get it again.
401 
402                             // #i112855#
403                             // cl: I'm not sure why we checked here also for mxTextObj->GetOutlinerParaObjet
404                             // this caused SdrEndTextEdit() to be called also when not in text editing and
405                             // this does not make sense and caused troubles. (see issue 112855)
406 
407 //                          ::Outliner* pOutl = mpView->GetTextEditOutliner();
408 //
409 //                          if (mxTextObj.is() && (mxTextObj->GetOutlinerParaObject() ||
410 //                              (pOutl && pOutl->GetText(pOutl->GetParagraph( 0 )).Len() != 0)))
411                             if( mpView->IsTextEdit() )
412                             {
413                                 mpView->SdrEndTextEdit();
414 
415                                 if(aVEvt.pHdl)
416                                 {
417                                     // force new handle identification, the pointer will be dead here
418                                     // since SdrEndTextEdit has resetted (deleted) the handles.
419                                     aVEvt.pHdl = 0;
420                                     mpView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
421                                 }
422                             }
423 
424                             if (!aVEvt.pHdl)
425                             {
426                                 if( eHit == SDRHIT_UNMARKEDOBJECT )
427                                 {
428                                     if ( !rMEvt.IsShift() )
429                                         mpView->UnmarkAll();
430 
431                                     mpView->MarkObj(aVEvt.pRootObj, pPV);
432                                 }
433 
434                                 // Objekt draggen
435                                 bFirstMouseMove = sal_True;
436                                 aDragTimer.Start();
437                             }
438 
439 
440                             if ( ! rMEvt.IsRight())
441                             {
442                                 // we need to pick again since SdrEndTextEdit can rebuild the handles list
443                                 eHit = mpView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
444                                 if( (eHit == SDRHIT_HANDLE) || (eHit == SDRHIT_MARKEDOBJECT) )
445                                 {
446                                     sal_uInt16 nDrgLog = sal_uInt16 ( mpWindow->PixelToLogic(Size(DRGPIX,0)).Width() );
447                                     mpView->BegDragObj(aMDPos, (OutputDevice*) NULL, aVEvt.pHdl, nDrgLog);
448                                 }
449                             }
450                             bReturn = true;
451                         }
452                     }
453                     else if ( nSlotId != SID_TEXTEDIT &&
454                               (bPermanent || !bFirstObjCreated) )
455                     {
456                         /**********************************************************
457                         * Objekt erzeugen
458                         **********************************************************/
459                         mpView->SetCurrentObj(OBJ_TEXT);
460                         mpView->SetEditMode(SDREDITMODE_CREATE);
461                         sal_uInt16 nDrgLog = sal_uInt16 ( mpWindow->PixelToLogic(Size(DRGPIX,0)).Width() );
462                         mpView->BegCreateObj(aMDPos, (OutputDevice*) NULL, nDrgLog);
463                     }
464                     else
465                     {
466                         /**********************************************************
467                         * Selektieren
468                         **********************************************************/
469                         if( !rMEvt.IsShift() )
470                             mpView->UnmarkAll();
471 
472                         mpView->BegMarkObj( aMDPos );
473                     }
474                 }
475             }
476         }
477     }
478     else if ( rMEvt.GetClicks() == 2 && !mpView->IsTextEdit() )
479     {
480         MouseEvent aMEvt( mpWindow->GetPointerPosPixel() );
481         SetInEditMode( aMEvt, sal_False );
482     }
483 
484     if (!bIsInDragMode)
485     {
486         ForcePointer(&rMEvt);
487         mpViewShell->GetViewFrame()->GetBindings().Invalidate(SidArray);
488     }
489 
490     return (bReturn);
491 }
492 
493 /*************************************************************************
494 |*
495 |* MouseMove-event
496 |*
497 \************************************************************************/
498 
499 sal_Bool FuText::MouseMove(const MouseEvent& rMEvt)
500 {
501     sal_Bool bReturn = FuDraw::MouseMove(rMEvt);
502 
503     if (aDragTimer.IsActive() )
504     {
505         if( bFirstMouseMove )
506             bFirstMouseMove = sal_False;
507         else
508             aDragTimer.Stop();
509     }
510 
511     if (!bReturn && mpView->IsAction() && !mpDocSh->IsReadOnly())
512     {
513         Point aPix(rMEvt.GetPosPixel());
514         Point aPnt(mpWindow->PixelToLogic(aPix));
515 
516         ForceScroll(aPix);
517         mpView->MovAction(aPnt);
518     }
519 
520     ForcePointer(&rMEvt);
521 
522     return (bReturn);
523 }
524 
525 /*************************************************************************
526 |*
527 |* MouseButtonUp-event
528 |*
529 \************************************************************************/
530 
531 // #97016#
532 void FuText::ImpSetAttributesForNewTextObject(SdrTextObj* pTxtObj)
533 {
534     if(mpDoc->GetDocumentType() == DOCUMENT_TYPE_IMPRESS)
535     {
536         if( nSlotId == SID_ATTR_CHAR )
537         {
538             // Impress-Textobjekt wird erzeugt (faellt auf Zeilenhoehe zusammen)
539             // Damit das Objekt beim anschliessenden Erzeugen gleich die richtige
540             // Hoehe bekommt (sonst wird zuviel gepainted)
541             SfxItemSet aSet(mpViewShell->GetPool());
542             aSet.Put(SdrTextMinFrameHeightItem(0));
543             aSet.Put(SdrTextAutoGrowWidthItem(sal_False));
544             aSet.Put(SdrTextAutoGrowHeightItem(sal_True));
545             pTxtObj->SetMergedItemSet(aSet);
546             pTxtObj->AdjustTextFrameWidthAndHeight();
547             aSet.Put(SdrTextMaxFrameHeightItem(pTxtObj->GetLogicRect().GetSize().Height()));
548             pTxtObj->SetMergedItemSet(aSet);
549         }
550         else if( nSlotId == SID_ATTR_CHAR_VERTICAL )
551         {
552             SfxItemSet aSet(mpViewShell->GetPool());
553             aSet.Put(SdrTextMinFrameWidthItem(0));
554             aSet.Put(SdrTextAutoGrowWidthItem(sal_True));
555             aSet.Put(SdrTextAutoGrowHeightItem(sal_False));
556 
557             // #91853# Needs to be set since default is SDRTEXTHORZADJUST_BLOCK
558             aSet.Put(SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_RIGHT));
559             pTxtObj->SetMergedItemSet(aSet);
560             pTxtObj->AdjustTextFrameWidthAndHeight();
561             aSet.Put(SdrTextMaxFrameWidthItem(pTxtObj->GetLogicRect().GetSize().Width()));
562             pTxtObj->SetMergedItemSet(aSet);
563         }
564     }
565     else
566     {
567         if( nSlotId == SID_ATTR_CHAR_VERTICAL )
568         {
569             // draw text object, needs to be initialized when vertical text is used
570             SfxItemSet aSet(mpViewShell->GetPool());
571 
572             // #91510#
573             aSet.Put(SdrTextAutoGrowWidthItem(sal_True));
574             aSet.Put(SdrTextAutoGrowHeightItem(sal_False));
575 
576             // #91508#
577             //aSet.Put(SdrTextVertAdjustItem(SDRTEXTVERTADJUST_TOP));
578             //aSet.Put(SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_RIGHT));
579 
580             // #107235#
581             // Set defaults for vertical klick-n'drag text object, pool defaults are:
582             // SdrTextVertAdjustItem: SDRTEXTVERTADJUST_TOP
583             // SdrTextHorzAdjustItem: SDRTEXTHORZADJUST_BLOCK
584             // Analog to that (thus, #91508# was not completely correct):
585             aSet.Put(SdrTextVertAdjustItem(SDRTEXTVERTADJUST_BLOCK));
586             aSet.Put(SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_RIGHT));
587 
588             pTxtObj->SetMergedItemSet(aSet);
589         }
590     }
591 }
592 
593 // #97016#
594 void FuText::ImpSetAttributesFitToSize(SdrTextObj* pTxtObj)
595 {
596     // FitToSize (An Rahmen anpassen)
597     SfxItemSet aSet(mpViewShell->GetPool(), SDRATTR_TEXT_AUTOGROWHEIGHT, SDRATTR_TEXT_AUTOGROWWIDTH);
598     SdrFitToSizeType eFTS = SDRTEXTFIT_PROPORTIONAL;
599     aSet.Put(SdrTextFitToSizeTypeItem(eFTS));
600     aSet.Put(SdrTextAutoGrowHeightItem(sal_False));
601     aSet.Put(SdrTextAutoGrowWidthItem(sal_False));
602     pTxtObj->SetMergedItemSet(aSet);
603     pTxtObj->AdjustTextFrameWidthAndHeight();
604 }
605 
606 // #97016#
607 void FuText::ImpSetAttributesFitToSizeVertical(SdrTextObj* pTxtObj)
608 {
609     SfxItemSet aSet(mpViewShell->GetPool(),
610         SDRATTR_TEXT_AUTOGROWHEIGHT, SDRATTR_TEXT_AUTOGROWWIDTH);
611     SdrFitToSizeType eFTS = SDRTEXTFIT_PROPORTIONAL;
612     aSet.Put(SdrTextFitToSizeTypeItem(eFTS));
613     aSet.Put(SdrTextAutoGrowHeightItem(sal_False));
614     aSet.Put(SdrTextAutoGrowWidthItem(sal_False));
615     pTxtObj->SetMergedItemSet(aSet);
616     pTxtObj->AdjustTextFrameWidthAndHeight();
617 }
618 
619 // #97016#
620 void FuText::ImpSetAttributesFitCommon(SdrTextObj* pTxtObj)
621 {
622     // Normales Textobjekt
623     if (mpDoc->GetDocumentType() == DOCUMENT_TYPE_IMPRESS)
624     {
625         if( nSlotId == SID_ATTR_CHAR )
626         {
627             // Impress-Textobjekt (faellt auf Zeilenhoehe zusammen)
628             SfxItemSet aSet(mpViewShell->GetPool());
629             aSet.Put(SdrTextMinFrameHeightItem(0));
630             aSet.Put(SdrTextMaxFrameHeightItem(0));
631             aSet.Put(SdrTextAutoGrowHeightItem(sal_True));
632             aSet.Put(SdrTextAutoGrowWidthItem(sal_False));
633             pTxtObj->SetMergedItemSet(aSet);
634         }
635         else if( nSlotId == SID_ATTR_CHAR_VERTICAL )
636         {
637             SfxItemSet aSet(mpViewShell->GetPool());
638             aSet.Put(SdrTextMinFrameWidthItem(0));
639             aSet.Put(SdrTextMaxFrameWidthItem(0));
640             aSet.Put(SdrTextAutoGrowWidthItem(sal_True));
641             aSet.Put(SdrTextAutoGrowHeightItem(sal_False));
642             pTxtObj->SetMergedItemSet(aSet);
643         }
644 
645         pTxtObj->AdjustTextFrameWidthAndHeight();
646     }
647 }
648 
649 sal_Bool FuText::MouseButtonUp(const MouseEvent& rMEvt)
650 {
651     sal_Bool bReturn = sal_False;
652 
653     if (aDragTimer.IsActive())
654     {
655         aDragTimer.Stop();
656         bIsInDragMode = sal_False;
657     }
658 
659     mpViewShell->GetViewFrame()->GetBindings().Invalidate( SidArray );
660 
661     Point aPnt( mpWindow->PixelToLogic( rMEvt.GetPosPixel() ) );
662 
663     if( (mpView && mpView->MouseButtonUp(rMEvt, mpWindow)) || rMEvt.GetClicks() == 2 )
664         return (sal_True); // Event von der SdrView ausgewertet
665 
666     sal_Bool bEmptyTextObj = sal_False;
667 
668     if (mxTextObj.is())
669     {
670         const SdrMarkList& rMarkList = mpView->GetMarkedObjectList();
671 
672         if (rMarkList.GetMarkCount() == 1
673             && ( rMarkList.GetMark(0)->GetMarkedSdrObj() == mxTextObj.get()) )
674         {
675             if( mxTextObj.is() && !GetTextObj()->GetOutlinerParaObject() )
676                 bEmptyTextObj = sal_True;
677             else
678                 bFirstObjCreated = sal_True;
679         }
680         else
681         {
682             mxTextObj.reset( 0 );
683         }
684     }
685 
686     if( mpView && mpView->IsDragObj())
687     {
688         /**********************************************************************
689         * Objekt wurde verschoben
690         **********************************************************************/
691         FrameView* pFrameView = mpViewShell->GetFrameView();
692         sal_Bool bDragWithCopy = (rMEvt.IsMod1() && pFrameView->IsDragWithCopy());
693 
694         if (bDragWithCopy)
695         {
696             bDragWithCopy = !mpView->IsPresObjSelected(sal_False, sal_True);
697         }
698 
699         mpView->SetDragWithCopy(bDragWithCopy);
700         mpView->EndDragObj( mpView->IsDragWithCopy() );
701         mpView->ForceMarkedToAnotherPage();
702         mpView->SetCurrentObj(OBJ_TEXT);
703 
704         sal_uInt16 nDrgLog = sal_uInt16 ( mpWindow->PixelToLogic(Size(DRGPIX,0)).Width() );
705 
706         if ( mpView->IsRotateAllowed() && mpViewShell->GetFrameView()->IsClickChangeRotation() && (rMEvt.GetClicks() != 2) &&
707             !rMEvt.IsShift() && !rMEvt.IsMod1() && !rMEvt.IsMod2() && !rMEvt.IsRight() &&
708             Abs(aPnt.X() - aMDPos.X()) < nDrgLog &&
709             Abs(aPnt.Y() - aMDPos.Y()) < nDrgLog)
710         {
711             // toggle to rotation mode
712             mpViewShell->GetViewFrame()->GetDispatcher()->Execute( SID_OBJECT_ROTATE, SFX_CALLMODE_ASYNCHRON | SFX_CALLMODE_RECORD );
713         }
714     }
715     else if( mpView && mpView->IsCreateObj() && rMEvt.IsLeft())
716     {
717         /**********************************************************************
718         * Objekt wurde erzeugt
719         **********************************************************************/
720         mxTextObj.reset( dynamic_cast< SdrTextObj* >( mpView->GetCreateObj() ) );
721 
722         if( mxTextObj.is() )
723         {
724             //AW outliner needs to be set to vertical when there is no
725             // outliner object up to now; also it needs to be set back to not
726             // vertical when there was a vertical one used last time.
727             OutlinerParaObject* pOPO = GetTextObj()->GetOutlinerParaObject();
728             SdrOutliner& rOutl = mxTextObj->GetModel()->GetDrawOutliner(GetTextObj());
729             sal_Bool bVertical((pOPO && pOPO->IsVertical())
730                 || nSlotId == SID_ATTR_CHAR_VERTICAL
731                 || nSlotId == SID_TEXT_FITTOSIZE_VERTICAL);
732             rOutl.SetVertical(bVertical);
733 
734             // #107235#
735             // Before ImpSetAttributesForNewTextObject the vertical writing mode
736             // needs to be set at the object. This is done here at the OutlinerParaObject
737             // directly to not mirror the layout text items involved. These items will be set
738             // from ImpSetAttributesForNewTextObject and below.
739             OutlinerParaObject* pPara = GetTextObj()->GetOutlinerParaObject();
740 
741             if(!pPara)
742             {
743                 GetTextObj()->ForceOutlinerParaObject();
744                 pPara = GetTextObj()->GetOutlinerParaObject();
745             }
746 
747             if(pPara && (bool)bVertical != pPara->IsVertical())
748             {
749                 // set ParaObject orientation accordingly
750                 pPara->SetVertical(bVertical);
751             }
752 
753             // #97016#
754             ImpSetAttributesForNewTextObject(GetTextObj());
755         }
756 
757         if (!mpView->EndCreateObj(SDRCREATE_FORCEEND))
758         {
759             // Textobjekt konnte nicht erzeugt werden
760             mxTextObj.reset(0);
761         }
762         else if (nSlotId == SID_TEXT_FITTOSIZE)
763         {
764             // #97016#
765             ImpSetAttributesFitToSize(GetTextObj());
766 
767             SetInEditMode(rMEvt, sal_False);
768         }
769         else if ( nSlotId == SID_TEXT_FITTOSIZE_VERTICAL )
770         {
771             // #97016#
772             ImpSetAttributesFitToSizeVertical(GetTextObj());
773 
774             SetInEditMode(rMEvt, sal_False);
775         }
776         else
777         {
778             // #97016#
779             ImpSetAttributesFitCommon(GetTextObj());
780 
781             // Damit die Handles und der graue Rahmen stimmen
782             mpView->AdjustMarkHdl();
783             mpView->PickHandle(aPnt);
784             SetInEditMode(rMEvt, sal_False);
785         }
786     }
787     else if ( mpView && mpView->IsAction())
788     {
789         mpView->EndAction();
790     }
791 
792     ForcePointer(&rMEvt);
793     mpWindow->ReleaseMouse();
794     sal_uInt16 nDrgLog1 = sal_uInt16 ( mpWindow->PixelToLogic(Size(DRGPIX,0)).Width() );
795 
796     if ( mpView && !mpView->AreObjectsMarked() &&
797          Abs(aMDPos.X() - aPnt.X()) < nDrgLog1 &&
798          Abs(aMDPos.Y() - aPnt.Y()) < nDrgLog1 &&
799          !rMEvt.IsShift() && !rMEvt.IsMod2() )
800     {
801         SdrPageView* pPV = mpView->GetSdrPageView();
802         SdrViewEvent aVEvt;
803         mpView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
804         mpView->MarkObj(aVEvt.pRootObj, pPV);
805     }
806 
807     if ( !mxTextObj.is() && mpView )
808     {
809         if ( ( (!bEmptyTextObj   &&  bPermanent) ||
810              (!bFirstObjCreated && !bPermanent) ) &&
811               !mpDocSh->IsReadOnly()               &&
812               nSlotId != SID_TEXTEDIT )
813         {
814             /**********************************************************************
815             * Mengentext (linksbuendiges AutoGrow)
816             **********************************************************************/
817             mpView->SetCurrentObj(OBJ_TEXT);
818             mpView->SetEditMode(SDREDITMODE_CREATE);
819             sal_uInt16 nDrgLog = sal_uInt16 ( mpWindow->PixelToLogic(Size(DRGPIX,0)).Width() );
820             mpView->BegCreateObj(aMDPos, (OutputDevice*) NULL, nDrgLog);
821 
822             sal_Bool bSnapEnabled = mpView->IsSnapEnabled();
823 
824             if (bSnapEnabled)
825                 mpView->SetSnapEnabled(sal_False);
826 
827             aPnt.X() += nDrgLog + nDrgLog;
828             aPnt.Y() += nDrgLog + nDrgLog;
829             mpView->MovAction(aPnt);
830 
831             mxTextObj.reset( dynamic_cast< SdrTextObj* >( mpView->GetCreateObj() ) );
832 
833             if(mxTextObj.is())
834             {
835                 GetTextObj()->SetDisableAutoWidthOnDragging(sal_True);
836             }
837 
838             if(!mpView->EndCreateObj(SDRCREATE_FORCEEND))
839             {
840                 mxTextObj.reset(0);
841             }
842 
843             if(bSnapEnabled)
844                 mpView->SetSnapEnabled(bSnapEnabled);
845 
846             if(mxTextObj.is())
847             {
848                 SfxItemSet aSet(mpViewShell->GetPool());
849                 aSet.Put(SdrTextMinFrameHeightItem(0));
850                 aSet.Put(SdrTextMinFrameWidthItem(0));
851                 aSet.Put(SdrTextAutoGrowHeightItem(sal_True));
852                 aSet.Put(SdrTextAutoGrowWidthItem(sal_True));
853 
854                 // #91508#
855                 if(nSlotId == SID_ATTR_CHAR_VERTICAL)
856                 {
857                     // #107235#
858                     //
859                     // Here, all items which need to be different from pool default need to be set
860                     // again on the newly created text object.
861                     // Since this is a simple klick text object, it is first created, then SetVertical()
862                     // is used, then ImpSetAttributesForNewTextObject is called and then the object is
863                     // deleted again since not the minimum drag distance was travelled. Then, a new
864                     // klick text object is created and thus all that stuff needs to be set again here.
865                     //
866                     // Before using the new object the vertical writing mode
867                     // needs to be set. This is done here at the OutlinerParaObject
868                     // directly to not mirror the layout text items involved. These items will be set
869                     // below.
870                     OutlinerParaObject* pPara = GetTextObj()->GetOutlinerParaObject();
871 
872                     if(!pPara)
873                     {
874                         GetTextObj()->ForceOutlinerParaObject();
875                         pPara = GetTextObj()->GetOutlinerParaObject();
876                     }
877 
878                     if(pPara && sal_True != pPara->IsVertical())
879                     {
880                         // set ParaObject orientation accordingly
881                         pPara->SetVertical(sal_True);
882                     }
883 
884                     // #91508#
885                     // aSet.Put(SdrTextVertAdjustItem(SDRTEXTVERTADJUST_TOP));
886                     aSet.Put(SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_RIGHT));
887 
888                     // #107235#
889                     // Analog to the else case below, for vertical simple click texts
890                     // one of the defaulted setted items from ImpSetAttributesForNewTextObject
891                     // needs to be adapted to non-block mode. This could have been done with the
892                     // #104122#, but was obviously overseen.
893                     const SfxItemSet& rSet = mpView->GetDefaultAttr();
894                     SvxFrameDirection eDirection = (SvxFrameDirection)((SvxFrameDirectionItem&)rSet.Get(EE_PARA_WRITINGDIR)).GetValue();
895 
896                     if(FRMDIR_HORI_RIGHT_TOP == eDirection || FRMDIR_VERT_TOP_RIGHT == eDirection)
897                     {
898                         aSet.Put(SdrTextVertAdjustItem(SDRTEXTVERTADJUST_BOTTOM));
899                     }
900                     else
901                     {
902                         aSet.Put(SdrTextVertAdjustItem(SDRTEXTVERTADJUST_TOP));
903                     }
904                 }
905                 else
906                 {
907                     // #104122# This is for Format/Page settings. Since this also leads
908                     // to the object defaults to be changed, i think this code can be
909                     // removed. CL. wanted to take a look before adding this.
910                     //const SdrTextHorzAdjust eHA = ( ( pDoc && pDoc->GetDefaultWritingMode() == ::com::sun::star::text::WritingMode_RL_TB ) ?
911                     //                                SDRTEXTHORZADJUST_RIGHT : SDRTEXTHORZADJUST_LEFT );
912                     //aSet.Put( SdrTextHorzAdjustItem( eHA ) );
913 
914                     // #104122# Look in the object defaults if left-to-right is wanted. If
915                     // yes, set text anchoring to right to let the box grow to left.
916                     const SfxItemSet& rSet = mpView->GetDefaultAttr();
917                     SvxFrameDirection eDirection = (SvxFrameDirection)((SvxFrameDirectionItem&)rSet.Get(EE_PARA_WRITINGDIR)).GetValue();
918 
919                     if(FRMDIR_HORI_RIGHT_TOP == eDirection)
920                     {
921                         aSet.Put(SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_RIGHT));
922                     }
923                     else
924                     {
925                         aSet.Put(SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_LEFT));
926                     }
927                 }
928 
929                 GetTextObj()->SetMergedItemSet(aSet);
930                 GetTextObj()->SetDisableAutoWidthOnDragging(sal_True);
931                 SetInEditMode(rMEvt, sal_False);
932             }
933 
934             bFirstObjCreated = sal_True;
935         }
936         else
937         {
938             // In die Fkt. Selektion wechseln
939             if (mpView->SdrEndTextEdit() == SDRENDTEXTEDIT_DELETED)
940             {
941                 mxTextObj.reset(0);
942             }
943 
944             mpViewShell->GetViewFrame()->GetDispatcher()->Execute( SID_OBJECT_SELECT,
945                                       SFX_CALLMODE_ASYNCHRON | SFX_CALLMODE_RECORD );
946         }
947     }
948 
949     bMBDown = sal_False;
950     FuConstruct::MouseButtonUp(rMEvt);
951     return (bReturn);
952 }
953 
954 /*************************************************************************
955 |*
956 |* Tastaturereignisse bearbeiten
957 |*
958 |* Wird ein KeyEvent bearbeitet, so ist der Return-Wert sal_True, andernfalls
959 |* sal_False.
960 |*
961 \************************************************************************/
962 
963 sal_Bool FuText::KeyInput(const KeyEvent& rKEvt)
964 {
965     sal_Bool bReturn = sal_False;
966     mpView->SetMarkHdlWhenTextEdit(sal_True);
967 
968     KeyCode nCode = rKEvt.GetKeyCode();
969     sal_Bool bShift = nCode.IsShift();
970 
971     // #97016# IV
972     if(mxTextObj.is())
973     {
974         // maybe object is deleted, test if it's equal to the selected object
975         const SdrMarkList& rMarkList = mpView->GetMarkedObjectList();
976         SdrObject* pSelectedObj = 0L;
977 
978         if(1 == rMarkList.GetMarkCount())
979         {
980             SdrMark* pMark = rMarkList.GetMark(0);
981             pSelectedObj = pMark->GetMarkedSdrObj();
982         }
983 
984         if(mxTextObj.get() != pSelectedObj)
985         {
986             mxTextObj.reset(0);
987         }
988     }
989 
990     if ( mxTextObj.is() && mxTextObj->GetObjInventor() == SdrInventor && mxTextObj->GetObjIdentifier() == OBJ_TITLETEXT && rKEvt.GetKeyCode().GetCode() == KEY_RETURN )
991     {
992         // Titeltext-Objekt: immer "weiche" Umbrueche
993         bShift = sal_True;
994     }
995 
996     sal_uInt16 nKey = nCode.GetCode();
997     KeyCode aKeyCode (nKey, bShift, nCode.IsMod1(), nCode.IsMod2(), nCode.IsMod3() );
998     KeyEvent aKEvt(rKEvt.GetCharCode(), aKeyCode);
999 
1000     sal_Bool bOK = sal_True;
1001 
1002     if (mpDocSh->IsReadOnly())
1003     {
1004         bOK = !EditEngine::DoesKeyChangeText(aKEvt);
1005     }
1006     if( aKeyCode.GetCode() == KEY_PAGEUP || aKeyCode.GetCode() == KEY_PAGEDOWN )
1007     {
1008         bOK = sal_False;   // default handling in base class
1009     }
1010 
1011     if (bOK && mpView->KeyInput(aKEvt, mpWindow) )
1012     {
1013         bReturn = sal_True;
1014 
1015         mpViewShell->GetViewFrame()->GetBindings().Invalidate( SidArray );
1016 
1017 //      if ( pTextObj )
1018 //          pTextObj->SetEmptyPresObj(sal_False);
1019     }
1020     else if (aKeyCode == KEY_ESCAPE)
1021     {
1022         bReturn = cancel();
1023     }
1024 
1025     if( bPermanent )
1026     {
1027         mpView->SetCurrentObj(OBJ_TEXT);
1028         mpView->SetEditMode(SDREDITMODE_CREATE);
1029     }
1030 
1031     if (!bReturn)
1032     {
1033         bReturn = FuDraw::KeyInput(aKEvt);
1034     }
1035 
1036     return (bReturn);
1037 }
1038 
1039 
1040 
1041 /*************************************************************************
1042 |*
1043 |* Function aktivieren
1044 |*
1045 \************************************************************************/
1046 
1047 void FuText::Activate()
1048 {
1049     mpView->SetQuickTextEditMode(mpViewShell->GetFrameView()->IsQuickEdit());
1050 
1051     // #i89661# it's no longer necessary to make it so big here, it's fine tuned
1052     // for text objects in SdrMarkView::CheckSingleSdrObjectHit
1053     mpView->SetHitTolerancePixel( 2 * HITPIX );
1054 
1055     OutlinerView* pOLV = mpView->GetTextEditOutlinerView();
1056 
1057     if (pOLV)
1058         pOLV->ShowCursor();
1059 
1060     FuConstruct::Activate();
1061 
1062     if( pOLV )
1063         mpView->SetEditMode(SDREDITMODE_EDIT);
1064 }
1065 
1066 
1067 /*************************************************************************
1068 |*
1069 |* Function deaktivieren
1070 |*
1071 \************************************************************************/
1072 
1073 void FuText::Deactivate()
1074 {
1075     OutlinerView* pOLV = mpView->GetTextEditOutlinerView();
1076 
1077     if (pOLV)
1078         pOLV->HideCursor();
1079 
1080     mpView->SetHitTolerancePixel( HITPIX );
1081 
1082     FuConstruct::Deactivate();
1083 }
1084 
1085 
1086 /*************************************************************************
1087 |*
1088 |* Objekt in Edit-Mode setzen
1089 |*
1090 \************************************************************************/
1091 
1092 void FuText::SetInEditMode(const MouseEvent& rMEvt, sal_Bool bQuickDrag)
1093 {
1094     SdrPageView* pPV = mpView->GetSdrPageView();
1095     if( mxTextObj.is() && (mxTextObj->GetPage() == pPV->GetPage()) )
1096     {
1097         mpView->SetCurrentObj(OBJ_TEXT);
1098 
1099         if( bPermanent )
1100             mpView->SetEditMode(SDREDITMODE_CREATE);
1101         else
1102             mpView->SetEditMode(SDREDITMODE_EDIT);
1103 
1104         sal_Bool bEmptyOutliner = sal_False;
1105 
1106         if (!GetTextObj()->GetOutlinerParaObject() && mpView->GetTextEditOutliner())
1107         {
1108             ::Outliner* pOutl = mpView->GetTextEditOutliner();
1109             sal_uLong nParaAnz = pOutl->GetParagraphCount();
1110             Paragraph* p1stPara = pOutl->GetParagraph( 0 );
1111 
1112             if (nParaAnz==1 && p1stPara)
1113             {
1114                 // Bei nur einem Pararaph
1115                 if (pOutl->GetText(p1stPara).Len() == 0)
1116                 {
1117                     bEmptyOutliner = sal_True;
1118                 }
1119             }
1120         }
1121 
1122         if (GetTextObj() != mpView->GetTextEditObject() || bEmptyOutliner)
1123         {
1124             sal_uInt32 nInv = mxTextObj->GetObjInventor();
1125             sal_uInt16 nSdrObjKind = mxTextObj->GetObjIdentifier();
1126 
1127             if (nInv == SdrInventor && GetTextObj()->HasTextEdit() &&
1128                 (nSdrObjKind == OBJ_TEXT ||
1129                 nSdrObjKind == OBJ_TITLETEXT ||
1130                 nSdrObjKind == OBJ_OUTLINETEXT || !mxTextObj->IsEmptyPresObj() ) )
1131             {
1132                 // Neuen Outliner machen (gehoert der SdrObjEditView)
1133                 SdrOutliner* pOutl = SdrMakeOutliner( OUTLINERMODE_OUTLINEOBJECT, mpDoc );
1134 
1135                 if (bEmptyOutliner)
1136                     mpView->SdrEndTextEdit(sal_True);
1137 
1138                 SdrTextObj* pTextObj = GetTextObj();
1139                 if( pTextObj )
1140                 {
1141                     OutlinerParaObject* pOPO = pTextObj->GetOutlinerParaObject();
1142                     if( ( pOPO && pOPO->IsVertical() ) || (nSlotId == SID_ATTR_CHAR_VERTICAL) || (nSlotId == SID_TEXT_FITTOSIZE_VERTICAL) )
1143                         pOutl->SetVertical( sal_True );
1144 
1145                     if( pTextObj->getTextCount() > 1 )
1146                     {
1147                         Point aPix(rMEvt.GetPosPixel());
1148                         Point aPnt(mpWindow->PixelToLogic(aPix));
1149                         pTextObj->setActiveText( pTextObj->CheckTextHit(aPnt ) );
1150                     }
1151 
1152                     if (mpView->SdrBeginTextEdit(pTextObj, pPV, mpWindow, sal_True, pOutl) && mxTextObj->GetObjInventor() == SdrInventor)
1153                     {
1154                         bFirstObjCreated = sal_True;
1155                         DeleteDefaultText();
1156 
1157                         OutlinerView* pOLV = mpView->GetTextEditOutlinerView();
1158 
1159                         nSdrObjKind = mxTextObj->GetObjIdentifier();
1160 
1161                         SdrViewEvent aVEvt;
1162                         SdrHitKind eHit = mpView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
1163 
1164                         if (eHit == SDRHIT_TEXTEDIT)
1165                         {
1166                             // Text getroffen
1167                             if (nSdrObjKind == OBJ_TEXT ||
1168                                 nSdrObjKind == OBJ_TITLETEXT ||
1169                                 nSdrObjKind == OBJ_OUTLINETEXT ||
1170                                 nSdrObjKind == OBJ_TABLE ||
1171                                 nSlotId == SID_TEXTEDIT ||
1172                                 !bQuickDrag)
1173                             {
1174                                 pOLV->MouseButtonDown(rMEvt);
1175                                 pOLV->MouseMove(rMEvt);
1176                                 pOLV->MouseButtonUp(rMEvt);
1177                             }
1178 
1179                             if (mpViewShell->GetFrameView()->IsQuickEdit() && bQuickDrag && GetTextObj()->GetOutlinerParaObject())
1180                             {
1181                                 pOLV->MouseButtonDown(rMEvt);
1182                             }
1183                         }
1184                         else
1185                         {
1186                             // #98198# Move cursor to end of text
1187                             ESelection aNewSelection(EE_PARA_NOT_FOUND, EE_INDEX_NOT_FOUND, EE_PARA_NOT_FOUND, EE_INDEX_NOT_FOUND);
1188                             pOLV->SetSelection(aNewSelection);
1189                         }
1190                     }
1191                     else
1192                     {
1193                         mpView->RestoreDefaultText(dynamic_cast< SdrTextObj* >( mxTextObj.get() ));
1194                     }
1195                 }
1196             }
1197         }
1198     }
1199     else
1200     {
1201         mxTextObj.reset(0);
1202     }
1203 }
1204 
1205 /*************************************************************************
1206 |*
1207 |* Texteingabe wird gestartet, ggf. Default-Text loeschen
1208 |*
1209 \************************************************************************/
1210 
1211 sal_Bool FuText::DeleteDefaultText()
1212 {
1213     sal_Bool bDeleted = sal_False;
1214 
1215     if ( mxTextObj.is() && mxTextObj->IsEmptyPresObj() )
1216     {
1217         String aString;
1218         SdPage* pPage = (SdPage*) mxTextObj->GetPage();
1219 
1220         if (pPage)
1221         {
1222             PresObjKind ePresObjKind = pPage->GetPresObjKind(mxTextObj.get());
1223 
1224             if ( (ePresObjKind == PRESOBJ_TITLE   ||
1225                   ePresObjKind == PRESOBJ_OUTLINE ||
1226                   ePresObjKind == PRESOBJ_NOTES   ||
1227                   ePresObjKind == PRESOBJ_TEXT) &&
1228                   !pPage->IsMasterPage() )
1229             {
1230                 ::Outliner* pOutliner = mpView->GetTextEditOutliner();
1231                 SfxStyleSheet* pSheet = pOutliner->GetStyleSheet( 0 );
1232                 sal_Bool bIsUndoEnabled = pOutliner->IsUndoEnabled();
1233                 if( bIsUndoEnabled )
1234                     pOutliner->EnableUndo(sal_False);
1235 
1236                 pOutliner->SetText( String(), pOutliner->GetParagraph( 0 ) );
1237 
1238                 if( bIsUndoEnabled )
1239                     pOutliner->EnableUndo(sal_True);
1240 
1241                 if (pSheet &&
1242                     (ePresObjKind == PRESOBJ_NOTES || ePresObjKind == PRESOBJ_TEXT))
1243                     pOutliner->SetStyleSheet(0, pSheet);
1244 
1245                 mxTextObj->SetEmptyPresObj(sal_True);
1246                 bDeleted = sal_True;
1247             }
1248         }
1249     }
1250 
1251     return(bDeleted);
1252 }
1253 
1254 /*************************************************************************
1255 |*
1256 |* Command-event
1257 |*
1258 \************************************************************************/
1259 
1260 sal_Bool FuText::Command(const CommandEvent& rCEvt)
1261 {
1262     return( FuPoor::Command(rCEvt) );
1263 }
1264 
1265 /*************************************************************************
1266 |*
1267 |* Help-event
1268 |*
1269 \************************************************************************/
1270 
1271 sal_Bool FuText::RequestHelp(const HelpEvent& rHEvt)
1272 {
1273     sal_Bool bReturn = sal_False;
1274 
1275     OutlinerView* pOLV = mpView->GetTextEditOutlinerView();
1276 
1277     if ((Help::IsBalloonHelpEnabled() || Help::IsQuickHelpEnabled()) &&
1278         mxTextObj.is() && pOLV && pOLV->GetFieldUnderMousePointer())
1279     {
1280         String aHelpText;
1281         const SvxFieldItem* pFieldItem = pOLV->GetFieldUnderMousePointer();
1282         const SvxFieldData* pField = pFieldItem->GetField();
1283 
1284         if (pField && pField->ISA(SvxURLField))
1285         {
1286             /******************************************************************
1287             * URL-Field
1288             ******************************************************************/
1289             aHelpText = INetURLObject::decode( ((const SvxURLField*)pField)->GetURL(), '%', INetURLObject::DECODE_WITH_CHARSET );
1290         }
1291         if (aHelpText.Len())
1292         {
1293             Rectangle aLogicPix = mpWindow->LogicToPixel(mxTextObj->GetLogicRect());
1294             Rectangle aScreenRect(mpWindow->OutputToScreenPixel(aLogicPix.TopLeft()),
1295                                   mpWindow->OutputToScreenPixel(aLogicPix.BottomRight()));
1296 
1297             if (Help::IsBalloonHelpEnabled())
1298             {
1299                 bReturn = Help::ShowBalloon( (Window*)mpWindow, rHEvt.GetMousePosPixel(), aScreenRect, aHelpText);
1300             }
1301             else if (Help::IsQuickHelpEnabled())
1302             {
1303                 bReturn = Help::ShowQuickHelp( (Window*)mpWindow, aScreenRect, aHelpText);
1304             }
1305         }
1306     }
1307 
1308     if (!bReturn)
1309     {
1310         bReturn = FuConstruct::RequestHelp(rHEvt);
1311     }
1312 
1313     return(bReturn);
1314 }
1315 
1316 /*************************************************************************
1317 |*
1318 |* Request verarbeiten
1319 |*
1320 \************************************************************************/
1321 
1322 void FuText::ReceiveRequest(SfxRequest& rReq)
1323 {
1324     nSlotId = rReq.GetSlot();
1325 
1326     // Dann Basisklasse rufen (dort wird u.a. nSlotId NICHT gesetzt)
1327     FuPoor::ReceiveRequest(rReq);
1328 
1329     if (nSlotId == SID_TEXTEDIT || mpViewShell->GetFrameView()->IsQuickEdit() || /*#95971#*/ SID_ATTR_CHAR == nSlotId)
1330     {
1331         MouseEvent aMEvt(mpWindow->GetPointerPosPixel());
1332 
1333         mxTextObj.reset(0);
1334 
1335         if (nSlotId == SID_TEXTEDIT)
1336         {
1337             // Wird gerade editiert?
1338             if(!bTestText)
1339                 mxTextObj.reset( dynamic_cast< SdrTextObj* >( mpView->GetTextEditObject() ) );
1340 
1341             if (!mxTextObj.is())
1342             {
1343                 // Versuchen, ein Obj zu selektieren
1344                 SdrPageView* pPV = mpView->GetSdrPageView();
1345                 SdrViewEvent aVEvt;
1346                 mpView->PickAnything(aMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
1347                 mpView->MarkObj(aVEvt.pRootObj, pPV);
1348 
1349                 if (aVEvt.pObj && aVEvt.pObj->ISA(SdrTextObj))
1350                 {
1351                     mxTextObj.reset( static_cast< SdrTextObj* >( aVEvt.pObj ) );
1352                 }
1353             }
1354         }
1355         else if (mpView->AreObjectsMarked())
1356         {
1357             const SdrMarkList& rMarkList = mpView->GetMarkedObjectList();
1358 
1359             if (rMarkList.GetMarkCount() == 1)
1360             {
1361                 SdrObject* pObj = rMarkList.GetMark(0)->GetMarkedSdrObj();
1362 
1363                 if (pObj->ISA(SdrTextObj))
1364                 {
1365                     mxTextObj.reset( static_cast< SdrTextObj* >( pObj ) );
1366                 }
1367             }
1368         }
1369 
1370         sal_Bool bQuickDrag = sal_True;
1371 
1372         const SfxItemSet* pArgs = rReq.GetArgs();
1373 
1374         if (pArgs
1375 
1376             // #98198# test for type before using
1377             && SID_TEXTEDIT == nSlotId
1378             && SFX_ITEM_SET == pArgs->GetItemState(SID_TEXTEDIT)
1379 
1380             && (sal_uInt16) ((SfxUInt16Item&) pArgs->Get(SID_TEXTEDIT)).GetValue() == 2)
1381         {
1382             // Anwahl per Doppelklick -> kein QuickDrag zulassen
1383             bQuickDrag = sal_False;
1384         }
1385 
1386         SetInEditMode(aMEvt, bQuickDrag);
1387     }
1388 }
1389 
1390 
1391 
1392 /*************************************************************************
1393 |*
1394 |* SpellChecker: Error-LinkHdl
1395 |*
1396 \************************************************************************/
1397 
1398 IMPL_LINK( FuText, SpellError, void *, nLang )
1399 {
1400     String aError( SvtLanguageTable::GetLanguageString( (LanguageType)(sal_uLong)nLang ) );
1401     ErrorHandler::HandleError(* new StringErrorInfo(
1402                                 ERRCODE_SVX_LINGU_LANGUAGENOTEXISTS, aError) );
1403     return 0;
1404 }
1405 
1406 
1407 /*************************************************************************
1408 |*
1409 |* Reaktion auf Doppelklick
1410 |*
1411 \************************************************************************/
1412 void FuText::DoubleClick(const MouseEvent& )
1413 {
1414     // Nichts zu tun
1415 }
1416 
1417 /** #97016#
1418     #105815# Removed the insertion of default text and putting a new text
1419     object directly into edit mode.
1420 */
1421 SdrObject* FuText::CreateDefaultObject(const sal_uInt16 nID, const Rectangle& rRectangle)
1422 {
1423     // case SID_TEXTEDIT:   // BASIC ???
1424     // case SID_ATTR_CHAR:
1425     // case SID_ATTR_CHAR_VERTICAL:
1426     // case SID_TEXT_FITTOSIZE:
1427     // case SID_TEXT_FITTOSIZE_VERTICAL:
1428 
1429     SdrObject* pObj = SdrObjFactory::MakeNewObject(
1430         mpView->GetCurrentObjInventor(), mpView->GetCurrentObjIdentifier(),
1431         0L, mpDoc);
1432 
1433     if(pObj)
1434     {
1435         if(pObj->ISA(SdrTextObj))
1436         {
1437             SdrTextObj* pText = (SdrTextObj*)pObj;
1438             pText->SetLogicRect(rRectangle);
1439 
1440             sal_Bool bVertical = (SID_ATTR_CHAR_VERTICAL == nID || SID_TEXT_FITTOSIZE_VERTICAL == nID);
1441             pText->SetVerticalWriting(bVertical);
1442 
1443             // #97016#
1444             ImpSetAttributesForNewTextObject(pText);
1445 
1446             if (nSlotId == SID_TEXT_FITTOSIZE)
1447             {
1448                 // #97016#
1449                 ImpSetAttributesFitToSize(pText);
1450             }
1451             else if ( nSlotId == SID_TEXT_FITTOSIZE_VERTICAL )
1452             {
1453                 // #97016#
1454                 ImpSetAttributesFitToSizeVertical(pText);
1455             }
1456             else
1457             {
1458                 // #97016#
1459                 ImpSetAttributesFitCommon(pText);
1460             }
1461 
1462             // Put text object into edit mode.
1463             SdrPageView* pPV = mpView->GetSdrPageView();
1464             mpView->SdrBeginTextEdit(pText, pPV);
1465         }
1466         else
1467         {
1468             DBG_ERROR("Object is NO text object");
1469         }
1470     }
1471 
1472     return pObj;
1473 }
1474 
1475 
1476 
1477 
1478 /** is called when the currenct function should be aborted. <p>
1479     This is used when a function gets a KEY_ESCAPE but can also
1480     be called directly.
1481 
1482     @returns true if a active function was aborted
1483 */
1484 bool FuText::cancel()
1485 {
1486     if ( mpView->IsTextEdit() )
1487     {
1488         if(mpView->SdrEndTextEdit() == SDRENDTEXTEDIT_DELETED)
1489             mxTextObj.reset(0);
1490 
1491         mpView->SetCurrentObj(OBJ_TEXT);
1492         mpView->SetEditMode(SDREDITMODE_EDIT);
1493         return true;
1494     }
1495     else
1496     {
1497         return false;
1498     }
1499 }
1500 
1501 void FuText::ChangeFontSize( bool bGrow, OutlinerView* pOLV, const FontList* pFontList, ::sd::View* pView )
1502 {
1503     if( !pFontList || !pView )
1504         return;
1505 
1506     if( pOLV )
1507     {
1508         pOLV->GetEditView().ChangeFontSize( bGrow, pFontList );
1509     }
1510     else
1511     {
1512 //      SdDrawDocument* pDoc = pView->GetDoc();
1513 
1514         const SdrMarkList& rMarkList = pView->GetMarkedObjectList();
1515         for( sal_uInt32 nMark = 0; nMark < rMarkList.GetMarkCount(); nMark++ )
1516         {
1517             SdrTextObj* pTextObj = dynamic_cast< SdrTextObj* >( rMarkList.GetMark(nMark)->GetMarkedSdrObj() );
1518             if( pTextObj )
1519             {
1520                 for( sal_Int32 nText = 0; nText < pTextObj->getTextCount(); nText++ )
1521                 {
1522                     pTextObj->setActiveText( nText );
1523 
1524                     // Put text object into edit mode.
1525                     SdrPageView* pPV = pView->GetSdrPageView();
1526                     pView->SdrBeginTextEdit(pTextObj, pPV);
1527 
1528                     pOLV = pView->GetTextEditOutlinerView();
1529                     if( pOLV )
1530                     {
1531                         EditEngine* pEditEngine = pOLV->GetEditView().GetEditEngine();
1532                         if( pEditEngine )
1533                         {
1534                             ESelection aSel;
1535                             aSel.nEndPara = pEditEngine->GetParagraphCount()-1;
1536                             aSel.nEndPos = pEditEngine->GetTextLen(aSel.nEndPara);
1537                             pOLV->SetSelection(aSel);
1538                         }
1539 
1540                         ChangeFontSize( bGrow, pOLV, pFontList, pView );
1541                     }
1542 
1543                     pView->SdrEndTextEdit();
1544                 }
1545 
1546                 SfxItemSet aShapeSet( pTextObj->GetMergedItemSet() );
1547                 if( EditView::ChangeFontSize( bGrow, aShapeSet, pFontList ) )
1548                 {
1549                     pTextObj->SetObjectItemNoBroadcast( aShapeSet.Get( EE_CHAR_FONTHEIGHT ) );
1550                     pTextObj->SetObjectItemNoBroadcast( aShapeSet.Get( EE_CHAR_FONTHEIGHT_CJK ) );
1551                     pTextObj->SetObjectItemNoBroadcast( aShapeSet.Get( EE_CHAR_FONTHEIGHT_CTL ) );
1552                 }
1553             }
1554         }
1555     }
1556 }
1557 
1558 } // end of namespace sd
1559 
1560