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