summaryrefslogtreecommitdiffstats
path: root/kpovmodeler/pmpatternedit.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kpovmodeler/pmpatternedit.cpp')
-rw-r--r--kpovmodeler/pmpatternedit.cpp1073
1 files changed, 1073 insertions, 0 deletions
diff --git a/kpovmodeler/pmpatternedit.cpp b/kpovmodeler/pmpatternedit.cpp
new file mode 100644
index 00000000..1f9647c2
--- /dev/null
+++ b/kpovmodeler/pmpatternedit.cpp
@@ -0,0 +1,1073 @@
+/*
+**************************************************************************
+ description
+ --------------------
+ copyright : (C) 2001 by Luis Carvalho
+ email : lpassos@mail.telepac.pt
+ copyright : (C) 2001 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. *
+* *
+**************************************************************************/
+
+
+#include "pmpatternedit.h"
+#include "pmpattern.h"
+#include "pmvectoredit.h"
+#include "pmlineedits.h"
+#include "pmvector.h"
+
+#include <qwidget.h>
+#include <qlayout.h>
+#include <qcombobox.h>
+#include <qlabel.h>
+#include <qlineedit.h>
+#include <qcheckbox.h>
+#include <qpushbutton.h>
+#include <ktabctl.h>
+#include <klocale.h>
+#include <kmessagebox.h>
+#include <kdialog.h>
+#include <kfiledialog.h>
+#include <kiconloader.h>
+
+PMPatternEdit::PMPatternEdit( QWidget* parent, const char* name )
+ : Base( parent, name )
+{
+ m_pDisplayedObject = 0;
+}
+
+void PMPatternEdit::createTopWidgets( )
+{
+ Base::createTopWidgets( );
+
+ QGridLayout* layout;
+ QHBoxLayout* hl;
+ QVBoxLayout* vl;
+ QGridLayout* gl;
+
+ layout = new QGridLayout( topLayout( ), 12, 2 );
+ hl = new QHBoxLayout( KDialog::spacingHint( ) );
+ hl->addWidget( new QLabel( i18n( "Type:" ), this ) );
+ m_pTypeCombo = new QComboBox( false, this );
+ m_pTypeCombo->insertItem( i18n( "Agate" ) );
+ m_pTypeCombo->insertItem( i18n( "Average" ) );
+ m_pTypeCombo->insertItem( i18n( "Boxed" ) );
+ m_pTypeCombo->insertItem( i18n( "Bozo" ) );
+ m_pTypeCombo->insertItem( i18n( "Bumps" ) );
+ m_pTypeCombo->insertItem( i18n( "Cells" ) );
+ m_pTypeCombo->insertItem( i18n( "Crackle" ) );
+ m_pTypeCombo->insertItem( i18n( "Cylindrical" ) );
+ m_pTypeCombo->insertItem( i18n( "Density File" ) );
+ m_pTypeCombo->insertItem( i18n( "Dents" ) );
+ m_pTypeCombo->insertItem( i18n( "Gradient" ) );
+ m_pTypeCombo->insertItem( i18n( "Granite" ) );
+ m_pTypeCombo->insertItem( i18n( "Julia" ) );
+ m_pTypeCombo->insertItem( i18n( "Leopard" ) );
+ m_pTypeCombo->insertItem( i18n( "Mandel" ) );
+ m_pTypeCombo->insertItem( i18n( "Marble" ) );
+ m_pTypeCombo->insertItem( i18n( "Onion" ) );
+ m_pTypeCombo->insertItem( i18n( "Planar" ) );
+ m_pTypeCombo->insertItem( i18n( "Quilt" ) );
+ m_pTypeCombo->insertItem( i18n( "Radial" ) );
+ m_pTypeCombo->insertItem( i18n( "Ripples" ) );
+ m_pTypeCombo->insertItem( i18n( "Slope" ) );
+ m_pTypeCombo->insertItem( i18n( "Spherical" ) );
+ m_pTypeCombo->insertItem( i18n( "Spiral1" ) );
+ m_pTypeCombo->insertItem( i18n( "Spiral2" ) );
+ m_pTypeCombo->insertItem( i18n( "Spotted" ) );
+ m_pTypeCombo->insertItem( i18n( "Waves" ) );
+ m_pTypeCombo->insertItem( i18n( "Wood" ) );
+ m_pTypeCombo->insertItem( i18n( "Wrinkles" ) );
+ hl->addWidget( m_pTypeCombo );
+ hl->addStretch( 1 );
+ layout->addMultiCellLayout( hl, 0, 0, 0, 1 );
+
+ m_pAgateTurbulenceLabel = new QLabel( i18n( "Turbulence:" ), this );
+ layout->addWidget( m_pAgateTurbulenceLabel, 1, 0 );
+ m_pAgateTurbulenceEdit = new PMFloatEdit( this );
+ layout->addWidget( m_pAgateTurbulenceEdit, 1, 1, AlignLeft );
+
+ m_pCrackleWidget = new QWidget( this );
+ vl = new QVBoxLayout( m_pCrackleWidget, 0, KDialog::spacingHint( ) );
+ hl = new QHBoxLayout( vl );
+ hl->addWidget( new QLabel( i18n( "Form:" ), m_pCrackleWidget ) );
+ m_pCrackleForm = new PMVectorEdit( "x", "y", "z", m_pCrackleWidget );
+ hl->addWidget( m_pCrackleForm );
+ hl->addStretch( 1 );
+ hl = new QHBoxLayout( vl );
+ gl = new QGridLayout( hl, 3, 2 );
+ gl->addWidget( new QLabel( i18n( "Metric:" ), m_pCrackleWidget ), 0, 0 );
+ m_pCrackleMetric = new PMIntEdit( m_pCrackleWidget );
+ m_pCrackleMetric->setValidation( true, 1, false, 0 );
+ gl->addWidget( m_pCrackleMetric, 0, 1 );
+ gl->addWidget( new QLabel( i18n( "Offset:" ), m_pCrackleWidget ), 1, 0 );
+ m_pCrackleOffset = new PMFloatEdit( m_pCrackleWidget );
+ gl->addWidget( m_pCrackleOffset, 1, 1 );
+ m_pCrackleSolid = new QCheckBox( i18n( "Solid:" ), m_pCrackleWidget );
+ gl->addMultiCellWidget( m_pCrackleSolid, 2, 2, 0, 1 );
+ hl->addStretch( 1 );
+ layout->addMultiCellWidget( m_pCrackleWidget, 2, 2, 0, 1 );
+
+ m_pDensityWidget = new QWidget( this );
+ vl = new QVBoxLayout( m_pDensityWidget, 0, KDialog::spacingHint( ) );
+ hl = new QHBoxLayout( vl );
+ hl->addWidget( new QLabel( i18n( "File:" ), m_pDensityWidget ) );
+ m_pDensityFile = new QLineEdit( m_pDensityWidget );
+ hl->addWidget( m_pDensityFile, 1 );
+ m_pDensityFileBrowse = new QPushButton( m_pDensityWidget );
+ m_pDensityFileBrowse->setPixmap( SmallIcon( "fileopen" ) );
+ hl->addWidget( m_pDensityFileBrowse );
+ hl = new QHBoxLayout( vl );
+ hl->addWidget( new QLabel( i18n( "Interpolation:" ), m_pDensityWidget ) );
+ m_pDensityInterpolate = new QComboBox( false, m_pDensityWidget );
+ m_pDensityInterpolate->insertItem( i18n( "None" ) );
+ m_pDensityInterpolate->insertItem( i18n( "Trilinear" ) );
+ hl->addWidget( m_pDensityInterpolate );
+ hl->addStretch( 1 );
+ layout->addMultiCellWidget( m_pDensityWidget, 3, 3, 0, 1 );
+
+ m_pGradientLabel = new QLabel( i18n( "Gradient:" ), this );
+ layout->addWidget( m_pGradientLabel, 4, 0 );
+ m_pGradientEdit = new PMVectorEdit( "x", "y", "z", this );
+ layout->addWidget( m_pGradientEdit, 4, 1 );
+
+ m_pJuliaComplexLabel = new QLabel( i18n( "Complex number:" ), this );
+ layout->addWidget( m_pJuliaComplexLabel, 5, 0 );
+ m_pJuliaComplex = new PMVectorEdit( "Real", "Imaginary", this );
+ layout->addWidget( m_pJuliaComplex, 5, 1 );
+
+ m_pFractalWidget = new QWidget( this );
+ vl = new QVBoxLayout( m_pFractalWidget, 0, KDialog::spacingHint( ) );
+ hl = new QHBoxLayout( vl );
+ m_pFractalMagnet = new QCheckBox( i18n( "Magnet" ), m_pFractalWidget );
+ hl->addWidget( m_pFractalMagnet );
+ m_pFractalMagnetType = new QComboBox( false, m_pFractalWidget );
+ m_pFractalMagnetType->insertItem( i18n( "Type 1" ) );
+ m_pFractalMagnetType->insertItem( i18n( "Type 2" ) );
+ hl->addWidget( m_pFractalMagnetType );
+ hl->addStretch( 1 );
+ hl = new QHBoxLayout( vl );
+ gl = new QGridLayout( hl, 2, 2 );
+ gl->addWidget( new QLabel( i18n( "Maximum iterations:" ), m_pFractalWidget ), 0, 0 );
+ m_pMaxIterationsEdit = new PMIntEdit( m_pFractalWidget );
+ m_pMaxIterationsEdit->setValidation( true, 1, false, 0 );
+ gl->addWidget( m_pMaxIterationsEdit, 0, 1 );
+ m_pFractalExponentLabel = new QLabel( i18n( "Exponent:" ), m_pFractalWidget );
+ gl->addWidget( m_pFractalExponentLabel, 1, 0 );
+ m_pFractalExponent = new PMIntEdit( m_pFractalWidget );
+ m_pFractalExponent->setValidation( true, 2, true, 33 );
+ gl->addWidget( m_pFractalExponent, 1, 1 );
+ hl->addStretch( 1 );
+ hl = new QHBoxLayout( vl );
+ gl = new QGridLayout( hl, 2, 4 );
+ gl->addWidget( new QLabel( i18n( "Exterior type:" ), m_pFractalWidget ), 0, 0 );
+ m_pFractalExtType = new QComboBox( false, m_pFractalWidget );
+ m_pFractalExtType->insertItem( i18n( "0: Returns Just 1" ) );
+ m_pFractalExtType->insertItem( i18n( "1: Iterations Until Bailout" ) );
+ m_pFractalExtType->insertItem( i18n( "2: Real Part" ) );
+ m_pFractalExtType->insertItem( i18n( "3: Imaginary Part" ) );
+ m_pFractalExtType->insertItem( i18n( "4: Squared Real Part" ) );
+ m_pFractalExtType->insertItem( i18n( "5: Squared Imaginary Part" ) );
+ m_pFractalExtType->insertItem( i18n( "6: Absolute Value" ) );
+ gl->addWidget( m_pFractalExtType, 0, 1 );
+ gl->addWidget( new QLabel( i18n( "Factor:" ), m_pFractalWidget ), 0, 2 );
+ m_pFractalExtFactor = new PMFloatEdit( m_pFractalWidget );
+ gl->addWidget( m_pFractalExtFactor, 0, 3 );
+ gl->addWidget( new QLabel( i18n( "Interior type:" ), m_pFractalWidget ), 1, 0 );
+ m_pFractalIntType = new QComboBox( false, m_pFractalWidget );
+ m_pFractalIntType->insertItem( i18n( "0: Returns Just 1" ) );
+ m_pFractalIntType->insertItem( i18n( "1: Absolute Value Smallest" ) );
+ m_pFractalIntType->insertItem( i18n( "2: Real Part" ) );
+ m_pFractalIntType->insertItem( i18n( "3: Imaginary Part" ) );
+ m_pFractalIntType->insertItem( i18n( "4: Squared Real Part" ) );
+ m_pFractalIntType->insertItem( i18n( "5: Squared Imaginary Part" ) );
+ m_pFractalIntType->insertItem( i18n( "6: Absolute Value Last" ) );
+ gl->addWidget( m_pFractalIntType, 1, 1 );
+ gl->addWidget( new QLabel( i18n( "Factor:" ), m_pFractalWidget ), 1, 2 );
+ m_pFractalIntFactor = new PMFloatEdit( m_pFractalWidget );
+ gl->addWidget( m_pFractalIntFactor, 1, 3 );
+ hl->addStretch( 1 );
+ layout->addMultiCellWidget( m_pFractalWidget, 6, 6, 0, 1 );
+
+ m_pQuiltControlsLabel = new QLabel( i18n( "Quilt controls:" ), this );
+ m_pQuiltControl0Edit = new PMFloatEdit( this );
+ m_pQuiltControl1Edit = new PMFloatEdit( this );
+ hl = new QHBoxLayout( );
+ hl->addWidget( m_pQuiltControl0Edit );
+ hl->addWidget( m_pQuiltControl1Edit );
+ hl->addStretch( 1 );
+ layout->addWidget( m_pQuiltControlsLabel, 7, 0 );
+ layout->addLayout( hl, 7, 1 );
+
+ m_pSlopeWidget = new QWidget( this );
+ vl = new QVBoxLayout( m_pSlopeWidget, 0, KDialog::spacingHint( ) );
+ hl = new QHBoxLayout( vl );
+ hl->addWidget( new QLabel( i18n( "Direction:" ), m_pSlopeWidget ) );
+ m_pSlopeDirection = new PMVectorEdit( "x", "y", "z", m_pSlopeWidget );
+ hl->addWidget( m_pSlopeDirection );
+ hl = new QHBoxLayout( vl );
+ gl = new QGridLayout( hl, 2, 2 );
+ gl->addWidget( new QLabel( i18n( "Low slope:" ), m_pSlopeWidget ), 0, 0 );
+ m_pSlopeLoSlope = new PMFloatEdit( m_pSlopeWidget );
+ m_pSlopeLoSlope->setValidation( true, 0.0, true, 1.0 );
+ gl->addWidget( m_pSlopeLoSlope, 0, 1 );
+ gl->addWidget( new QLabel( i18n( "High slope:" ), m_pSlopeWidget ), 1, 0 );
+ m_pSlopeHiSlope = new PMFloatEdit( m_pSlopeWidget );
+ m_pSlopeHiSlope->setValidation( true, 0.0, true, 1.0 );
+ gl->addWidget( m_pSlopeHiSlope, 1, 1 );
+ hl->addStretch( 1 );
+ hl = new QHBoxLayout( vl );
+ m_pSlopeAltFlag = new QCheckBox( i18n( "Altitiude" ), m_pSlopeWidget );
+ hl->addWidget( m_pSlopeAltFlag );
+ m_pSlopeAltitude = new PMVectorEdit( "x", "y", "z", m_pSlopeWidget );
+ hl->addWidget( m_pSlopeAltitude );
+ hl = new QHBoxLayout( vl );
+ gl = new QGridLayout( hl, 2, 2 );
+ m_pSlopeLoAltLabel = new QLabel( i18n( "Low altitude:" ), m_pSlopeWidget );
+ gl->addWidget( m_pSlopeLoAltLabel, 0, 0 );
+ m_pSlopeLoAlt = new PMFloatEdit( m_pSlopeWidget );
+ gl->addWidget( m_pSlopeLoAlt, 0, 1 );
+ m_pSlopeHiAltLabel = new QLabel( i18n( "High altitude:" ), m_pSlopeWidget );
+ gl->addWidget( m_pSlopeHiAltLabel, 1, 0 );
+ m_pSlopeHiAlt = new PMFloatEdit( m_pSlopeWidget );
+ gl->addWidget( m_pSlopeHiAlt, 1, 1 );
+ hl->addStretch( 1 );
+ layout->addMultiCellWidget( m_pSlopeWidget, 8, 8, 0, 1 );
+
+ m_pSpiralNumberLabel = new QLabel( i18n( "Spiral number:" ), this );
+ m_pSpiralNumberEdit = new PMIntEdit( this );
+ layout->addWidget( m_pSpiralNumberLabel, 9, 0 );
+ layout->addWidget( m_pSpiralNumberEdit, 9, 1, AlignLeft );
+
+ m_pDepthLabel = new QLabel( i18n( "Depth:" ), this );
+ m_pDepthEdit = new PMFloatEdit( this );
+ layout->addWidget( m_pDepthLabel, 10, 0 );
+ layout->addWidget( m_pDepthEdit, 10, 1, AlignLeft );
+
+ m_pNoiseGeneratorLabel = new QLabel( i18n( "Noise generator:" ), this );
+ m_pNoiseGenerator = new QComboBox( false, this );
+ m_pNoiseGenerator->insertItem( i18n( "Use Global Setting" ) );
+ m_pNoiseGenerator->insertItem( i18n( "Original" ) );
+ m_pNoiseGenerator->insertItem( i18n( "Range Corrected" ) );
+ m_pNoiseGenerator->insertItem( i18n( "Perlin" ) );
+ layout->addWidget( m_pNoiseGeneratorLabel, 11, 0 );
+ layout->addWidget( m_pNoiseGenerator, 11, 1 );
+
+ m_pEnableTurbulenceEdit = new QCheckBox( i18n( "Turbulence" ), this );
+ topLayout( )->addWidget( m_pEnableTurbulenceEdit );
+ m_pTurbulenceWidget = new QWidget( this );
+ vl = new QVBoxLayout( m_pTurbulenceWidget, 0, KDialog::spacingHint( ) );
+ hl = new QHBoxLayout( vl );
+ hl->addWidget( new QLabel( i18n( "Value:" ), m_pTurbulenceWidget ) );
+ m_pValueVectorEdit = new PMVectorEdit( "x", "y", "z", m_pTurbulenceWidget );
+ hl->addWidget( m_pValueVectorEdit );
+ hl = new QHBoxLayout( vl );
+ gl = new QGridLayout( hl, 3, 2 );
+ gl->addWidget( new QLabel( i18n( "Octaves:" ), m_pTurbulenceWidget ), 0, 0 );
+ m_pOctavesEdit = new PMIntEdit( m_pTurbulenceWidget );
+ gl->addWidget( m_pOctavesEdit, 0, 1 );
+ gl->addWidget( new QLabel( i18n( "Omega:" ), m_pTurbulenceWidget ), 1, 0 );
+ m_pOmegaEdit = new PMFloatEdit( m_pTurbulenceWidget );
+ gl->addWidget( m_pOmegaEdit, 1, 1 );
+ gl->addWidget( new QLabel( i18n( "Lambda:" ), m_pTurbulenceWidget ), 2, 0 );
+ m_pLambdaEdit = new PMFloatEdit( m_pTurbulenceWidget );
+ gl->addWidget( m_pLambdaEdit, 2, 1 );
+ hl->addStretch( 1 );
+ topLayout( )->addWidget( m_pTurbulenceWidget );
+
+ /* connect all signals to slots/signals */
+ connect( m_pTypeCombo, SIGNAL( activated( int ) ), SLOT( slotComboChanged( int ) ) );
+
+ connect( m_pAgateTurbulenceEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pCrackleForm, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pCrackleMetric, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pCrackleOffset, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pCrackleSolid, SIGNAL( clicked( ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pDensityInterpolate, SIGNAL( activated( int ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pDensityFile, SIGNAL( textChanged( const QString& ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pDensityFileBrowse, SIGNAL( clicked( ) ), SLOT( slotDensityFileBrowseClicked( ) ) );
+
+ connect( m_pGradientEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pJuliaComplex, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pFractalMagnet, SIGNAL( clicked( ) ), SLOT( slotFractalMagnetClicked( ) ) );
+ connect( m_pFractalMagnetType, SIGNAL( activated( int ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pMaxIterationsEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pFractalExponent, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pFractalExtType, SIGNAL( activated( int ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pFractalExtFactor, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pFractalIntType, SIGNAL( activated( int ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pFractalIntFactor, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pQuiltControl0Edit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pQuiltControl1Edit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pSlopeDirection, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pSlopeLoSlope, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pSlopeHiSlope, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pSlopeAltFlag, SIGNAL( clicked( ) ), SLOT( slotSlopeAltFlagClicked( ) ) );
+ connect( m_pSlopeAltitude, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pSlopeLoAlt, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pSlopeHiAlt, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pSpiralNumberEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pNoiseGenerator, SIGNAL( activated( int ) ), SIGNAL( dataChanged( ) ) );
+
+ connect( m_pEnableTurbulenceEdit, SIGNAL( clicked( ) ), SLOT( slotTurbulenceClicked( ) ) );
+ connect( m_pValueVectorEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pOctavesEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pOmegaEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pLambdaEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+ connect( m_pDepthEdit, SIGNAL( dataChanged( ) ), SIGNAL( dataChanged( ) ) );
+}
+
+void PMPatternEdit::displayObject( PMObject* o )
+{
+ QString str;
+ bool readOnly;
+
+ if( o->isA( "Pattern" ) )
+ {
+ m_pDisplayedObject = ( PMPattern* ) o;
+ readOnly = m_pDisplayedObject->isReadOnly( );
+
+ switch( m_pDisplayedObject->patternType( ) )
+ {
+ case PMPattern::PatternAgate:
+ setPatternType( 0 );
+ break;
+ case PMPattern::PatternAverage:
+ setPatternType( 1 );
+ break;
+ case PMPattern::PatternBoxed:
+ setPatternType( 2 );
+ break;
+ case PMPattern::PatternBozo:
+ setPatternType( 3 );
+ break;
+ case PMPattern::PatternBumps:
+ setPatternType( 4 );
+ break;
+ case PMPattern::PatternCells:
+ setPatternType( 5 );
+ break;
+ case PMPattern::PatternCrackle:
+ setPatternType( 6 );
+ break;
+ case PMPattern::PatternCylindrical:
+ setPatternType( 7 );
+ break;
+ case PMPattern::PatternDensity:
+ setPatternType( 8 );
+ break;
+ case PMPattern::PatternDents:
+ setPatternType( 9 );
+ break;
+ case PMPattern::PatternGradient:
+ setPatternType( 10 );
+ break;
+ case PMPattern::PatternGranite:
+ setPatternType( 11 );
+ break;
+ case PMPattern::PatternJulia:
+ setPatternType( 12 );
+ break;
+ case PMPattern::PatternLeopard:
+ setPatternType( 13 );
+ break;
+ case PMPattern::PatternMandel:
+ setPatternType( 14 );
+ break;
+ case PMPattern::PatternMarble:
+ setPatternType( 15 );
+ break;
+ case PMPattern::PatternOnion:
+ setPatternType( 16 );
+ break;
+ case PMPattern::PatternPlanar:
+ setPatternType( 17 );
+ break;
+ case PMPattern::PatternQuilted:
+ setPatternType( 18 );
+ break;
+ case PMPattern::PatternRadial:
+ setPatternType( 19 );
+ break;
+ case PMPattern::PatternRipples:
+ setPatternType( 20 );
+ break;
+ case PMPattern::PatternSlope:
+ setPatternType( 21 );
+ break;
+ case PMPattern::PatternSpherical:
+ setPatternType( 22 );
+ break;
+ case PMPattern::PatternSpiral1:
+ setPatternType( 23 );
+ break;
+ case PMPattern::PatternSpiral2:
+ setPatternType( 24 );
+ break;
+ case PMPattern::PatternSpotted:
+ setPatternType( 25 );
+ break;
+ case PMPattern::PatternWaves:
+ setPatternType( 26 );
+ break;
+ case PMPattern::PatternWood:
+ setPatternType( 27 );
+ break;
+ case PMPattern::PatternWrinkles:
+ setPatternType( 28 );
+ break;
+ }
+ m_pTypeCombo->setEnabled( !readOnly );
+
+ m_pAgateTurbulenceEdit->setValue( m_pDisplayedObject->agateTurbulence( ) );
+ m_pAgateTurbulenceEdit->setReadOnly( readOnly );
+
+ m_pCrackleForm->setVector( m_pDisplayedObject->crackleForm( ) );
+ m_pCrackleForm->setReadOnly( readOnly );
+ m_pCrackleMetric->setValue( m_pDisplayedObject->crackleMetric( ) );
+ m_pCrackleMetric->setReadOnly( readOnly );
+ m_pCrackleOffset->setValue( m_pDisplayedObject->crackleOffset( ) );
+ m_pCrackleOffset->setReadOnly( readOnly );
+ m_pCrackleSolid->setChecked( m_pDisplayedObject->crackleSolid( ) );
+ m_pCrackleSolid->setEnabled( !readOnly );
+
+ m_pDensityFile->setText( m_pDisplayedObject->densityFile( ) );
+ m_pDensityFile->setEnabled( !readOnly );
+ m_pDensityInterpolate->setCurrentItem( m_pDisplayedObject->densityInterpolate( ) );
+ m_pDensityInterpolate->setEnabled( !readOnly );
+
+ m_pGradientEdit->setVector( m_pDisplayedObject->gradient( ) );
+ m_pGradientEdit->setReadOnly( readOnly );
+
+ m_pJuliaComplex->setVector( m_pDisplayedObject->juliaComplex( ) );
+ m_pJuliaComplex->setReadOnly( readOnly );
+ m_pFractalMagnet->setChecked( m_pDisplayedObject->fractalMagnet( ) );
+ m_pFractalMagnet->setEnabled( !readOnly );
+ m_pFractalMagnetType->setCurrentItem( m_pDisplayedObject->fractalMagnetType( ) - 1 );
+ m_pFractalMagnetType->setEnabled( !readOnly );
+ m_pMaxIterationsEdit->setValue( m_pDisplayedObject->maxIterations( ) );
+ m_pMaxIterationsEdit->setReadOnly( readOnly );
+ m_pFractalExponent->setValue( m_pDisplayedObject->fractalExponent( ) );
+ m_pFractalExponent->setReadOnly( readOnly );
+ m_pFractalExtType->setCurrentItem( m_pDisplayedObject->fractalExtType( ) );
+ m_pFractalExtType->setEnabled( !readOnly );
+ m_pFractalExtFactor->setValue( m_pDisplayedObject->fractalExtFactor( ) );
+ m_pFractalExtFactor->setReadOnly( readOnly );
+ m_pFractalIntType->setCurrentItem( m_pDisplayedObject->fractalIntType( ) );
+ m_pFractalIntType->setEnabled( !readOnly );
+ m_pFractalIntFactor->setValue( m_pDisplayedObject->fractalIntFactor( ) );
+ m_pFractalIntFactor->setReadOnly( readOnly );
+
+ m_pQuiltControl0Edit->setValue( m_pDisplayedObject->quiltControl0( ) );
+ m_pQuiltControl0Edit->setReadOnly( readOnly );
+ m_pQuiltControl1Edit->setValue( m_pDisplayedObject->quiltControl1( ) );
+ m_pQuiltControl1Edit->setReadOnly( readOnly );
+
+ m_pSlopeDirection->setVector( m_pDisplayedObject->slopeDirection( ) );
+ m_pSlopeDirection->setReadOnly( readOnly );
+ m_pSlopeLoSlope->setValue( m_pDisplayedObject->slopeLoSlope( ) );
+ m_pSlopeLoSlope->setReadOnly( readOnly );
+ m_pSlopeHiSlope->setValue( m_pDisplayedObject->slopeHiSlope( ) );
+ m_pSlopeHiSlope->setReadOnly( readOnly );
+ m_pSlopeAltFlag->setChecked( m_pDisplayedObject->slopeAltFlag( ) );
+ m_pSlopeAltFlag->setEnabled( !readOnly );
+ m_pSlopeAltitude->setVector( m_pDisplayedObject->slopeAltitude( ) );
+ m_pSlopeAltitude->setReadOnly( readOnly );
+ m_pSlopeLoAlt->setValue( m_pDisplayedObject->slopeLoAltitude( ) );
+ m_pSlopeLoAlt->setReadOnly( readOnly );
+ m_pSlopeHiAlt->setValue( m_pDisplayedObject->slopeHiAltitude( ) );
+ m_pSlopeHiAlt->setReadOnly( readOnly );
+
+ m_pSpiralNumberEdit->setValue( m_pDisplayedObject->spiralNumberArms( ) );
+ m_pSpiralNumberEdit->setReadOnly( readOnly );
+
+ m_pNoiseGenerator->setCurrentItem( m_pDisplayedObject->noiseGenerator( ) );
+ m_pNoiseGenerator->setEnabled( !readOnly );
+
+ m_pEnableTurbulenceEdit->setChecked( m_pDisplayedObject->isTurbulenceEnabled( ) );
+ m_pEnableTurbulenceEdit->setEnabled( !readOnly );
+ m_pValueVectorEdit->setVector( m_pDisplayedObject->valueVector( ) );
+ m_pValueVectorEdit->setReadOnly( readOnly );
+ m_pOctavesEdit->setValue( m_pDisplayedObject->octaves( ) );
+ m_pOctavesEdit->setReadOnly( readOnly );
+ m_pOmegaEdit->setValue( m_pDisplayedObject->omega( ) );
+ m_pOmegaEdit->setReadOnly( readOnly );
+ m_pLambdaEdit->setValue( m_pDisplayedObject->lambda( ) );
+ m_pLambdaEdit->setReadOnly( readOnly );
+
+ if( o->parent( ) && ( o->parent( )->type( ) == "Normal" ) )
+ {
+ m_pDepthEdit->setValue( m_pDisplayedObject->depth( ) );
+ m_pDepthEdit->setReadOnly( readOnly );
+ m_pDepthEdit->show( );
+ m_pDepthLabel->show( );
+ emit sizeChanged( );
+ }
+ else
+ {
+ m_pDepthEdit->hide( );
+ m_pDepthLabel->hide( );
+ emit sizeChanged( );
+ }
+
+ slotFractalMagnetClicked( );
+ slotSlopeAltFlagClicked( );
+ slotTurbulenceClicked( );
+ Base::displayObject( o );
+ }
+ else
+ kdError( PMArea ) << "PMPatternEdit: Can't display object\n";
+}
+
+void PMPatternEdit::setPatternType( int i )
+{
+ m_pTypeCombo->setCurrentItem( i );
+ slotComboChanged( i );
+}
+
+void PMPatternEdit::saveContents( )
+{
+ if( m_pDisplayedObject )
+ {
+ Base::saveContents( );
+ switch( m_pTypeCombo->currentItem( ) )
+ {
+ case 0:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternAgate );
+ m_pDisplayedObject->setAgateTurbulence( m_pAgateTurbulenceEdit->value( ) );
+ break;
+ case 1:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternAverage );
+ break;
+ case 2:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternBoxed );
+ break;
+ case 3:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternBozo );
+ m_pDisplayedObject->setNoiseGenerator(
+ ( PMPattern::PMNoiseType ) m_pNoiseGenerator->currentItem( ) );
+ break;
+ case 4:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternBumps );
+ m_pDisplayedObject->setNoiseGenerator(
+ ( PMPattern::PMNoiseType ) m_pNoiseGenerator->currentItem( ) );
+ break;
+ case 5:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternCells );
+ break;
+ case 6:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternCrackle );
+ m_pDisplayedObject->setCrackleForm( m_pCrackleForm->vector( ) );
+ m_pDisplayedObject->setCrackleMetric( m_pCrackleMetric->value( ) );
+ m_pDisplayedObject->setCrackleOffset( m_pCrackleOffset->value( ) );
+ m_pDisplayedObject->setCrackleSolid( m_pCrackleSolid->isChecked( ) );
+ break;
+ case 7:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternCylindrical );
+ break;
+ case 8:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternDensity );
+ m_pDisplayedObject->setDensityFile( m_pDensityFile->text( ) );
+ m_pDisplayedObject->setDensityInterpolate( m_pDensityInterpolate->currentItem( ) );
+ break;
+ case 9:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternDents );
+ break;
+ case 10:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternGradient );
+ m_pDisplayedObject->setGradient( m_pGradientEdit->vector( ) );
+ break;
+ case 11:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternGranite );
+ m_pDisplayedObject->setNoiseGenerator(
+ ( PMPattern::PMNoiseType ) m_pNoiseGenerator->currentItem( ) );
+ break;
+ case 12:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternJulia );
+ m_pDisplayedObject->setJuliaComplex( m_pJuliaComplex->vector( ) );
+ m_pDisplayedObject->setFractalMagnet( m_pFractalMagnet->isChecked( ) );
+ m_pDisplayedObject->setFractalMagnetType( m_pFractalMagnetType->currentItem( ) + 1 );
+ m_pDisplayedObject->setMaxIterations( m_pMaxIterationsEdit->value( ) );
+ m_pDisplayedObject->setFractalExponent( m_pFractalExponent->value( ) );
+ m_pDisplayedObject->setFractalExtType( m_pFractalExtType->currentItem( ) );
+ m_pDisplayedObject->setFractalExtFactor( m_pFractalExtFactor->value( ) );
+ m_pDisplayedObject->setFractalIntType( m_pFractalIntType->currentItem( ) );
+ m_pDisplayedObject->setFractalIntFactor( m_pFractalIntFactor->value( ) );
+ break;
+ case 13:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternLeopard );
+ break;
+ case 14:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternMandel );
+ m_pDisplayedObject->setFractalMagnet( m_pFractalMagnet->isChecked( ) );
+ m_pDisplayedObject->setFractalMagnetType( m_pFractalMagnetType->currentItem( ) + 1 );
+ m_pDisplayedObject->setMaxIterations( m_pMaxIterationsEdit->value( ) );
+ m_pDisplayedObject->setFractalExponent( m_pFractalExponent->value( ) );
+ m_pDisplayedObject->setFractalExtType( m_pFractalExtType->currentItem( ) );
+ m_pDisplayedObject->setFractalExtFactor( m_pFractalExtFactor->value( ) );
+ m_pDisplayedObject->setFractalIntType( m_pFractalIntType->currentItem( ) );
+ m_pDisplayedObject->setFractalIntFactor( m_pFractalIntFactor->value( ) );
+ break;
+ case 15:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternMarble );
+ break;
+ case 16:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternOnion );
+ break;
+ case 17:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternPlanar );
+ break;
+ case 18:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternQuilted );
+ m_pDisplayedObject->setQuiltControl0( m_pQuiltControl0Edit->value( ) );
+ m_pDisplayedObject->setQuiltControl1( m_pQuiltControl1Edit->value( ) );
+ break;
+ case 19:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternRadial );
+ break;
+ case 20:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternRipples );
+ break;
+ case 21:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternSlope );
+ m_pDisplayedObject->setSlopeDirection( m_pSlopeDirection->vector( ) );
+ m_pDisplayedObject->setSlopeLoSlope( m_pSlopeLoSlope->value( ) );
+ m_pDisplayedObject->setSlopeHiSlope( m_pSlopeHiSlope->value( ) );
+ m_pDisplayedObject->setSlopeAltFlag( m_pSlopeAltFlag->isChecked( ) );
+ m_pDisplayedObject->setSlopeAltitude( m_pSlopeAltitude->vector( ) );
+ m_pDisplayedObject->setSlopeLoAlt( m_pSlopeLoAlt->value( ) );
+ m_pDisplayedObject->setSlopeHiAlt( m_pSlopeHiAlt->value( ) );
+ break;
+ case 22:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternSpherical );
+ break;
+ case 23:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternSpiral1 );
+ m_pDisplayedObject->setSpiralNumberArms( m_pSpiralNumberEdit->value( ) );
+ break;
+ case 24:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternSpiral2 );
+ m_pDisplayedObject->setSpiralNumberArms( m_pSpiralNumberEdit->value( ) );
+ break;
+ case 25:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternSpotted );
+ break;
+ case 26:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternWaves );
+ break;
+ case 27:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternWood );
+ break;
+ case 28:
+ m_pDisplayedObject->setPatternType( PMPattern::PatternWrinkles );
+ m_pDisplayedObject->setNoiseGenerator(
+ ( PMPattern::PMNoiseType ) m_pNoiseGenerator->currentItem( ) );
+ break;
+ }
+ m_pDisplayedObject->enableTurbulence( m_pEnableTurbulenceEdit->isChecked( ) );
+ m_pDisplayedObject->setValueVector( m_pValueVectorEdit->vector( ) );
+ m_pDisplayedObject->setOctaves( m_pOctavesEdit->value( ) );
+ m_pDisplayedObject->setOmega( m_pOmegaEdit->value( ) );
+ m_pDisplayedObject->setLambda( m_pLambdaEdit->value( ) );
+
+ if( m_pDisplayedObject->parent( ) &&
+ ( m_pDisplayedObject->parent( )->type( ) == "Normal" ) )
+ m_pDisplayedObject->setDepth( m_pDepthEdit->value( ) );
+ }
+}
+
+bool PMPatternEdit::isDataValid( )
+{
+ switch( m_pTypeCombo->currentItem( ) )
+ {
+ case 0: // Agate
+ if( !m_pAgateTurbulenceEdit->isDataValid( ) )
+ return false;
+ break;
+ case 6: // Crackle
+ if ( !m_pCrackleMetric->isDataValid( ) )
+ return false;
+ break;
+ case 10: // Gradient
+ if( !m_pGradientEdit->isDataValid( ) )
+ return false;
+ break;
+ case 12: // Julia
+ case 14: // Mandel
+ if ( !m_pMaxIterationsEdit->isDataValid( ) )
+ return false;
+ if ( !m_pFractalExponent->isDataValid( ) )
+ return false;
+ break;
+ case 18: // Quilt
+ if( !m_pQuiltControl0Edit->isDataValid( ) )
+ return false;
+ if( !m_pQuiltControl1Edit->isDataValid( ) )
+ return false;
+ break;
+ case 21: // Slope
+ if( !m_pSlopeLoSlope->isDataValid( ) )
+ return false;
+ if( !m_pSlopeHiSlope->isDataValid( ) )
+ return false;
+ break;
+ case 23: // Spiral1
+ case 24: // Spiral2
+ if( !m_pSpiralNumberEdit->isDataValid( ) )
+ return false;
+ break;
+ default:
+ break;
+ }
+ if( m_pEnableTurbulenceEdit->isChecked( ) ) {
+ if( !m_pValueVectorEdit->isDataValid( ) ) return false;
+ if( !m_pOctavesEdit->isDataValid( ) ) return false;
+ if( !m_pOmegaEdit->isDataValid( ) ) return false;
+ if( !m_pLambdaEdit->isDataValid( ) ) return false;
+ }
+ if( m_pDisplayedObject->parent( ) &&
+ m_pDisplayedObject->parent( )->type( ) == "Normal" &&
+ !m_pDepthEdit->isDataValid( ) )
+ return false;
+
+ return Base::isDataValid( );
+}
+
+void PMPatternEdit::slotComboChanged( int c )
+{
+ switch( c )
+ {
+ case 0: /* Agate */
+ m_pAgateTurbulenceEdit->show( );
+ m_pAgateTurbulenceLabel->show( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 3: /* Bozo */
+ case 4: /* Bumps */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->show( );
+ m_pNoiseGenerator->show( );
+ break;
+ case 6: /* Crackle */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->show( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 8: /* Density File */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->show( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 10: /* Gradient */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->show( );
+ m_pGradientLabel->show( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 11: /* Granite */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->show( );
+ m_pNoiseGenerator->show( );
+ break;
+ case 12: /* Julia */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->show( );
+ m_pJuliaComplex->show( );
+ m_pFractalWidget->show( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 14: /* Mandel */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->show( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 18: /* Quilted */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->show( );
+ m_pQuiltControl0Edit->show( );
+ m_pQuiltControl1Edit->show( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 21: /* Slope */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->show( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 23: /* Spiral1 */
+ case 24: /* Spiral2 */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->show( );
+ m_pSpiralNumberLabel->show( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ case 28: /* Wrinkles */
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->show( );
+ m_pNoiseGenerator->show( );
+ break;
+ default:
+ m_pAgateTurbulenceEdit->hide( );
+ m_pAgateTurbulenceLabel->hide( );
+ m_pCrackleWidget->hide( );
+ m_pDensityWidget->hide( );
+ m_pGradientEdit->hide( );
+ m_pGradientLabel->hide( );
+ m_pJuliaComplexLabel->hide( );
+ m_pJuliaComplex->hide( );
+ m_pFractalWidget->hide( );
+ m_pQuiltControlsLabel->hide( );
+ m_pQuiltControl0Edit->hide( );
+ m_pQuiltControl1Edit->hide( );
+ m_pSlopeWidget->hide( );
+ m_pSpiralNumberEdit->hide( );
+ m_pSpiralNumberLabel->hide( );
+ m_pNoiseGeneratorLabel->hide( );
+ m_pNoiseGenerator->hide( );
+ break;
+ }
+ emit dataChanged( );
+ emit sizeChanged( );
+}
+
+void PMPatternEdit::slotDensityFileBrowseClicked( )
+{
+ QString str = KFileDialog::getOpenFileName( QString::null, QString::null );
+
+ if( !str.isEmpty() )
+ {
+ m_pDensityFile->setText( str );
+ emit dataChanged( );
+ }
+}
+
+void PMPatternEdit::slotFractalMagnetClicked( )
+{
+ if ( m_pFractalMagnet->isChecked( ) )
+ {
+ m_pFractalMagnetType->show( );
+ m_pFractalExponentLabel->hide( );
+ m_pFractalExponent->hide( );
+ }
+ else
+ {
+ m_pFractalMagnetType->hide( );
+ m_pFractalExponentLabel->show( );
+ m_pFractalExponent->show( );
+ }
+ m_pFractalWidget->adjustSize( );
+ emit dataChanged( );
+ emit sizeChanged( );
+}
+
+void PMPatternEdit::slotSlopeAltFlagClicked( )
+{
+ if ( m_pSlopeAltFlag->isChecked( ) )
+ {
+ m_pSlopeAltitude->show( );
+ m_pSlopeLoAltLabel->show( );
+ m_pSlopeLoAlt->show( );
+ m_pSlopeHiAltLabel->show( );
+ m_pSlopeHiAlt->show( );
+ }
+ else
+ {
+ m_pSlopeAltitude->hide( );
+ m_pSlopeLoAltLabel->hide( );
+ m_pSlopeLoAlt->hide( );
+ m_pSlopeHiAltLabel->hide( );
+ m_pSlopeHiAlt->hide( );
+ }
+ m_pSlopeWidget->adjustSize( );
+ emit dataChanged( );
+ emit sizeChanged( );
+}
+
+void PMPatternEdit::slotTurbulenceClicked( )
+{
+ if(m_pEnableTurbulenceEdit->isChecked( ) )
+ m_pTurbulenceWidget->show( );
+ else
+ m_pTurbulenceWidget->hide( );
+
+ emit dataChanged( );
+ emit sizeChanged( );
+}
+
+#include "pmpatternedit.moc"