/* ************************************************************************** description -------------------- copyright : (C) 2003 by Leon Pennington email : leon@leonscape.co.uk ************************************************************************** ************************************************************************** * * * 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 "pmradiosityedit.h" #include "pmradiosity.h" #include "pmlineedits.h" #include <tqlayout.h> #include <tqlabel.h> #include <tqcheckbox.h> #include <klocale.h> #include <kdialog.h> #include <kmessagebox.h> PMRadiosityEdit::PMRadiosityEdit( TQWidget* parent, const char* name ) : Base( parent, name ) { m_pDisplayedObject = 0; } void PMRadiosityEdit::createTopWidgets( ) { TQHBoxLayout* hl; TQGridLayout *gl; TQLabel* lbl; Base::createTopWidgets( ); hl = new TQHBoxLayout( topLayout( ) ); gl = new TQGridLayout( hl, 15, 2 ); lbl = new TQLabel( i18n( "Adc bailout:" ), this ); m_pAdcBailout = new PMFloatEdit( this ); m_pAdcBailout->setValidation( true, 0, true, 1 ); gl->addWidget( lbl, 0, 0 ); gl->addWidget( m_pAdcBailout, 0, 1 ); m_pAlwaysSample = new TQCheckBox( i18n( "Always sample" ), this ); gl->addMultiCellWidget( m_pAlwaysSample, 1, 1, 0, 1 ); lbl = new TQLabel( i18n( "Brightness:" ), this ); m_pBrightness = new PMFloatEdit( this ); m_pBrightness->setValidation( true, 0, false, 0 ); gl->addWidget( lbl, 2, 0 ); gl->addWidget( m_pBrightness, 2, 1 ); lbl = new TQLabel( i18n( "Count:" ), this ); m_pCount = new PMIntEdit( this ); m_pCount->setValidation( true, 0, true, 1600 ); gl->addWidget( lbl, 3, 0 ); gl->addWidget( m_pCount, 3, 1 ); lbl = new TQLabel( i18n( "Error boundary:" ), this ); m_pErrorBound = new PMFloatEdit( this ); m_pErrorBound->setValidation( true, 0, false, 0 ); gl->addWidget( lbl, 4, 0 ); gl->addWidget( m_pErrorBound, 4, 1 ); lbl = new TQLabel( i18n( "Gray threshold:" ), this ); m_pGrayThreshold = new PMFloatEdit( this ); m_pGrayThreshold->setValidation( true, 0, true, 1 ); gl->addWidget( lbl, 5, 0 ); gl->addWidget( m_pGrayThreshold, 5, 1 ); lbl = new TQLabel( i18n( "Low error factor:" ), this ); m_pLowErrorFactor = new PMFloatEdit( this ); m_pLowErrorFactor->setValidation( true, 0, true, 1 ); gl->addWidget( lbl, 6, 0 ); gl->addWidget( m_pLowErrorFactor, 6, 1 ); lbl = new TQLabel( i18n( "Maximum sample:" ), this ); m_pMaxSample = new PMFloatEdit( this ); m_pMaxSample->setValidation( true, -1, false, 0 ); gl->addWidget( lbl, 7, 0 ); gl->addWidget( m_pMaxSample, 7, 1 ); m_pMedia = new TQCheckBox( i18n( "Media" ), this ); gl->addMultiCellWidget( m_pMedia, 8, 8, 0, 1 ); lbl = new TQLabel( i18n( "Minimum reuse:" ), this ); m_pMinimumReuse = new PMFloatEdit( this ); m_pMinimumReuse->setValidation( true, 0, true, 1 ); gl->addWidget( lbl, 9, 0 ); gl->addWidget( m_pMinimumReuse, 9, 1 ); lbl = new TQLabel( i18n( "Nearest count:" ), this ); m_pNearestCount = new PMIntEdit( this ); m_pNearestCount->setValidation( true, 0, true, 20 ); gl->addWidget( lbl, 10, 0 ); gl->addWidget( m_pNearestCount, 10, 1 ); m_pNormal = new TQCheckBox( i18n( "Normal" ), this ); gl->addMultiCellWidget( m_pNormal, 11, 11, 0, 1 ); lbl = new TQLabel( i18n( "Pretrace start:" ), this ); m_pPretraceStart = new PMFloatEdit( this ); m_pPretraceStart->setValidation( true, 0, true, 1 ); gl->addWidget( lbl, 12, 0 ); gl->addWidget( m_pPretraceStart, 12, 1 ); lbl = new TQLabel( i18n( "Pretrace end:" ), this ); m_pPretraceEnd = new PMFloatEdit( this ); m_pPretraceEnd->setValidation( true, 0, true, 1 ); gl->addWidget( lbl, 13, 0 ); gl->addWidget( m_pPretraceEnd, 13, 1 ); lbl = new TQLabel( i18n( "Recursion limit:" ), this ); m_pRecursionLimit = new PMIntEdit( this ); m_pRecursionLimit->setValidation( true, 1, true, 20 ); gl->addWidget( lbl, 14, 0 ); gl->addWidget( m_pRecursionLimit, 14, 1 ); hl->addStretch( 1 ); connect( m_pAdcBailout, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pAlwaysSample, TQT_SIGNAL( clicked( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pBrightness, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pCount, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pErrorBound, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pGrayThreshold, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pLowErrorFactor, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pMaxSample, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pMedia, TQT_SIGNAL( clicked( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pMinimumReuse, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pNearestCount, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pNormal, TQT_SIGNAL( clicked( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pPretraceStart, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pPretraceEnd, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); connect( m_pRecursionLimit, TQT_SIGNAL( dataChanged( ) ), TQT_SIGNAL( dataChanged( ) ) ); } void PMRadiosityEdit::displayObject( PMObject* o ) { if( o->isA( "Radiosity" ) ) { bool readOnly = o->isReadOnly( ); m_pDisplayedObject = ( PMRadiosity* ) o; m_pAdcBailout->setValue( m_pDisplayedObject->adcBailout( ) ); m_pAdcBailout->setReadOnly( readOnly ); m_pAlwaysSample->setChecked( m_pDisplayedObject->alwaysSample( ) ); m_pAlwaysSample->setEnabled( !readOnly ); m_pBrightness->setValue( m_pDisplayedObject->brightness( ) ); m_pBrightness->setReadOnly( readOnly ); m_pCount->setValue( m_pDisplayedObject->count( ) ); m_pCount->setReadOnly( readOnly ); m_pErrorBound->setValue( m_pDisplayedObject->errorBound( ) ); m_pErrorBound->setReadOnly( readOnly ); m_pGrayThreshold->setValue( m_pDisplayedObject->grayThreshold( ) ); m_pGrayThreshold->setReadOnly( readOnly ); m_pLowErrorFactor->setValue( m_pDisplayedObject->lowErrorFactor( ) ); m_pLowErrorFactor->setReadOnly( readOnly ); m_pMaxSample->setValue( m_pDisplayedObject->maxSample( ) ); m_pMaxSample->setReadOnly( readOnly ); m_pMedia->setChecked( m_pDisplayedObject->media( ) ); m_pMedia->setEnabled( !readOnly ); m_pMinimumReuse->setValue( m_pDisplayedObject->minimumReuse( ) ); m_pMinimumReuse->setReadOnly( readOnly ); m_pNearestCount->setValue( m_pDisplayedObject->nearestCount( ) ); m_pNearestCount->setReadOnly( readOnly ); m_pNormal->setChecked( m_pDisplayedObject->normal( ) ); m_pNormal->setEnabled( !readOnly ); m_pPretraceStart->setValue( m_pDisplayedObject->pretraceStart( ) ); m_pPretraceStart->setReadOnly( readOnly ); m_pPretraceEnd->setValue( m_pDisplayedObject->pretraceEnd( ) ); m_pPretraceEnd->setReadOnly( readOnly ); m_pRecursionLimit->setValue( m_pDisplayedObject->recursionLimit( ) ); m_pRecursionLimit->setReadOnly( readOnly ); Base::displayObject( o ); } else kdError( PMArea ) << "PMRadiosityEdit: Can't display object\n"; } void PMRadiosityEdit::saveContents( ) { if( m_pDisplayedObject ) { Base::saveContents( ); m_pDisplayedObject->setAdcBailout( m_pAdcBailout->value( ) ); m_pDisplayedObject->setAlwaysSample( m_pAlwaysSample->isChecked( ) ); m_pDisplayedObject->setBrightness( m_pBrightness->value( ) ); m_pDisplayedObject->setCount( m_pCount->value( ) ); m_pDisplayedObject->setErrorBound( m_pErrorBound->value( ) ); m_pDisplayedObject->setGrayThreshold( m_pGrayThreshold->value( ) ); m_pDisplayedObject->setLowErrorFactor( m_pLowErrorFactor->value( ) ); m_pDisplayedObject->setMaxSample( m_pMaxSample->value( ) ); m_pDisplayedObject->setMedia( m_pMedia->isChecked( ) ); m_pDisplayedObject->setMinimumReuse( m_pMinimumReuse->value( ) ); m_pDisplayedObject->setNearestCount( m_pNearestCount->value( ) ); m_pDisplayedObject->setNormal( m_pNormal->isChecked( ) ); m_pDisplayedObject->setPretraceStart( m_pPretraceStart->value( ) ); m_pDisplayedObject->setPretraceEnd( m_pPretraceEnd->value( ) ); m_pDisplayedObject->setRecursionLimit( m_pRecursionLimit->value( ) ); } } bool PMRadiosityEdit::isDataValid( ) { if( !m_pAdcBailout->isDataValid( ) ) return false; if( !m_pBrightness->isDataValid( ) ) return false; if( !m_pCount->isDataValid( ) ) return false; if( !m_pErrorBound->isDataValid( ) ) return false; if( !m_pGrayThreshold->isDataValid( ) ) return false; if( !m_pLowErrorFactor->isDataValid( ) ) return false; if( !m_pMaxSample->isDataValid( ) ) return false; if( !m_pMinimumReuse->isDataValid( ) ) return false; if( !m_pNearestCount->isDataValid( ) ) return false; if( !m_pPretraceStart->isDataValid( ) ) return false; if( !m_pPretraceEnd->isDataValid( ) ) return false; if( !m_pRecursionLimit->isDataValid( ) ) return false; return Base::isDataValid( ); } #include "pmradiosityedit.moc"