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/pmpatternedit.cpp

1074 lines
44 KiB

/*
**************************************************************************
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 <tdelocale.h>
#include <tdemessagebox.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"