xref: /trunk/main/sd/source/ui/func/fuconcs.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_sd.hxx"
30 
31 #include "fuconcs.hxx"
32 #include <svx/svdpagv.hxx>
33 
34 
35 #include <svx/svxids.hrc>
36 #include <svx/dialogs.hrc>
37 #include <svx/dialmgr.hxx>
38 
39 #include "app.hrc"
40 #include <svl/aeitem.hxx>
41 #include <svx/xlnstwit.hxx>
42 #include <svx/xlnedwit.hxx>
43 #include <svx/xlnedit.hxx>
44 #include <svx/xlnstit.hxx>
45 #include <svx/xlnwtit.hxx>
46 #include <sfx2/viewfrm.hxx>
47 #include <svx/sdtmfitm.hxx>
48 #include <svx/sxekitm.hxx>
49 #include <svx/sderitm.hxx>
50 #include <sfx2/dispatch.hxx>
51 #include <svx/svdopath.hxx>
52 #include <svx/svdocirc.hxx>
53 #include <svl/intitem.hxx>
54 #include <sfx2/request.hxx>
55 #include <editeng/adjitem.hxx>
56 #include <svx/xtable.hxx>
57 #include <svx/sdasitm.hxx>
58 #include <svx/tbxcustomshapes.hxx>
59 #include <svx/svdoashp.hxx>
60 #include <svx/sdtagitm.hxx>
61 
62 // #88751#
63 #include <svx/svdocapt.hxx>
64 
65 // #97016#
66 #include <svx/svdomeas.hxx>
67 #include "ViewShell.hxx"
68 #include "ViewShellBase.hxx"
69 #include "ToolBarManager.hxx"
70 // #109583#
71 #include <editeng/writingmodeitem.hxx>
72 #include <svx/gallery.hxx>
73 #include <svl/itempool.hxx>
74 #include <com/sun/star/uno/Any.hxx>
75 
76 #include "sdresid.hxx"
77 #include "View.hxx"
78 #include "sdpage.hxx"
79 #include "Window.hxx"
80 #include "stlpool.hxx"
81 #include "drawdoc.hxx"
82 #include "res_bmp.hrc"
83 #include "glob.hrc"
84 
85 namespace sd {
86 
87 TYPEINIT1( FuConstructCustomShape, FuConstruct );
88 
89 /*************************************************************************
90 |*
91 |* Konstruktor
92 |*
93 \************************************************************************/
94 
95 FuConstructCustomShape::FuConstructCustomShape (
96         ViewShell*          pViewSh,
97         ::sd::Window*       pWin,
98         ::sd::View*         pView,
99         SdDrawDocument*     pDoc,
100         SfxRequest&         rReq ) :
101     FuConstruct(pViewSh, pWin, pView, pDoc, rReq)
102 {
103 }
104 
105 FunctionReference FuConstructCustomShape::Create( ViewShell* pViewSh, ::sd::Window* pWin, ::sd::View* pView, SdDrawDocument* pDoc, SfxRequest& rReq, bool bPermanent )
106 {
107     FuConstructCustomShape* pFunc;
108     FunctionReference xFunc( pFunc = new FuConstructCustomShape( pViewSh, pWin, pView, pDoc, rReq ) );
109     xFunc->DoExecute(rReq);
110     pFunc->SetPermanent( bPermanent );
111     return xFunc;
112 }
113 
114 void FuConstructCustomShape::DoExecute( SfxRequest& rReq )
115 {
116     FuConstruct::DoExecute( rReq );
117 
118     const SfxItemSet* pArgs = rReq.GetArgs();
119     if ( pArgs )
120     {
121         const SfxStringItem& rItm = (const SfxStringItem&)pArgs->Get( rReq.GetSlot() );
122         aCustomShape = rItm.GetValue();
123     }
124 
125     mpViewShell->GetViewShellBase().GetToolBarManager()->SetToolBar(
126         ToolBarManager::TBG_FUNCTION,
127         ToolBarManager::msDrawingObjectToolBar);
128 }
129 
130 /*************************************************************************
131 |*
132 |* MouseButtonDown-event
133 |*
134 \************************************************************************/
135 
136 sal_Bool FuConstructCustomShape::MouseButtonDown(const MouseEvent& rMEvt)
137 {
138     sal_Bool bReturn = FuConstruct::MouseButtonDown(rMEvt);
139 
140     if ( rMEvt.IsLeft() && !mpView->IsAction() )
141     {
142         Point aPnt( mpWindow->PixelToLogic( rMEvt.GetPosPixel() ) );
143 
144         mpWindow->CaptureMouse();
145         sal_uInt16 nDrgLog = sal_uInt16 ( mpWindow->PixelToLogic(Size(DRGPIX,0)).Width() );
146 
147         mpView->BegCreateObj(aPnt, (OutputDevice*) NULL, nDrgLog);
148 
149         SdrObject* pObj = mpView->GetCreateObj();
150         if ( pObj )
151         {
152             SetAttributes( pObj );
153             sal_Bool bForceFillStyle = sal_True;
154             sal_Bool bForceNoFillStyle = sal_False;
155             if ( ((SdrObjCustomShape*)pObj)->UseNoFillStyle() )
156             {
157                 bForceFillStyle = sal_False;
158                 bForceNoFillStyle = sal_True;
159             }
160             SfxItemSet aAttr(mpDoc->GetPool());
161             SetStyleSheet( aAttr, pObj, bForceFillStyle, bForceNoFillStyle );
162             pObj->SetMergedItemSet(aAttr);
163         }
164     }
165 
166     return bReturn;
167 }
168 
169 /*************************************************************************
170 |*
171 |* MouseMove-event
172 |*
173 \************************************************************************/
174 
175 sal_Bool FuConstructCustomShape::MouseMove(const MouseEvent& rMEvt)
176 {
177     return FuConstruct::MouseMove(rMEvt);
178 }
179 
180 /*************************************************************************
181 |*
182 |* MouseButtonUp-event
183 |*
184 \************************************************************************/
185 
186 sal_Bool FuConstructCustomShape::MouseButtonUp(const MouseEvent& rMEvt)
187 {
188     sal_Bool bReturn(sal_False);
189 
190     if(mpView->IsCreateObj() && rMEvt.IsLeft())
191     {
192         SdrObject* pObj = mpView->GetCreateObj();
193         if( pObj && mpView->EndCreateObj( SDRCREATE_FORCEEND ) )
194         {
195             bReturn = sal_True;
196         }
197     }
198     bReturn = FuConstruct::MouseButtonUp (rMEvt) || bReturn;
199 
200     if (!bPermanent)
201         mpViewShell->GetViewFrame()->GetDispatcher()->Execute(SID_OBJECT_SELECT, SFX_CALLMODE_ASYNCHRON);
202 
203     return bReturn;
204 }
205 
206 /*************************************************************************
207 |*
208 |* Tastaturereignisse bearbeiten
209 |*
210 |* Wird ein KeyEvent bearbeitet, so ist der Return-Wert sal_True, andernfalls
211 |* sal_False.
212 |*
213 \************************************************************************/
214 
215 sal_Bool FuConstructCustomShape::KeyInput(const KeyEvent& rKEvt)
216 {
217     sal_Bool bReturn = FuConstruct::KeyInput(rKEvt);
218     return(bReturn);
219 }
220 
221 /*************************************************************************
222 |*
223 |* Function aktivieren
224 |*
225 \************************************************************************/
226 
227 void FuConstructCustomShape::Activate()
228 {
229     mpView->SetCurrentObj( OBJ_CUSTOMSHAPE );
230     FuConstruct::Activate();
231 }
232 
233 /*************************************************************************
234 |*
235 |* Attribute fuer das zu erzeugende Objekt setzen
236 |*
237 \************************************************************************/
238 
239 void FuConstructCustomShape::SetAttributes( SdrObject* pObj )
240 {
241     sal_Bool bAttributesAppliedFromGallery = sal_False;
242 
243     if ( GalleryExplorer::GetSdrObjCount( GALLERY_THEME_POWERPOINT ) )
244     {
245         std::vector< rtl::OUString > aObjList;
246         if ( GalleryExplorer::FillObjListTitle( GALLERY_THEME_POWERPOINT, aObjList ) )
247         {
248             sal_uInt16 i;
249             for ( i = 0; i < aObjList.size(); i++ )
250             {
251                 if ( aObjList[ i ].equalsIgnoreAsciiCase( aCustomShape ) )
252                 {
253                     FmFormModel aFormModel;
254                     SfxItemPool& rPool = aFormModel.GetItemPool();
255                     rPool.FreezeIdRanges();
256                     if ( GalleryExplorer::GetSdrObj( GALLERY_THEME_POWERPOINT, i, &aFormModel ) )
257                     {
258                         const SdrPage* pPage = aFormModel.GetPage( 0 );
259                         if ( pPage )
260                         {
261                             const SdrObject* pSourceObj = pPage->GetObj( 0 );
262                             if( pSourceObj )
263                             {
264                                 const SfxItemSet& rSource = pSourceObj->GetMergedItemSet();
265                                 SfxItemSet aDest( pObj->GetModel()->GetItemPool(),              // ranges from SdrAttrObj
266                                 SDRATTR_START, SDRATTR_SHADOW_LAST,
267                                 SDRATTR_MISC_FIRST, SDRATTR_MISC_LAST,
268                                 SDRATTR_TEXTDIRECTION, SDRATTR_TEXTDIRECTION,
269                                 // Graphic Attributes
270                                 SDRATTR_GRAF_FIRST, SDRATTR_GRAF_LAST,
271                                 // 3d Properties
272                                 SDRATTR_3D_FIRST, SDRATTR_3D_LAST,
273                                 // CustomShape properties
274                                 SDRATTR_CUSTOMSHAPE_FIRST, SDRATTR_CUSTOMSHAPE_LAST,
275                                 // range from SdrTextObj
276                                 EE_ITEMS_START, EE_ITEMS_END,
277                                 // end
278                                 0, 0);
279                                 aDest.Set( rSource );
280                                 pObj->SetMergedItemSet( aDest );
281                                 sal_Int32 nAngle = pSourceObj->GetRotateAngle();
282                                 if ( nAngle )
283                                 {
284                                     double a = nAngle * F_PI18000;
285                                     pObj->NbcRotate( pObj->GetSnapRect().Center(), nAngle, sin( a ), cos( a ) );
286                                 }
287                                 bAttributesAppliedFromGallery = sal_True;
288 
289 
290     /*
291                                 com::sun::star::uno::Any aAny;
292                                 if ( ((SdrCustomShapeGeometryItem&)pObj->GetMergedItem( SDRATTR_CUSTOMSHAPE_GEOMETRY )).QueryValue( aAny ) )
293                                 {
294                                     aGeometryItem.PutValue( aAny );
295                                     pObj->SetMergedItem( aGeometryItem );
296                                     bAttributesAppliedFromGallery = sal_True;
297                                 }
298     */
299                             }
300                         }
301                     }
302                     break;
303                 }
304             }
305         }
306     }
307     if ( !bAttributesAppliedFromGallery )
308     {
309         pObj->SetMergedItem( SvxAdjustItem( SVX_ADJUST_CENTER, EE_PARA_JUST ) );
310         pObj->SetMergedItem( SdrTextVertAdjustItem( SDRTEXTVERTADJUST_CENTER ) );
311         pObj->SetMergedItem( SdrTextHorzAdjustItem( SDRTEXTHORZADJUST_BLOCK ) );
312         pObj->SetMergedItem( SdrTextAutoGrowHeightItem( sal_False ) );
313         ((SdrObjCustomShape*)pObj)->MergeDefaultAttributes( &aCustomShape );
314     }
315 }
316 
317 // #97016#
318 SdrObject* FuConstructCustomShape::CreateDefaultObject(const sal_uInt16, const Rectangle& rRectangle)
319 {
320     SdrObject* pObj = SdrObjFactory::MakeNewObject(
321         mpView->GetCurrentObjInventor(), mpView->GetCurrentObjIdentifier(),
322         0L, mpDoc);
323 
324     if( pObj )
325     {
326         Rectangle aRect( rRectangle );
327         if ( doConstructOrthogonal() )
328             ImpForceQuadratic( aRect );
329         pObj->SetLogicRect( aRect );
330         SetAttributes( pObj );
331         SfxItemSet aAttr(mpDoc->GetPool());
332         SetStyleSheet(aAttr, pObj);
333         pObj->SetMergedItemSet(aAttr);
334     }
335     return pObj;
336 }
337 
338 // #i33136#
339 bool FuConstructCustomShape::doConstructOrthogonal() const
340 {
341     return SdrObjCustomShape::doConstructOrthogonal(aCustomShape);
342 }
343 
344 } // end of namespace sd
345