diff options
author | Xisco Fauli <anistenis@gmail.com> | 2011-08-21 21:50:13 +0200 |
---|---|---|
committer | Xisco Fauli <anistenis@gmail.com> | 2011-08-21 21:50:13 +0200 |
commit | 6c76e4db034fd2c43884698b1a30225fd00b3bfd (patch) | |
tree | 1937cb9be81cd2b9f3d0ad27adcc7a7531b8f29d /svx/inc/galobj.hxx | |
parent | e9440fb5a0579096423c081b0f0a2185b628e896 (diff) | |
parent | 36703ca1de68cd62782d0d425123521a5bc6732b (diff) |
Merge branch 'master' into feature/gsoc2011_wizards
Conflicts:
automation/source/inc/cmdbasestream.hxx
automation/source/server/cmdbasestream.cxx
automation/source/server/retstrm.hxx
automation/source/testtool/cmdstrm.cxx
automation/source/testtool/cmdstrm.hxx
automation/source/testtool/tcommuni.cxx
basctl/prj/d.lst
basctl/uiconfig/basicide/toolbar/findbar.xml
cui/source/dialogs/about.cxx
cui/source/dialogs/about.src
cui/source/inc/about.hxx
extensions/source/abpilot/abpservices.cxx
extensions/source/dbpilots/dbpservices.cxx
extensions/source/propctrlr/pcrservices.cxx
extensions/source/svg/makefile.mk
forms/Library_frm.mk
lingucomponent/source/hyphenator/altlinuxhyph/hyphen/hyphenimp.cxx
lingucomponent/source/spellcheck/spell/sspellimp.cxx
package/prj/d.lst
package/source/zipapi/XMemoryStream.cxx
package/source/zipapi/XMemoryStream.hxx
setup_native/prj/d.lst
setup_native/source/win32/customactions/relnotes/makefile.mk
tools/test/export.map
wizards/com/sun/star/wizards/common/ConfigGroup.py
wizards/com/sun/star/wizards/common/ConfigNode.py
wizards/com/sun/star/wizards/common/Configuration.py
wizards/com/sun/star/wizards/common/Desktop.py
wizards/com/sun/star/wizards/common/FileAccess.py
wizards/com/sun/star/wizards/common/Helper.py
wizards/com/sun/star/wizards/common/SystemDialog.py
wizards/com/sun/star/wizards/document/OfficeDocument.py
wizards/com/sun/star/wizards/fax/FaxDocument.py
wizards/com/sun/star/wizards/fax/FaxWizardDialog.py
wizards/com/sun/star/wizards/fax/FaxWizardDialogConst.py
wizards/com/sun/star/wizards/fax/FaxWizardDialogImpl.py
wizards/com/sun/star/wizards/fax/FaxWizardDialogResources.py
wizards/com/sun/star/wizards/letter/LetterDocument.py
wizards/com/sun/star/wizards/letter/LetterWizardDialog.py
wizards/com/sun/star/wizards/letter/LetterWizardDialogConst.py
wizards/com/sun/star/wizards/letter/LetterWizardDialogImpl.py
wizards/com/sun/star/wizards/letter/LetterWizardDialogResources.py
wizards/com/sun/star/wizards/text/TextDocument.py
wizards/com/sun/star/wizards/text/TextFieldHandler.py
wizards/com/sun/star/wizards/text/TextSectionHandler.py
wizards/com/sun/star/wizards/text/ViewHandler.py
wizards/com/sun/star/wizards/ui/UnoDialog.py
wizards/com/sun/star/wizards/ui/UnoDialog2.py
wizards/com/sun/star/wizards/ui/WizardDialog.py
wizards/com/sun/star/wizards/ui/event/CommonListener.py
wizards/com/sun/star/wizards/ui/event/DataAware.py
wizards/com/sun/star/wizards/ui/event/RadioDataAware.py
wizards/com/sun/star/wizards/ui/event/UnoDataAware.py
wizards/util/helpids.h
wizards/util/hidother.src
xmlsecurity/prj/build.lst
xmlsecurity/prj/d.lst
xmlsecurity/qa/certext/SanCertExt.cxx
Diffstat (limited to 'svx/inc/galobj.hxx')
-rw-r--r-- | svx/inc/galobj.hxx | 241 |
1 files changed, 241 insertions, 0 deletions
diff --git a/svx/inc/galobj.hxx b/svx/inc/galobj.hxx new file mode 100644 index 000000000000..46f018db4f7c --- /dev/null +++ b/svx/inc/galobj.hxx @@ -0,0 +1,241 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * 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_GALOBJ_HXX_ +#define _SVX_GALOBJ_HXX_ + +#include <tools/urlobj.hxx> +#include <vcl/graph.hxx> +#include "svx/galmisc.hxx" + +// ----------- +// - Defines - +// ----------- + +#define S_THUMB 80 + +// ----------------------------------------------------------------------------- + +#define SGA_FORMAT_NONE 0x00000000L +#define SGA_FORMAT_STRING 0x00000001L +#define SGA_FORMAT_GRAPHIC 0x00000010L +#define SGA_FORMAT_SOUND 0x00000100L +#define SGA_FORMAT_OLE 0x00001000L +#define SGA_FORMAT_SVDRAW 0x00010000L +#define SGA_FORMAT_ALL 0xFFFFFFFFL + +// ---------------- +// - GalSoundType - +// ---------------- + +enum GalSoundType +{ + SOUND_STANDARD = 0, + SOUND_COMPUTER = 1, + SOUND_MISC = 2, + SOUND_MUSIC = 3, + SOUND_NATURE = 4, + SOUND_SPEECH = 5, + SOUND_TECHNIC = 6, + SOUND_ANIMAL = 7 +}; + +// ------------- +// - SgaObject - +// ------------- + +class SVX_DLLPUBLIC SgaObject +{ + friend class GalleryTheme; + +private: + + void ImplUpdateURL( const INetURLObject& rNewURL ) { aURL = rNewURL; } + +protected: + + Bitmap aThumbBmp; + GDIMetaFile aThumbMtf; + INetURLObject aURL; + String aUserName; + String aTitle; + sal_Bool bIsValid; + sal_Bool bIsThumbBmp; + + virtual void WriteData( SvStream& rOut, const String& rDestDir ) const; + virtual void ReadData( SvStream& rIn, sal_uInt16& rReadVersion ); + + sal_Bool CreateThumb( const Graphic& rGraphic ); + +public: + + SgaObject(); + virtual ~SgaObject() {}; + + virtual SgaObjKind GetObjKind() const = 0; + virtual sal_uInt16 GetVersion() const = 0; + + virtual Bitmap GetThumbBmp() const { return aThumbBmp; } + const GDIMetaFile& GetThumbMtf() const { return aThumbMtf; } + const INetURLObject& GetURL() const { return aURL; } + sal_Bool IsValid() const { return bIsValid; } + sal_Bool IsThumbBitmap() const { return bIsThumbBmp; } + + const String GetTitle() const; + void SetTitle( const String& rTitle ); + + friend SvStream& operator<<( SvStream& rOut, const SgaObject& rObj ); + friend SvStream& operator>>( SvStream& rIn, SgaObject& rObj ); +}; + +// ------------------ +// - SgaObjectSound - +// ------------------ + +class SgaObjectSound : public SgaObject +{ +private: + + GalSoundType eSoundType; + + virtual void WriteData( SvStream& rOut, const String& rDestDir ) const; + virtual void ReadData( SvStream& rIn, sal_uInt16& rReadVersion ); + + virtual sal_uInt16 GetVersion() const { return 6; } + +public: + + SgaObjectSound(); + SgaObjectSound( const INetURLObject& rURL ); + virtual ~SgaObjectSound(); + + virtual SgaObjKind GetObjKind() const { return SGA_OBJ_SOUND; } + virtual Bitmap GetThumbBmp() const; + GalSoundType GetSoundType() const { return eSoundType; } +}; + +// ------------------- +// - SgaObjectSvDraw - +// ------------------- + +class FmFormModel; + +class SgaObjectSvDraw : public SgaObject +{ + using SgaObject::CreateThumb; + +private: + + sal_Bool CreateThumb( const FmFormModel& rModel ); + + virtual void WriteData( SvStream& rOut, const String& rDestDir ) const; + virtual void ReadData( SvStream& rIn, sal_uInt16& rReadVersion ); + + virtual sal_uInt16 GetVersion() const { return 5; } + +public: + + SgaObjectSvDraw(); + SgaObjectSvDraw( const FmFormModel& rModel, const INetURLObject& rURL ); + SgaObjectSvDraw( SvStream& rIStm, const INetURLObject& rURL ); + virtual ~SgaObjectSvDraw() {}; + + virtual SgaObjKind GetObjKind() const { return SGA_OBJ_SVDRAW; } + +public: + + static sal_Bool DrawCentered( OutputDevice* pOut, const FmFormModel& rModel ); +}; + +// ---------------- +// - SgaObjectBmp - +// ---------------- + +class SgaObjectBmp: public SgaObject +{ +private: + + void Init( const Graphic& rGraphic, const INetURLObject& rURL ); + + virtual void WriteData( SvStream& rOut, const String& rDestDir ) const; + virtual void ReadData( SvStream& rIn, sal_uInt16& rReadVersion ); + + virtual sal_uInt16 GetVersion() const { return 5; } + +public: + + SgaObjectBmp(); + SgaObjectBmp( const INetURLObject& rURL ); + SgaObjectBmp( const Graphic& rGraphic, const INetURLObject& rURL, const String& rFormat ); + virtual ~SgaObjectBmp() {}; + + virtual SgaObjKind GetObjKind() const { return SGA_OBJ_BMP; } +}; + +// ----------------- +// - SgaObjectAnim - +// ----------------- + +class SgaObjectAnim : public SgaObjectBmp +{ +private: + + SgaObjectAnim( const INetURLObject& ) {}; + +public: + + SgaObjectAnim(); + SgaObjectAnim( const Graphic& rGraphic, const INetURLObject& rURL, const String& rFormatName ); + + virtual ~SgaObjectAnim() {}; + + virtual SgaObjKind GetObjKind() const { return SGA_OBJ_ANIM; } +}; + +// ----------------- +// - SgaObjectINet - +// ----------------- + +class SgaObjectINet : public SgaObjectAnim +{ +private: + + SgaObjectINet( const INetURLObject& ) {}; + +public: + + SgaObjectINet(); + SgaObjectINet( const Graphic& rGraphic, const INetURLObject& rURL, const String& rFormatName ); + + virtual ~SgaObjectINet() {}; + + virtual SgaObjKind GetObjKind() const { return SGA_OBJ_INET; } +}; +#endif + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |