You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdegraphics/kpovmodeler/pmjuliafractal.h

175 lines
4.9 KiB

//-*-C++-*-
/*
**************************************************************************
description
--------------------
copyright : (C) 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 PMJULIAFRACTAL_H
#define PMJULIAFRACTAL_H
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include "pmsolidobject.h"
#include "pmvector.h"
class PMViewStructure;
/**
* Class for povray julia fractals.
*/
class PMJuliaFractal : public PMSolidObject
{
typedef PMSolidObject Base;
public:
enum AlgebraType { Quaternion, Hypercomplex };
enum FunctionType { FTsqr, FTcube, FTexp, FTreciprocal, FTsin, FTasin,
FTsinh, FTasinh, FTcos, FTacos, FTcosh, FTacosh,
FTtan, FTatan, FTtanh, FTatanh, FTlog, FTpwr };
/**
* Creates an empty PMJuliaFractal
*/
PMJuliaFractal( PMPart* part );
/**
* Copy constructor
*/
PMJuliaFractal( const PMJuliaFractal& f );
/**
* deletes the PMJuliaFractal
*/
virtual ~PMJuliaFractal( );
/** */
virtual PMObject* copy( ) const { return new PMJuliaFractal( *this ); }
/** */
virtual TQString description( ) const;
/** */
virtual PMMetaObject* metaObject( ) const;
/** */
virtual void cleanUp( ) const;
/** */
virtual void serialize( TQDomElement& e, TQDomDocument& doc ) const;
/** */
virtual void readAttributes( const PMXMLHelper& h );
/**
* Returns a new @ref PMJuliaFractalEdit
*/
virtual PMDialogEditBase* editWidget( TQWidget* parent ) const;
/**
* Returns the name of the pixmap that is displayed in the tree view
* and dialog view
*/
virtual TQString pixmap( ) const { return TQString( "pmjuliafractal" ); }
/** */
virtual void restoreMemento( PMMemento* s );
/**
* Returns the 4d julia parameter vector
*/
PMVector juliaParameter( ) const { return m_juliaParameter; }
/**
* Sets the julia parameter vector
*/
void setJuliaParameter( const PMVector& p );
/**
* Returns the algebra type
*/
AlgebraType algebraType( ) const { return m_algebraType; }
/**
* Sets the algebra type
*/
void setAlgebraType( AlgebraType t );
/**
* Returns the function type
*/
FunctionType functionType( ) const { return m_functionType; }
/**
* Sets the function type
*/
void setFunctionType( FunctionType t );
/**
* Returns the maximum number of iterations
*/
int maximumIterations( ) const { return m_maxIterations; }
/**
* Sets the maximum number of iterations
*/
void setMaximumIterations( int m );
/**
* Returns the precision
*/
double precision( ) const { return m_precision; }
/**
* Sets the precision
*/
void setPrecision( double p );
/**
* Returns the slice normal (4D vector)
*/
PMVector sliceNormal( ) const { return m_sliceNormal; }
/**
* Sets the slice normal (4D vector)
*/
void setSliceNormal( const PMVector& v );
/**
* Returns the slice distance
*/
double sliceDistance( ) const { return m_sliceDistance; }
/**
* Sets the slice distance
*/
void setSliceDistance( double d );
/**
* Returns the exponent for the pow function type (2D vector)
*/
PMVector exponent( ) const { return m_exponent; }
/**
* Sets the exponent for the pow function type (2D Vector)
*/
void setExponent( const PMVector& p );
static TQString functionTypeToString( FunctionType t );
static FunctionType stringToFunctionType( const TQString& str );
static TQString algebraTypeToString( AlgebraType t );
static AlgebraType stringToAlgebraType( const TQString& str );
private:
/**
* IDs for @ref PMMementoData
*/
enum PMJuliaFractalMementoID { PMJuliaParameterID, PMAlgebraTypeID,
PMFunctionTypeID, PMMaxIterationsID,
PMPrecisionID, PMSliceNormalID,
PMSliceDistanceID, PMExponentID };
PMVector m_juliaParameter;
AlgebraType m_algebraType;
FunctionType m_functionType;
int m_maxIterations;
double m_precision;
PMVector m_sliceNormal;
double m_sliceDistance;
PMVector m_exponent;
static PMMetaObject* s_pMetaObject;
};
#endif