diff options
Diffstat (limited to 'kpovmodeler/pmpovraymatrix.h')
-rw-r--r-- | kpovmodeler/pmpovraymatrix.h | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/kpovmodeler/pmpovraymatrix.h b/kpovmodeler/pmpovraymatrix.h new file mode 100644 index 00000000..25a1e03b --- /dev/null +++ b/kpovmodeler/pmpovraymatrix.h @@ -0,0 +1,97 @@ +//-*-C++-*- +/* +************************************************************************** + description + -------------------- + copyright : (C) 2000-2002 by Andreas Zehender + email : [email protected] +************************************************************************** + +************************************************************************** +* * +* 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 PMPOVRAYMATRIX_H +#define PMPOVRAYMATRIX_H + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include "pmobject.h" + +/** + * Class for povray matrix transformations. + */ + +class PMPovrayMatrix : public PMObject +{ + typedef PMObject Base; +public: + /** + * Creates an identity matrix + */ + PMPovrayMatrix( PMPart* part ); + /** + * Copy constructor + */ + PMPovrayMatrix( const PMPovrayMatrix& m ); + /** + * deletes the object + */ + virtual ~PMPovrayMatrix( ); + + /** */ + virtual PMObject* copy( ) const { return new PMPovrayMatrix( *this ); } + /** */ + virtual QString description( ) const; + + /** */ + virtual PMMetaObject* metaObject( ) const; + /** */ + virtual void cleanUp( ) const; + + /** */ + virtual void serialize( QDomElement& e, QDomDocument& doc ) const; + /** */ + virtual void readAttributes( const PMXMLHelper& h ); + /** + * Returns a new @ref PMPovrayMatrixEdit + */ + virtual PMDialogEditBase* editWidget( QWidget* parent ) const; + /** */ + virtual QString pixmap( ) const { return QString( "pmmatrix" ); } + + /** + * Returns the matrix values. + */ + PMVector values( ) const { return m_values; } + /** + * Sets the matrix values. Has to be a vector with size 12. + */ + void setValues( const PMVector& v ); + + /** */ + virtual void restoreMemento( PMMemento* s ); + /** */ + virtual bool hasTransformationMatrix( ) const { return true; } + /** */ + virtual PMMatrix transformationMatrix( ) const; + +private: + /** + * IDs for @ref PMMementoData + */ + enum PMMatrixMementoID { PMMatrixID }; + PMVector m_values; + + static PMMetaObject* s_pMetaObject; +}; + +#endif |