From 47d455dd55be855e4cc691c32f687f723d9247ee Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdegraphics@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kpovmodeler/pmtexturebase.h | 96 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 96 insertions(+) create mode 100644 kpovmodeler/pmtexturebase.h (limited to 'kpovmodeler/pmtexturebase.h') diff --git a/kpovmodeler/pmtexturebase.h b/kpovmodeler/pmtexturebase.h new file mode 100644 index 00000000..2bd687f6 --- /dev/null +++ b/kpovmodeler/pmtexturebase.h @@ -0,0 +1,96 @@ +//-*-C++-*- +/* +************************************************************************** + description + -------------------- + copyright : (C) 2001-2002 by Andreas Zehender + email : zehender@kde.org +************************************************************************** + +************************************************************************** +* * +* This program is free software; you can redistribute it and/or modify * +* it under the terms of the GNU General Public License as published by * +* the Free Software Foundation; either version 2 of the License, or * +* (at your option) any later version. * +* * +**************************************************************************/ + + +#ifndef PMTEXTUREBASE_H +#define PMTEXTUREBASE_H + +#ifdef HAVE_CONFIG_H +#include +#endif + +#include + +#include "pmnamedobject.h" +#include "pmdeclare.h" + +/** + * Base class for all textures that can link to declares + */ +class PMTextureBase : public PMNamedObject +{ + typedef PMNamedObject Base; +public: + /** + * Creates an PMTextureBase + */ + PMTextureBase( PMPart* part ); + /** + * Copy constructor + */ + PMTextureBase( const PMTextureBase& b ); + /** + * Deletes the object + */ + virtual ~PMTextureBase( ); + + /** */ + virtual void serialize( QDomElement& e, QDomDocument& doc ) const; + /** */ + virtual void readAttributes( const PMXMLHelper& h ); + + /** */ + virtual PMMetaObject* metaObject( ) const; + /** */ + virtual void cleanUp( ) const; + + /** */ + virtual void restoreMemento( PMMemento* s ); + + /** */ + virtual PMDeclare* linkedObject( ) const { return m_pLinkedObject; } + /** + * Sets the linked object. Returns true if successful + */ + bool setLinkedObject( PMDeclare* o ); + /** + * Returns true if a linked object is set. Used by the + * insert possibilities framework. + */ + bool hasLinkedObject( ) const { return m_pLinkedObject; } + + /** + * Method used by the properties framework + */ + PMObject* linkedObjectProperty( ) const { return m_pLinkedObject; } + /** + * Method used by the properties framework + */ + void setLinkedObjectProperty( PMObject* o ); +private: + /** + * IDs for @ref PMMementoData + */ + enum PMTextureBaseMementoID { PMLinkedObjectID }; + PMDeclare* m_pLinkedObject; + + static PMMetaObject* s_pMetaObject; +}; + + +#endif -- cgit v1.2.3