1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: sdxfer.cxx,v $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
31 // MARKER(update_precomp.py): autogen include statement, do not remove
32 #include "precompiled_sd.hxx"
33 #include <com/sun/star/embed/XTransactedObject.hpp>
34 #include <com/sun/star/embed/XEmbedPersist.hpp>
35 #include <com/sun/star/embed/ElementModes.hpp>
36 #include <com/sun/star/lang/XComponent.hpp>
37 #include <vos/mutex.hxx>
38 #include <unotools/ucbstreamhelper.hxx>
39 #ifndef _UNTOOLS_TEMPFILE_HXX
40 #include <unotools/tempfile.hxx>
42 #include <svx/eeitem.hxx>
43 #include <svx/flditem.hxx>
44 #include <svx/svdpagv.hxx>
45 #include <sfx2/app.hxx>
46 #include <vcl/msgbox.hxx>
47 #include <svx/svdoole2.hxx>
48 #include <svx/svdograf.hxx>
49 #include <svx/svdotext.hxx>
50 #include <svx/outlobj.hxx>
51 #include <sot/storage.hxx>
52 #include <svtools/itempool.hxx>
53 #include <svx/editobj.hxx>
54 #include <svx/fmglob.hxx>
55 #include <svx/svdouno.hxx>
56 #include <tools/urlobj.hxx>
57 #include <sot/formats.hxx>
58 #include <svtools/urlbmk.hxx>
59 #include <svx/outliner.hxx>
61 //#ifndef _SVDETC_HXX //autogen
62 //#include <svx/svdetc.hxx>
64 #include <com/sun/star/form/FormButtonType.hpp>
65 #include <com/sun/star/beans/XPropertySet.hpp>
66 #include <unotools/streamwrap.hxx>
68 #include <svx/svdotable.hxx>
69 #include <svx/unomodel.hxx>
70 #include <svx/svditer.hxx>
71 #include <sfx2/docfile.hxx>
72 #include <comphelper/storagehelper.hxx>
73 #include <svtools/embedtransfer.hxx>
74 #include "DrawDocShell.hxx"
77 #include "drawview.hxx"
78 #include "drawdoc.hxx"
79 #include "stlpool.hxx"
80 #include "strings.hrc"
81 #include "sdresid.hxx"
82 #include "imapinfo.hxx"
84 #include "unomodel.hxx"
85 #include <vcl/virdev.hxx>
91 using namespace ::com::sun::star
;
92 using namespace ::com::sun::star::lang
;
93 using namespace ::com::sun::star::uno
;
94 using namespace ::com::sun::star::io
;
95 using namespace ::com::sun::star::datatransfer
;
96 using namespace ::com::sun::star::datatransfer::clipboard
;
102 #define SDTRANSFER_OBJECTTYPE_DRAWMODEL 0x00000001
103 #define SDTRANSFER_OBJECTTYPE_DRAWOLE 0x00000002
105 // ------------------
106 // - SdTransferable -
107 // ------------------
109 SdTransferable::SdTransferable( SdDrawDocument
* pSrcDoc
, ::sd::View
* pWorkView
, BOOL bInitOnGetData
)
110 : mpPageDocShell( NULL
)
111 , mpOLEDataHelper( NULL
)
113 , mpSdView( pWorkView
)
114 , mpSdViewIntern( pWorkView
)
115 , mpSdDrawDocument( NULL
)
116 , mpSdDrawDocumentIntern( NULL
)
117 , mpSourceDoc( pSrcDoc
)
122 , mbInternalMove( FALSE
)
123 , mbOwnDocument( FALSE
)
125 , mbLateInit( bInitOnGetData
)
126 , mbPageTransferable( FALSE
)
127 , mbPageTransferablePersistent( FALSE
)
128 , mbIsUnoObj( false )
131 StartListening( *mpSourceDoc
);
134 StartListening( *pWorkView
);
140 // -----------------------------------------------------------------------------
142 SdTransferable::~SdTransferable()
145 EndListening( *mpSourceDoc
);
148 EndListening( *const_cast< sd::View
*>( mpSdView
) );
150 Application::GetSolarMutex().acquire();
154 for( void* p
= maPageBookmarks
.First(); p
; p
= maPageBookmarks
.Next() )
155 delete static_cast< String
* >( p
);
158 delete mpSdViewIntern
;
160 delete mpOLEDataHelper
;
162 if( maDocShellRef
.Is() )
164 SfxObjectShell
* pObj
= maDocShellRef
;
165 ::sd::DrawDocShell
* pDocSh
= static_cast< ::sd::DrawDocShell
*>(pObj
);
169 maDocShellRef
.Clear();
172 delete mpSdDrawDocumentIntern
;
181 Application::GetSolarMutex().release();
184 // -----------------------------------------------------------------------------
186 void SdTransferable::CreateObjectReplacement( SdrObject
* pObj
)
190 delete mpOLEDataHelper
, mpOLEDataHelper
= NULL
;
191 delete mpGraphic
, mpGraphic
= NULL
;
192 delete mpBookmark
, mpBookmark
= NULL
;
193 delete mpImageMap
, mpImageMap
= NULL
;
195 if( pObj
->ISA( SdrOle2Obj
) )
199 uno::Reference
< embed::XEmbeddedObject
> xObj
= static_cast< SdrOle2Obj
* >( pObj
)->GetObjRef();
200 uno::Reference
< embed::XEmbedPersist
> xPersist( xObj
, uno::UNO_QUERY
);
201 if( xObj
.is() && xPersist
.is() && xPersist
->hasEntry() )
203 mpOLEDataHelper
= new TransferableDataHelper( new SvEmbedTransferHelper( xObj
, static_cast< SdrOle2Obj
* >( pObj
)->GetGraphic(), static_cast< SdrOle2Obj
* >( pObj
)->GetAspect() ) );
205 // TODO/LATER: the standalone handling of the graphic should not be used any more in future
206 // The EmbedDataHelper should bring the graphic in future
207 Graphic
* pObjGr
= static_cast< SdrOle2Obj
* >( pObj
)->GetGraphic();
209 mpGraphic
= new Graphic( *pObjGr
);
212 catch( uno::Exception
& )
215 else if( pObj
->ISA( SdrGrafObj
) && (mpSourceDoc
&& !mpSourceDoc
->GetAnimationInfo( pObj
)) )
217 mpGraphic
= new Graphic( static_cast< SdrGrafObj
* >( pObj
)->GetTransformedGraphic() );
219 else if( pObj
->IsUnoObj() && FmFormInventor
== pObj
->GetObjInventor() && ( pObj
->GetObjIdentifier() == (UINT16
) OBJ_FM_BUTTON
) )
221 SdrUnoObj
* pUnoCtrl
= static_cast< SdrUnoObj
* >( pObj
);
223 if (pUnoCtrl
&& FmFormInventor
== pUnoCtrl
->GetObjInventor())
225 Reference
< ::com::sun::star::awt::XControlModel
> xControlModel( pUnoCtrl
->GetUnoControlModel() );
227 if( !xControlModel
.is() )
230 Reference
< ::com::sun::star::beans::XPropertySet
> xPropSet( xControlModel
, UNO_QUERY
);
235 ::com::sun::star::form::FormButtonType eButtonType
;
236 Any
aTmp( xPropSet
->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "ButtonType" ) ) ) );
238 if( aTmp
>>= eButtonType
)
240 ::rtl::OUString aLabel
, aURL
;
242 xPropSet
->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Label" ) ) ) >>= aLabel
;
243 xPropSet
->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("TargetURL") ) ) >>= aURL
;
245 mpBookmark
= new INetBookmark( String( aURL
), String( aLabel
) );
249 else if( pObj
->ISA( SdrTextObj
) )
251 const OutlinerParaObject
* pPara
;
253 if( (pPara
= static_cast< SdrTextObj
* >( pObj
)->GetOutlinerParaObject()) != 0 )
255 const SvxFieldItem
* pField
;
257 if( (pField
= pPara
->GetTextObject().GetField()) != 0 )
259 const SvxFieldData
* pData
= pField
->GetField();
261 if( pData
&& pData
->ISA( SvxURLField
) )
263 const SvxURLField
* pURL
= (SvxURLField
*) pData
;
265 mpBookmark
= new INetBookmark( pURL
->GetURL(), pURL
->GetRepresentation() );
271 SdIMapInfo
* pInfo
= static_cast< SdDrawDocument
* >( pObj
->GetModel() )->GetIMapInfo( static_cast< SdrObject
* >( pObj
) );
274 mpImageMap
= new ImageMap( pInfo
->GetImageMap() );
276 mbIsUnoObj
= pObj
&& pObj
->IsUnoObj();
280 // -----------------------------------------------------------------------------
282 void SdTransferable::CreateData()
284 if( mpSdDrawDocument
&& !mpSdViewIntern
)
288 SdPage
* pPage
= mpSdDrawDocument
->GetSdPage(0, PK_STANDARD
);
290 if( 1 == pPage
->GetObjCount() )
291 CreateObjectReplacement( pPage
->GetObj( 0 ) );
293 mpVDev
= new VirtualDevice( *Application::GetDefaultDevice() );
294 mpVDev
->SetMapMode( MapMode( mpSdDrawDocumentIntern
->GetScaleUnit(), Point(), mpSdDrawDocumentIntern
->GetScaleFraction(), mpSdDrawDocumentIntern
->GetScaleFraction() ) );
295 mpSdViewIntern
= new ::sd::View( mpSdDrawDocumentIntern
, mpVDev
);
296 mpSdViewIntern
->EndListening(*mpSdDrawDocumentIntern
);
297 mpSdViewIntern
->hideMarkHandles();
298 SdrPageView
* pPageView
= mpSdViewIntern
->ShowSdrPage(pPage
);
299 ((SdrMarkView
*)mpSdViewIntern
)->MarkAllObj(pPageView
);
301 else if( mpSdView
&& !mpSdDrawDocumentIntern
)
303 const SdrMarkList
& rMarkList
= mpSdView
->GetMarkedObjectList();
305 if( rMarkList
.GetMarkCount() == 1 )
306 CreateObjectReplacement( rMarkList
.GetMark( 0 )->GetMarkedSdrObj() );
309 mpSourceDoc
->CreatingDataObj(this);
310 mpSdDrawDocumentIntern
= (SdDrawDocument
*) mpSdView
->GetAllMarkedModel();
312 mpSourceDoc
->CreatingDataObj(0);
314 if( !maDocShellRef
.Is() && mpSdDrawDocumentIntern
->GetDocSh() )
315 maDocShellRef
= mpSdDrawDocumentIntern
->GetDocSh();
317 if( !maDocShellRef
.Is() )
319 DBG_ERROR( "SdTransferable::CreateData(), failed to create a model with persist, clipboard operation will fail for OLE objects!" );
320 mbOwnDocument
= TRUE
;
323 // Groesse der Source-Seite uebernehmen
324 SdrPageView
* pPgView
= mpSdView
->GetSdrPageView();
325 SdPage
* pOldPage
= (SdPage
*) pPgView
->GetPage();
326 SdrModel
* pOldModel
= mpSdView
->GetModel();
327 SdStyleSheetPool
* pOldStylePool
= (SdStyleSheetPool
*) pOldModel
->GetStyleSheetPool();
328 SdStyleSheetPool
* pNewStylePool
= (SdStyleSheetPool
*) mpSdDrawDocumentIntern
->GetStyleSheetPool();
329 SdPage
* pPage
= mpSdDrawDocumentIntern
->GetSdPage( 0, PK_STANDARD
);
330 String
aOldLayoutName( pOldPage
->GetLayoutName() );
332 pPage
->SetSize( pOldPage
->GetSize() );
333 pPage
->SetLayoutName( aOldLayoutName
);
334 pNewStylePool
->CopyGraphicSheets( *pOldStylePool
);
335 pNewStylePool
->CopyCellSheets( *pOldStylePool
);
336 pNewStylePool
->CopyTableStyles( *pOldStylePool
);
337 aOldLayoutName
.Erase( aOldLayoutName
.SearchAscii( SD_LT_SEPARATOR
) );
338 SdStyleSheetVector aCreatedSheets
;
339 pNewStylePool
->CopyLayoutSheets( aOldLayoutName
, *pOldStylePool
, aCreatedSheets
);
342 // set VisArea and adjust objects if neccessary
343 if( maVisArea
.IsEmpty() &&
344 mpSdDrawDocumentIntern
&& mpSdViewIntern
&&
345 mpSdDrawDocumentIntern
->GetPageCount() )
347 SdPage
* pPage
= mpSdDrawDocumentIntern
->GetSdPage( 0, PK_STANDARD
);
349 if( 1 == mpSdDrawDocumentIntern
->GetPageCount() )
351 Point
aOrigin( ( maVisArea
= mpSdViewIntern
->GetAllMarkedRect() ).TopLeft() );
352 Size
aVector( -aOrigin
.X(), -aOrigin
.Y() );
354 for( ULONG nObj
= 0, nObjCount
= pPage
->GetObjCount(); nObj
< nObjCount
; nObj
++ )
356 SdrObject
* pObj
= pPage
->GetObj( nObj
);
357 pObj
->NbcMove( aVector
);
361 maVisArea
.SetSize( pPage
->GetSize() );
363 // Die Ausgabe soll am Nullpunkt erfolgen
364 maVisArea
.SetPos( Point() );
368 // -----------------------------------------------------------------------------
370 BOOL
lcl_HasOnlyControls( SdrModel
* pModel
)
372 BOOL bOnlyControls
= FALSE
; // default if there are no objects
376 SdrPage
* pPage
= pModel
->GetPage(0);
379 SdrObjListIter
aIter( *pPage
, IM_DEEPNOGROUPS
);
380 SdrObject
* pObj
= aIter
.Next();
383 bOnlyControls
= TRUE
; // only set if there are any objects at all
386 if (!pObj
->ISA(SdrUnoObj
))
388 bOnlyControls
= FALSE
;
397 return bOnlyControls
;
400 // -----------------------------------------------------------------------------
402 bool lcl_HasOnlyOneTable( SdrModel
* pModel
)
406 SdrPage
* pPage
= pModel
->GetPage(0);
407 if (pPage
&& pPage
->GetObjCount() == 1 )
409 if( dynamic_cast< sdr::table::SdrTableObj
* >( pPage
->GetObj(0) ) != 0 )
416 // -----------------------------------------------------------------------------
418 void SdTransferable::AddSupportedFormats()
420 if( !mbPageTransferable
|| mbPageTransferablePersistent
)
426 AddFormat( SOT_FORMATSTR_ID_OBJECTDESCRIPTOR
);
428 if( mpOLEDataHelper
)
430 AddFormat( SOT_FORMATSTR_ID_EMBED_SOURCE
);
432 DataFlavorExVector
aVector( mpOLEDataHelper
->GetDataFlavorExVector() );
433 DataFlavorExVector::iterator
aIter( aVector
.begin() ), aEnd( aVector
.end() );
435 while( aIter
!= aEnd
)
436 AddFormat( *aIter
++ );
441 AddFormat( SOT_FORMATSTR_ID_DRAWING
);
443 AddFormat( SOT_FORMATSTR_ID_SVXB
);
445 if( mpGraphic
->GetType() == GRAPHIC_BITMAP
)
447 AddFormat( SOT_FORMAT_BITMAP
);
448 AddFormat( SOT_FORMAT_GDIMETAFILE
);
452 AddFormat( SOT_FORMAT_GDIMETAFILE
);
453 AddFormat( SOT_FORMAT_BITMAP
);
456 else if( mpBookmark
)
458 AddFormat( SOT_FORMATSTR_ID_NETSCAPE_BOOKMARK
);
459 AddFormat( FORMAT_STRING
);
463 AddFormat( SOT_FORMATSTR_ID_EMBED_SOURCE
);
464 AddFormat( SOT_FORMATSTR_ID_DRAWING
);
465 if( !mpSdDrawDocument
|| !lcl_HasOnlyControls( mpSdDrawDocument
) )
467 AddFormat( SOT_FORMAT_GDIMETAFILE
);
468 AddFormat( SOT_FORMAT_BITMAP
);
471 if( lcl_HasOnlyOneTable( mpSdDrawDocument
) )
472 AddFormat( SOT_FORMAT_RTF
);
476 AddFormat( SOT_FORMATSTR_ID_SVIM
);
480 // -----------------------------------------------------------------------------
482 sal_Bool
SdTransferable::GetData( const DataFlavor
& rFlavor
)
484 sal_uInt32 nFormat
= SotExchange::GetFormat( rFlavor
);
485 sal_Bool bOK
= sal_False
;
489 if( nFormat
== SOT_FORMAT_RTF
&& lcl_HasOnlyOneTable( mpSdDrawDocument
) )
491 bOK
= SetTableRTF( mpSdDrawDocument
, rFlavor
);
493 else if( mpOLEDataHelper
&& mpOLEDataHelper
->HasFormat( rFlavor
) )
495 ULONG nOldSwapMode
= 0;
497 if( mpSdDrawDocumentIntern
)
499 nOldSwapMode
= mpSdDrawDocumentIntern
->GetSwapGraphicsMode();
500 mpSdDrawDocumentIntern
->SetSwapGraphicsMode( SDR_SWAPGRAPHICSMODE_PURGE
);
503 // TODO/LATER: support all the graphical formats, the embedded object scenario should not have separated handling
504 if( nFormat
== FORMAT_GDIMETAFILE
&& mpGraphic
)
505 bOK
= SetGDIMetaFile( mpGraphic
->GetGDIMetaFile(), rFlavor
);
507 bOK
= SetAny( mpOLEDataHelper
->GetAny( rFlavor
), rFlavor
);
509 if( mpSdDrawDocumentIntern
)
510 mpSdDrawDocumentIntern
->SetSwapGraphicsMode( nOldSwapMode
);
512 else if( HasFormat( nFormat
) )
514 if( ( nFormat
== SOT_FORMATSTR_ID_LINKSRCDESCRIPTOR
|| nFormat
== SOT_FORMATSTR_ID_OBJECTDESCRIPTOR
) && mpObjDesc
)
516 bOK
= SetTransferableObjectDescriptor( *mpObjDesc
, rFlavor
);
518 else if( nFormat
== SOT_FORMATSTR_ID_DRAWING
)
520 SfxObjectShellRef
aOldRef( maDocShellRef
);
522 maDocShellRef
.Clear();
526 SdDrawDocument
* pInternDoc
= mpSdViewIntern
->GetDoc();
528 pInternDoc
->CreatingDataObj(this);
529 SdDrawDocument
* pDoc
= dynamic_cast< SdDrawDocument
* >( mpSdViewIntern
->GetAllMarkedModel() );
531 pInternDoc
->CreatingDataObj(0);
533 bOK
= SetObject( pDoc
, SDTRANSFER_OBJECTTYPE_DRAWMODEL
, rFlavor
);
535 if( maDocShellRef
.Is() )
537 maDocShellRef
->DoClose();
545 maDocShellRef
= aOldRef
;
547 else if( nFormat
== FORMAT_GDIMETAFILE
)
550 bOK
= SetGDIMetaFile( mpSdViewIntern
->GetAllMarkedMetaFile( TRUE
), rFlavor
);
552 else if( nFormat
== FORMAT_BITMAP
)
555 bOK
= SetBitmap( mpSdViewIntern
->GetAllMarkedBitmap( TRUE
), rFlavor
);
557 else if( ( nFormat
== FORMAT_STRING
) && mpBookmark
)
559 bOK
= SetString( mpBookmark
->GetURL(), rFlavor
);
561 else if( ( nFormat
== SOT_FORMATSTR_ID_SVXB
) && mpGraphic
)
563 bOK
= SetGraphic( *mpGraphic
, rFlavor
);
565 else if( ( nFormat
== SOT_FORMATSTR_ID_SVIM
) && mpImageMap
)
567 bOK
= SetImageMap( *mpImageMap
, rFlavor
);
569 else if( mpBookmark
)
571 bOK
= SetINetBookmark( *mpBookmark
, rFlavor
);
573 else if( nFormat
== SOT_FORMATSTR_ID_EMBED_SOURCE
)
575 ULONG nOldSwapMode
= 0;
577 if( mpSdDrawDocumentIntern
)
579 nOldSwapMode
= mpSdDrawDocumentIntern
->GetSwapGraphicsMode();
580 mpSdDrawDocumentIntern
->SetSwapGraphicsMode( SDR_SWAPGRAPHICSMODE_PURGE
);
583 if( !maDocShellRef
.Is() )
585 maDocShellRef
= new ::sd::DrawDocShell(
586 mpSdDrawDocumentIntern
,
587 SFX_CREATE_MODE_EMBEDDED
,
589 mpSdDrawDocumentIntern
->GetDocumentType());
590 mbOwnDocument
= FALSE
;
591 maDocShellRef
->DoInitNew( NULL
);
594 maDocShellRef
->SetVisArea( maVisArea
);
595 bOK
= SetObject( &maDocShellRef
, SDTRANSFER_OBJECTTYPE_DRAWOLE
, rFlavor
);
597 if( mpSdDrawDocumentIntern
)
598 mpSdDrawDocumentIntern
->SetSwapGraphicsMode( nOldSwapMode
);
605 // -----------------------------------------------------------------------------
608 #include <sfx2/docfile.hxx>
611 sal_Bool
SdTransferable::WriteObject( SotStorageStreamRef
& rxOStm
, void* pObject
, sal_uInt32 nObjectType
, const DataFlavor
& )
613 sal_Bool bRet
= sal_False
;
615 switch( nObjectType
)
617 case( SDTRANSFER_OBJECTTYPE_DRAWMODEL
):
621 static const BOOL bDontBurnInStyleSheet
= ( getenv( "AVOID_BURN_IN_FOR_GALLERY_THEME" ) != NULL
);
622 SdDrawDocument
* pDoc
= (SdDrawDocument
*) pObject
;
623 if ( !bDontBurnInStyleSheet
)
624 pDoc
->BurnInStyleSheetAttributes();
625 rxOStm
->SetBufferSize( 16348 );
627 Reference
< XComponent
> xComponent( new SdXImpressDocument( pDoc
, sal_True
) );
628 pDoc
->setUnoModel( Reference
< XInterface
>::query( xComponent
) );
631 com::sun::star::uno::Reference
<com::sun::star::io::XOutputStream
> xDocOut( new utl::OOutputStreamWrapper( *rxOStm
) );
632 if( SvxDrawingLayerExport( pDoc
, xDocOut
, xComponent
, (pDoc
->GetDocumentType() == DOCUMENT_TYPE_IMPRESS
) ? "com.sun.star.comp.Impress.XMLClipboardExporter" : "com.sun.star.comp.DrawingLayer.XMLExporter" ) )
638 const rtl::OUString aURL( RTL_CONSTASCII_USTRINGPARAM( "file:///e:/test.xml" ) );
639 SfxMedium aMedium( aURL, STREAM_WRITE | STREAM_TRUNC, TRUE );
641 com::sun::star::uno::Reference<com::sun::star::io::XOutputStream> xDocOut( new utl::OOutputStreamWrapper( *aMedium.GetOutStream() ) );
642 if( SvxDrawingLayerExport( pDoc, xDocOut, xComponent, (pDoc->GetDocumentType() == DOCUMENT_TYPE_IMPRESS) ? "com.sun.star.comp.Impress.XMLClipboardExporter" : "com.sun.star.comp.DrawingLayer.XMLExporter" ) )
647 xComponent
->dispose();
648 bRet
= ( rxOStm
->GetError() == ERRCODE_NONE
);
652 DBG_ERROR( "sd::SdTransferable::WriteObject(), exception catched!" );
658 case( SDTRANSFER_OBJECTTYPE_DRAWOLE
):
660 SfxObjectShell
* pEmbObj
= (SfxObjectShell
*) pObject
;
661 ::utl::TempFile aTempFile
;
662 aTempFile
.EnableKillingFile();
666 uno::Reference
< embed::XStorage
> xWorkStore
=
667 ::comphelper::OStorageHelper::GetStorageFromURL( aTempFile
.GetURL(), embed::ElementModes::READWRITE
);
669 // write document storage
670 pEmbObj
->SetupStorage( xWorkStore
, SOFFICE_FILEFORMAT_CURRENT
, sal_False
);
671 // mba: no relative ULRs for clipboard!
672 SfxMedium
aMedium( xWorkStore
, String() );
673 bRet
= pEmbObj
->DoSaveObjectAs( aMedium
, FALSE
);
674 pEmbObj
->DoSaveCompleted();
676 uno::Reference
< embed::XTransactedObject
> xTransact( xWorkStore
, uno::UNO_QUERY
);
677 if ( xTransact
.is() )
680 SvStream
* pSrcStm
= ::utl::UcbStreamHelper::CreateStream( aTempFile
.GetURL(), STREAM_READ
);
683 rxOStm
->SetBufferSize( 0xff00 );
704 // -----------------------------------------------------------------------------
706 void SdTransferable::DragFinished( sal_Int8 nDropAction
)
709 ( (::sd::View
*) mpSdView
)->DragFinished( nDropAction
);
712 // -----------------------------------------------------------------------------
714 void SdTransferable::ObjectReleased()
716 if( this == SD_MOD()->pTransferClip
)
717 SD_MOD()->pTransferClip
= NULL
;
719 if( this == SD_MOD()->pTransferDrag
)
720 SD_MOD()->pTransferDrag
= NULL
;
722 if( this == SD_MOD()->pTransferSelection
)
723 SD_MOD()->pTransferSelection
= NULL
;
726 // -----------------------------------------------------------------------------
728 void SdTransferable::SetObjectDescriptor( const TransferableObjectDescriptor
& rObjDesc
)
731 mpObjDesc
= new TransferableObjectDescriptor( rObjDesc
);
732 PrepareOLE( rObjDesc
);
735 // -----------------------------------------------------------------------------
737 void SdTransferable::SetPageBookmarks( const List
& rPageBookmarks
, BOOL bPersistent
)
742 mpSdViewIntern
->HideSdrPage();
745 mpSdDrawDocument
->ClearModel(sal_False
);
747 mpPageDocShell
= NULL
;
749 for( void* p
= maPageBookmarks
.First(); p
; p
= maPageBookmarks
.Next() )
750 delete static_cast< String
* >( p
);
754 mpSdDrawDocument
->CreateFirstPages(mpSourceDoc
);
755 mpSdDrawDocument
->InsertBookmarkAsPage( const_cast< List
* >( &rPageBookmarks
), NULL
, FALSE
, TRUE
, 1, TRUE
, mpSourceDoc
->GetDocSh(), TRUE
, TRUE
, FALSE
);
759 mpPageDocShell
= mpSourceDoc
->GetDocSh();
761 for( ULONG i
= 0; i
< rPageBookmarks
.Count(); i
++ )
762 maPageBookmarks
.Insert( new String( *static_cast< String
* >( rPageBookmarks
.GetObject( i
) ) ), LIST_APPEND
);
765 if( mpSdViewIntern
&& mpSdDrawDocument
)
767 SdPage
* pPage
= mpSdDrawDocument
->GetSdPage( 0, PK_STANDARD
);
771 ( (SdrMarkView
*) mpSdViewIntern
)->MarkAllObj( (SdrPageView
*) mpSdViewIntern
->ShowSdrPage( pPage
) );
775 // set flags for page transferable; if ( mbPageTransferablePersistent == FALSE ),
776 // don't offer any formats => it's just for internal puposes
777 mbPageTransferable
= TRUE
;
778 mbPageTransferablePersistent
= bPersistent
;
782 // -----------------------------------------------------------------------------
784 sal_Int64 SAL_CALL
SdTransferable::getSomething( const ::com::sun::star::uno::Sequence
< sal_Int8
>& rId
) throw( ::com::sun::star::uno::RuntimeException
)
788 if( ( rId
.getLength() == 16 ) &&
789 ( 0 == rtl_compareMemory( getUnoTunnelId().getConstArray(), rId
.getConstArray(), 16 ) ) )
791 nRet
= sal::static_int_cast
<sal_Int64
>(reinterpret_cast<sal_IntPtr
>(this));
801 // -----------------------------------------------------------------------------
803 const ::com::sun::star::uno::Sequence
< sal_Int8
>& SdTransferable::getUnoTunnelId()
805 static ::com::sun::star::uno::Sequence
< sal_Int8
> aSeq
;
807 if( !aSeq
.getLength() )
809 static osl::Mutex aCreateMutex
;
810 osl::MutexGuard
aGuard( aCreateMutex
);
813 rtl_createUuid( reinterpret_cast< sal_uInt8
* >( aSeq
.getArray() ), 0, sal_True
);
819 // -----------------------------------------------------------------------------
821 SdTransferable
* SdTransferable::getImplementation( const Reference
< XInterface
>& rxData
) throw()
825 Reference
< ::com::sun::star::lang::XUnoTunnel
> xUnoTunnel( rxData
, UNO_QUERY_THROW
);
826 return reinterpret_cast<SdTransferable
*>(sal::static_int_cast
<sal_uIntPtr
>(xUnoTunnel
->getSomething( SdTransferable::getUnoTunnelId()) ) );
828 catch( const ::com::sun::star::uno::Exception
& )
834 // -----------------------------------------------------------------------------
837 void SdTransferable::Notify( SfxBroadcaster
& rBC
, const SfxHint
& rHint
)
839 const SdrHint
* pSdrHint
= dynamic_cast< const SdrHint
* >( &rHint
);
842 if( HINT_MODELCLEARED
== pSdrHint
->GetKind() )
844 EndListening(*mpSourceDoc
);
850 const SfxSimpleHint
* pSimpleHint
= dynamic_cast< const SfxSimpleHint
* >(&rHint
);
851 if(pSimpleHint
&& (pSimpleHint
->GetId() == SFX_HINT_DYING
) )
853 if( &rBC
== mpSourceDoc
)
855 if( &rBC
== mpSdViewIntern
)
857 if( &rBC
== mpSdView
)
863 sal_Bool
SdTransferable::SetTableRTF( SdDrawDocument
* pModel
, const DataFlavor
& rFlavor
)
867 SdrPage
* pPage
= pModel
->GetPage(0);
868 if (pPage
&& pPage
->GetObjCount() == 1 )
870 sdr::table::SdrTableObj
* pTableObj
= dynamic_cast< sdr::table::SdrTableObj
* >( pPage
->GetObj(0) );
873 SvMemoryStream
aMemStm( 65535, 65535 );
874 sdr::table::SdrTableObj::ExportAsRTF( aMemStm
, *pTableObj
);
875 return SetAny( Any( Sequence
< sal_Int8
>( reinterpret_cast< const sal_Int8
* >( aMemStm
.GetData() ), aMemStm
.Seek( STREAM_SEEK_TO_END
) ) ), rFlavor
);