diff options
Diffstat (limited to 'svx/inc/svx/galmisc.hxx')
-rw-r--r-- | svx/inc/svx/galmisc.hxx | 265 |
1 files changed, 265 insertions, 0 deletions
diff --git a/svx/inc/svx/galmisc.hxx b/svx/inc/svx/galmisc.hxx new file mode 100644 index 0000000000..e028acee26 --- /dev/null +++ b/svx/inc/svx/galmisc.hxx @@ -0,0 +1,265 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2008 by Sun Microsystems, Inc. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * $RCSfile: galmisc.hxx,v $ + * $Revision: 1.19 $ + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +#ifndef _SVX_GALMISC_HXX_ +#define _SVX_GALMISC_HXX_ + +#include <sot/storage.hxx> +#include <tools/urlobj.hxx> +#include <svtools/imap.hxx> +#include <svl/hint.hxx> +#include <svtools/transfer.hxx> +#include <svx/svdobj.hxx> +#include <com/sun/star/uno/Reference.h> +#include <com/sun/star/awt/XProgressMonitor.hpp> +#include "svx/svxdllapi.h" +#include <tools/date.hxx> +#include <tools/time.hxx> + +// ------------ +// - Forwards - +// ------------ + +class GalleryTheme; + +// ---------------- +// - ExchangeData - +// ---------------- + +struct ExchangeData +{ + GalleryTheme* pTheme; + String aEditedTitle; + Date aThemeChangeDate; + Time aThemeChangeTime; +}; + +enum SgaObjKind +{ + SGA_OBJ_NONE = 0, // Abstraktes Objekt + SGA_OBJ_BMP = 1, // Bitmap-Objekt + SGA_OBJ_SOUND = 2, // Sound-Objekt + SGA_OBJ_VIDEO = 3, // Video-Objekt + SGA_OBJ_ANIM = 4, // Animations-Objekt + SGA_OBJ_SVDRAW = 5, // Svdraw-Objekt + SGA_OBJ_INET = 6 // Grafik aus dem Internet +}; + +// ----------- +// - Defines - +// ----------- + +#define IV_IMAPINFO (UINT32('S')*0x00000001+UINT32('D')*0x00000100+UINT32('U')*0x00010000+UINT32('D')*0x01000000) +#define ID_IMAPINFO 2 + +#define USERDATA_HDL() (LINK(this,SgaUserDataFactory,MakeUserData)) + +#define GAL_RESID( nId ) ResId( nId, *GetGalleryResMgr() ) +#define STREAMBUF_SIZE 16384L + +#define SGA_IMPORT_NONE 0x0000 +#define SGA_IMPORT_FILE 0x0001 +#define SGA_IMPORT_INET 0x0002 + +#define GALLERY_PROGRESS_RANGE 10000 + +#define GALLERY_FG_COLOR Application::GetSettings().GetStyleSettings().GetWindowTextColor() +#define GALLERY_BG_COLOR Application::GetSettings().GetStyleSettings().GetWindowColor() +#define GALLERY_DLG_COLOR Application::GetSettings().GetStyleSettings().GetDialogColor() + +// ------------- +// - Functions - +// ------------- + +class ResMgr; +class String; +class SvStream; +class Graphic; +class FmFormModel; +class ImageMap; +class Gallery; + +SVX_DLLPUBLIC ResMgr* GetGalleryResMgr(); +USHORT GalleryGraphicImport( const INetURLObject& rURL, Graphic& rGraphic, String& rFilterName, BOOL bShowProgress = FALSE ); +BOOL GallerySvDrawImport( SvStream& rIStm, SdrModel& rModel ); +BOOL CreateIMapGraphic( const FmFormModel& rModel, Graphic& rGraphic, ImageMap& rImageMap ); +SVX_DLLPUBLIC String GetReducedString( const INetURLObject& rURL, ULONG nMaxLen ); +String GetSvDrawStreamNameFromURL( const INetURLObject& rSvDrawObjURL ); + +BOOL FileExists( const INetURLObject& rURL ); +BOOL CreateDir( const INetURLObject& rURL ); +BOOL CopyFile( const INetURLObject& rSrcURL, const INetURLObject& rDstURL ); +BOOL KillFile( const INetURLObject& rURL ); +BitmapEx GalleryResGetBitmapEx( sal_uInt32 nId ); + + +// --------------- +// - SgaIMapInfo - +// --------------- + +class SgaIMapInfo : public SdrObjUserData, public SfxListener +{ + ImageMap aImageMap; + +public: + SgaIMapInfo() : SdrObjUserData( IV_IMAPINFO, ID_IMAPINFO, 0 ) {}; + + SgaIMapInfo( const ImageMap& rImageMap) : + SdrObjUserData( IV_IMAPINFO, ID_IMAPINFO, 0 ), + aImageMap( rImageMap ) {}; + + virtual ~SgaIMapInfo() {}; + + virtual SdrObjUserData* Clone( SdrObject* ) const + { + SgaIMapInfo* pInfo = new SgaIMapInfo; + pInfo->aImageMap = aImageMap; + return pInfo; + } + + const ImageMap& GetImageMap() const { return aImageMap; } +}; + +// ---------------------- +// - SgaUserDataFactory - +// ---------------------- + +class SgaUserDataFactory +{ +public: + SgaUserDataFactory() { SdrObjFactory::InsertMakeUserDataHdl( USERDATA_HDL() ); } + ~SgaUserDataFactory() { SdrObjFactory::RemoveMakeUserDataHdl( USERDATA_HDL() ); } + + DECL_LINK( MakeUserData, SdrObjFactory* ); +}; + +// ------------------- +// - GalleryProgress - +// ------------------- + +class GraphicFilter; + +class SVX_DLLPUBLIC GalleryProgress +{ + ::com::sun::star::uno::Reference< ::com::sun::star::awt::XProgressBar > mxProgressBar; + GraphicFilter* mpFilter; + + public: + + GalleryProgress( GraphicFilter* pFilter = NULL ); + ~GalleryProgress(); + + void Update( ULONG nVal, ULONG nMaxVal ); +}; + +// ----------------------- +// - GalleryTransferable - +// ----------------------- + +class Gallery; +class GalleryTheme; +class GraphicObject; + +class GalleryTransferable : public TransferableHelper +{ +friend class GalleryTheme; +using TransferableHelper::CopyToClipboard; + +private: + + GalleryTheme* mpTheme; + SgaObjKind meObjectKind; + sal_uInt32 mnObjectPos; + SotStorageStreamRef mxModelStream; + GraphicObject* mpGraphicObject; + ImageMap* mpImageMap; + INetURLObject* mpURL; + +protected: + + GalleryTransferable( GalleryTheme* pTheme, ULONG nObjectPos, bool bLazy ); + ~GalleryTransferable(); + + void InitData( bool bLazy ); + + // TransferableHelper + virtual void AddSupportedFormats(); + virtual sal_Bool GetData( const ::com::sun::star::datatransfer::DataFlavor& rFlavor ); + virtual sal_Bool WriteObject( SotStorageStreamRef& rxOStm, void* pUserObject, sal_uInt32 nUserObjectId, const ::com::sun::star::datatransfer::DataFlavor& rFlavor ); + virtual void DragFinished( sal_Int8 nDropAction ); + virtual void ObjectReleased(); + + void CopyToClipboard( Window* pWindow ); + void StartDrag( Window* pWindow, sal_Int8 nDragSourceActions, + sal_Int32 nDragPointer = DND_POINTER_NONE, + sal_Int32 nDragImage = DND_IMAGE_NONE ); +}; + +// --------------- +// - GalleryHint - +// --------------- + +#define GALLERY_HINT_NONE 0x00000000 +#define GALLERY_HINT_CLOSE_THEME 0x00000001 +#define GALLERY_HINT_THEME_REMOVED 0x00000002 +#define GALLERY_HINT_THEME_RENAMED 0x00000004 +#define GALLERY_HINT_THEME_CREATED 0x00000008 +#define GALLERY_HINT_THEME_UPDATEVIEW 0x00000010 +#define GALLERY_HINT_CLOSE_OBJECT 0x00000020 +#define GALLERY_HINT_OBJECT_REMOVED 0x00000040 + +// ----------------------------------------------------------------------------- + +class GalleryHint : public SfxHint +{ +private: + + ULONG mnType; + String maThemeName; + String maStringData; + ULONG mnData1; + ULONG mnData2; + +public: + + GalleryHint( ULONG nType, const String& rThemeName, ULONG nData1 = 0UL, ULONG nData2 = 0UL ) : + mnType( nType ), maThemeName( rThemeName ), mnData1( nData1 ), mnData2( nData2 ) {} + + GalleryHint( ULONG nType, const String& rThemeName, const String& rStringData, ULONG nData1 = 0UL, ULONG nData2 = 0UL ) : + mnType( nType ), maThemeName( rThemeName ), maStringData( rStringData ), mnData1( nData1 ), mnData2( nData2 ) {} + + ULONG GetType() const { return mnType; } + const String& GetThemeName() const { return maThemeName; } + const String& GetStringData() const { return maStringData; } + ULONG GetData1() const { return mnData1; } + ULONG GetData2() const { return mnData2; } +}; + + #endif |