mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 10:10:33 +05:00
0023614: EDF 16256 - Coordinates of a group
This commit is contained in:
parent
401b2a2e54
commit
9a3f7d877e
@ -61,6 +61,7 @@ module SMESH
|
|||||||
FT_MultiConnection2D,
|
FT_MultiConnection2D,
|
||||||
FT_Length,
|
FT_Length,
|
||||||
FT_Length2D,
|
FT_Length2D,
|
||||||
|
FT_Length3D,
|
||||||
FT_Deflection2D,
|
FT_Deflection2D,
|
||||||
FT_NodeConnectivityNumber,
|
FT_NodeConnectivityNumber,
|
||||||
FT_BelongToMeshGroup,
|
FT_BelongToMeshGroup,
|
||||||
@ -118,7 +119,8 @@ module SMESH
|
|||||||
*/
|
*/
|
||||||
interface NumericalFunctor: Functor
|
interface NumericalFunctor: Functor
|
||||||
{
|
{
|
||||||
double GetValue( in long theElementId );
|
double GetValue ( in long theElementId );
|
||||||
|
boolean IsApplicable( in long theElementId );
|
||||||
|
|
||||||
Histogram GetHistogram ( in short nbIntervals, in boolean isLogarithmic );
|
Histogram GetHistogram ( in short nbIntervals, in boolean isLogarithmic );
|
||||||
Histogram GetLocalHistogram( in short nbIntervals, in boolean isLogarithmic,
|
Histogram GetLocalHistogram( in short nbIntervals, in boolean isLogarithmic,
|
||||||
@ -151,6 +153,7 @@ module SMESH
|
|||||||
typedef sequence<Value> Values;
|
typedef sequence<Value> Values;
|
||||||
Values GetValues();
|
Values GetValues();
|
||||||
};
|
};
|
||||||
|
interface Length3D : NumericalFunctor{};
|
||||||
interface Deflection2D : NumericalFunctor{};
|
interface Deflection2D : NumericalFunctor{};
|
||||||
interface MultiConnection : NumericalFunctor{};
|
interface MultiConnection : NumericalFunctor{};
|
||||||
interface MultiConnection2D : NumericalFunctor
|
interface MultiConnection2D : NumericalFunctor
|
||||||
@ -588,6 +591,7 @@ module SMESH
|
|||||||
MaxElementLength3D CreateMaxElementLength3D();
|
MaxElementLength3D CreateMaxElementLength3D();
|
||||||
Length CreateLength();
|
Length CreateLength();
|
||||||
Length2D CreateLength2D();
|
Length2D CreateLength2D();
|
||||||
|
Length3D CreateLength3D();
|
||||||
Deflection2D CreateDeflection2D();
|
Deflection2D CreateDeflection2D();
|
||||||
MultiConnection CreateMultiConnection();
|
MultiConnection CreateMultiConnection();
|
||||||
MultiConnection2D CreateMultiConnection2D();
|
MultiConnection2D CreateMultiConnection2D();
|
||||||
|
@ -233,7 +233,7 @@ bool NumericalFunctor::GetPoints(const int theId,
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
const SMDS_MeshElement* anElem = myMesh->FindElement( theId );
|
const SMDS_MeshElement* anElem = myMesh->FindElement( theId );
|
||||||
if ( !anElem || anElem->GetType() != this->GetType() )
|
if ( !IsApplicable( anElem ))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return GetPoints( anElem, theRes );
|
return GetPoints( anElem, theRes );
|
||||||
@ -292,6 +292,24 @@ double NumericalFunctor::Round( const double & aVal )
|
|||||||
return ( myPrecision >= 0 ) ? floor( aVal * myPrecisionValue + 0.5 ) / myPrecisionValue : aVal;
|
return ( myPrecision >= 0 ) ? floor( aVal * myPrecisionValue + 0.5 ) / myPrecisionValue : aVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Return true if a value can be computed for a given element.
|
||||||
|
* Some NumericalFunctor's are meaningful for elements of a certain
|
||||||
|
* geometry only.
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
bool NumericalFunctor::IsApplicable( const SMDS_MeshElement* element ) const
|
||||||
|
{
|
||||||
|
return element && element->GetType() == this->GetType();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool NumericalFunctor::IsApplicable( long theElementId ) const
|
||||||
|
{
|
||||||
|
return IsApplicable( myMesh->FindElement( theElementId ));
|
||||||
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Return histogram of functor values
|
* \brief Return histogram of functor values
|
||||||
@ -901,6 +919,11 @@ double AspectRatio::GetValue( const TSequenceOfXYZ& P )
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool AspectRatio::IsApplicable( const SMDS_MeshElement* element ) const
|
||||||
|
{
|
||||||
|
return ( NumericalFunctor::IsApplicable( element ) && !element->IsPoly() );
|
||||||
|
}
|
||||||
|
|
||||||
double AspectRatio::GetBadRate( double Value, int /*nbNodes*/ ) const
|
double AspectRatio::GetBadRate( double Value, int /*nbNodes*/ ) const
|
||||||
{
|
{
|
||||||
// the aspect ratio is in the range [1.0,infinity]
|
// the aspect ratio is in the range [1.0,infinity]
|
||||||
@ -1007,6 +1030,11 @@ double AspectRatio3D::GetValue( long theId )
|
|||||||
return aVal;
|
return aVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool AspectRatio3D::IsApplicable( const SMDS_MeshElement* element ) const
|
||||||
|
{
|
||||||
|
return ( NumericalFunctor::IsApplicable( element ) && !element->IsPoly() );
|
||||||
|
}
|
||||||
|
|
||||||
double AspectRatio3D::GetValue( const TSequenceOfXYZ& P )
|
double AspectRatio3D::GetValue( const TSequenceOfXYZ& P )
|
||||||
{
|
{
|
||||||
double aQuality = 0.0;
|
double aQuality = 0.0;
|
||||||
@ -1015,11 +1043,11 @@ double AspectRatio3D::GetValue( const TSequenceOfXYZ& P )
|
|||||||
int nbNodes = P.size();
|
int nbNodes = P.size();
|
||||||
|
|
||||||
if( myCurrElement->IsQuadratic() ) {
|
if( myCurrElement->IsQuadratic() ) {
|
||||||
if(nbNodes==10) nbNodes=4; // quadratic tetrahedron
|
if (nbNodes==10) nbNodes=4; // quadratic tetrahedron
|
||||||
else if(nbNodes==13) nbNodes=5; // quadratic pyramid
|
else if(nbNodes==13) nbNodes=5; // quadratic pyramid
|
||||||
else if(nbNodes==15) nbNodes=6; // quadratic pentahedron
|
else if(nbNodes==15) nbNodes=6; // quadratic pentahedron
|
||||||
else if(nbNodes==20) nbNodes=8; // quadratic hexahedron
|
else if(nbNodes==20) nbNodes=8; // quadratic hexahedron
|
||||||
else if(nbNodes==27) nbNodes=8; // quadratic hexahedron
|
else if(nbNodes==27) nbNodes=8; // tri-quadratic hexahedron
|
||||||
else return aQuality;
|
else return aQuality;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1296,6 +1324,11 @@ SMDSAbs_ElementType AspectRatio3D::GetType() const
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
|
bool Warping::IsApplicable( const SMDS_MeshElement* element ) const
|
||||||
|
{
|
||||||
|
return NumericalFunctor::IsApplicable( element ) && element->NbNodes() == 4;
|
||||||
|
}
|
||||||
|
|
||||||
double Warping::GetValue( const TSequenceOfXYZ& P )
|
double Warping::GetValue( const TSequenceOfXYZ& P )
|
||||||
{
|
{
|
||||||
if ( P.size() != 4 )
|
if ( P.size() != 4 )
|
||||||
@ -1360,6 +1393,11 @@ SMDSAbs_ElementType Warping::GetType() const
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
|
bool Taper::IsApplicable( const SMDS_MeshElement* element ) const
|
||||||
|
{
|
||||||
|
return ( NumericalFunctor::IsApplicable( element ) && element->NbNodes() == 4 );
|
||||||
|
}
|
||||||
|
|
||||||
double Taper::GetValue( const TSequenceOfXYZ& P )
|
double Taper::GetValue( const TSequenceOfXYZ& P )
|
||||||
{
|
{
|
||||||
if ( P.size() != 4 )
|
if ( P.size() != 4 )
|
||||||
@ -1418,6 +1456,11 @@ static inline double skewAngle( const gp_XYZ& p1, const gp_XYZ& p2, const gp_XYZ
|
|||||||
return v1.Magnitude() < gp::Resolution() || v2.Magnitude() < gp::Resolution() ? 0. : v1.Angle( v2 );
|
return v1.Magnitude() < gp::Resolution() || v2.Magnitude() < gp::Resolution() ? 0. : v1.Angle( v2 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Skew::IsApplicable( const SMDS_MeshElement* element ) const
|
||||||
|
{
|
||||||
|
return ( NumericalFunctor::IsApplicable( element ) && element->NbNodes() <= 4 );
|
||||||
|
}
|
||||||
|
|
||||||
double Skew::GetValue( const TSequenceOfXYZ& P )
|
double Skew::GetValue( const TSequenceOfXYZ& P )
|
||||||
{
|
{
|
||||||
if ( P.size() != 3 && P.size() != 4 )
|
if ( P.size() != 3 && P.size() != 4 )
|
||||||
@ -1534,11 +1577,34 @@ SMDSAbs_ElementType Length::GetType() const
|
|||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
/*
|
/*
|
||||||
Class : Length2D
|
Class : Length3D
|
||||||
Description : Functor for calculating minimal length of edge
|
Description : Functor for calculating minimal length of element edge
|
||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
|
Length3D::Length3D():
|
||||||
|
Length2D ( SMDSAbs_Volume )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*
|
||||||
|
Class : Length2D
|
||||||
|
Description : Functor for calculating minimal length of element edge
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
Length2D::Length2D( SMDSAbs_ElementType type ):
|
||||||
|
myType ( type )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Length2D::IsApplicable( const SMDS_MeshElement* element ) const
|
||||||
|
{
|
||||||
|
return ( NumericalFunctor::IsApplicable( element ) &&
|
||||||
|
element->GetEntityType() != SMDSEntity_Polyhedra );
|
||||||
|
}
|
||||||
|
|
||||||
double Length2D::GetValue( const TSequenceOfXYZ& P )
|
double Length2D::GetValue( const TSequenceOfXYZ& P )
|
||||||
{
|
{
|
||||||
double aVal = 0;
|
double aVal = 0;
|
||||||
@ -1783,7 +1849,7 @@ double Length2D::GetBadRate( double Value, int /*nbNodes*/ ) const
|
|||||||
|
|
||||||
SMDSAbs_ElementType Length2D::GetType() const
|
SMDSAbs_ElementType Length2D::GetType() const
|
||||||
{
|
{
|
||||||
return SMDSAbs_Face;
|
return myType;
|
||||||
}
|
}
|
||||||
|
|
||||||
Length2D::Value::Value(double theLength,long thePntId1, long thePntId2):
|
Length2D::Value::Value(double theLength,long thePntId1, long thePntId2):
|
||||||
@ -1805,84 +1871,90 @@ bool Length2D::Value::operator<(const Length2D::Value& x) const
|
|||||||
|
|
||||||
void Length2D::GetValues(TValues& theValues)
|
void Length2D::GetValues(TValues& theValues)
|
||||||
{
|
{
|
||||||
TValues aValues;
|
if ( myType == SMDSAbs_Face )
|
||||||
for ( SMDS_FaceIteratorPtr anIter = myMesh->facesIterator(); anIter->more(); )
|
|
||||||
{
|
{
|
||||||
const SMDS_MeshFace* anElem = anIter->next();
|
for ( SMDS_FaceIteratorPtr anIter = myMesh->facesIterator(); anIter->more(); )
|
||||||
if ( anElem->IsQuadratic() )
|
|
||||||
{
|
{
|
||||||
// use special nodes iterator
|
const SMDS_MeshFace* anElem = anIter->next();
|
||||||
SMDS_NodeIteratorPtr anIter = anElem->interlacedNodesIterator();
|
if ( anElem->IsQuadratic() )
|
||||||
long aNodeId[4] = { 0,0,0,0 };
|
{
|
||||||
gp_Pnt P[4];
|
// use special nodes iterator
|
||||||
|
SMDS_NodeIteratorPtr anIter = anElem->interlacedNodesIterator();
|
||||||
|
long aNodeId[4] = { 0,0,0,0 };
|
||||||
|
gp_Pnt P[4];
|
||||||
|
|
||||||
double aLength = 0;
|
double aLength = 0;
|
||||||
if ( anIter->more() )
|
if ( anIter->more() )
|
||||||
{
|
{
|
||||||
const SMDS_MeshNode* aNode = anIter->next();
|
const SMDS_MeshNode* aNode = anIter->next();
|
||||||
P[0] = P[1] = SMESH_NodeXYZ( aNode );
|
P[0] = P[1] = SMESH_NodeXYZ( aNode );
|
||||||
aNodeId[0] = aNodeId[1] = aNode->GetID();
|
aNodeId[0] = aNodeId[1] = aNode->GetID();
|
||||||
aLength = 0;
|
aLength = 0;
|
||||||
}
|
}
|
||||||
for ( ; anIter->more(); )
|
for ( ; anIter->more(); )
|
||||||
{
|
{
|
||||||
const SMDS_MeshNode* N1 = anIter->next();
|
const SMDS_MeshNode* N1 = anIter->next();
|
||||||
P[2] = SMESH_NodeXYZ( N1 );
|
P[2] = SMESH_NodeXYZ( N1 );
|
||||||
aNodeId[2] = N1->GetID();
|
aNodeId[2] = N1->GetID();
|
||||||
aLength = P[1].Distance(P[2]);
|
aLength = P[1].Distance(P[2]);
|
||||||
if(!anIter->more()) break;
|
if(!anIter->more()) break;
|
||||||
const SMDS_MeshNode* N2 = anIter->next();
|
const SMDS_MeshNode* N2 = anIter->next();
|
||||||
P[3] = SMESH_NodeXYZ( N2 );
|
P[3] = SMESH_NodeXYZ( N2 );
|
||||||
aNodeId[3] = N2->GetID();
|
aNodeId[3] = N2->GetID();
|
||||||
aLength += P[2].Distance(P[3]);
|
aLength += P[2].Distance(P[3]);
|
||||||
|
Value aValue1(aLength,aNodeId[1],aNodeId[2]);
|
||||||
|
Value aValue2(aLength,aNodeId[2],aNodeId[3]);
|
||||||
|
P[1] = P[3];
|
||||||
|
aNodeId[1] = aNodeId[3];
|
||||||
|
theValues.insert(aValue1);
|
||||||
|
theValues.insert(aValue2);
|
||||||
|
}
|
||||||
|
aLength += P[2].Distance(P[0]);
|
||||||
Value aValue1(aLength,aNodeId[1],aNodeId[2]);
|
Value aValue1(aLength,aNodeId[1],aNodeId[2]);
|
||||||
Value aValue2(aLength,aNodeId[2],aNodeId[3]);
|
Value aValue2(aLength,aNodeId[2],aNodeId[0]);
|
||||||
P[1] = P[3];
|
|
||||||
aNodeId[1] = aNodeId[3];
|
|
||||||
theValues.insert(aValue1);
|
theValues.insert(aValue1);
|
||||||
theValues.insert(aValue2);
|
theValues.insert(aValue2);
|
||||||
}
|
}
|
||||||
aLength += P[2].Distance(P[0]);
|
else {
|
||||||
Value aValue1(aLength,aNodeId[1],aNodeId[2]);
|
SMDS_NodeIteratorPtr aNodesIter = anElem->nodeIterator();
|
||||||
Value aValue2(aLength,aNodeId[2],aNodeId[0]);
|
long aNodeId[2] = {0,0};
|
||||||
theValues.insert(aValue1);
|
gp_Pnt P[3];
|
||||||
theValues.insert(aValue2);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
SMDS_NodeIteratorPtr aNodesIter = anElem->nodeIterator();
|
|
||||||
long aNodeId[2] = {0,0};
|
|
||||||
gp_Pnt P[3];
|
|
||||||
|
|
||||||
double aLength;
|
double aLength;
|
||||||
const SMDS_MeshElement* aNode;
|
const SMDS_MeshElement* aNode;
|
||||||
if ( aNodesIter->more())
|
if ( aNodesIter->more())
|
||||||
{
|
{
|
||||||
aNode = aNodesIter->next();
|
aNode = aNodesIter->next();
|
||||||
P[0] = P[1] = SMESH_NodeXYZ( aNode );
|
P[0] = P[1] = SMESH_NodeXYZ( aNode );
|
||||||
aNodeId[0] = aNodeId[1] = aNode->GetID();
|
aNodeId[0] = aNodeId[1] = aNode->GetID();
|
||||||
aLength = 0;
|
aLength = 0;
|
||||||
}
|
}
|
||||||
for( ; aNodesIter->more(); )
|
for( ; aNodesIter->more(); )
|
||||||
{
|
{
|
||||||
aNode = aNodesIter->next();
|
aNode = aNodesIter->next();
|
||||||
long anId = aNode->GetID();
|
long anId = aNode->GetID();
|
||||||
|
|
||||||
P[2] = SMESH_NodeXYZ( aNode );
|
P[2] = SMESH_NodeXYZ( aNode );
|
||||||
|
|
||||||
aLength = P[1].Distance(P[2]);
|
aLength = P[1].Distance(P[2]);
|
||||||
|
|
||||||
Value aValue(aLength,aNodeId[1],anId);
|
Value aValue(aLength,aNodeId[1],anId);
|
||||||
aNodeId[1] = anId;
|
aNodeId[1] = anId;
|
||||||
P[1] = P[2];
|
P[1] = P[2];
|
||||||
|
theValues.insert(aValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
aLength = P[0].Distance(P[1]);
|
||||||
|
|
||||||
|
Value aValue(aLength,aNodeId[0],aNodeId[1]);
|
||||||
theValues.insert(aValue);
|
theValues.insert(aValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
aLength = P[0].Distance(P[1]);
|
|
||||||
|
|
||||||
Value aValue(aLength,aNodeId[0],aNodeId[1]);
|
|
||||||
theValues.insert(aValue);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// not implemented
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
@ -136,6 +136,8 @@ namespace SMESH{
|
|||||||
const std::vector<int>& elements,
|
const std::vector<int>& elements,
|
||||||
const double* minmax=0,
|
const double* minmax=0,
|
||||||
const bool isLogarithmic = false);
|
const bool isLogarithmic = false);
|
||||||
|
bool IsApplicable( long theElementId ) const;
|
||||||
|
virtual bool IsApplicable( const SMDS_MeshElement* element ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const = 0;
|
virtual SMDSAbs_ElementType GetType() const = 0;
|
||||||
virtual double GetBadRate( double Value, int nbNodes ) const = 0;
|
virtual double GetBadRate( double Value, int nbNodes ) const = 0;
|
||||||
long GetPrecision() const;
|
long GetPrecision() const;
|
||||||
@ -176,8 +178,8 @@ namespace SMESH{
|
|||||||
virtual double GetBadRate( double Value, int nbNodes ) const;
|
virtual double GetBadRate( double Value, int nbNodes ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const;
|
virtual SMDSAbs_ElementType GetType() const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Class : MaxElementLength3D
|
Class : MaxElementLength3D
|
||||||
Description : Functor calculating maximum length of 3D element
|
Description : Functor calculating maximum length of 3D element
|
||||||
@ -212,6 +214,7 @@ namespace SMESH{
|
|||||||
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
||||||
virtual double GetBadRate( double Value, int nbNodes ) const;
|
virtual double GetBadRate( double Value, int nbNodes ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const;
|
virtual SMDSAbs_ElementType GetType() const;
|
||||||
|
virtual bool IsApplicable( const SMDS_MeshElement* element ) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -225,6 +228,7 @@ namespace SMESH{
|
|||||||
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
||||||
virtual double GetBadRate( double Value, int nbNodes ) const;
|
virtual double GetBadRate( double Value, int nbNodes ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const;
|
virtual SMDSAbs_ElementType GetType() const;
|
||||||
|
virtual bool IsApplicable( const SMDS_MeshElement* element ) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -237,7 +241,8 @@ namespace SMESH{
|
|||||||
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
||||||
virtual double GetBadRate( double Value, int nbNodes ) const;
|
virtual double GetBadRate( double Value, int nbNodes ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const;
|
virtual SMDSAbs_ElementType GetType() const;
|
||||||
|
virtual bool IsApplicable( const SMDS_MeshElement* element ) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
double ComputeA( const gp_XYZ&, const gp_XYZ&, const gp_XYZ&, const gp_XYZ& ) const;
|
double ComputeA( const gp_XYZ&, const gp_XYZ&, const gp_XYZ&, const gp_XYZ& ) const;
|
||||||
};
|
};
|
||||||
@ -252,6 +257,7 @@ namespace SMESH{
|
|||||||
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
||||||
virtual double GetBadRate( double Value, int nbNodes ) const;
|
virtual double GetBadRate( double Value, int nbNodes ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const;
|
virtual SMDSAbs_ElementType GetType() const;
|
||||||
|
virtual bool IsApplicable( const SMDS_MeshElement* element ) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -263,6 +269,7 @@ namespace SMESH{
|
|||||||
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
||||||
virtual double GetBadRate( double Value, int nbNodes ) const;
|
virtual double GetBadRate( double Value, int nbNodes ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const;
|
virtual SMDSAbs_ElementType GetType() const;
|
||||||
|
virtual bool IsApplicable( const SMDS_MeshElement* element ) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -291,10 +298,12 @@ namespace SMESH{
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
Class : Length2D
|
Class : Length2D
|
||||||
Description : Functor for calculating minimal length of edge
|
Description : Functor for calculating minimal length of edges of element
|
||||||
*/
|
*/
|
||||||
class SMESHCONTROLS_EXPORT Length2D: public virtual NumericalFunctor{
|
class SMESHCONTROLS_EXPORT Length2D: public virtual NumericalFunctor{
|
||||||
public:
|
public:
|
||||||
|
Length2D( SMDSAbs_ElementType type = SMDSAbs_Face );
|
||||||
|
virtual bool IsApplicable( const SMDS_MeshElement* element ) const;
|
||||||
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
virtual double GetValue( const TSequenceOfXYZ& thePoints );
|
||||||
virtual double GetBadRate( double Value, int nbNodes ) const;
|
virtual double GetBadRate( double Value, int nbNodes ) const;
|
||||||
virtual SMDSAbs_ElementType GetType() const;
|
virtual SMDSAbs_ElementType GetType() const;
|
||||||
@ -306,9 +315,22 @@ namespace SMESH{
|
|||||||
};
|
};
|
||||||
typedef std::set<Value> TValues;
|
typedef std::set<Value> TValues;
|
||||||
void GetValues(TValues& theValues);
|
void GetValues(TValues& theValues);
|
||||||
|
|
||||||
|
private:
|
||||||
|
SMDSAbs_ElementType myType;
|
||||||
};
|
};
|
||||||
typedef boost::shared_ptr<Length2D> Length2DPtr;
|
typedef boost::shared_ptr<Length2D> Length2DPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
Class : Length2D
|
||||||
|
Description : Functor for calculating minimal length of edges of 3D element
|
||||||
|
*/
|
||||||
|
class SMESHCONTROLS_EXPORT Length3D: public virtual Length2D {
|
||||||
|
public:
|
||||||
|
Length3D();
|
||||||
|
};
|
||||||
|
typedef boost::shared_ptr<Length3D> Length3DPtr;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Class : Deflection2D
|
Class : Deflection2D
|
||||||
Description : Functor for calculating distance between a face and geometry
|
Description : Functor for calculating distance between a face and geometry
|
||||||
|
@ -165,6 +165,7 @@ SET(_other_HEADERS
|
|||||||
SMESHGUI_MeshEditPreview.h
|
SMESHGUI_MeshEditPreview.h
|
||||||
SMESHGUI_IdValidator.h
|
SMESHGUI_IdValidator.h
|
||||||
SMESHGUI_FileValidator.h
|
SMESHGUI_FileValidator.h
|
||||||
|
SMESHGUI_SelectionProxy.h
|
||||||
SMESH_SMESHGUI.hxx
|
SMESH_SMESHGUI.hxx
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -189,6 +190,7 @@ SET(_other_SOURCES
|
|||||||
SMESHGUI_GroupDlg.cxx
|
SMESHGUI_GroupDlg.cxx
|
||||||
SMESHGUI_RemoveNodesDlg.cxx
|
SMESHGUI_RemoveNodesDlg.cxx
|
||||||
SMESHGUI_RemoveElementsDlg.cxx
|
SMESHGUI_RemoveElementsDlg.cxx
|
||||||
|
SMESHGUI_SelectionProxy.cxx
|
||||||
SMESHGUI_MeshInfo.cxx
|
SMESHGUI_MeshInfo.cxx
|
||||||
SMESHGUI_Measurements.cxx
|
SMESHGUI_Measurements.cxx
|
||||||
SMESHGUI_Preferences_ScalarBarDlg.cxx
|
SMESHGUI_Preferences_ScalarBarDlg.cxx
|
||||||
|
@ -1571,6 +1571,7 @@ void SMESHGUI_FilterTable::updateAdditionalWidget()
|
|||||||
aCriterion == SMESH::FT_MaxElementLength3D ||
|
aCriterion == SMESH::FT_MaxElementLength3D ||
|
||||||
aCriterion == SMESH::FT_Length ||
|
aCriterion == SMESH::FT_Length ||
|
||||||
aCriterion == SMESH::FT_Length2D ||
|
aCriterion == SMESH::FT_Length2D ||
|
||||||
|
aCriterion == SMESH::FT_Length3D ||
|
||||||
aCriterion == SMESH::FT_Deflection2D ||
|
aCriterion == SMESH::FT_Deflection2D ||
|
||||||
aCriterion == SMESH::FT_BallDiameter );
|
aCriterion == SMESH::FT_BallDiameter );
|
||||||
|
|
||||||
@ -1618,6 +1619,7 @@ const char* SMESHGUI_FilterTable::getPrecision( const int aType )
|
|||||||
retval = "len_tol_precision"; break;
|
retval = "len_tol_precision"; break;
|
||||||
case SMESH::FT_Length:
|
case SMESH::FT_Length:
|
||||||
case SMESH::FT_Length2D:
|
case SMESH::FT_Length2D:
|
||||||
|
case SMESH::FT_Length3D:
|
||||||
case SMESH::FT_Deflection2D:
|
case SMESH::FT_Deflection2D:
|
||||||
case SMESH::FT_MaxElementLength2D:
|
case SMESH::FT_MaxElementLength2D:
|
||||||
case SMESH::FT_MaxElementLength3D:
|
case SMESH::FT_MaxElementLength3D:
|
||||||
@ -1830,6 +1832,7 @@ void SMESHGUI_FilterTable::onCriterionChanged (const int row, const int col, con
|
|||||||
|
|
||||||
case SMESH::FT_Length:
|
case SMESH::FT_Length:
|
||||||
case SMESH::FT_Length2D:
|
case SMESH::FT_Length2D:
|
||||||
|
case SMESH::FT_Length3D:
|
||||||
case SMESH::FT_Deflection2D: anIsDoubleCriterion = true; break;
|
case SMESH::FT_Deflection2D: anIsDoubleCriterion = true; break;
|
||||||
|
|
||||||
case SMESH::FT_BelongToMeshGroup: break;
|
case SMESH::FT_BelongToMeshGroup: break;
|
||||||
@ -2270,6 +2273,7 @@ const QMap<int, QString>& SMESHGUI_FilterTable::getCriteria (const int theType)
|
|||||||
aCriteria[ SMESH::FT_BadOrientedVolume ] = tr("BAD_ORIENTED_VOLUME");
|
aCriteria[ SMESH::FT_BadOrientedVolume ] = tr("BAD_ORIENTED_VOLUME");
|
||||||
aCriteria[ SMESH::FT_BareBorderVolume ] = tr("BARE_BORDER_VOLUME");
|
aCriteria[ SMESH::FT_BareBorderVolume ] = tr("BARE_BORDER_VOLUME");
|
||||||
aCriteria[ SMESH::FT_OverConstrainedVolume] = tr("OVER_CONSTRAINED_VOLUME");
|
aCriteria[ SMESH::FT_OverConstrainedVolume] = tr("OVER_CONSTRAINED_VOLUME");
|
||||||
|
aCriteria[ SMESH::FT_Length3D ] = tr("LENGTH3D");
|
||||||
aCriteria[ SMESH::FT_Volume3D ] = tr("VOLUME_3D");
|
aCriteria[ SMESH::FT_Volume3D ] = tr("VOLUME_3D");
|
||||||
aCriteria[ SMESH::FT_MaxElementLength3D ] = tr("MAX_ELEMENT_LENGTH_3D");
|
aCriteria[ SMESH::FT_MaxElementLength3D ] = tr("MAX_ELEMENT_LENGTH_3D");
|
||||||
aCriteria[ SMESH::FT_LinearOrQuadratic ] = tr("LINEAR");
|
aCriteria[ SMESH::FT_LinearOrQuadratic ] = tr("LINEAR");
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -19,14 +19,12 @@
|
|||||||
//
|
//
|
||||||
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
//
|
//
|
||||||
// File : SMESHGUI_MeshInfo.h
|
|
||||||
// Author : Vadim SANDLER, Open CASCADE S.A.S. (vadim.sandler@opencascade.com)
|
|
||||||
|
|
||||||
#ifndef SMESHGUI_MESHINFO_H
|
#ifndef SMESHGUI_MESHINFO_H
|
||||||
#define SMESHGUI_MESHINFO_H
|
#define SMESHGUI_MESHINFO_H
|
||||||
|
|
||||||
#include "SMESH_SMESHGUI.hxx"
|
#include "SMESH_SMESHGUI.hxx"
|
||||||
#include "SMESH_ControlsDef.hxx"
|
#include "SMESHGUI_SelectionProxy.h"
|
||||||
|
|
||||||
#ifndef DISABLE_PLOT2DVIEWER
|
#ifndef DISABLE_PLOT2DVIEWER
|
||||||
#include <Plot2d_Histogram.h>
|
#include <Plot2d_Histogram.h>
|
||||||
@ -34,17 +32,12 @@
|
|||||||
#include <qwt_plot.h>
|
#include <qwt_plot.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <QFrame>
|
|
||||||
#include <QDialog>
|
#include <QDialog>
|
||||||
#include <QList>
|
#include <QList>
|
||||||
#include <QMap>
|
#include <QMap>
|
||||||
#include <QSet>
|
#include <QSet>
|
||||||
#include <QTreeWidget>
|
|
||||||
#include <QVector>
|
|
||||||
|
|
||||||
#include <SALOMEconfig.h>
|
#include <SALOMEconfig.h>
|
||||||
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
|
||||||
#include CORBA_SERVER_HEADER(SMESH_Group)
|
|
||||||
#include CORBA_SERVER_HEADER(SMESH_Filter)
|
#include CORBA_SERVER_HEADER(SMESH_Filter)
|
||||||
|
|
||||||
#include <SALOME_InteractiveObject.hxx>
|
#include <SALOME_InteractiveObject.hxx>
|
||||||
@ -54,51 +47,65 @@ class QAbstractButton;
|
|||||||
class QButtonGroup;
|
class QButtonGroup;
|
||||||
class QCheckBox;
|
class QCheckBox;
|
||||||
class QContextMenuEvent;
|
class QContextMenuEvent;
|
||||||
class QGridLayout;
|
|
||||||
class QLabel;
|
class QLabel;
|
||||||
class QLineEdit;
|
class QLineEdit;
|
||||||
class QPushButton;
|
|
||||||
class QTabWidget;
|
class QTabWidget;
|
||||||
class QTextBrowser;
|
class QTextBrowser;
|
||||||
|
class QTreeWidget;
|
||||||
|
class QTreeWidgetItem;
|
||||||
class SMDS_MeshElement;
|
class SMDS_MeshElement;
|
||||||
class SMDS_MeshNode;
|
class SMDS_MeshNode;
|
||||||
class SMESHGUI_IdPreview;
|
class SMESHGUI_IdPreview;
|
||||||
class SMESHGUI_SpinBox;
|
class SMESHGUI_SpinBox;
|
||||||
class SMESH_Actor;
|
|
||||||
|
|
||||||
class ExtraWidget;
|
class ExtraWidget;
|
||||||
|
class GroupCombo;
|
||||||
|
class InfoWriter;
|
||||||
|
|
||||||
class SMESHGUI_EXPORT SMESHGUI_MeshInfo : public QFrame
|
class SMESHGUI_EXPORT SMESHGUI_Info : public QWidget
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
SMESHGUI_Info( QWidget* = 0 );
|
||||||
|
virtual void saveInfo( QTextStream& ) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class SMESHGUI_EXPORT SMESHGUI_BaseInfo : public SMESHGUI_Info
|
||||||
{
|
{
|
||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
enum {
|
enum
|
||||||
iName,
|
{
|
||||||
|
iStart,
|
||||||
|
iObjectStart = iStart,
|
||||||
|
iName = iObjectStart,
|
||||||
iObject,
|
iObject,
|
||||||
iNodesStart,
|
iObjectEnd,
|
||||||
|
iNodesStart = iObjectEnd,
|
||||||
iNodes,
|
iNodes,
|
||||||
iNodesEnd,
|
iNodesEnd,
|
||||||
iElementsStart = iNodesEnd,
|
iElementsStart = iNodesEnd,
|
||||||
iElements,
|
iElementsTitleStart = iElementsStart,
|
||||||
iNbStart,
|
iElementsTitle,
|
||||||
iNb,
|
iElementsTitleEnd,
|
||||||
iNbEnd,
|
iElementsTotalStart = iElementsTitleEnd,
|
||||||
i0DStart = iNbEnd,
|
iElementsTotal,
|
||||||
|
iElementsTotalEnd,
|
||||||
|
i0DStart = iElementsTotalEnd,
|
||||||
i0D,
|
i0D,
|
||||||
i0DEnd,
|
i0DEnd,
|
||||||
iBallsStart = i0DEnd,
|
iBallsStart = i0DEnd,
|
||||||
iBalls,
|
iBalls,
|
||||||
iBallsEnd,
|
iBallsEnd,
|
||||||
i1DStart = iBallsEnd,
|
i1DStart = iBallsEnd,
|
||||||
i1D,
|
i1D,
|
||||||
i1DEnd,
|
i1DEnd,
|
||||||
i2DStart = i1DEnd,
|
i2DStart = i1DEnd,
|
||||||
i2D,
|
i2D,
|
||||||
i2DTriangles,
|
i2DTriangles,
|
||||||
i2DQuadrangles,
|
i2DQuadrangles,
|
||||||
i2DPolygons,
|
i2DPolygons,
|
||||||
i2DEnd,
|
i2DEnd,
|
||||||
i3DStart = i2DEnd,
|
i3DStart = i2DEnd,
|
||||||
i3D,
|
i3D,
|
||||||
i3DTetrahedrons,
|
i3DTetrahedrons,
|
||||||
i3DHexahedrons,
|
i3DHexahedrons,
|
||||||
@ -107,45 +114,49 @@ class SMESHGUI_EXPORT SMESHGUI_MeshInfo : public QFrame
|
|||||||
i3DHexaPrisms,
|
i3DHexaPrisms,
|
||||||
i3DPolyhedrons,
|
i3DPolyhedrons,
|
||||||
i3DEnd,
|
i3DEnd,
|
||||||
iElementsEnd = i3DEnd
|
iElementsEnd = i3DEnd,
|
||||||
|
iEnd,
|
||||||
|
iOther = iEnd
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum
|
||||||
iSingle = 1,
|
{
|
||||||
iTotal = iSingle,
|
iLabel,
|
||||||
|
iSingle,
|
||||||
|
iTotal = iSingle,
|
||||||
iLinear,
|
iLinear,
|
||||||
iQuadratic,
|
iQuadratic,
|
||||||
iBiQuadratic
|
iBiQuadratic,
|
||||||
|
iNbColumns
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef QList<QWidget*> wlist;
|
typedef QMap<int, QWidget*> wlist;
|
||||||
typedef QVector<wlist> iwlist;
|
typedef QMap<int, wlist> iwlist;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SMESHGUI_MeshInfo( QWidget* = 0 );
|
SMESHGUI_BaseInfo( QWidget* = 0 );
|
||||||
~SMESHGUI_MeshInfo();
|
~SMESHGUI_BaseInfo();
|
||||||
|
|
||||||
void showInfo( SMESH::SMESH_IDSource_ptr );
|
void showInfo( const SMESH::SelectionProxy& );
|
||||||
void clear();
|
void clear();
|
||||||
void saveInfo( QTextStream &out );
|
void saveInfo( QTextStream& );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
enum { Bold = 0x01, Italic = 0x02 };
|
QWidget* addWidget( QWidget*, int, int, int = 1 );
|
||||||
|
QWidget* widget( int, int ) const;
|
||||||
QLabel* createField();
|
QString value( int, int ) const;
|
||||||
QWidget* createLine();
|
void setFieldsVisible( int, int, bool );
|
||||||
void setFontAttributes( QWidget*, int, bool = true );
|
|
||||||
void setFieldsVisible( int, int, bool );
|
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
void updateInfo();
|
||||||
void loadMesh();
|
void loadMesh();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
iwlist myWidgets;
|
iwlist myWidgets;
|
||||||
QPushButton* myLoadBtn;
|
SMESH::SelectionProxy myProxy;
|
||||||
};
|
};
|
||||||
|
|
||||||
class SMESHGUI_EXPORT SMESHGUI_ElemInfo : public QWidget
|
class SMESHGUI_EXPORT SMESHGUI_ElemInfo : public SMESHGUI_Info
|
||||||
{
|
{
|
||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
@ -153,74 +164,60 @@ public:
|
|||||||
SMESHGUI_ElemInfo( QWidget* = 0 );
|
SMESHGUI_ElemInfo( QWidget* = 0 );
|
||||||
~SMESHGUI_ElemInfo();
|
~SMESHGUI_ElemInfo();
|
||||||
|
|
||||||
void setSource( SMESH_Actor*, SMESH::SMESH_IDSource_var );
|
void showInfo( const SMESH::SelectionProxy&, uint, bool );
|
||||||
void showInfo( long, bool );
|
void showInfo( const SMESH::SelectionProxy&, QSet<uint>, bool );
|
||||||
void showInfo( QSet<long>, bool );
|
void showInfo( const SMESH::SelectionProxy& );
|
||||||
void clear();
|
void clear();
|
||||||
virtual void saveInfo( QTextStream &out ) = 0;
|
void saveInfo( QTextStream& );
|
||||||
|
|
||||||
gp_XYZ getGravityCenter( const SMDS_MeshElement* e ) { return gravityCenter(e); }
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
struct XYZ
|
enum { ShowNone, ShowNodes, ShowElements };
|
||||||
{
|
|
||||||
double myX, myY, myZ;
|
|
||||||
XYZ() { myX = myY = myZ = 0.0; }
|
|
||||||
XYZ(double x, double y, double z) { myX = x; myY = y; myZ = z; }
|
|
||||||
void add( double x, double y, double z ) { myX += x; myY += y; myZ += z; }
|
|
||||||
void divide( double a ) { if ( a != 0.) { myX /= a; myY /= a; myZ /= a; } }
|
|
||||||
double x() const { return myX; }
|
|
||||||
double y() const { return myY; }
|
|
||||||
double z() const { return myZ; }
|
|
||||||
operator gp_XYZ() const { return gp_XYZ( myX, myY, myZ ); }
|
|
||||||
};
|
|
||||||
typedef QMap< int, QList<int> > Connectivity;
|
|
||||||
|
|
||||||
QWidget* frame() const;
|
QWidget* centralWidget() const;
|
||||||
SMESH_Actor* actor() const;
|
|
||||||
bool isElements() const;
|
|
||||||
bool hasShapeToMesh() const { return myMeshHasShape; }
|
|
||||||
|
|
||||||
virtual void information( const QList<long>& ) = 0;
|
SMESH::SelectionProxy proxy() const;
|
||||||
|
int what() const;
|
||||||
|
|
||||||
|
QString type2str( int, bool = false );
|
||||||
|
QString stype2str( int );
|
||||||
|
QString etype2str( int );
|
||||||
|
QString ctrl2str( int );
|
||||||
|
void writeInfo( InfoWriter*, const QList<uint>& );
|
||||||
|
virtual void information( const QList<uint>& ) = 0;
|
||||||
virtual void clearInternal();
|
virtual void clearInternal();
|
||||||
|
|
||||||
Connectivity nodeConnectivity( const SMDS_MeshNode* );
|
|
||||||
QString formatConnectivity( Connectivity, int );
|
|
||||||
XYZ gravityCenter( const SMDS_MeshElement* );
|
|
||||||
XYZ normal( const SMDS_MeshElement* );
|
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void itemInfo( int );
|
void itemInfo( int type, const QString& ids );
|
||||||
void itemInfo( const QString& );
|
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void showPrevious();
|
void showPrevious();
|
||||||
void showNext();
|
void showNext();
|
||||||
void updateControls();
|
void updateControls();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SMESH_Actor* myActor;
|
QWidget* myFrame;
|
||||||
QList<long> myIDs;
|
ExtraWidget* myExtra;
|
||||||
int myIsElement;
|
SMESH::SelectionProxy myProxy;
|
||||||
QWidget* myFrame;
|
int myWhat;
|
||||||
ExtraWidget* myExtra;
|
QList<uint> myIDs;
|
||||||
int myIndex;
|
int myIndex;
|
||||||
bool myMeshHasShape;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class SMESHGUI_EXPORT SMESHGUI_SimpleElemInfo : public SMESHGUI_ElemInfo
|
class SMESHGUI_EXPORT SMESHGUI_SimpleElemInfo : public SMESHGUI_ElemInfo
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SMESHGUI_SimpleElemInfo( QWidget* = 0 );
|
SMESHGUI_SimpleElemInfo( QWidget* = 0 );
|
||||||
void saveInfo( QTextStream &out );
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void information( const QList<long>& );
|
void information( const QList<uint>& );
|
||||||
void clearInternal();
|
void clearInternal();
|
||||||
|
|
||||||
private:
|
private slots:
|
||||||
|
void connectivityClicked(const QUrl &);
|
||||||
|
|
||||||
|
private:
|
||||||
QTextBrowser* myInfo;
|
QTextBrowser* myInfo;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -229,85 +226,86 @@ class SMESHGUI_EXPORT SMESHGUI_TreeElemInfo : public SMESHGUI_ElemInfo
|
|||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
class ItemDelegate;
|
class ItemDelegate;
|
||||||
|
class ItemCreator;
|
||||||
enum { Bold = 0x01, All = 0x80 };
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SMESHGUI_TreeElemInfo( QWidget* = 0 );
|
SMESHGUI_TreeElemInfo( QWidget* = 0 );
|
||||||
void saveInfo( QTextStream &out );
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void contextMenuEvent( QContextMenuEvent* e );
|
void contextMenuEvent( QContextMenuEvent* );
|
||||||
void information( const QList<long>& );
|
void information( const QList<uint>& );
|
||||||
void nodeInfo( const SMDS_MeshNode*, int, int, QTreeWidgetItem* );
|
void nodeInfo( const SMDS_MeshNode*, int, int, QTreeWidgetItem* );
|
||||||
void clearInternal();
|
void clearInternal();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void itemDoubleClicked( QTreeWidgetItem*, int );
|
void itemDoubleClicked( QTreeWidgetItem*, int );
|
||||||
void saveExpanded( QTreeWidgetItem* );
|
void saveExpanded( QTreeWidgetItem* );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QTreeWidgetItem* createItem( QTreeWidgetItem* = 0, int = 0 );
|
QTreeWidgetItem* createItem( QTreeWidgetItem* = 0, int = 0 );
|
||||||
QString expandedResource( QTreeWidgetItem* );
|
QString expandedResource( QTreeWidgetItem* );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QTreeWidget* myInfo;
|
QTreeWidget* myInfo;
|
||||||
};
|
};
|
||||||
|
|
||||||
class GrpComputor: public QObject
|
class InfoComputor: public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GrpComputor( SMESH::SMESH_GroupBase_ptr, QTreeWidgetItem*, QObject*, bool = false);
|
enum { GrpSize, GrpNbNodes };
|
||||||
QTreeWidgetItem* getItem() { return myItem; }
|
|
||||||
|
InfoComputor( QObject*, const SMESH::SelectionProxy&, int );
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void computed();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void compute();
|
void compute();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SMESH::SMESH_GroupBase_var myGroup;
|
SMESH::SelectionProxy myProxy;
|
||||||
QTreeWidgetItem* myItem;
|
int myOperation;
|
||||||
bool myToComputeSize;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class SMESHGUI_EXPORT SMESHGUI_AddInfo : public QTreeWidget
|
class SMESHGUI_EXPORT SMESHGUI_AddInfo : public SMESHGUI_Info
|
||||||
{
|
{
|
||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
enum { Bold = 0x01, All = 0x80 };
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SMESHGUI_AddInfo( QWidget* = 0 );
|
SMESHGUI_AddInfo( QWidget* = 0 );
|
||||||
~SMESHGUI_AddInfo();
|
~SMESHGUI_AddInfo();
|
||||||
|
|
||||||
void showInfo( SMESH::SMESH_IDSource_ptr );
|
void showInfo( const SMESH::SelectionProxy& );
|
||||||
// void clear();
|
void clear();
|
||||||
void saveInfo( QTextStream &out );
|
void saveInfo( QTextStream& );
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void changeLoadToCompute();
|
void updateInfo();
|
||||||
void showPreviousGroups();
|
void showPreviousGroups();
|
||||||
void showNextGroups();
|
void showNextGroups();
|
||||||
void showPreviousSubMeshes();
|
void showPreviousSubMeshes();
|
||||||
void showNextSubMeshes();
|
void showNextSubMeshes();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QTreeWidgetItem* createItem( QTreeWidgetItem* = 0, int = 0 );
|
QTreeWidgetItem* createItem( QTreeWidgetItem* = 0, int = 0 );
|
||||||
void meshInfo( SMESH::SMESH_Mesh_ptr, QTreeWidgetItem* );
|
void meshInfo( const SMESH::SelectionProxy&, QTreeWidgetItem* );
|
||||||
void subMeshInfo( SMESH::SMESH_subMesh_ptr, QTreeWidgetItem* );
|
void subMeshInfo( const SMESH::SelectionProxy&, QTreeWidgetItem* );
|
||||||
void groupInfo( SMESH::SMESH_GroupBase_ptr, QTreeWidgetItem* );
|
void groupInfo( const SMESH::SelectionProxy&, QTreeWidgetItem* );
|
||||||
|
|
||||||
void showGroups();
|
void showGroups();
|
||||||
void showSubMeshes();
|
void showSubMeshes();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QList<GrpComputor*> myComputors;
|
SMESH::SelectionProxy myProxy;
|
||||||
SMESH::ListOfGroups_var myGroups;
|
QTreeWidget* myTree;
|
||||||
SMESH::submesh_array_var mySubMeshes;
|
QList<InfoComputor*> myComputors;
|
||||||
|
QList<SMESH::SelectionProxy> myGroups;
|
||||||
|
QList<SMESH::SelectionProxy> mySubMeshes;
|
||||||
};
|
};
|
||||||
|
|
||||||
class SMESHGUI_EXPORT SMESHGUI_CtrlInfo : public QFrame
|
class SMESHGUI_EXPORT SMESHGUI_CtrlInfo : public SMESHGUI_Info
|
||||||
{
|
{
|
||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
@ -315,62 +313,59 @@ public:
|
|||||||
SMESHGUI_CtrlInfo( QWidget* = 0 );
|
SMESHGUI_CtrlInfo( QWidget* = 0 );
|
||||||
~SMESHGUI_CtrlInfo();
|
~SMESHGUI_CtrlInfo();
|
||||||
|
|
||||||
void showInfo( SMESH::SMESH_IDSource_ptr );
|
void showInfo( const SMESH::SelectionProxy& );
|
||||||
void saveInfo( QTextStream &out );
|
void saveInfo( QTextStream& );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
enum ObjectType { Mesh, SubMesh, Group };
|
enum ObjectType { Mesh, SubMesh, Group };
|
||||||
QLabel* createField();
|
QwtPlot* createPlot( QWidget* );
|
||||||
QwtPlot* createPlot( QWidget* );
|
void clearInternal();
|
||||||
void setFontAttributes( QWidget* );
|
|
||||||
void clearInternal();
|
|
||||||
#ifndef DISABLE_PLOT2DVIEWER
|
#ifndef DISABLE_PLOT2DVIEWER
|
||||||
Plot2d_Histogram* getHistogram( SMESH::NumericalFunctor_ptr functor );
|
Plot2d_Histogram* getHistogram( SMESH::NumericalFunctor_ptr );
|
||||||
#endif
|
#endif
|
||||||
void computeNb( int ft, int iBut, int iWdg );
|
void computeNb( int, int, int );
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void computeAspectRatio();
|
void computeAspectRatio();
|
||||||
void computeAspectRatio3D();
|
void computeAspectRatio3D();
|
||||||
void computeFreeNodesInfo();
|
void computeFreeNodesInfo();
|
||||||
void computeNodesNbConnInfo();
|
void computeNodesNbConnInfo();
|
||||||
void computeDoubleNodesInfo();
|
void computeDoubleNodesInfo();
|
||||||
void computeDoubleEdgesInfo();
|
void computeDoubleEdgesInfo();
|
||||||
void computeDoubleFacesInfo();
|
void computeDoubleFacesInfo();
|
||||||
void computeOverConstrainedFacesInfo();
|
void computeOverConstrainedFacesInfo();
|
||||||
void computeDoubleVolumesInfo();
|
void computeDoubleVolumesInfo();
|
||||||
void computeOverConstrainedVolumesInfo();
|
void computeOverConstrainedVolumesInfo();
|
||||||
void setTolerance( const double theTolerance );
|
void setTolerance( double );
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef SALOME::GenericObj_wrap< SMESH::Predicate > TPredicate;
|
typedef SALOME::GenericObj_wrap< SMESH::Predicate > TPredicate;
|
||||||
typedef SALOME::GenericObj_wrap< SMESH::NumericalFunctor > TNumFunctor;
|
typedef SALOME::GenericObj_wrap< SMESH::NumericalFunctor > TNumFunctor;
|
||||||
SMESH::SMESH_IDSource_var myObject;
|
SMESH::SelectionProxy myProxy;
|
||||||
ObjectType myObjectType;
|
ObjectType myObjectType;
|
||||||
SMESHGUI_SpinBox* myToleranceWidget;
|
SMESHGUI_SpinBox* myToleranceWidget;
|
||||||
QList<QLabel*> myWidgets;
|
QList<QLabel*> myWidgets;
|
||||||
QGridLayout* myMainLayout;
|
QwtPlot* myPlot;
|
||||||
QwtPlot* myPlot;
|
QwtPlot* myPlot3D;
|
||||||
QwtPlot* myPlot3D;
|
QList<QAbstractButton*> myButtons;
|
||||||
QList<QAbstractButton*> myButtons;
|
QList<TPredicate> myPredicates;
|
||||||
QList<TPredicate> myPredicates;
|
TNumFunctor myAspectRatio, myAspectRatio3D, myNodeConnFunctor;
|
||||||
TNumFunctor myAspectRatio, myAspectRatio3D, myNodeConnFunctor;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class SMESHGUI_EXPORT SMESHGUI_MeshInfoDlg : public QDialog
|
class SMESHGUI_EXPORT SMESHGUI_MeshInfoDlg : public QDialog
|
||||||
{
|
{
|
||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
enum { NodeMode, ElemMode };
|
enum { NodeMode, ElemMode, GroupMode };
|
||||||
|
|
||||||
public:
|
public:
|
||||||
//! Information type
|
//! Information type
|
||||||
enum {
|
enum
|
||||||
|
{
|
||||||
BaseInfo, //!< base mesh information
|
BaseInfo, //!< base mesh information
|
||||||
ElemInfo, //!< mesh element information
|
ElemInfo, //!< mesh element information
|
||||||
AddInfo, //!< additional information
|
AddInfo, //!< additional information
|
||||||
CtrlInfo //!< controls information
|
CtrlInfo //!< controls information
|
||||||
};
|
};
|
||||||
|
|
||||||
SMESHGUI_MeshInfoDlg( QWidget* = 0, int = BaseInfo );
|
SMESHGUI_MeshInfoDlg( QWidget* = 0, int = BaseInfo );
|
||||||
@ -381,33 +376,35 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
void keyPressEvent( QKeyEvent* );
|
void keyPressEvent( QKeyEvent* );
|
||||||
void enterEvent( QEvent* );
|
|
||||||
|
signals:
|
||||||
|
void switchMode( int );
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void help();
|
void help();
|
||||||
void updateSelection();
|
void updateSelection();
|
||||||
void updateInfo();
|
void updateInfo();
|
||||||
void activate();
|
|
||||||
void deactivate();
|
void deactivate();
|
||||||
void modeChanged();
|
void modeChanged();
|
||||||
void idChanged();
|
void idChanged();
|
||||||
void idPreviewChange(bool);
|
void idPreviewChange( bool );
|
||||||
void showItemInfo( int );
|
void showItemInfo( int type, const QString& ids );
|
||||||
void showItemInfo( const QString& );
|
|
||||||
void dump();
|
void dump();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QTabWidget* myTabWidget;
|
void showInfo( const SMESH::SelectionProxy& );
|
||||||
SMESHGUI_MeshInfo* myBaseInfo;
|
|
||||||
QButtonGroup* myMode;
|
SMESH::SelectionProxy myProxy;
|
||||||
QLineEdit* myID;
|
QTabWidget* myTabWidget;
|
||||||
QCheckBox* myIDPreviewCheck;
|
SMESHGUI_BaseInfo* myBaseInfo;
|
||||||
SMESHGUI_IdPreview* myIDPreview;
|
SMESHGUI_ElemInfo* myElemInfo;
|
||||||
SMESHGUI_ElemInfo* myElemInfo;
|
SMESHGUI_AddInfo* myAddInfo;
|
||||||
SMESHGUI_AddInfo* myAddInfo;
|
SMESHGUI_CtrlInfo* myCtrlInfo;
|
||||||
SMESHGUI_CtrlInfo* myCtrlInfo;
|
QButtonGroup* myMode;
|
||||||
SMESH_Actor* myActor;
|
QLineEdit* myID;
|
||||||
Handle(SALOME_InteractiveObject) myIO;
|
QCheckBox* myIDPreviewCheck;
|
||||||
|
GroupCombo* myGroups;
|
||||||
|
SMESHGUI_IdPreview* myIDPreview;
|
||||||
};
|
};
|
||||||
|
|
||||||
class SMESHGUI_EXPORT SMESHGUI_CtrlInfoDlg : public QDialog
|
class SMESHGUI_EXPORT SMESHGUI_CtrlInfoDlg : public QDialog
|
||||||
@ -423,14 +420,16 @@ public:
|
|||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void updateInfo();
|
void updateInfo();
|
||||||
void activate();
|
|
||||||
void deactivate();
|
void deactivate();
|
||||||
void updateSelection();
|
void updateSelection();
|
||||||
void help();
|
void help();
|
||||||
void dump();
|
void dump();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SMESHGUI_CtrlInfo* myCtrlInfo;
|
void showInfo( const SMESH::SelectionProxy& );
|
||||||
|
|
||||||
|
SMESH::SelectionProxy myProxy;
|
||||||
|
SMESHGUI_CtrlInfo* myCtrlInfo;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SMESHGUI_MESHINFO_H
|
#endif // SMESHGUI_MESHINFO_H
|
||||||
|
@ -1622,7 +1622,7 @@ SMESHGUI_SplitVolumesDlg::SMESHGUI_SplitVolumesDlg(SMESHGUI* theModule)
|
|||||||
}
|
}
|
||||||
if ( myEntityTypeGrp )
|
if ( myEntityTypeGrp )
|
||||||
{
|
{
|
||||||
myEntityTypeGrp->button(0)->setText( tr("SMESH_TETRAS"));
|
myEntityTypeGrp->button(0)->setText( tr("SMESH_TETRAHEDRON"));
|
||||||
myEntityTypeGrp->button(1)->setText( tr("SMESH_PRISM"));
|
myEntityTypeGrp->button(1)->setText( tr("SMESH_PRISM"));
|
||||||
if ( QGroupBox* gb = qobject_cast< QGroupBox* >( myEntityTypeGrp->button(0)->parent() ))
|
if ( QGroupBox* gb = qobject_cast< QGroupBox* >( myEntityTypeGrp->button(0)->parent() ))
|
||||||
gb->setTitle( tr("TARGET_ELEM_TYPE"));
|
gb->setTitle( tr("TARGET_ELEM_TYPE"));
|
||||||
|
1585
src/SMESHGUI/SMESHGUI_SelectionProxy.cxx
Normal file
1585
src/SMESHGUI/SMESHGUI_SelectionProxy.cxx
Normal file
File diff suppressed because it is too large
Load Diff
204
src/SMESHGUI/SMESHGUI_SelectionProxy.h
Normal file
204
src/SMESHGUI/SMESHGUI_SelectionProxy.h
Normal file
@ -0,0 +1,204 @@
|
|||||||
|
// Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE
|
||||||
|
//
|
||||||
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
||||||
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
||||||
|
//
|
||||||
|
// This library is free software; you can redistribute it and/or
|
||||||
|
// modify it under the terms of the GNU Lesser General Public
|
||||||
|
// License as published by the Free Software Foundation; either
|
||||||
|
// version 2.1 of the License, or (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This library is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
// Lesser General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU Lesser General Public
|
||||||
|
// License along with this library; if not, write to the Free Software
|
||||||
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
//
|
||||||
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef SMESHGUI_SELECTIONPROXY_H
|
||||||
|
#define SMESHGUI_SELECTIONPROXY_H
|
||||||
|
|
||||||
|
#include "SMESH_SMESHGUI.hxx"
|
||||||
|
|
||||||
|
#include <SALOME_InteractiveObject.hxx>
|
||||||
|
#include <SALOMEconfig.h>
|
||||||
|
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
||||||
|
#include CORBA_SERVER_HEADER(GEOM_Gen)
|
||||||
|
|
||||||
|
#include <QColor>
|
||||||
|
#include <QList>
|
||||||
|
#include <QMap>
|
||||||
|
#include <QSet>
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
#include <gp_XYZ.hxx>
|
||||||
|
|
||||||
|
class SMESH_Actor;
|
||||||
|
|
||||||
|
namespace SMESH
|
||||||
|
{
|
||||||
|
class SMESHGUI_EXPORT MeshInfo
|
||||||
|
{
|
||||||
|
QMap<int, long> myInfo;
|
||||||
|
public:
|
||||||
|
MeshInfo();
|
||||||
|
uint info( int ) const;
|
||||||
|
uint operator[] ( int );
|
||||||
|
uint count( int, int ) const;
|
||||||
|
private:
|
||||||
|
void addInfo( int, long );
|
||||||
|
friend class SelectionProxy;
|
||||||
|
};
|
||||||
|
|
||||||
|
class SMESHGUI_EXPORT MedInfo
|
||||||
|
{
|
||||||
|
QString myFileName;
|
||||||
|
uint mySize;
|
||||||
|
uint myMajor, myMinor, myRelease;
|
||||||
|
public:
|
||||||
|
MedInfo();
|
||||||
|
bool isValid() const;
|
||||||
|
QString fileName() const;
|
||||||
|
uint size() const;
|
||||||
|
QString version() const;
|
||||||
|
private:
|
||||||
|
void setFileName( const QString& );
|
||||||
|
void setSize( uint );
|
||||||
|
void setVersion( uint, uint, uint );
|
||||||
|
friend class SelectionProxy;
|
||||||
|
};
|
||||||
|
|
||||||
|
class SMESHGUI_EXPORT Position
|
||||||
|
{
|
||||||
|
int myShapeId;
|
||||||
|
int myShapeType;
|
||||||
|
double myU, myV;
|
||||||
|
bool myHasU, myHasV;
|
||||||
|
public:
|
||||||
|
Position();
|
||||||
|
bool isValid() const;
|
||||||
|
int shapeId() const;
|
||||||
|
int shapeType() const;
|
||||||
|
bool hasU() const;
|
||||||
|
double u() const;
|
||||||
|
bool hasV() const;
|
||||||
|
double v() const;
|
||||||
|
private:
|
||||||
|
void setShapeId( int );
|
||||||
|
void setShapeType( int );
|
||||||
|
void setU( double );
|
||||||
|
void setV( double );
|
||||||
|
friend class SelectionProxy;
|
||||||
|
};
|
||||||
|
|
||||||
|
class XYZ
|
||||||
|
{
|
||||||
|
double myX, myY, myZ;
|
||||||
|
public:
|
||||||
|
XYZ();
|
||||||
|
XYZ( double, double, double );
|
||||||
|
XYZ( const gp_XYZ& );
|
||||||
|
void add( double, double, double );
|
||||||
|
void divide( double );
|
||||||
|
double x() const;
|
||||||
|
double y() const;
|
||||||
|
double z() const;
|
||||||
|
operator gp_XYZ() const;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef QMap< int, QList<int> > Connectivity;
|
||||||
|
|
||||||
|
class SMESHGUI_EXPORT SelectionProxy
|
||||||
|
{
|
||||||
|
Handle(SALOME_InteractiveObject) myIO;
|
||||||
|
SMESH::SMESH_IDSource_var myObject;
|
||||||
|
SMESH_Actor* myActor;
|
||||||
|
bool myDirty;
|
||||||
|
|
||||||
|
public:
|
||||||
|
enum Type
|
||||||
|
{
|
||||||
|
Unknown,
|
||||||
|
Mesh,
|
||||||
|
Submesh,
|
||||||
|
Group,
|
||||||
|
GroupStd,
|
||||||
|
GroupGeom,
|
||||||
|
GroupFilter
|
||||||
|
};
|
||||||
|
|
||||||
|
// construction
|
||||||
|
SelectionProxy();
|
||||||
|
SelectionProxy( const Handle(SALOME_InteractiveObject)& );
|
||||||
|
SelectionProxy( SMESH::SMESH_IDSource_ptr );
|
||||||
|
SelectionProxy( const SelectionProxy& );
|
||||||
|
|
||||||
|
SelectionProxy& operator= ( const SelectionProxy& );
|
||||||
|
|
||||||
|
// comparison
|
||||||
|
bool operator== ( const SelectionProxy& );
|
||||||
|
|
||||||
|
// general purpose methods
|
||||||
|
void refresh();
|
||||||
|
|
||||||
|
bool isNull() const;
|
||||||
|
operator bool() const;
|
||||||
|
|
||||||
|
SMESH::SMESH_IDSource_ptr object() const;
|
||||||
|
const Handle(SALOME_InteractiveObject)& io() const;
|
||||||
|
SMESH_Actor* actor() const;
|
||||||
|
|
||||||
|
bool isValid() const;
|
||||||
|
void load();
|
||||||
|
|
||||||
|
// methods common to all types of proxy
|
||||||
|
QString name() const;
|
||||||
|
Type type() const;
|
||||||
|
MeshInfo meshInfo() const;
|
||||||
|
SelectionProxy mesh() const;
|
||||||
|
bool hasShapeToMesh() const;
|
||||||
|
GEOM::GEOM_Object_ptr shape() const;
|
||||||
|
QString shapeName() const;
|
||||||
|
int shapeType() const;
|
||||||
|
bool isMeshLoaded() const;
|
||||||
|
|
||||||
|
bool hasNode( int );
|
||||||
|
bool nodeCoordinates( int, XYZ& );
|
||||||
|
bool nodeConnectivity( int, Connectivity& );
|
||||||
|
bool nodePosition( int, Position& );
|
||||||
|
QList<SelectionProxy> nodeGroups( int ) const;
|
||||||
|
|
||||||
|
bool hasElement( int );
|
||||||
|
SMESH::ElementType elementType( int ) const;
|
||||||
|
int elementEntityType( int ) const;
|
||||||
|
bool elementConnectivity( int, Connectivity& );
|
||||||
|
bool perFaceConnectivity( int, Connectivity&, int& );
|
||||||
|
bool elementPosition( int, Position& );
|
||||||
|
bool elementGravityCenter( int, XYZ& );
|
||||||
|
bool elementNormal( int, XYZ& );
|
||||||
|
bool elementControl( int, int, double, double& ) const;
|
||||||
|
QList<SelectionProxy> elementGroups( int ) const;
|
||||||
|
|
||||||
|
// methods that work for mesh only
|
||||||
|
MedInfo medFileInfo() const;
|
||||||
|
QList<SelectionProxy> submeshes() const;
|
||||||
|
QList<SelectionProxy> groups() const;
|
||||||
|
|
||||||
|
// methods that work for group only
|
||||||
|
SMESH::ElementType groupElementType() const;
|
||||||
|
QColor color() const;
|
||||||
|
int size( bool = false ) const;
|
||||||
|
int nbNodes( bool = false ) const;
|
||||||
|
QSet<uint> ids() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void init();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // SMESHGUI_SELECTIONPROXY_H
|
@ -1940,7 +1940,7 @@ add the exported data to its contents?</translation>
|
|||||||
<translation>Height:</translation>
|
<translation>Height:</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SMESH_HEXAS</source>
|
<source>SMESH_HEXAHEDRON</source>
|
||||||
<translation>Hexahedron</translation>
|
<translation>Hexahedron</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -2790,7 +2790,7 @@ Check algorithm documentation for supported geometry</translation>
|
|||||||
<translation>Symmetry</translation>
|
<translation>Symmetry</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SMESH_TETRAS</source>
|
<source>SMESH_TETRAHEDRON</source>
|
||||||
<translation>Tetrahedron</translation>
|
<translation>Tetrahedron</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -4551,6 +4551,10 @@ It can't be deleted </translation>
|
|||||||
<source>SMESH_3D_ALGO_GROUP_ADVANCED</source>
|
<source>SMESH_3D_ALGO_GROUP_ADVANCED</source>
|
||||||
<translation>Advanced</translation>
|
<translation>Advanced</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>SMESH_HEX_PRISM</source>
|
||||||
|
<translation>Hexagonal Prism</translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SMESHGUI_FieldSelectorWdg</name>
|
<name>SMESHGUI_FieldSelectorWdg</name>
|
||||||
@ -5997,6 +6001,10 @@ Please enter correct value and try again</translation>
|
|||||||
<source>LENGTH2D</source>
|
<source>LENGTH2D</source>
|
||||||
<translation>Length 2D</translation>
|
<translation>Length 2D</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>LENGTH3D</source>
|
||||||
|
<translation>Length 3D</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>DEFLECTION2D</source>
|
<source>DEFLECTION2D</source>
|
||||||
<translation>Deflection 2D</translation>
|
<translation>Deflection 2D</translation>
|
||||||
@ -7442,7 +7450,7 @@ as they are of improper type:
|
|||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SMESHGUI_MeshInfo</name>
|
<name>SMESHGUI_BaseInfo</name>
|
||||||
<message>
|
<message>
|
||||||
<source>BASE_INFO</source>
|
<source>BASE_INFO</source>
|
||||||
<translation>Base information</translation>
|
<translation>Base information</translation>
|
||||||
@ -7571,6 +7579,18 @@ as they are of improper type:
|
|||||||
<source>OBJECT_GROUP_BALLS</source>
|
<source>OBJECT_GROUP_BALLS</source>
|
||||||
<translation>Group of balls</translation>
|
<translation>Group of balls</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_STANDALONE</source>
|
||||||
|
<translation>(standalone)</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_GEOM</source>
|
||||||
|
<translation>(on geometry)</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_FILTER</source>
|
||||||
|
<translation>(on filter)</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>BUT_LOAD_MESH</source>
|
<source>BUT_LOAD_MESH</source>
|
||||||
<translation>Load mesh from server</translation>
|
<translation>Load mesh from server</translation>
|
||||||
@ -7606,6 +7626,10 @@ as they are of improper type:
|
|||||||
<source>ELEM_MODE</source>
|
<source>ELEM_MODE</source>
|
||||||
<translation>Element</translation>
|
<translation>Element</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>GROUP_MODE</source>
|
||||||
|
<translation>Group</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SHOW_IDS</source>
|
<source>SHOW_IDS</source>
|
||||||
<translation>Show IDs</translation>
|
<translation>Show IDs</translation>
|
||||||
@ -7637,6 +7661,10 @@ as they are of improper type:
|
|||||||
<source>COORDINATES</source>
|
<source>COORDINATES</source>
|
||||||
<translation>Coordinates</translation>
|
<translation>Coordinates</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>NB_NODES</source>
|
||||||
|
<translation>Nb nodes</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>CONNECTIVITY</source>
|
<source>CONNECTIVITY</source>
|
||||||
<translation>Connectivity</translation>
|
<translation>Connectivity</translation>
|
||||||
@ -7935,6 +7963,18 @@ as they are of improper type:
|
|||||||
<source>FILE_NAME</source>
|
<source>FILE_NAME</source>
|
||||||
<translation>File name</translation>
|
<translation>File name</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>FILE_SIZE</source>
|
||||||
|
<translation>Size</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>FILE_VERSION</source>
|
||||||
|
<translation>Version</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>VERSION_UNKNOWN</source>
|
||||||
|
<translation>Unknown</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STANDALONE_MESH</source>
|
<source>STANDALONE_MESH</source>
|
||||||
<translation>Standalone</translation>
|
<translation>Standalone</translation>
|
||||||
|
@ -1919,7 +1919,7 @@ les données exportées ?</translation>
|
|||||||
<translation>Hauteur :</translation>
|
<translation>Hauteur :</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SMESH_HEXAS</source>
|
<source>SMESH_HEXAHEDRON</source>
|
||||||
<translation>Hexaèdre</translation>
|
<translation>Hexaèdre</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -2765,7 +2765,7 @@ Référez-vous à la documentation sur l'algorithme et la géométrie suppo
|
|||||||
<translation>Symétrie</translation>
|
<translation>Symétrie</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SMESH_TETRAS</source>
|
<source>SMESH_TETRAHEDRON</source>
|
||||||
<translation>Tétraèdre</translation>
|
<translation>Tétraèdre</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -4519,6 +4519,10 @@ Il ne peut pas être supprimé.</translation>
|
|||||||
<source>SMESH_3D_ALGO_GROUP_ADVANCED</source>
|
<source>SMESH_3D_ALGO_GROUP_ADVANCED</source>
|
||||||
<translation>Avancé</translation>
|
<translation>Avancé</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>SMESH_HEX_PRISM</source>
|
||||||
|
<translation>Prisme hexagonal</translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SMESHGUI_FieldSelectorWdg</name>
|
<name>SMESHGUI_FieldSelectorWdg</name>
|
||||||
@ -7377,7 +7381,7 @@ en raison de leurs types incompatibles:
|
|||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SMESHGUI_MeshInfo</name>
|
<name>SMESHGUI_BaseInfo</name>
|
||||||
<message>
|
<message>
|
||||||
<source>BASE_INFO</source>
|
<source>BASE_INFO</source>
|
||||||
<translation>Informations de base</translation>
|
<translation>Informations de base</translation>
|
||||||
@ -7506,6 +7510,18 @@ en raison de leurs types incompatibles:
|
|||||||
<source>OBJECT_GROUP_BALLS</source>
|
<source>OBJECT_GROUP_BALLS</source>
|
||||||
<translation>Groupe d'éléments particulaires</translation>
|
<translation>Groupe d'éléments particulaires</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_STANDALONE</source>
|
||||||
|
<translation>(autonome)</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_GEOM</source>
|
||||||
|
<translation>(lié à une géométrie)</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_FILTER</source>
|
||||||
|
<translation>(lié à un filtre)</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>BUT_LOAD_MESH</source>
|
<source>BUT_LOAD_MESH</source>
|
||||||
<translation>Charger un maillage depuis un serveur</translation>
|
<translation>Charger un maillage depuis un serveur</translation>
|
||||||
@ -7541,6 +7557,10 @@ en raison de leurs types incompatibles:
|
|||||||
<source>ELEM_MODE</source>
|
<source>ELEM_MODE</source>
|
||||||
<translation>Elément</translation>
|
<translation>Elément</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>GROUP_MODE</source>
|
||||||
|
<translation>Groupe</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SHOW_IDS</source>
|
<source>SHOW_IDS</source>
|
||||||
<translation>Montre les IDs</translation>
|
<translation>Montre les IDs</translation>
|
||||||
@ -7870,6 +7890,14 @@ en raison de leurs types incompatibles:
|
|||||||
<source>FILE_NAME</source>
|
<source>FILE_NAME</source>
|
||||||
<translation>Nom du fichier</translation>
|
<translation>Nom du fichier</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>FILE_SIZE</source>
|
||||||
|
<translation>Taille du fichier</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>FILE_VERSION</source>
|
||||||
|
<translation>Format du fichier</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STANDALONE_MESH</source>
|
<source>STANDALONE_MESH</source>
|
||||||
<translation>Autonome</translation>
|
<translation>Autonome</translation>
|
||||||
|
@ -1868,7 +1868,7 @@
|
|||||||
<translation>高さ:</translation>
|
<translation>高さ:</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SMESH_HEXAS</source>
|
<source>SMESH_HEXAHEDRON</source>
|
||||||
<translation>六面体</translation>
|
<translation>六面体</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -2704,7 +2704,7 @@
|
|||||||
<translation>オブジェクトの反転</translation>
|
<translation>オブジェクトの反転</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SMESH_TETRAS</source>
|
<source>SMESH_TETRAHEDRON</source>
|
||||||
<translation>四面体</translation>
|
<translation>四面体</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -4427,6 +4427,10 @@
|
|||||||
<source>SMESH_3D_ALGO_GROUP_ADVANCED</source>
|
<source>SMESH_3D_ALGO_GROUP_ADVANCED</source>
|
||||||
<translation>アドバンス</translation>
|
<translation>アドバンス</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>SMESH_HEX_PRISM</source>
|
||||||
|
<translation>六角形プリズム</translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SMESHGUI_FieldSelectorWdg</name>
|
<name>SMESHGUI_FieldSelectorWdg</name>
|
||||||
@ -7202,7 +7206,7 @@
|
|||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SMESHGUI_MeshInfo</name>
|
<name>SMESHGUI_BaseInfo</name>
|
||||||
<message>
|
<message>
|
||||||
<source>BASE_INFO</source>
|
<source>BASE_INFO</source>
|
||||||
<translation>基本情報</translation>
|
<translation>基本情報</translation>
|
||||||
@ -7331,6 +7335,18 @@
|
|||||||
<source>OBJECT_GROUP_BALLS</source>
|
<source>OBJECT_GROUP_BALLS</source>
|
||||||
<translation>粒子状物質の要素のグループ</translation>
|
<translation>粒子状物質の要素のグループ</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_STANDALONE</source>
|
||||||
|
<translation type="unfinished">(standalone)</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_GEOM</source>
|
||||||
|
<translation type="unfinished">(on geometry)</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>OBJECT_GROUP_FILTER</source>
|
||||||
|
<translation type="unfinished">(on filter)</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>BUT_LOAD_MESH</source>
|
<source>BUT_LOAD_MESH</source>
|
||||||
<translation>サーバーからメッシュをロード</translation>
|
<translation>サーバーからメッシュをロード</translation>
|
||||||
@ -7366,6 +7382,10 @@
|
|||||||
<source>ELEM_MODE</source>
|
<source>ELEM_MODE</source>
|
||||||
<translation>要素</translation>
|
<translation>要素</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>GROUP_MODE</source>
|
||||||
|
<translation type="unfinished">Group</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SHOW_IDS</source>
|
<source>SHOW_IDS</source>
|
||||||
<translation>IDの表示</translation>
|
<translation>IDの表示</translation>
|
||||||
@ -7695,6 +7715,14 @@
|
|||||||
<source>FILE_NAME</source>
|
<source>FILE_NAME</source>
|
||||||
<translation>ファイルの名前</translation>
|
<translation>ファイルの名前</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>FILE_SIZE</source>
|
||||||
|
<translation type="unfinished">Size</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>FILE_VERSION</source>
|
||||||
|
<translation type="unfinished">Version</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STANDALONE_MESH</source>
|
<source>STANDALONE_MESH</source>
|
||||||
<translation>自律</translation>
|
<translation>自律</translation>
|
||||||
|
@ -217,6 +217,11 @@ CORBA::Double NumericalFunctor_i::GetValue( CORBA::Long theId )
|
|||||||
return myNumericalFunctorPtr->GetValue( theId );
|
return myNumericalFunctorPtr->GetValue( theId );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CORBA::Boolean NumericalFunctor_i::IsApplicable( CORBA::Long theElementId )
|
||||||
|
{
|
||||||
|
return myNumericalFunctorPtr->IsApplicable( theElementId );
|
||||||
|
}
|
||||||
|
|
||||||
SMESH::Histogram* NumericalFunctor_i::GetHistogram(CORBA::Short nbIntervals, CORBA::Boolean isLogarithmic)
|
SMESH::Histogram* NumericalFunctor_i::GetHistogram(CORBA::Short nbIntervals, CORBA::Boolean isLogarithmic)
|
||||||
{
|
{
|
||||||
std::vector<int> nbEvents;
|
std::vector<int> nbEvents;
|
||||||
@ -521,6 +526,46 @@ SMESH::Length2D::Values* Length2D_i::GetValues()
|
|||||||
return aResult._retn();
|
return aResult._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
Class : Length3D_i
|
||||||
|
Description : Functor for calculating length of edge
|
||||||
|
*/
|
||||||
|
Length3D_i::Length3D_i()
|
||||||
|
{
|
||||||
|
myNumericalFunctorPtr.reset( new Controls::Length3D() );
|
||||||
|
myFunctorPtr = myNumericalFunctorPtr;
|
||||||
|
}
|
||||||
|
|
||||||
|
FunctorType Length3D_i::GetFunctorType()
|
||||||
|
{
|
||||||
|
return SMESH::FT_Length3D;
|
||||||
|
}
|
||||||
|
|
||||||
|
// SMESH::Length3D::Values* Length3D_i::GetValues()
|
||||||
|
// {
|
||||||
|
// SMESH::Controls::Length3D::TValues aValues;
|
||||||
|
// (dynamic_cast<SMESH::Controls::Length3D*>(myFunctorPtr.get()))->GetValues( aValues );
|
||||||
|
|
||||||
|
// long i = 0, iEnd = aValues.size();
|
||||||
|
|
||||||
|
// SMESH::Length3D::Values_var aResult = new SMESH::Length3D::Values(iEnd);
|
||||||
|
// aResult->length(iEnd);
|
||||||
|
|
||||||
|
// SMESH::Controls::Length3D::TValues::const_iterator anIter;
|
||||||
|
// for ( anIter = aValues.begin() ; anIter != aValues.end(); anIter++, i++ )
|
||||||
|
// {
|
||||||
|
// const SMESH::Controls::Length3D::Value& aVal = *anIter;
|
||||||
|
// SMESH::Length3D::Value &aValue = aResult[ i ];
|
||||||
|
|
||||||
|
// aValue.myLength = aVal.myLength;
|
||||||
|
// aValue.myPnt1 = aVal.myPntId[ 0 ];
|
||||||
|
// aValue.myPnt2 = aVal.myPntId[ 1 ];
|
||||||
|
// }
|
||||||
|
|
||||||
|
// return aResult._retn();
|
||||||
|
// }
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Class : Deflection2D_i
|
Class : Deflection2D_i
|
||||||
Description : Functor for calculating distance between a face and geometry
|
Description : Functor for calculating distance between a face and geometry
|
||||||
@ -2107,11 +2152,19 @@ Length2D_ptr FilterManager_i::CreateLength2D()
|
|||||||
return anObj._retn();
|
return anObj._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Length3D_ptr FilterManager_i::CreateLength3D()
|
||||||
|
{
|
||||||
|
SMESH::Length3D_i* aServant = new SMESH::Length3D_i();
|
||||||
|
SMESH::Length3D_var anObj = aServant->_this();
|
||||||
|
TPythonDump()<<aServant<<" = "<<this<<".CreateLength3D()";
|
||||||
|
return anObj._retn();
|
||||||
|
}
|
||||||
|
|
||||||
Deflection2D_ptr FilterManager_i::CreateDeflection2D()
|
Deflection2D_ptr FilterManager_i::CreateDeflection2D()
|
||||||
{
|
{
|
||||||
SMESH::Deflection2D_i* aServant = new SMESH::Deflection2D_i();
|
SMESH::Deflection2D_i* aServant = new SMESH::Deflection2D_i();
|
||||||
SMESH::Deflection2D_var anObj = aServant->_this();
|
SMESH::Deflection2D_var anObj = aServant->_this();
|
||||||
TPythonDump()<<aServant<<" = "<<this<<".CreateLength2D()";
|
TPythonDump()<<aServant<<" = "<<this<<".CreateDeflection2D()";
|
||||||
return anObj._retn();
|
return anObj._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2988,6 +3041,9 @@ CORBA::Boolean Filter_i::SetCriteria( const SMESH::Filter::Criteria& theCriteria
|
|||||||
case SMESH::FT_Length2D:
|
case SMESH::FT_Length2D:
|
||||||
aFunctor = aFilterMgr->CreateLength2D();
|
aFunctor = aFilterMgr->CreateLength2D();
|
||||||
break;
|
break;
|
||||||
|
case SMESH::FT_Length3D:
|
||||||
|
aFunctor = aFilterMgr->CreateLength3D();
|
||||||
|
break;
|
||||||
case SMESH::FT_Deflection2D:
|
case SMESH::FT_Deflection2D:
|
||||||
aFunctor = aFilterMgr->CreateDeflection2D();
|
aFunctor = aFilterMgr->CreateDeflection2D();
|
||||||
break;
|
break;
|
||||||
@ -3489,6 +3545,7 @@ static inline LDOMString toString( CORBA::Long theType )
|
|||||||
case FT_MultiConnection2D : return "Borders at multi-connections 2D";
|
case FT_MultiConnection2D : return "Borders at multi-connections 2D";
|
||||||
case FT_Length : return "Length";
|
case FT_Length : return "Length";
|
||||||
case FT_Length2D : return "Length 2D";
|
case FT_Length2D : return "Length 2D";
|
||||||
|
case FT_Length3D : return "Length 3D";
|
||||||
case FT_Deflection2D : return "Deflection 2D";
|
case FT_Deflection2D : return "Deflection 2D";
|
||||||
case FT_LessThan : return "Less than";
|
case FT_LessThan : return "Less than";
|
||||||
case FT_MoreThan : return "More than";
|
case FT_MoreThan : return "More than";
|
||||||
@ -3538,6 +3595,7 @@ static inline SMESH::FunctorType toFunctorType( const LDOMString& theStr )
|
|||||||
// else if ( theStr.equals( "Borders at multi-connections 2D" ) ) return FT_MultiConnection2D;
|
// else if ( theStr.equals( "Borders at multi-connections 2D" ) ) return FT_MultiConnection2D;
|
||||||
else if ( theStr.equals( "Length" ) ) return FT_Length;
|
else if ( theStr.equals( "Length" ) ) return FT_Length;
|
||||||
// else if ( theStr.equals( "Length2D" ) ) return FT_Length2D;
|
// else if ( theStr.equals( "Length2D" ) ) return FT_Length2D;
|
||||||
|
// else if ( theStr.equals( "Length3D" ) ) return FT_Length3D;
|
||||||
else if ( theStr.equals( "Deflection" ) ) return FT_Deflection2D;
|
else if ( theStr.equals( "Deflection" ) ) return FT_Deflection2D;
|
||||||
else if ( theStr.equals( "Range of IDs" ) ) return FT_RangeOfIds;
|
else if ( theStr.equals( "Range of IDs" ) ) return FT_RangeOfIds;
|
||||||
else if ( theStr.equals( "Bad Oriented Volume" ) ) return FT_BadOrientedVolume;
|
else if ( theStr.equals( "Bad Oriented Volume" ) ) return FT_BadOrientedVolume;
|
||||||
@ -4104,6 +4162,7 @@ static const char** getFunctNames()
|
|||||||
"FT_MultiConnection2D",
|
"FT_MultiConnection2D",
|
||||||
"FT_Length",
|
"FT_Length",
|
||||||
"FT_Length2D",
|
"FT_Length2D",
|
||||||
|
"FT_Length3D",
|
||||||
"FT_Deflection2D",
|
"FT_Deflection2D",
|
||||||
"FT_NodeConnectivityNumber",
|
"FT_NodeConnectivityNumber",
|
||||||
"FT_BelongToMeshGroup",
|
"FT_BelongToMeshGroup",
|
||||||
|
@ -99,6 +99,7 @@ namespace SMESH
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CORBA::Double GetValue( CORBA::Long theElementId );
|
CORBA::Double GetValue( CORBA::Long theElementId );
|
||||||
|
CORBA::Boolean IsApplicable( CORBA::Long theElementId );
|
||||||
SMESH::Histogram* GetHistogram(CORBA::Short nbIntervals,
|
SMESH::Histogram* GetHistogram(CORBA::Short nbIntervals,
|
||||||
CORBA::Boolean isLogarithmic);
|
CORBA::Boolean isLogarithmic);
|
||||||
SMESH::Histogram* GetLocalHistogram(CORBA::Short nbIntervals,
|
SMESH::Histogram* GetLocalHistogram(CORBA::Short nbIntervals,
|
||||||
@ -271,6 +272,22 @@ namespace SMESH
|
|||||||
Controls::Length2DPtr myLength2DPtr;
|
Controls::Length2DPtr myLength2DPtr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
Class : Length3D_i
|
||||||
|
Description : Functor for calculating length of edge
|
||||||
|
*/
|
||||||
|
class SMESH_I_EXPORT Length3D_i: public virtual POA_SMESH::Length3D,
|
||||||
|
public virtual NumericalFunctor_i
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Length3D_i();
|
||||||
|
//SMESH::Length2D::Values* GetValues();
|
||||||
|
FunctorType GetFunctorType();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
Controls::Length3DPtr myLength3DPtr;
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Class : Deflection2D_i
|
Class : Deflection2D_i
|
||||||
Description : Functor for calculating distance between a face and geometry
|
Description : Functor for calculating distance between a face and geometry
|
||||||
@ -1103,6 +1120,7 @@ namespace SMESH
|
|||||||
MaxElementLength3D_ptr CreateMaxElementLength3D();
|
MaxElementLength3D_ptr CreateMaxElementLength3D();
|
||||||
Length_ptr CreateLength();
|
Length_ptr CreateLength();
|
||||||
Length2D_ptr CreateLength2D();
|
Length2D_ptr CreateLength2D();
|
||||||
|
Length3D_ptr CreateLength3D();
|
||||||
Deflection2D_ptr CreateDeflection2D();
|
Deflection2D_ptr CreateDeflection2D();
|
||||||
NodeConnectivityNumber_ptr CreateNodeConnectivityNumber();
|
NodeConnectivityNumber_ptr CreateNodeConnectivityNumber();
|
||||||
MultiConnection_ptr CreateMultiConnection();
|
MultiConnection_ptr CreateMultiConnection();
|
||||||
|
@ -4720,8 +4720,9 @@ SMESH::long_array* SMESH_Mesh_i::GetElemNodes(const CORBA::Long id)
|
|||||||
if ( const SMDS_MeshElement* elem = aMeshDS->FindElement(id) )
|
if ( const SMDS_MeshElement* elem = aMeshDS->FindElement(id) )
|
||||||
{
|
{
|
||||||
aResult->length( elem->NbNodes() );
|
aResult->length( elem->NbNodes() );
|
||||||
for ( int i = 0; i < elem->NbNodes(); ++i )
|
for ( CORBA::ULong i = 0; i < aResult->length(); ++i )
|
||||||
aResult[ i ] = elem->GetNode( i )->GetID();
|
if ( const SMDS_MeshNode* n = elem->GetNode( i ))
|
||||||
|
aResult[ i ] = n->GetID();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return aResult._retn();
|
return aResult._retn();
|
||||||
@ -4837,7 +4838,7 @@ SMESH::long_array* SMESH_Mesh_i::GetElemFaceNodes(CORBA::Long elemId,
|
|||||||
{
|
{
|
||||||
if ( const SMDS_MeshElement* elem = aMeshDS->FindElement(elemId) )
|
if ( const SMDS_MeshElement* elem = aMeshDS->FindElement(elemId) )
|
||||||
{
|
{
|
||||||
SMDS_VolumeTool vtool( elem );
|
SMDS_VolumeTool vtool( elem, /*skipCentralNodes = */false );
|
||||||
if ( faceIndex < vtool.NbFaces() )
|
if ( faceIndex < vtool.NbFaces() )
|
||||||
{
|
{
|
||||||
aResult->length( vtool.NbFaceNodes( faceIndex ));
|
aResult->length( vtool.NbFaceNodes( faceIndex ));
|
||||||
|
@ -426,6 +426,7 @@ namespace SMESH
|
|||||||
case FT_MultiConnection2D: myStream<< "aMultiConnection2D"; break;
|
case FT_MultiConnection2D: myStream<< "aMultiConnection2D"; break;
|
||||||
case FT_Length: myStream<< "aLength"; break;
|
case FT_Length: myStream<< "aLength"; break;
|
||||||
case FT_Length2D: myStream<< "aLength2D"; break;
|
case FT_Length2D: myStream<< "aLength2D"; break;
|
||||||
|
case FT_Length3D: myStream<< "aLength3D"; break;
|
||||||
case FT_Deflection2D: myStream<< "aDeflection2D"; break;
|
case FT_Deflection2D: myStream<< "aDeflection2D"; break;
|
||||||
case FT_NodeConnectivityNumber:myStream<< "aNodeConnectivityNumber";break;
|
case FT_NodeConnectivityNumber:myStream<< "aNodeConnectivityNumber";break;
|
||||||
case FT_BelongToMeshGroup: myStream<< "aBelongToMeshGroup"; break;
|
case FT_BelongToMeshGroup: myStream<< "aBelongToMeshGroup"; break;
|
||||||
|
Loading…
Reference in New Issue
Block a user