/*
**************************************************************************
                                 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 <tqwidget.h>
#include <tqlayout.h>
#include <tqcombobox.h>
#include <tqlabel.h>
#include <tqlineedit.h>
#include <tqcheckbox.h>
#include <tqpushbutton.h>
#include <ktabctl.h>
#include <klocale.h>
#include <kmessagebox.h>
#include <kdialog.h>
#include <tdefiledialog.h>
#include <kiconloader.h>

PMPatternEdit::PMPatternEdit( TQWidget* parent, const char* name )
      : Base( parent, name )
{
   m_pDisplayedObject = 0;
}

void PMPatternEdit::createTopWidgets( )
{
   Base::createTopWidgets( );

   TQGridLayout* layout;
   TQHBoxLayout* hl;
   TQVBoxLayout* vl;
   TQGridLayout* gl;

   layout = new TQGridLayout( topLayout( ), 12, 2 );
   hl = new TQHBoxLayout( KDialog::spacingHint( ) );
   hl->addWidget( new TQLabel( i18n( "Type:" ), this ) );
   m_pTypeCombo = new TQComboBox( 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 TQLabel( i18n( "Turbulence:" ), this );
   layout->addWidget( m_pAgateTurbulenceLabel, 1, 0 );
   m_pAgateTurbulenceEdit = new PMFloatEdit( this );
   layout->addWidget( m_pAgateTurbulenceEdit, 1, 1, AlignLeft );

   m_pCrackleWidget = new TQWidget( this );
   vl = new TQVBoxLayout( m_pCrackleWidget, 0, KDialog::spacingHint( ) );
   hl = new TQHBoxLayout( vl );
   hl->addWidget( new TQLabel( i18n( "Form:" ), m_pCrackleWidget ) );
   m_pCrackleForm = new PMVectorEdit( "x", "y", "z", m_pCrackleWidget );
   hl->addWidget( m_pCrackleForm );
   hl->addStretch( 1 );
   hl = new TQHBoxLayout( vl );
   gl = new TQGridLayout( hl, 3, 2 );
   gl->addWidget( new TQLabel( 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 TQLabel( i18n( "Offset:" ), m_pCrackleWidget ), 1, 0 );
   m_pCrackleOffset = new PMFloatEdit( m_pCrackleWidget );
   gl->addWidget( m_pCrackleOffset, 1, 1 );
   m_pCrackleSolid = new TQCheckBox( 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 TQWidget( this );
   vl = new TQVBoxLayout( m_pDensityWidget, 0, KDialog::spacingHint( ) );
   hl = new TQHBoxLayout( vl );
   hl->addWidget( new TQLabel( i18n( "File:" ), m_pDensityWidget ) );
   m_pDensityFile = new TQLineEdit( m_pDensityWidget );
   hl->addWidget( m_pDensityFile, 1 );
   m_pDensityFileBrowse = new TQPushButton( m_pDensityWidget );
   m_pDensityFileBrowse->setPixmap( SmallIcon( "fileopen" ) );
   hl->addWidget( m_pDensityFileBrowse );
   hl = new TQHBoxLayout( vl );
   hl->addWidget( new TQLabel( i18n( "Interpolation:" ), m_pDensityWidget ) );
   m_pDensityInterpolate = new TQComboBox( 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 TQLabel( 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 TQLabel( 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 TQWidget( this );
   vl = new TQVBoxLayout( m_pFractalWidget, 0, KDialog::spacingHint( ) );
   hl = new TQHBoxLayout( vl );
   m_pFractalMagnet = new TQCheckBox( i18n( "Magnet" ), m_pFractalWidget );
   hl->addWidget( m_pFractalMagnet );
   m_pFractalMagnetType = new TQComboBox( false, m_pFractalWidget );
   m_pFractalMagnetType->insertItem( i18n( "Type 1" ) );
   m_pFractalMagnetType->insertItem( i18n( "Type 2" ) );
   hl->addWidget( m_pFractalMagnetType );
   hl->addStretch( 1 );
   hl = new TQHBoxLayout( vl );
   gl = new TQGridLayout( hl, 2, 2 );
   gl->addWidget( new TQLabel( 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 TQLabel( 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 TQHBoxLayout( vl );
   gl = new TQGridLayout( hl, 2, 4 );
   gl->addWidget( new TQLabel( i18n( "Exterior type:" ), m_pFractalWidget ), 0, 0 );
   m_pFractalExtType = new TQComboBox( 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 TQLabel( i18n( "Factor:" ), m_pFractalWidget ), 0, 2 );
   m_pFractalExtFactor = new PMFloatEdit( m_pFractalWidget );
   gl->addWidget( m_pFractalExtFactor, 0, 3 );
   gl->addWidget( new TQLabel( i18n( "Interior type:" ), m_pFractalWidget ), 1, 0 );
   m_pFractalIntType = new TQComboBox( 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 TQLabel( 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 TQLabel( i18n( "Quilt controls:" ), this );
   m_pQuiltControl0Edit = new PMFloatEdit( this );
   m_pQuiltControl1Edit = new PMFloatEdit( this );
   hl = new TQHBoxLayout( );
   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 TQWidget( this );
   vl = new TQVBoxLayout( m_pSlopeWidget, 0, KDialog::spacingHint( ) );
   hl = new TQHBoxLayout( vl );
   hl->addWidget( new TQLabel( i18n( "Direction:" ), m_pSlopeWidget ) );
   m_pSlopeDirection = new PMVectorEdit( "x", "y", "z", m_pSlopeWidget );
   hl->addWidget( m_pSlopeDirection );
   hl = new TQHBoxLayout( vl );
   gl = new TQGridLayout( hl, 2, 2 );
   gl->addWidget( new TQLabel( 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 TQLabel( 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 TQHBoxLayout( vl );
   m_pSlopeAltFlag = new TQCheckBox( i18n( "Altitiude" ), m_pSlopeWidget );
   hl->addWidget( m_pSlopeAltFlag );
   m_pSlopeAltitude = new PMVectorEdit( "x", "y", "z", m_pSlopeWidget );
   hl->addWidget( m_pSlopeAltitude );
   hl = new TQHBoxLayout( vl );
   gl = new TQGridLayout( hl, 2, 2 );
   m_pSlopeLoAltLabel = new TQLabel( 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 TQLabel( 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 TQLabel( 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 TQLabel( i18n( "Depth:" ), this );
   m_pDepthEdit = new PMFloatEdit( this );
   layout->addWidget( m_pDepthLabel, 10, 0 );
   layout->addWidget( m_pDepthEdit, 10, 1, AlignLeft );

   m_pNoiseGeneratorLabel = new TQLabel( i18n( "Noise generator:" ), this );
   m_pNoiseGenerator = new TQComboBox( 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 TQCheckBox( i18n( "Turbulence" ), this );
   topLayout( )->addWidget( m_pEnableTurbulenceEdit );
   m_pTurbulenceWidget = new TQWidget( this );
   vl = new TQVBoxLayout( m_pTurbulenceWidget, 0, KDialog::spacingHint( ) );
   hl = new TQHBoxLayout( vl );
   hl->addWidget(  new TQLabel( i18n( "Value:" ), m_pTurbulenceWidget ) );
   m_pValueVectorEdit = new PMVectorEdit( "x", "y", "z", m_pTurbulenceWidget );
   hl->addWidget( m_pValueVectorEdit );
   hl = new TQHBoxLayout( vl );
   gl = new TQGridLayout( hl, 3, 2 );
   gl->addWidget( new TQLabel( i18n( "Octaves:" ), m_pTurbulenceWidget ), 0, 0 );
   m_pOctavesEdit = new PMIntEdit( m_pTurbulenceWidget );
   gl->addWidget( m_pOctavesEdit, 0, 1 );
   gl->addWidget( new TQLabel( i18n( "Omega:" ), m_pTurbulenceWidget ), 1, 0 );
   m_pOmegaEdit = new PMFloatEdit( m_pTurbulenceWidget );
   gl->addWidget( m_pOmegaEdit, 1, 1 );
   gl->addWidget( new TQLabel( 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, TQT_SIGNAL( activated( int ) ), TQT_SLOT( slotComboChanged( int ) ) );

   connect( m_pAgateTurbulenceEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pCrackleForm, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pCrackleMetric, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pCrackleOffset, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pCrackleSolid, TQT_SIGNAL( clicked( ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pDensityInterpolate, TQT_SIGNAL( activated( int ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pDensityFile, TQT_SIGNAL( textChanged( const TQString& ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pDensityFileBrowse, TQT_SIGNAL( clicked( ) ), TQT_SLOT( slotDensityFileBrowseClicked( ) ) );

   connect( m_pGradientEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pJuliaComplex, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pFractalMagnet, TQT_SIGNAL( clicked( ) ), TQT_SLOT( slotFractalMagnetClicked( ) ) );
   connect( m_pFractalMagnetType, TQT_SIGNAL( activated( int ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pMaxIterationsEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pFractalExponent, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pFractalExtType, TQT_SIGNAL( activated( int ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pFractalExtFactor, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pFractalIntType, TQT_SIGNAL( activated( int ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pFractalIntFactor, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pQuiltControl0Edit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pQuiltControl1Edit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pSlopeDirection, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pSlopeLoSlope, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pSlopeHiSlope, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pSlopeAltFlag, TQT_SIGNAL( clicked( ) ), TQT_SLOT( slotSlopeAltFlagClicked( ) ) );
   connect( m_pSlopeAltitude, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pSlopeLoAlt, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pSlopeHiAlt, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pSpiralNumberEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pNoiseGenerator, TQT_SIGNAL( activated( int ) ), TQT_SIGNAL( dataChanged( ) ) );

   connect( m_pEnableTurbulenceEdit, TQT_SIGNAL( clicked( ) ), TQT_SLOT( slotTurbulenceClicked( ) ) );
   connect( m_pValueVectorEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pOctavesEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pOmegaEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pLambdaEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
   connect( m_pDepthEdit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) );
}

void PMPatternEdit::displayObject( PMObject* o )
{
   TQString 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( )
{
   TQString str = KFileDialog::getOpenFileName( TQString(), TQString() );

   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"