mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-12 01:30:34 +05:00
PAL2967. Add Scale Factor parameter to Nb Of Segments hyp
This commit is contained in:
parent
53fd9e1ce5
commit
d4cdc63f90
@ -26,10 +26,20 @@
|
|||||||
|
|
||||||
#include "StdMeshersGUI_Parameters.h"
|
#include "StdMeshersGUI_Parameters.h"
|
||||||
|
|
||||||
|
//#include "SMESHGUI_SpinBox.h" // for the sake of COORD_MAX, COORD_MIN definition
|
||||||
|
|
||||||
#include <qobject.h>
|
#include <qobject.h>
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
#define VALUE_MAX 1.0e+15 // COORD_MAX
|
||||||
|
#define VALUE_MAX_2 (VALUE_MAX*VALUE_MAX)
|
||||||
|
#define VALUE_MAX_3 (VALUE_MAX*VALUE_MAX*VALUE_MAX)
|
||||||
|
|
||||||
|
#define VALUE_SMALL 1.0e-15
|
||||||
|
#define VALUE_SMALL_2 (VALUE_SMALL*VALUE_SMALL)
|
||||||
|
#define VALUE_SMALL_3 (VALUE_SMALL*VALUE_SMALL*VALUE_SMALL)
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : HasParameters
|
//function : HasParameters
|
||||||
//purpose :
|
//purpose :
|
||||||
@ -100,49 +110,52 @@ void StdMeshersGUI_Parameters::GetParameters (const QString& hyp
|
|||||||
{
|
{
|
||||||
paramList.push_back( DOUBLE_PARAM (1.0,
|
paramList.push_back( DOUBLE_PARAM (1.0,
|
||||||
QObject::tr("SMESH_LOCAL_LENGTH_PARAM"),
|
QObject::tr("SMESH_LOCAL_LENGTH_PARAM"),
|
||||||
1E-3, 999.999, 1.0, 6));
|
VALUE_SMALL, VALUE_MAX, 1.0, 6));
|
||||||
}
|
}
|
||||||
else if (hypType.compare("NumberOfSegments") == 0)
|
else if (hypType.compare("NumberOfSegments") == 0)
|
||||||
{
|
{
|
||||||
paramList.push_back ( INT_PARAM (3,
|
paramList.push_back ( INT_PARAM (3,
|
||||||
QObject::tr("SMESH_NB_SEGMENTS_PARAM"),
|
QObject::tr("SMESH_NB_SEGMENTS_PARAM"),
|
||||||
1, 9999 ));
|
1, 9999 ));
|
||||||
|
paramList.push_back ( DOUBLE_PARAM (1.0,
|
||||||
|
QObject::tr("SMESH_NB_SEGMENTS_SCALE_PARAM"),
|
||||||
|
VALUE_SMALL, VALUE_MAX, 0.1, 6 ));
|
||||||
}
|
}
|
||||||
else if (hypType.compare("Arithmetic1D") == 0)
|
else if (hypType.compare("Arithmetic1D") == 0)
|
||||||
{
|
{
|
||||||
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
||||||
QObject::tr("SMESH_START_LENGTH_PARAM"),
|
QObject::tr("SMESH_START_LENGTH_PARAM"),
|
||||||
1E-3, 999.999, 1, 6));
|
VALUE_SMALL, VALUE_MAX, 1, 6));
|
||||||
paramList.push_back( DOUBLE_PARAM ( 10.0,
|
paramList.push_back( DOUBLE_PARAM ( 10.0,
|
||||||
QObject::tr("SMESH_END_LENGTH_PARAM"),
|
QObject::tr("SMESH_END_LENGTH_PARAM"),
|
||||||
1E-3, 999.999, 1, 6));
|
VALUE_SMALL, VALUE_MAX, 1, 6));
|
||||||
}
|
}
|
||||||
else if (hypType.compare("MaxElementArea") == 0)
|
else if (hypType.compare("MaxElementArea") == 0)
|
||||||
{
|
{
|
||||||
paramList.push_back( DOUBLE_PARAM (1.0,
|
paramList.push_back( DOUBLE_PARAM (1.0,
|
||||||
QObject::tr("SMESH_MAX_ELEMENT_AREA_PARAM"),
|
QObject::tr("SMESH_MAX_ELEMENT_AREA_PARAM"),
|
||||||
1.E-6, 999999.999, 1.0, 6));
|
VALUE_SMALL_2, VALUE_MAX_2, 1.0, 6));
|
||||||
}
|
}
|
||||||
else if (hypType.compare("MaxElementVolume") == 0)
|
else if (hypType.compare("MaxElementVolume") == 0)
|
||||||
{
|
{
|
||||||
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
||||||
QObject::tr("SMESH_MAX_ELEMENT_VOLUME_PARAM"),
|
QObject::tr("SMESH_MAX_ELEMENT_VOLUME_PARAM"),
|
||||||
1.E-9, 1.E9, 1.0, 6));
|
VALUE_SMALL_3, VALUE_MAX_3, 1.0, 6));
|
||||||
}
|
}
|
||||||
else if (hypType.compare("StartEndLength") == 0)
|
else if (hypType.compare("StartEndLength") == 0)
|
||||||
{
|
{
|
||||||
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
||||||
QObject::tr("SMESH_START_LENGTH_PARAM"),
|
QObject::tr("SMESH_START_LENGTH_PARAM"),
|
||||||
1.0E-3, 999.999, 1, 6));
|
VALUE_SMALL, VALUE_MAX, 1, 6));
|
||||||
paramList.push_back( DOUBLE_PARAM ( 10.0,
|
paramList.push_back( DOUBLE_PARAM ( 10.0,
|
||||||
QObject::tr("SMESH_END_LENGTH_PARAM"),
|
QObject::tr("SMESH_END_LENGTH_PARAM"),
|
||||||
1.0E-3, 999.999, 1, 6));
|
VALUE_SMALL, VALUE_MAX, 1, 6));
|
||||||
}
|
}
|
||||||
else if (hypType.compare("Deflection1D") == 0)
|
else if (hypType.compare("Deflection1D") == 0)
|
||||||
{
|
{
|
||||||
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
paramList.push_back( DOUBLE_PARAM ( 1.0,
|
||||||
QObject::tr("SMESH_DEFLECTION1D_PARAM"),
|
QObject::tr("SMESH_DEFLECTION1D_PARAM"),
|
||||||
1.0E-3, 999.999, 1, 6));
|
VALUE_SMALL, VALUE_MAX, 1, 6));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,6 +188,7 @@ void StdMeshersGUI_Parameters::GetParameters (SMESH::SMESH_Hypothesis_ptr the
|
|||||||
StdMeshers::StdMeshers_NumberOfSegments_var NOS =
|
StdMeshers::StdMeshers_NumberOfSegments_var NOS =
|
||||||
StdMeshers::StdMeshers_NumberOfSegments::_narrow(theHyp);
|
StdMeshers::StdMeshers_NumberOfSegments::_narrow(theHyp);
|
||||||
SetInitValue( paramList.front(), (int) NOS->GetNumberOfSegments());
|
SetInitValue( paramList.front(), (int) NOS->GetNumberOfSegments());
|
||||||
|
SetInitValue( paramList.back(), NOS->GetScaleFactor());
|
||||||
}
|
}
|
||||||
else if (hypType.compare("Arithmetic1D") == 0)
|
else if (hypType.compare("Arithmetic1D") == 0)
|
||||||
{
|
{
|
||||||
@ -236,7 +250,7 @@ void StdMeshersGUI_Parameters::GetParameters (SMESH::SMESH_Hypothesis_ptr
|
|||||||
else {
|
else {
|
||||||
int aIntValue = 0;
|
int aIntValue = 0;
|
||||||
(*paramIt)->GetNewInt(aIntValue);
|
(*paramIt)->GetNewInt(aIntValue);
|
||||||
params += QString::number(aIntValue);;
|
params += QString::number(aIntValue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -268,8 +282,11 @@ bool StdMeshersGUI_Parameters::SetParameters(SMESH::SMESH_Hypothesis_ptr
|
|||||||
StdMeshers::StdMeshers_NumberOfSegments_var NOS =
|
StdMeshers::StdMeshers_NumberOfSegments_var NOS =
|
||||||
StdMeshers::StdMeshers_NumberOfSegments::_narrow(theHyp);
|
StdMeshers::StdMeshers_NumberOfSegments::_narrow(theHyp);
|
||||||
int NbSeg = NOS->GetNumberOfSegments();
|
int NbSeg = NOS->GetNumberOfSegments();
|
||||||
|
double Scale = NOS->GetScaleFactor() ;
|
||||||
modified = paramList.front()->GetNewInt( NbSeg );
|
modified = paramList.front()->GetNewInt( NbSeg );
|
||||||
|
modified = paramList.back()->GetNewDouble( Scale ) || modified;
|
||||||
NOS->SetNumberOfSegments(NbSeg);
|
NOS->SetNumberOfSegments(NbSeg);
|
||||||
|
NOS->SetScaleFactor( Scale );
|
||||||
}
|
}
|
||||||
else if (hypType.compare("Arithmetic1D") == 0)
|
else if (hypType.compare("Arithmetic1D") == 0)
|
||||||
{
|
{
|
||||||
|
@ -29,6 +29,9 @@ msgstr "Number of Segments"
|
|||||||
msgid "SMESH_NB_SEGMENTS_PARAM"
|
msgid "SMESH_NB_SEGMENTS_PARAM"
|
||||||
msgstr "Number of Segments"
|
msgstr "Number of Segments"
|
||||||
|
|
||||||
|
msgid "SMESH_NB_SEGMENTS_SCALE_PARAM"
|
||||||
|
msgstr "Scale Factor"
|
||||||
|
|
||||||
msgid "SMESH_NB_SEGMENTS_TITLE"
|
msgid "SMESH_NB_SEGMENTS_TITLE"
|
||||||
msgstr "Hypothesis Construction"
|
msgstr "Hypothesis Construction"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user