Fix on - Bug PAL7220: DEVELOPMENT : 3D Aspect Ratio

This commit is contained in:
apo 2004-12-23 10:31:25 +00:00
parent ca135511fb
commit 07085534b5
16 changed files with 852 additions and 1103 deletions

View File

@ -1,379 +1,382 @@
// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
// //
// This library is free software; you can redistribute it and/or // This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public // modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either // License as published by the Free Software Foundation; either
// version 2.1 of the License. // version 2.1 of the License.
// //
// This library is distributed in the hope that it will be useful, // This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of // but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details. // Lesser General Public License for more details.
// //
// You should have received a copy of the GNU Lesser General Public // You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software // License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
// //
// See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org // See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
// //
// //
// //
// File : SMESH_Filter.idl // File : SMESH_Filter.idl
// Author : Alexey Petrov, OCC // Author : Alexey Petrov, OCC
#ifndef _SMESH_FILTER_IDL_ #ifndef _SMESH_FILTER_IDL_
#define _SMESH_FILTER_IDL_ #define _SMESH_FILTER_IDL_
#include "SALOME_Exception.idl" #include "SALOME_Exception.idl"
#include "SALOME_GenericObj.idl" #include "SALOME_GenericObj.idl"
#include "SMESH_Mesh.idl" #include "SMESH_Mesh.idl"
module GEOM module GEOM
{ {
interface GEOM_Object; interface GEOM_Object;
}; };
module SMESH module SMESH
{ {
/*! /*!
* Enumeration of functor types * Enumeration of functor types
*/ */
enum FunctorType enum FunctorType
{ {
FT_AspectRatio, FT_AspectRatio,
FT_Warping, FT_AspectRatio3D,
FT_MinimumAngle, FT_Warping,
FT_Taper, FT_MinimumAngle,
FT_Skew, FT_Taper,
FT_Area, FT_Skew,
FT_FreeBorders, FT_Area,
FT_FreeEdges, FT_FreeBorders,
FT_MultiConnection, FT_FreeEdges,
FT_Length, FT_MultiConnection,
FT_BelongToGeom, FT_Length,
FT_BelongToPlane, FT_BelongToGeom,
FT_BelongToCylinder, FT_BelongToPlane,
FT_RangeOfIds, FT_BelongToCylinder,
FT_LessThan, FT_RangeOfIds,
FT_MoreThan, FT_LessThan,
FT_EqualTo, FT_MoreThan,
FT_LogicalNOT, FT_EqualTo,
FT_LogicalAND, FT_LogicalNOT,
FT_LogicalOR, FT_LogicalAND,
FT_Undefined FT_LogicalOR,
}; FT_Undefined
};
/*!
* Base interface for all functors ( i.e. numerical functors and predicates ) /*!
*/ * Base interface for all functors ( i.e. numerical functors and predicates )
interface Functor: SALOME::GenericObj */
{ interface Functor: SALOME::GenericObj
void SetMesh( in SMESH_Mesh theMesh ); {
FunctorType GetFunctorType(); void SetMesh( in SMESH_Mesh theMesh );
ElementType GetElementType(); FunctorType GetFunctorType();
}; ElementType GetElementType();
};
/*!
* Numerical functors are intended for calculating value by Id of mesh entity /*!
*/ * Numerical functors are intended for calculating value by Id of mesh entity
interface NumericalFunctor: Functor */
{ interface NumericalFunctor: Functor
double GetValue( in long theElementId ); {
double GetValue( in long theElementId );
/*!
* Set precision for calculation. It is a position after point which is /*!
* used to functor value after calculation. * Set precision for calculation. It is a position after point which is
*/ * used to functor value after calculation.
void SetPrecision( in long thePrecision ); */
long GetPrecision(); void SetPrecision( in long thePrecision );
}; long GetPrecision();
interface MinimumAngle : NumericalFunctor{}; };
interface AspectRatio : NumericalFunctor{}; interface MinimumAngle : NumericalFunctor{};
interface Warping : NumericalFunctor{}; interface AspectRatio : NumericalFunctor{};
interface Taper : NumericalFunctor{}; interface AspectRatio3D : NumericalFunctor{};
interface Skew : NumericalFunctor{}; interface Warping : NumericalFunctor{};
interface Area : NumericalFunctor{}; interface Taper : NumericalFunctor{};
interface Length : NumericalFunctor{}; interface Skew : NumericalFunctor{};
interface MultiConnection : NumericalFunctor{}; interface Area : NumericalFunctor{};
interface Length : NumericalFunctor{};
/*! interface MultiConnection : NumericalFunctor{};
* Predicates are intended for verification of criteria,
* must return bool value by mesh id /*!
*/ * Predicates are intended for verification of criteria,
interface Predicate: Functor * must return bool value by mesh id
{ */
boolean IsSatisfy( in long thEntityId ); interface Predicate: Functor
}; {
boolean IsSatisfy( in long thEntityId );
/*! };
* Logical functor (predicate) "Belong To Geometry".
* Verify whether mesh element or node belong to pointed Geom Object /*!
*/ * Logical functor (predicate) "Belong To Geometry".
interface BelongToGeom: Predicate * Verify whether mesh element or node belong to pointed Geom Object
{ */
void SetGeom( in GEOM::GEOM_Object theGeom ); interface BelongToGeom: Predicate
void SetElementType( in ElementType theType ); {
void SetGeom( in GEOM::GEOM_Object theGeom );
void SetShapeName( in string theName ); void SetElementType( in ElementType theType );
string GetShapeName();
}; void SetShapeName( in string theName );
string GetShapeName();
/*! };
* Logical functor (predicate) "Belong To Surface".
* Base interface for "belong to plane" and "belong to cylinder interfaces" /*!
*/ * Logical functor (predicate) "Belong To Surface".
interface BelongToSurface: Predicate * Base interface for "belong to plane" and "belong to cylinder interfaces"
{ */
void SetTolerance( in double theToler ); interface BelongToSurface: Predicate
double GetTolerance(); {
void SetShapeName( in string theName, in ElementType theType ); void SetTolerance( in double theToler );
string GetShapeName(); double GetTolerance();
}; void SetShapeName( in string theName, in ElementType theType );
string GetShapeName();
};
/*!
* Logical functor (predicate) "Belong To Plane".
* Verify whether mesh element lie in pointed Geom planar object /*!
*/ * Logical functor (predicate) "Belong To Plane".
interface BelongToPlane: BelongToSurface * Verify whether mesh element lie in pointed Geom planar object
{ */
void SetPlane( in GEOM::GEOM_Object theGeom, in ElementType theType ); interface BelongToPlane: BelongToSurface
}; {
void SetPlane( in GEOM::GEOM_Object theGeom, in ElementType theType );
/*! };
* Logical functor (predicate) "Belong To Culinder".
* Verify whether mesh element lie in pointed Geom cylindrical object /*!
*/ * Logical functor (predicate) "Belong To Culinder".
interface BelongToCylinder: BelongToSurface * Verify whether mesh element lie in pointed Geom cylindrical object
{ */
void SetCylinder( in GEOM::GEOM_Object theGeom, in ElementType theType ); interface BelongToCylinder: BelongToSurface
}; {
void SetCylinder( in GEOM::GEOM_Object theGeom, in ElementType theType );
/*! };
* Logical functor (predicate) "Free borders".
* Verify whether 1D mesh element is free ( i.e. connected to one face only ) /*!
*/ * Logical functor (predicate) "Free borders".
interface FreeBorders: Predicate{}; * Verify whether 1D mesh element is free ( i.e. connected to one face only )
*/
/*! interface FreeBorders: Predicate{};
* Logical functor (predicate) "Free edges".
* Verify whether 2D mesh element has free edges( i.e. edges connected to one face only ) /*!
*/ * Logical functor (predicate) "Free edges".
interface FreeEdges: Predicate * Verify whether 2D mesh element has free edges( i.e. edges connected to one face only )
*/
{ interface FreeEdges: Predicate
struct Border
{ {
long myElemId; struct Border
long myPnt1, myPnt2; {
}; long myElemId;
typedef sequence<Border> Borders; long myPnt1, myPnt2;
Borders GetBorders(); };
}; typedef sequence<Border> Borders;
Borders GetBorders();
};
/*!
* Abstract logical functor (predicate) "RangeOfIds".
* Verify whether an Entity Id belongs to defined sequence of id's /*!
*/ * Abstract logical functor (predicate) "RangeOfIds".
interface RangeOfIds: Predicate * Verify whether an Entity Id belongs to defined sequence of id's
{ */
void SetRange( in long_array theIds ); interface RangeOfIds: Predicate
boolean SetRangeStr( in string theRange ); {
string GetRangeStr(); void SetRange( in long_array theIds );
boolean SetRangeStr( in string theRange );
void SetElementType( in ElementType theType ); string GetRangeStr();
};
void SetElementType( in ElementType theType );
/*! };
* Comparator. Predicate for compare value calculated
* by numerical functor with threshold value /*!
*/ * Comparator. Predicate for compare value calculated
interface Comparator: Predicate * by numerical functor with threshold value
{ */
void SetMargin( in double theValue ); interface Comparator: Predicate
void SetNumFunctor( in NumericalFunctor theFunct ); {
double GetMargin(); void SetMargin( in double theValue );
}; void SetNumFunctor( in NumericalFunctor theFunct );
interface LessThan: Comparator{}; double GetMargin();
interface MoreThan: Comparator{}; };
interface EqualTo : Comparator interface LessThan: Comparator{};
{ interface MoreThan: Comparator{};
void SetTolerance( in double theToler ); interface EqualTo : Comparator
double GetTolerance(); {
}; void SetTolerance( in double theToler );
double GetTolerance();
/*! };
* Logical predicates are intended for compose predicates using boolean operations
*/ /*!
interface Logical: Predicate{}; * Logical predicates are intended for compose predicates using boolean operations
*/
interface LogicalNOT: Logical interface Logical: Predicate{};
{
void SetPredicate(in Predicate thePredicate); interface LogicalNOT: Logical
}; {
void SetPredicate(in Predicate thePredicate);
interface LogicalBinary: Logical };
{
void SetPredicate1( in Predicate thePredicate ); interface LogicalBinary: Logical
void SetPredicate2( in Predicate thePredicate ); {
}; void SetPredicate1( in Predicate thePredicate );
void SetPredicate2( in Predicate thePredicate );
interface LogicalAND: LogicalBinary{}; };
interface LogicalOR : LogicalBinary{};
interface LogicalAND: LogicalBinary{};
/*! interface LogicalOR : LogicalBinary{};
* Filter
*/ /*!
interface Filter: SALOME::GenericObj * Filter
{ */
/*! interface Filter: SALOME::GenericObj
* Structure containing information about one criterion {
* Type - FT_Taper, FT_Skew ... /*!
* Compare - FT_LessThan, FT_MoreThan, FT_EqualTo * Structure containing information about one criterion
* Threshold - threshold value * Type - FT_Taper, FT_Skew ...
* UnaryOp - unary logical operation: FT_LogicalNOT or FT_Undefined * Compare - FT_LessThan, FT_MoreThan, FT_EqualTo
* BinaryOp - binary logical operation FT_LogicalAND, FT_LogicalOR or * Threshold - threshold value
* (FT_Undefined must be for the last criterion) * UnaryOp - unary logical operation: FT_LogicalNOT or FT_Undefined
* ThresholdStr - Threshold value defined as string. Used for: * BinaryOp - binary logical operation FT_LogicalAND, FT_LogicalOR or
* 1. Diaposon of identifiers. Example: "1,2,3,5-10,12,27-29" * (FT_Undefined must be for the last criterion)
* 2. BelongToGeom predicate for storing name of shape * ThresholdStr - Threshold value defined as string. Used for:
* Tolerance - Tolerance is used for comparators (EqualTo comparision) and for * 1. Diaposon of identifiers. Example: "1,2,3,5-10,12,27-29"
* "Belong to plane" and "Belong to cylinder" predicates * 2. BelongToGeom predicate for storing name of shape
* TypeOfElement - type of element SMESH::NODE, SMESH::FACE (used by BelongToGeom predicate only) * Tolerance - Tolerance is used for comparators (EqualTo comparision) and for
* Precision - Precision of numerical functors * "Belong to plane" and "Belong to cylinder" predicates
*/ * TypeOfElement - type of element SMESH::NODE, SMESH::FACE (used by BelongToGeom predicate only)
struct Criterion * Precision - Precision of numerical functors
{ */
long Type; struct Criterion
long Compare; {
double Threshold; long Type;
string ThresholdStr; long Compare;
long UnaryOp; double Threshold;
long BinaryOp; string ThresholdStr;
double Tolerance; long UnaryOp;
ElementType TypeOfElement; long BinaryOp;
long Precision; double Tolerance;
}; ElementType TypeOfElement;
long Precision;
typedef sequence<Criterion> Criteria; };
void SetPredicate( in Predicate thePredicate ); typedef sequence<Criterion> Criteria;
long_array GetElementsId( in SMESH_Mesh theMesh );
ElementType GetElementType(); void SetPredicate( in Predicate thePredicate );
Predicate GetPredicate(); long_array GetElementsId( in SMESH_Mesh theMesh );
ElementType GetElementType();
boolean GetCriteria( out Criteria theCriteria ); Predicate GetPredicate();
boolean SetCriteria( in Criteria theCriteria );
}; boolean GetCriteria( out Criteria theCriteria );
boolean SetCriteria( in Criteria theCriteria );
};
/*!
* Interface for working with library of filters
*/ /*!
interface FilterLibrary : SALOME::GenericObj * Interface for working with library of filters
{ */
/*! interface FilterLibrary : SALOME::GenericObj
* Copy filter from library by name (new filter is created) {
*/ /*!
Filter Copy( in string theFilterName ); * Copy filter from library by name (new filter is created)
*/
/*! Filter Copy( in string theFilterName );
* Methods for editing library
*/ /*!
boolean Add ( in string theFilterName, in Filter theFilter ); * Methods for editing library
boolean AddEmpty( in string theFilterName, in ElementType theType ); // add empty filter */
boolean Delete ( in string theFilterName ); boolean Add ( in string theFilterName, in Filter theFilter );
boolean Replace ( in string theFilterName, in string theNewName, in Filter theFilter ); boolean AddEmpty( in string theFilterName, in ElementType theType ); // add empty filter
boolean Delete ( in string theFilterName );
/*! boolean Replace ( in string theFilterName, in string theNewName, in Filter theFilter );
* Save library on disk
*/ /*!
boolean Save(); * Save library on disk
boolean SaveAs( in string aFileName ); */
boolean Save();
/*! boolean SaveAs( in string aFileName );
* Query methods
*/ /*!
boolean IsPresent( in string aFilterName ); * Query methods
long NbFilters( in ElementType aType ); */
string_array GetNames( in ElementType aType ); boolean IsPresent( in string aFilterName );
string_array GetAllNames(); long NbFilters( in ElementType aType );
void SetFileName( in string aFilterName ); string_array GetNames( in ElementType aType );
string GetFileName(); string_array GetAllNames();
}; void SetFileName( in string aFilterName );
string GetFileName();
};
/*!
* Interface of Filter manager
*/ /*!
interface FilterManager: SALOME::GenericObj * Interface of Filter manager
{ */
/*! interface FilterManager: SALOME::GenericObj
* Create numerical functors {
*/ /*!
MinimumAngle CreateMinimumAngle(); * Create numerical functors
AspectRatio CreateAspectRatio(); */
Warping CreateWarping(); MinimumAngle CreateMinimumAngle();
Taper CreateTaper(); AspectRatio CreateAspectRatio();
Skew CreateSkew(); AspectRatio3D CreateAspectRatio3D();
Area CreateArea(); Warping CreateWarping();
Length CreateLength(); Taper CreateTaper();
MultiConnection CreateMultiConnection(); Skew CreateSkew();
Area CreateArea();
/*! Length CreateLength();
* Create logical functors ( predicates ) MultiConnection CreateMultiConnection();
*/
BelongToGeom CreateBelongToGeom(); /*!
BelongToPlane CreateBelongToPlane(); * Create logical functors ( predicates )
BelongToCylinder CreateBelongToCylinder(); */
BelongToGeom CreateBelongToGeom();
FreeBorders CreateFreeBorders(); BelongToPlane CreateBelongToPlane();
FreeEdges CreateFreeEdges(); BelongToCylinder CreateBelongToCylinder();
RangeOfIds CreateRangeOfIds(); FreeBorders CreateFreeBorders();
FreeEdges CreateFreeEdges();
/*!
* Create comparators ( predicates ) RangeOfIds CreateRangeOfIds();
*/
LessThan CreateLessThan(); /*!
MoreThan CreateMoreThan(); * Create comparators ( predicates )
EqualTo CreateEqualTo(); */
LessThan CreateLessThan();
/*! MoreThan CreateMoreThan();
* Create boolean operations ( predicates ) EqualTo CreateEqualTo();
*/
LogicalNOT CreateLogicalNOT(); /*!
LogicalAND CreateLogicalAND(); * Create boolean operations ( predicates )
LogicalOR CreateLogicalOR(); */
LogicalNOT CreateLogicalNOT();
/*! LogicalAND CreateLogicalAND();
* Create filter LogicalOR CreateLogicalOR();
*/
Filter CreateFilter(); /*!
* Create filter
/*! */
* Load filter library. If libary does not exist it is created Filter CreateFilter();
*/
FilterLibrary LoadLibrary( in string aFileName ); /*!
* Load filter library. If libary does not exist it is created
/*! */
* Create new library FilterLibrary LoadLibrary( in string aFileName );
*/
FilterLibrary CreateLibrary(); /*!
* Create new library
/*! */
* Delete library FilterLibrary CreateLibrary();
*/
boolean DeleteLibrary( in string aFileName ); /*!
}; * Delete library
}; */
boolean DeleteLibrary( in string aFileName );
};
#endif };
#endif

View File

@ -80,6 +80,7 @@
<popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6017" pos-id="" label-id="Aspect Ratio 3D" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
@ -235,6 +236,8 @@
<popup-item item-id="1134" pos-id="" label-id="Clipping" icon-id="" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="1134" pos-id="" label-id="Clipping" icon-id="" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<separator pos-id=""/> <separator pos-id=""/>
<submenu label-id="Control" item-id="2000" pos-id=""> <submenu label-id="Control" item-id="2000" pos-id="">
<popup-item item-id="200" pos-id="" label-id="Reset" icon-id="" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<separator pos-id=""/>
<popup-item item-id="6001" pos-id="" label-id="Length" icon-id="mesh_length.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6001" pos-id="" label-id="Length" icon-id="mesh_length.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6002" pos-id="" label-id="Free Edges" icon-id="mesh_free_edges.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6002" pos-id="" label-id="Free Edges" icon-id="mesh_free_edges.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6003" pos-id="" label-id="Free borders" icon-id="mesh_free_edges.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6003" pos-id="" label-id="Free borders" icon-id="mesh_free_edges.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
@ -242,12 +245,11 @@
<popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6017" pos-id="" label-id="Aspect Ratio 3D" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<separator pos-id=""/> <separator pos-id=""/>
<popup-item item-id="200" pos-id="" label-id="Reset" icon-id="" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<separator pos-id=""/>
<popup-item item-id="201" pos-id="" label-id="Scalar Bar Properties" icon-id="" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="201" pos-id="" label-id="Scalar Bar Properties" icon-id="" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
</submenu> </submenu>
<endsubmenu /> <endsubmenu />
@ -284,6 +286,7 @@
<popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6017" pos-id="" label-id="Aspect Ratio 3D" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
@ -328,6 +331,7 @@
<popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6011" pos-id="" label-id="Area" icon-id="mesh_area.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6012" pos-id="" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6013" pos-id="" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6017" pos-id="" label-id="Aspect Ratio 3D" icon-id="mesh_aspect.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6014" pos-id="" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6015" pos-id="" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
<popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/> <popup-item item-id="6016" pos-id="" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="" accel-id="" toggle-id="" execute-action=""/>
@ -376,6 +380,7 @@
<toolbutton-item item-id="6011" label-id="Area" icon-id="mesh_area.png" tooltip-id="Area" accel-id="" toggle-id="" execute-action=""/> <toolbutton-item item-id="6011" label-id="Area" icon-id="mesh_area.png" tooltip-id="Area" accel-id="" toggle-id="" execute-action=""/>
<toolbutton-item item-id="6012" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="Taper" accel-id="" toggle-id="" execute-action=""/> <toolbutton-item item-id="6012" label-id="Taper" icon-id="mesh_taper.png" tooltip-id="Taper" accel-id="" toggle-id="" execute-action=""/>
<toolbutton-item item-id="6013" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="Aspect Ratio" accel-id="" toggle-id="" execute-action=""/> <toolbutton-item item-id="6013" label-id="Aspect Ratio" icon-id="mesh_aspect.png" tooltip-id="Aspect Ratio" accel-id="" toggle-id="" execute-action=""/>
<toolbutton-item item-id="6017" label-id="Aspect Ratio 3D" icon-id="mesh_aspect.png" tooltip-id="Aspect Ratio 3D" accel-id="" toggle-id="" execute-action=""/>
<toolbutton-item item-id="6014" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="Minimum angle" accel-id="" toggle-id="" execute-action=""/> <toolbutton-item item-id="6014" label-id="Minimum angle" icon-id="mesh_angle.png" tooltip-id="Minimum angle" accel-id="" toggle-id="" execute-action=""/>
<toolbutton-item item-id="6015" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="Warping angle" accel-id="" toggle-id="" execute-action=""/> <toolbutton-item item-id="6015" label-id="Warping" icon-id="mesh_wrap.png" tooltip-id="Warping angle" accel-id="" toggle-id="" execute-action=""/>
<toolbutton-item item-id="6016" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="Skew" accel-id="" toggle-id="" execute-action=""/> <toolbutton-item item-id="6016" label-id="Skew" icon-id="mesh_skew.png" tooltip-id="Skew" accel-id="" toggle-id="" execute-action=""/>

View File

@ -31,7 +31,7 @@ VPATH=.:@srcdir@:@top_srcdir@/idl:$(top_builddir)/idl
@COMMENCE@ @COMMENCE@
EXPORT_HEADERS = SMESH_Controls.hxx EXPORT_HEADERS = SMESH_Controls.hxx SMESH_ControlsDef.hxx
# Libraries targets # Libraries targets

View File

@ -17,7 +17,7 @@
// //
// See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org // See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
#include "SMESH_Controls.hxx" #include "SMESH_ControlsDef.hxx"
int main(int argc, char** argv) int main(int argc, char** argv)
{ {

View File

@ -17,7 +17,7 @@
// //
// See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org // See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
#include "SMESH_Controls.hxx" #include "SMESH_ControlsDef.hxx"
#include <set> #include <set>
@ -33,7 +33,6 @@
#include <Geom_CylindricalSurface.hxx> #include <Geom_CylindricalSurface.hxx>
#include <Precision.hxx> #include <Precision.hxx>
#include <TColgp_Array1OfXYZ.hxx> #include <TColgp_Array1OfXYZ.hxx>
#include <TColgp_SequenceOfXYZ.hxx>
#include <TColStd_MapOfInteger.hxx> #include <TColStd_MapOfInteger.hxx>
#include <TColStd_SequenceOfAsciiString.hxx> #include <TColStd_SequenceOfAsciiString.hxx>
#include <TColStd_MapIteratorOfMapOfInteger.hxx> #include <TColStd_MapIteratorOfMapOfInteger.hxx>
@ -53,73 +52,71 @@
AUXILIARY METHODS AUXILIARY METHODS
*/ */
static inline double getAngle( const gp_XYZ& P1, const gp_XYZ& P2, const gp_XYZ& P3 ) namespace{
{ inline double getAngle( const gp_XYZ& P1, const gp_XYZ& P2, const gp_XYZ& P3 )
gp_Vec v1( P1 - P2 ), v2( P3 - P2 );
return v1.Magnitude() < gp::Resolution() ||
v2.Magnitude() < gp::Resolution() ? 0 : v1.Angle( v2 );
}
static inline double getArea( const gp_XYZ& P1, const gp_XYZ& P2, const gp_XYZ& P3 )
{
gp_Vec aVec1( P2 - P1 );
gp_Vec aVec2( P3 - P1 );
return ( aVec1 ^ aVec2 ).Magnitude() * 0.5;
}
static inline double getArea( const gp_Pnt& P1, const gp_Pnt& P2, const gp_Pnt& P3 )
{
return getArea( P1.XYZ(), P2.XYZ(), P3.XYZ() );
}
static inline double getDistance( const gp_XYZ& P1, const gp_XYZ& P2 )
{
double aDist = gp_Pnt( P1 ).Distance( gp_Pnt( P2 ) );
return aDist;
}
static int getNbMultiConnection( SMDS_Mesh* theMesh, const int theId )
{
if ( theMesh == 0 )
return 0;
const SMDS_MeshElement* anEdge = theMesh->FindElement( theId );
if ( anEdge == 0 || anEdge->GetType() != SMDSAbs_Edge || anEdge->NbNodes() != 2 )
return 0;
TColStd_MapOfInteger aMap;
int aResult = 0;
SMDS_ElemIteratorPtr anIter = anEdge->nodesIterator();
if ( anIter != 0 )
{ {
while( anIter->more() ) gp_Vec v1( P1 - P2 ), v2( P3 - P2 );
{
const SMDS_MeshNode* aNode = (SMDS_MeshNode*)anIter->next(); return v1.Magnitude() < gp::Resolution() ||
if ( aNode == 0 ) v2.Magnitude() < gp::Resolution() ? 0 : v1.Angle( v2 );
return 0;
SMDS_ElemIteratorPtr anElemIter = aNode->GetInverseElementIterator();
while( anElemIter->more() )
{
const SMDS_MeshElement* anElem = anElemIter->next();
if ( anElem != 0 && anElem->GetType() != SMDSAbs_Edge )
{
int anId = anElem->GetID();
if ( anIter->more() ) // i.e. first node
aMap.Add( anId );
else if ( aMap.Contains( anId ) )
aResult++;
}
}
}
} }
return aResult; inline double getArea( const gp_XYZ& P1, const gp_XYZ& P2, const gp_XYZ& P3 )
} {
gp_Vec aVec1( P2 - P1 );
gp_Vec aVec2( P3 - P1 );
return ( aVec1 ^ aVec2 ).Magnitude() * 0.5;
}
inline double getArea( const gp_Pnt& P1, const gp_Pnt& P2, const gp_Pnt& P3 )
{
return getArea( P1.XYZ(), P2.XYZ(), P3.XYZ() );
}
inline double getDistance( const gp_XYZ& P1, const gp_XYZ& P2 )
{
double aDist = gp_Pnt( P1 ).Distance( gp_Pnt( P2 ) );
return aDist;
}
int getNbMultiConnection( SMDS_Mesh* theMesh, const int theId )
{
if ( theMesh == 0 )
return 0;
const SMDS_MeshElement* anEdge = theMesh->FindElement( theId );
if ( anEdge == 0 || anEdge->GetType() != SMDSAbs_Edge || anEdge->NbNodes() != 2 )
return 0;
TColStd_MapOfInteger aMap;
int aResult = 0;
SMDS_ElemIteratorPtr anIter = anEdge->nodesIterator();
if ( anIter != 0 ) {
while( anIter->more() ) {
const SMDS_MeshNode* aNode = (SMDS_MeshNode*)anIter->next();
if ( aNode == 0 )
return 0;
SMDS_ElemIteratorPtr anElemIter = aNode->GetInverseElementIterator();
while( anElemIter->more() ) {
const SMDS_MeshElement* anElem = anElemIter->next();
if ( anElem != 0 && anElem->GetType() != SMDSAbs_Edge ) {
int anId = anElem->GetID();
if ( anIter->more() ) // i.e. first node
aMap.Add( anId );
else if ( aMap.Contains( anId ) )
aResult++;
}
}
}
}
return aResult;
}
}
using namespace SMESH::Controls; using namespace SMESH::Controls;
/* /*
@ -141,10 +138,10 @@ void NumericalFunctor::SetMesh( SMDS_Mesh* theMesh )
myMesh = theMesh; myMesh = theMesh;
} }
bool NumericalFunctor::GetPoints(const int theId, bool NumericalFunctor::GetPoints(const int theId,
TColgp_SequenceOfXYZ& theRes ) const TSequenceOfXYZ& theRes) const
{ {
theRes.Clear(); theRes.clear();
if ( myMesh == 0 ) if ( myMesh == 0 )
return false; return false;
@ -153,9 +150,9 @@ bool NumericalFunctor::GetPoints(const int theId,
} }
bool NumericalFunctor::GetPoints(const SMDS_MeshElement* anElem, bool NumericalFunctor::GetPoints(const SMDS_MeshElement* anElem,
TColgp_SequenceOfXYZ& theRes ) TSequenceOfXYZ& theRes)
{ {
theRes.Clear(); theRes.clear();
if ( anElem == 0) if ( anElem == 0)
return false; return false;
@ -167,8 +164,9 @@ bool NumericalFunctor::GetPoints(const SMDS_MeshElement* anElem,
while( anIter->more() ) while( anIter->more() )
{ {
const SMDS_MeshNode* aNode = (SMDS_MeshNode*)anIter->next(); const SMDS_MeshNode* aNode = (SMDS_MeshNode*)anIter->next();
if ( aNode != 0 ) if ( aNode != 0 ){
theRes.Append( gp_XYZ( aNode->X(), aNode->Y(), aNode->Z() ) ); theRes.push_back( gp_XYZ( aNode->X(), aNode->Y(), aNode->Z() ) );
}
} }
} }
@ -187,7 +185,7 @@ void NumericalFunctor::SetPrecision( const long thePrecision )
double NumericalFunctor::GetValue( long theId ) double NumericalFunctor::GetValue( long theId )
{ {
TColgp_SequenceOfXYZ P; TSequenceOfXYZ P;
if ( GetPoints( theId, P )) if ( GetPoints( theId, P ))
{ {
double aVal = GetValue( P ); double aVal = GetValue( P );
@ -196,7 +194,6 @@ double NumericalFunctor::GetValue( long theId )
double prec = pow( 10., (double)( myPrecision ) ); double prec = pow( 10., (double)( myPrecision ) );
aVal = floor( aVal * prec + 0.5 ) / prec; aVal = floor( aVal * prec + 0.5 ) / prec;
} }
return aVal; return aVal;
} }
@ -208,11 +205,11 @@ double NumericalFunctor::GetValue( long theId )
Description : Functor for calculation of minimum angle Description : Functor for calculation of minimum angle
*/ */
double MinimumAngle::GetValue( const TColgp_SequenceOfXYZ& P ) double MinimumAngle::GetValue( const TSequenceOfXYZ& P )
{ {
double aMin; double aMin;
if ( P.Length() == 3 ) if ( P.size() == 3 )
{ {
double A0 = getAngle( P( 3 ), P( 1 ), P( 2 ) ); double A0 = getAngle( P( 3 ), P( 1 ), P( 2 ) );
double A1 = getAngle( P( 1 ), P( 2 ), P( 3 ) ); double A1 = getAngle( P( 1 ), P( 2 ), P( 3 ) );
@ -220,7 +217,7 @@ double MinimumAngle::GetValue( const TColgp_SequenceOfXYZ& P )
aMin = Min( A0, Min( A1, A2 ) ); aMin = Min( A0, Min( A1, A2 ) );
} }
else if ( P.Length() == 4 ) else if ( P.size() == 4 )
{ {
double A0 = getAngle( P( 4 ), P( 1 ), P( 2 ) ); double A0 = getAngle( P( 4 ), P( 1 ), P( 2 ) );
double A1 = getAngle( P( 1 ), P( 2 ), P( 3 ) ); double A1 = getAngle( P( 1 ), P( 2 ), P( 3 ) );
@ -251,9 +248,9 @@ SMDSAbs_ElementType MinimumAngle::GetType() const
Class : AspectRatio Class : AspectRatio
Description : Functor for calculating aspect ratio Description : Functor for calculating aspect ratio
*/ */
double AspectRatio::GetValue( const TColgp_SequenceOfXYZ& P ) double AspectRatio::GetValue( const TSequenceOfXYZ& P )
{ {
int nbNodes = P.Length(); int nbNodes = P.size();
if ( nbNodes != 3 && nbNodes != 4 ) if ( nbNodes != 3 && nbNodes != 4 )
return 0; return 0;
@ -262,8 +259,8 @@ double AspectRatio::GetValue( const TColgp_SequenceOfXYZ& P )
double aLen[ nbNodes ]; double aLen[ nbNodes ];
for ( int i = 0; i < nbNodes - 1; i++ ) for ( int i = 0; i < nbNodes - 1; i++ )
aLen[ i ] = getDistance( P( i + 1 ), P( i + 2 ) ); aLen[ i ] = getDistance( P(i+1), P(i+2) );
aLen[ nbNodes - 1 ] = getDistance( P( 1 ), P( nbNodes ) ); aLen[ nbNodes - 1 ] = getDistance( P( 1 ), P(nbNodes) );
// Compute aspect ratio // Compute aspect ratio
@ -307,64 +304,52 @@ SMDSAbs_ElementType AspectRatio::GetType() const
Description : Functor for calculating aspect ratio Description : Functor for calculating aspect ratio
*/ */
static inline double getHalfPerimeter(double theTria[3]){ namespace{
return (theTria[0] + theTria[1] + theTria[2])/2.0;
inline double getHalfPerimeter(double theTria[3]){
return (theTria[0] + theTria[1] + theTria[2])/2.0;
}
inline double getArea(double theHalfPerim, double theTria[3]){
return sqrt(theHalfPerim*
(theHalfPerim-theTria[0])*
(theHalfPerim-theTria[1])*
(theHalfPerim-theTria[2]));
}
inline double getVolume(const TSequenceOfXYZ& P){
gp_Vec aVec1( P( 2 ) - P( 1 ) );
gp_Vec aVec2( P( 3 ) - P( 1 ) );
gp_Vec aVec3( P( 4 ) - P( 1 ) );
gp_Vec anAreaVec( aVec1 ^ aVec2 );
return abs(aVec3 * anAreaVec) / 6.0;
}
inline double getMaxHeight(double theLen[6])
{
double aHeight = max(theLen[0],theLen[1]);
aHeight = max(aHeight,theLen[2]);
aHeight = max(aHeight,theLen[3]);
aHeight = max(aHeight,theLen[4]);
aHeight = max(aHeight,theLen[5]);
return aHeight;
}
} }
static inline double getArea(double theHalfPerim, double theTria[3]){ double AspectRatio3D::GetValue( const TSequenceOfXYZ& P )
return sqrt(theHalfPerim*
(theHalfPerim-theTria[0])*
(theHalfPerim-theTria[1])*
(theHalfPerim-theTria[2]));
}
static inline double getVolume(double theLen[6]){
double a2 = theLen[0]*theLen[0];
double b2 = theLen[1]*theLen[1];
double c2 = theLen[2]*theLen[2];
double d2 = theLen[3]*theLen[3];
double e2 = theLen[4]*theLen[4];
double f2 = theLen[5]*theLen[5];
double P = 4.0*a2*b2*d2;
double Q = a2*(b2+d2-e2)-b2*(a2+d2-f2)-d2*(a2+b2-c2);
double R = (b2+d2-e2)*(a2+d2-f2)*(a2+d2-f2);
return sqrt(P-Q+R)/12.0;
}
static inline double getHeight( const gp_Pnt& P1, const gp_Pnt& P2,
const gp_Pnt& P3, const gp_Pnt& P4)
{
gp_Vec aVec1( P2.XYZ() - P1.XYZ() );
gp_Vec aVec2( P3.XYZ() - P1.XYZ() );
gp_Vec aNorm = aVec1 ^ aVec2;
aNorm /= aNorm.Magnitude();
gp_Vec aVec3( P4.XYZ() - P1.XYZ() );
double aDist = aVec1 * aVec2;
return fabs( aDist );
}
static inline double getMaxHeight( const TColgp_SequenceOfXYZ& P )
{
double aHeight = getHeight(P(1),P(2),P(3),P(4));
aHeight = max(aHeight,getHeight(P(1),P(2),P(4),P(3)));
aHeight = max(aHeight,getHeight(P(1),P(3),P(4),P(2)));
aHeight = max(aHeight,getHeight(P(2),P(3),P(4),P(1)));
return aHeight;
}
double AspectRatio3D::GetValue( const TColgp_SequenceOfXYZ& P )
{ {
double aQuality = 0.0; double aQuality = 0.0;
int nbNodes = P.Length(); int nbNodes = P.size();
switch(nbNodes){ switch(nbNodes){
case 4:{ case 4:{
double aLen[6] = { double aLen[6] = {
getDistance(P(1),P(2)), // a getDistance(P( 1 ),P( 2 )), // a
getDistance(P(2),P(3)), // b getDistance(P( 2 ),P( 3 )), // b
getDistance(P(3),P(1)), // c getDistance(P( 3 ),P( 1 )), // c
getDistance(P(2),P(4)), // d getDistance(P( 2 ),P( 4 )), // d
getDistance(P(3),P(4)), // e getDistance(P( 3 ),P( 4 )), // e
getDistance(P(1),P(4)) // f getDistance(P( 1 ),P( 4 )) // f
}; };
double aTria[4][3] = { double aTria[4][3] = {
{aLen[0],aLen[1],aLen[2]}, // abc {aLen[0],aLen[1],aLen[2]}, // abc
@ -372,15 +357,204 @@ double AspectRatio3D::GetValue( const TColgp_SequenceOfXYZ& P )
{aLen[1],aLen[3],aLen[4]}, // bde {aLen[1],aLen[3],aLen[4]}, // bde
{aLen[2],aLen[4],aLen[5]} // cef {aLen[2],aLen[4],aLen[5]} // cef
}; };
double aHalfPerim = getHalfPerimeter(aTria[0]); double aSumArea = 0.0;
double anArea = getArea(aHalfPerim,aTria[0]); double aHalfPerimeter = getHalfPerimeter(aTria[0]);
aHalfPerim = getHalfPerimeter(aTria[1]); double anArea = getArea(aHalfPerimeter,aTria[0]);
anArea += getArea(aHalfPerim,aTria[1]); aSumArea += anArea;
aHalfPerim = getHalfPerimeter(aTria[2]); aHalfPerimeter = getHalfPerimeter(aTria[1]);
anArea += getArea(aHalfPerim,aTria[2]); anArea = getArea(aHalfPerimeter,aTria[1]);
double aVolume = getVolume(aLen); aSumArea += anArea;
double aHeight = getMaxHeight(P); aHalfPerimeter = getHalfPerimeter(aTria[2]);
aQuality = 1.0/3.0*aHeight*anArea/aVolume; anArea = getArea(aHalfPerimeter,aTria[2]);
aSumArea += anArea;
aHalfPerimeter = getHalfPerimeter(aTria[3]);
anArea = getArea(aHalfPerimeter,aTria[3]);
aSumArea += anArea;
double aVolume = getVolume(P);
double aHeight = getMaxHeight(aLen);
static double aCoeff = sqrt(6.0)/36.0;
aQuality = aCoeff*aHeight*aSumArea/aVolume;
break;
}
case 5:{
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 3 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 3 ),P( 4 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 4 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 3 ),P( 4 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
break;
}
case 6:{
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 4 ),P( 6 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 4 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 5 ),P( 6 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 5 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 5 ),P( 4 ),P( 6 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 5 ),P( 4 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
break;
}
case 8:{
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 5 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 5 ),P( 4 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 5 ),P( 7 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 5 ),P( 8 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 6 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 6 ),P( 4 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 6 ),P( 7 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 6 ),P( 8 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 6 ),P( 5 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 6 ),P( 5 ),P( 4 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 6 ),P( 5 ),P( 7 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 6 ),P( 5 ),P( 8 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 8 ),P( 1 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 8 ),P( 2 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 8 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 8 ),P( 6 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 7 ),P( 1 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 7 ),P( 2 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 7 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 7 ),P( 6 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 4 ),P( 8 ),P( 7 ),P( 1 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 4 ),P( 8 ),P( 7 ),P( 2 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 4 ),P( 8 ),P( 7 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 4 ),P( 8 ),P( 7 ),P( 6 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 4 ),P( 8 ),P( 7 ),P( 2 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 4 ),P( 5 ),P( 8 ),P( 2 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 4 ),P( 5 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 6 ),P( 7 ),P( 1 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 2 ),P( 3 ),P( 6 ),P( 4 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 5 ),P( 6 ),P( 8 ),P( 3 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 7 ),P( 8 ),P( 6 ),P( 1 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 1 ),P( 2 ),P( 4 ),P( 7 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
{
gp_XYZ aXYZ[4] = {P( 3 ),P( 4 ),P( 2 ),P( 5 )};
aQuality = max(GetValue(TSequenceOfXYZ(&aXYZ[0],&aXYZ[4])),aQuality);
}
break; break;
} }
} }
@ -405,9 +579,9 @@ SMDSAbs_ElementType AspectRatio3D::GetType() const
Class : Warping Class : Warping
Description : Functor for calculating warping Description : Functor for calculating warping
*/ */
double Warping::GetValue( const TColgp_SequenceOfXYZ& P ) double Warping::GetValue( const TSequenceOfXYZ& P )
{ {
if ( P.Length() != 4 ) if ( P.size() != 4 )
return 0; return 0;
gp_XYZ G = ( P( 1 ) + P( 2 ) + P( 3 ) + P( 4 ) ) / 4; gp_XYZ G = ( P( 1 ) + P( 2 ) + P( 3 ) + P( 4 ) ) / 4;
@ -462,9 +636,9 @@ SMDSAbs_ElementType Warping::GetType() const
Class : Taper Class : Taper
Description : Functor for calculating taper Description : Functor for calculating taper
*/ */
double Taper::GetValue( const TColgp_SequenceOfXYZ& P ) double Taper::GetValue( const TSequenceOfXYZ& P )
{ {
if ( P.Length() != 4 ) if ( P.size() != 4 )
return 0; return 0;
// Compute taper // Compute taper
@ -514,14 +688,14 @@ 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 );
} }
double Skew::GetValue( const TColgp_SequenceOfXYZ& P ) double Skew::GetValue( const TSequenceOfXYZ& P )
{ {
if ( P.Length() != 3 && P.Length() != 4 ) if ( P.size() != 3 && P.size() != 4 )
return 0; return 0;
// Compute skew // Compute skew
static double PI2 = PI / 2; static double PI2 = PI / 2;
if ( P.Length() == 3 ) if ( P.size() == 3 )
{ {
double A0 = fabs( PI2 - skewAngle( P( 3 ), P( 1 ), P( 2 ) ) ); double A0 = fabs( PI2 - skewAngle( P( 3 ), P( 1 ), P( 2 ) ) );
double A1 = fabs( PI2 - skewAngle( P( 1 ), P( 2 ), P( 3 ) ) ); double A1 = fabs( PI2 - skewAngle( P( 1 ), P( 2 ), P( 3 ) ) );
@ -562,11 +736,11 @@ SMDSAbs_ElementType Skew::GetType() const
Class : Area Class : Area
Description : Functor for calculating area Description : Functor for calculating area
*/ */
double Area::GetValue( const TColgp_SequenceOfXYZ& P ) double Area::GetValue( const TSequenceOfXYZ& P )
{ {
if ( P.Length() == 3 ) if ( P.size() == 3 )
return getArea( P( 1 ), P( 2 ), P( 3 ) ); return getArea( P( 1 ), P( 2 ), P( 3 ) );
else if ( P.Length() == 4 ) else if ( P.size() == 4 )
return getArea( P( 1 ), P( 2 ), P( 3 ) ) + getArea( P( 1 ), P( 3 ), P( 4 ) ); return getArea( P( 1 ), P( 2 ), P( 3 ) ) + getArea( P( 1 ), P( 3 ), P( 4 ) );
else else
return 0; return 0;
@ -587,9 +761,9 @@ SMDSAbs_ElementType Area::GetType() const
Class : Length Class : Length
Description : Functor for calculating length off edge Description : Functor for calculating length off edge
*/ */
double Length::GetValue( const TColgp_SequenceOfXYZ& P ) double Length::GetValue( const TSequenceOfXYZ& P )
{ {
return ( P.Length() == 2 ? getDistance( P( 1 ), P( 2 ) ) : 0 ); return ( P.size() == 2 ? getDistance( P( 1 ), P( 2 ) ) : 0 );
} }
double Length::GetBadRate( double Value, int /*nbNodes*/ ) const double Length::GetBadRate( double Value, int /*nbNodes*/ ) const
@ -607,7 +781,7 @@ SMDSAbs_ElementType Length::GetType() const
Class : MultiConnection Class : MultiConnection
Description : Functor for calculating number of faces conneted to the edge Description : Functor for calculating number of faces conneted to the edge
*/ */
double MultiConnection::GetValue( const TColgp_SequenceOfXYZ& P ) double MultiConnection::GetValue( const TSequenceOfXYZ& P )
{ {
return 0; return 0;
} }
@ -1426,7 +1600,6 @@ static gp_XYZ getNormale( const SMDS_MeshFace* theFace )
gp_XYZ n; gp_XYZ n;
int aNbNode = theFace->NbNodes(); int aNbNode = theFace->NbNodes();
TColgp_Array1OfXYZ anArrOfXYZ(1,4); TColgp_Array1OfXYZ anArrOfXYZ(1,4);
gp_XYZ p1, p2, p3, p4;
SMDS_ElemIteratorPtr aNodeItr = theFace->nodesIterator(); SMDS_ElemIteratorPtr aNodeItr = theFace->nodesIterator();
int i = 1; int i = 1;
for ( ; aNodeItr->more() && i <= 4; i++ ) for ( ; aNodeItr->more() && i <= 4; i++ )
@ -1435,12 +1608,12 @@ static gp_XYZ getNormale( const SMDS_MeshFace* theFace )
anArrOfXYZ.SetValue(i, gp_XYZ( aNode->X(), aNode->Y(), aNode->Z() ) ); anArrOfXYZ.SetValue(i, gp_XYZ( aNode->X(), aNode->Y(), aNode->Z() ) );
} }
gp_XYZ q1 = anArrOfXYZ.Value(2) - anArrOfXYZ.Value(1); gp_XYZ q1 = anArrOfXYZ.Value( 2 ) - anArrOfXYZ.Value( 1 );
gp_XYZ q2 = anArrOfXYZ.Value(3) - anArrOfXYZ.Value(1); gp_XYZ q2 = anArrOfXYZ.Value( 3 ) - anArrOfXYZ.Value( 1 );
n = q1 ^ q2; n = q1 ^ q2;
if ( aNbNode > 3 ) if ( aNbNode > 3 )
{ {
gp_XYZ q3 = anArrOfXYZ.Value(4) - anArrOfXYZ.Value(1); gp_XYZ q3 = anArrOfXYZ.Value( 4 ) - anArrOfXYZ.Value( 1 );
n += q2 ^ q3; n += q2 ^ q3;
} }
double len = n.Modulus(); double len = n.Modulus();

View File

@ -20,508 +20,24 @@
#ifndef _SMESH_CONTROLS_HXX_ #ifndef _SMESH_CONTROLS_HXX_
#define _SMESH_CONTROLS_HXX_ #define _SMESH_CONTROLS_HXX_
#include <set>
#include <map>
#include <vector>
#include <boost/shared_ptr.hpp> #include <boost/shared_ptr.hpp>
#include "SMDSAbs_ElementType.hxx"
#include "SMDS_MeshNode.hxx"
#include <Geom_Surface.hxx>
#include <TColStd_SequenceOfInteger.hxx>
#include <TColStd_MapOfInteger.hxx>
#include <TCollection_AsciiString.hxx>
class SMDS_Mesh;
class SMESHDS_Mesh;
class SMESHDS_SubMesh;
class gp_Pnt;
class gp_XYZ;
class TColgp_SequenceOfXYZ;
class TopoDS_Shape;
class SMDS_MeshElement;
class SMDS_MeshFace;
class SMDS_MeshNode;
namespace SMESH{ namespace SMESH{
namespace Controls{ namespace Controls{
class Functor
{ class Functor;
public:
~Functor(){}
virtual void SetMesh( SMDS_Mesh* theMesh ) = 0;
virtual SMDSAbs_ElementType GetType() const = 0;
};
typedef boost::shared_ptr<Functor> FunctorPtr; typedef boost::shared_ptr<Functor> FunctorPtr;
class NumericalFunctor: public virtual Functor{
public: class NumericalFunctor;
NumericalFunctor();
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual double GetValue( long theElementId );
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints ) = 0;
virtual SMDSAbs_ElementType GetType() const = 0;
virtual double GetBadRate( double Value, int nbNodes ) const = 0;
long GetPrecision() const;
void SetPrecision( const long thePrecision );
bool GetPoints (const int theId,
TColgp_SequenceOfXYZ& theRes ) const;
static bool GetPoints (const SMDS_MeshElement* theElem,
TColgp_SequenceOfXYZ& theRes );
protected:
SMDS_Mesh* myMesh;
long myPrecision;
};
typedef boost::shared_ptr<NumericalFunctor> NumericalFunctorPtr; typedef boost::shared_ptr<NumericalFunctor> NumericalFunctorPtr;
/* class Predicate;
Class : SMESH_MinimumAngle
Description : Functor for calculation of minimum angle
*/
class MinimumAngle: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
Class : AspectRatio
Description : Functor for calculating aspect ratio
*/
class AspectRatio: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
Class : AspectRatio3D
Description : Functor for calculating aspect ratio of 3D elems.
*/
class AspectRatio3D: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
Class : Warping
Description : Functor for calculating warping
*/
class Warping: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
private:
double ComputeA( const gp_XYZ&, const gp_XYZ&, const gp_XYZ&, const gp_XYZ& ) const;
};
/*
Class : Taper
Description : Functor for calculating taper
*/
class Taper: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
Class : Skew
Description : Functor for calculating skew in degrees
*/
class Skew: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
Class : Area
Description : Functor for calculating area
*/
class Area: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
Class : Length
Description : Functor for calculating length of edge
*/
class Length: public virtual NumericalFunctor{
public:
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
Class : MultiConnection
Description : Functor for calculating number of faces conneted to the edge
*/
class MultiConnection: public virtual NumericalFunctor{
public:
virtual double GetValue( long theElementId );
virtual double GetValue( const TColgp_SequenceOfXYZ& thePoints );
virtual double GetBadRate( double Value, int nbNodes ) const;
virtual SMDSAbs_ElementType GetType() const;
};
/*
PREDICATES
*/
/*
Class : Predicate
Description : Base class for all predicates
*/
class Predicate: public virtual Functor{
public:
virtual bool IsSatisfy( long theElementId ) = 0;
virtual SMDSAbs_ElementType GetType() const = 0;
};
typedef boost::shared_ptr<Predicate> PredicatePtr; typedef boost::shared_ptr<Predicate> PredicatePtr;
/*
Class : FreeBorders
Description : Predicate for free borders
*/
class FreeBorders: public virtual Predicate{
public:
FreeBorders();
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual bool IsSatisfy( long theElementId );
virtual SMDSAbs_ElementType GetType() const;
protected:
SMDS_Mesh* myMesh;
};
/* }
Class : FreeEdges }
Description : Predicate for free Edges
*/
class FreeEdges: public virtual Predicate{
public:
FreeEdges();
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual bool IsSatisfy( long theElementId );
virtual SMDSAbs_ElementType GetType() const;
static bool IsFreeEdge( const SMDS_MeshNode** theNodes, const int theFaceId );
typedef long TElemId;
struct Border{
TElemId myElemId;
TElemId myPntId[2];
Border(long theElemId, long thePntId1, long thePntId2);
bool operator<(const Border& x) const;
};
typedef std::set<Border> TBorders;
void GetBoreders(TBorders& theBorders);
protected:
SMDS_Mesh* myMesh;
};
typedef boost::shared_ptr<FreeEdges> FreeEdgesPtr;
/*
Class : RangeOfIds
Description : Predicate for Range of Ids.
Range may be specified with two ways.
1. Using AddToRange method
2. With SetRangeStr method. Parameter of this method is a string
like as "1,2,3,50-60,63,67,70-"
*/
class RangeOfIds: public virtual Predicate
{
public:
RangeOfIds();
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual bool IsSatisfy( long theNodeId );
virtual SMDSAbs_ElementType GetType() const;
virtual void SetType( SMDSAbs_ElementType theType );
bool AddToRange( long theEntityId );
void GetRangeStr( TCollection_AsciiString& );
bool SetRangeStr( const TCollection_AsciiString& );
protected:
SMDS_Mesh* myMesh;
TColStd_SequenceOfInteger myMin;
TColStd_SequenceOfInteger myMax;
TColStd_MapOfInteger myIds;
SMDSAbs_ElementType myType;
};
typedef boost::shared_ptr<RangeOfIds> RangeOfIdsPtr;
/*
Class : Comparator
Description : Base class for comparators
*/
class Comparator: public virtual Predicate{
public:
Comparator();
virtual ~Comparator();
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual void SetMargin(double theValue);
virtual void SetNumFunctor(NumericalFunctorPtr theFunct);
virtual bool IsSatisfy( long theElementId ) = 0;
virtual SMDSAbs_ElementType GetType() const;
double GetMargin();
protected:
double myMargin;
NumericalFunctorPtr myFunctor;
};
typedef boost::shared_ptr<Comparator> ComparatorPtr;
/*
Class : LessThan
Description : Comparator "<"
*/
class LessThan: public virtual Comparator{
public:
virtual bool IsSatisfy( long theElementId );
};
/*
Class : MoreThan
Description : Comparator ">"
*/
class MoreThan: public virtual Comparator{
public:
virtual bool IsSatisfy( long theElementId );
};
/*
Class : EqualTo
Description : Comparator "="
*/
class EqualTo: public virtual Comparator{
public:
EqualTo();
virtual bool IsSatisfy( long theElementId );
virtual void SetTolerance( double theTol );
virtual double GetTolerance();
private:
double myToler;
};
typedef boost::shared_ptr<EqualTo> EqualToPtr;
/*
Class : LogicalNOT
Description : Logical NOT predicate
*/
class LogicalNOT: public virtual Predicate{
public:
LogicalNOT();
virtual ~LogicalNOT();
virtual bool IsSatisfy( long theElementId );
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual void SetPredicate(PredicatePtr thePred);
virtual SMDSAbs_ElementType GetType() const;
private:
PredicatePtr myPredicate;
};
typedef boost::shared_ptr<LogicalNOT> LogicalNOTPtr;
/*
Class : LogicalBinary
Description : Base class for binary logical predicate
*/
class LogicalBinary: public virtual Predicate{
public:
LogicalBinary();
virtual ~LogicalBinary();
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual void SetPredicate1(PredicatePtr thePred);
virtual void SetPredicate2(PredicatePtr thePred);
virtual SMDSAbs_ElementType GetType() const;
protected:
PredicatePtr myPredicate1;
PredicatePtr myPredicate2;
};
typedef boost::shared_ptr<LogicalBinary> LogicalBinaryPtr;
/*
Class : LogicalAND
Description : Logical AND
*/
class LogicalAND: public virtual LogicalBinary{
public:
virtual bool IsSatisfy( long theElementId );
};
/*
Class : LogicalOR
Description : Logical OR
*/
class LogicalOR: public virtual LogicalBinary{
public:
virtual bool IsSatisfy( long theElementId );
};
/*
Class : ManifoldPart
Description : Predicate for manifold part of mesh
*/
class ManifoldPart: public virtual Predicate{
public:
/* internal class for algorithm uses */
class Link
{
public:
Link( SMDS_MeshNode* theNode1,
SMDS_MeshNode* theNode2 );
~Link();
bool IsEqual( const ManifoldPart::Link& theLink ) const;
bool operator<(const ManifoldPart::Link& x) const;
SMDS_MeshNode* myNode1;
SMDS_MeshNode* myNode2;
};
bool IsEqual( const ManifoldPart::Link& theLink1,
const ManifoldPart::Link& theLink2 );
typedef std::set<ManifoldPart::Link> TMapOfLink;
typedef std::vector<SMDS_MeshFace*> TVectorOfFacePtr;
typedef std::vector<ManifoldPart::Link> TVectorOfLink;
typedef std::map<SMDS_MeshFace*,int> TDataMapFacePtrInt;
typedef std::map<ManifoldPart::Link,SMDS_MeshFace*> TDataMapOfLinkFacePtr;
ManifoldPart();
~ManifoldPart();
virtual void SetMesh( SMDS_Mesh* theMesh );
// inoke when all parameters already set
virtual bool IsSatisfy( long theElementId );
virtual SMDSAbs_ElementType GetType() const;
void SetAngleTolerance( const double theAngToler );
double GetAngleTolerance() const;
void SetIsOnlyManifold( const bool theIsOnly );
void SetStartElem( const long theStartElemId );
private:
bool process();
bool findConnected( const TDataMapFacePtrInt& theAllFacePtrInt,
SMDS_MeshFace* theStartFace,
TMapOfLink& theNonManifold,
TColStd_MapOfInteger& theResFaces );
bool isInPlane( const SMDS_MeshFace* theFace1,
const SMDS_MeshFace* theFace2 );
void expandBoundary( TMapOfLink& theMapOfBoundary,
TVectorOfLink& theSeqOfBoundary,
TDataMapOfLinkFacePtr& theDMapLinkFacePtr,
TMapOfLink& theNonManifold,
SMDS_MeshFace* theNextFace ) const;
void getFacesByLink( const Link& theLink,
TVectorOfFacePtr& theFaces ) const;
private:
SMDS_Mesh* myMesh;
TColStd_MapOfInteger myMapIds;
TColStd_MapOfInteger myMapBadGeomIds;
TVectorOfFacePtr myAllFacePtr;
TDataMapFacePtrInt myAllFacePtrIntDMap;
double myAngToler;
bool myIsOnlyManifold;
long myStartElemId;
};
typedef boost::shared_ptr<ManifoldPart> ManifoldPartPtr;
/*
Class : ElementsOnSurface
Description : Predicate elements that lying on indicated surface
(plane or cylinder)
*/
class ElementsOnSurface : public virtual Predicate {
public:
ElementsOnSurface();
~ElementsOnSurface();
virtual void SetMesh( SMDS_Mesh* theMesh );
virtual bool IsSatisfy( long theElementId );
virtual SMDSAbs_ElementType GetType() const;
void SetTolerance( const double theToler );
double GetTolerance() const;
void SetSurface( const TopoDS_Shape& theShape,
const SMDSAbs_ElementType theType );
private:
void process();
void process( const SMDS_MeshElement* theElem );
bool isOnSurface( const SMDS_MeshNode* theNode ) const;
private:
SMDS_Mesh* myMesh;
TColStd_MapOfInteger myIds;
SMDSAbs_ElementType myType;
Handle(Geom_Surface) mySurf;
double myToler;
};
typedef boost::shared_ptr<ElementsOnSurface> ElementsOnSurfacePtr;
/*
FILTER
*/
class Filter{
public:
Filter();
virtual ~Filter();
virtual void SetPredicate(PredicatePtr thePred);
typedef std::vector<long> TIdSequence;
virtual TIdSequence GetElementsId( SMDS_Mesh* theMesh );
protected:
PredicatePtr myPredicate;
};
};
};
#endif #endif

View File

@ -30,10 +30,10 @@
#include "SMESH_Actor.h" #include "SMESH_Actor.h"
#include "SMESH_ActorUtils.h" #include "SMESH_ActorUtils.h"
#include "SMESH_DeviceActor.h" #include "SMESH_DeviceActor.h"
#include "SMESH_ControlsDef.hxx"
#include "SALOME_ExtractUnstructuredGrid.h" #include "SALOME_ExtractUnstructuredGrid.h"
#include "QAD_Config.h" #include "QAD_Config.h"
#include "utilities.h"
#include <qstringlist.h> #include <qstringlist.h>
#include <vtkTimeStamp.h> #include <vtkTimeStamp.h>
@ -69,12 +69,12 @@
#include <vtkPlane.h> #include <vtkPlane.h>
#include <vtkImplicitBoolean.h> #include <vtkImplicitBoolean.h>
#include "utilities.h"
#ifdef _DEBUG_ #ifdef _DEBUG_
static int MYDEBUG = 0; static int MYDEBUG = 0;
static int MYDEBUGWITHFILES = 0;
#else #else
static int MYDEBUG = 0; static int MYDEBUG = 0;
static int MYDEBUGWITHFILES = 0;
#endif #endif
static int aLineWidthInc = 2; static int aLineWidthInc = 2;
@ -678,6 +678,14 @@ void SMESH_Actor::SetControlMode(eControl theMode){
myControlActor = my2DActor; myControlActor = my2DActor;
break; break;
} }
case eAspectRatio3D:
{
SMESH::Controls::AspectRatio3D* aControl = new SMESH::Controls::AspectRatio3D();
aControl->SetPrecision( myControlsPrecision );
aFunctor.reset( aControl );
myControlActor = my3DActor;
break;
}
case eMinimumAngle: case eMinimumAngle:
{ {
SMESH::Controls::MinimumAngle* aControl = new SMESH::Controls::MinimumAngle(); SMESH::Controls::MinimumAngle* aControl = new SMESH::Controls::MinimumAngle();

View File

@ -146,7 +146,8 @@ class SMESH_Actor : public SALOME_Actor{
bool GetCellsLabeled(){ return myIsCellsLabeled;} bool GetCellsLabeled(){ return myIsCellsLabeled;}
enum eControl{eNone, eLengthEdges, eFreeBorders, eFreeEdges, eMultiConnection, enum eControl{eNone, eLengthEdges, eFreeBorders, eFreeEdges, eMultiConnection,
eArea, eTaper, eAspectRatio, eMinimumAngle, eWarping, eSkew}; eArea, eTaper, eAspectRatio, eMinimumAngle, eWarping, eSkew,
eAspectRatio3D};
void SetControlMode(eControl theMode); void SetControlMode(eControl theMode);
eControl GetControlMode(){ return myColorMode;} eControl GetControlMode(){ return myColorMode;}

View File

@ -29,14 +29,13 @@
#include "SMESH_DeviceActor.h" #include "SMESH_DeviceActor.h"
#include "SMESH_ExtractGeometry.h" #include "SMESH_ExtractGeometry.h"
#include "SMESH_ControlsDef.hxx"
#include "SALOME_Transform.h" #include "SALOME_Transform.h"
#include "SALOME_TransformFilter.h" #include "SALOME_TransformFilter.h"
#include "SALOME_PassThroughFilter.h" #include "SALOME_PassThroughFilter.h"
#include "SALOME_ExtractUnstructuredGrid.h" #include "SALOME_ExtractUnstructuredGrid.h"
#include "utilities.h"
// VTK Includes // VTK Includes
#include <vtkObjectFactory.h> #include <vtkObjectFactory.h>
#include <vtkShrinkFilter.h> #include <vtkShrinkFilter.h>
@ -61,12 +60,12 @@
#include <vtkImplicitBoolean.h> #include <vtkImplicitBoolean.h>
#include "utilities.h"
#ifdef _DEBUG_ #ifdef _DEBUG_
static int MYDEBUG = 0; static int MYDEBUG = 0;
static int MYDEBUGWITHFILES = 0;
#else #else
static int MYDEBUG = 0; static int MYDEBUG = 0;
static int MYDEBUGWITHFILES = 0;
#endif #endif
using namespace std; using namespace std;
@ -304,7 +303,7 @@ void SMESH_DeviceActor::SetExtControlMode(SMESH::Controls::FunctorPtr theFunctor
anIdList->SetNumberOfIds(2); anIdList->SetNumberOfIds(2);
FreeEdges::TBorders::const_iterator anIter = aBorders.begin(); FreeEdges::TBorders::const_iterator anIter = aBorders.begin();
for(vtkIdType aVtkId; anIter != aBorders.end(); anIter++){ for(; anIter != aBorders.end(); anIter++){
const FreeEdges::Border& aBorder = *anIter; const FreeEdges::Border& aBorder = *anIter;
int aNode[2] = { int aNode[2] = {
myVisualObj->GetNodeVTKId(aBorder.myPntId[0]), myVisualObj->GetNodeVTKId(aBorder.myPntId[0]),

View File

@ -27,8 +27,9 @@
#include "SMESH_Object.h" #include "SMESH_Object.h"
#include "SMDS_Mesh.hxx" #include "SMDS_Mesh.hxx"
#include "SALOME_ExtractUnstructuredGrid.h"
#include "SMESH_Actor.h" #include "SMESH_Actor.h"
#include "SMESH_ControlsDef.hxx"
#include "SALOME_ExtractUnstructuredGrid.h"
#include CORBA_SERVER_HEADER(SALOME_Exception) #include CORBA_SERVER_HEADER(SALOME_Exception)
@ -117,7 +118,6 @@ namespace{
SMESH::log_array_var& theSeq, SMESH::log_array_var& theSeq,
CORBA::Long theId) CORBA::Long theId)
{ {
const SMESH::double_array& aCoords = theSeq[theId].coords;
const SMESH::long_array& anIndexes = theSeq[theId].indexes; const SMESH::long_array& anIndexes = theSeq[theId].indexes;
CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number; CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number;
if(3*aNbElems != anIndexes.length()) if(3*aNbElems != anIndexes.length())
@ -136,7 +136,6 @@ namespace{
SMESH::log_array_var& theSeq, SMESH::log_array_var& theSeq,
CORBA::Long theId) CORBA::Long theId)
{ {
const SMESH::double_array& aCoords = theSeq[theId].coords;
const SMESH::long_array& anIndexes = theSeq[theId].indexes; const SMESH::long_array& anIndexes = theSeq[theId].indexes;
CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number; CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number;
if(4*aNbElems != anIndexes.length()) if(4*aNbElems != anIndexes.length())
@ -156,7 +155,6 @@ namespace{
SMESH::log_array_var theSeq, SMESH::log_array_var theSeq,
CORBA::Long theId) CORBA::Long theId)
{ {
const SMESH::double_array& aCoords = theSeq[theId].coords;
const SMESH::long_array& anIndexes = theSeq[theId].indexes; const SMESH::long_array& anIndexes = theSeq[theId].indexes;
CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number; CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number;
if(5*aNbElems != anIndexes.length()) if(5*aNbElems != anIndexes.length())
@ -177,7 +175,6 @@ namespace{
SMESH::log_array_var& theSeq, SMESH::log_array_var& theSeq,
CORBA::Long theId) CORBA::Long theId)
{ {
const SMESH::double_array& aCoords = theSeq[theId].coords;
const SMESH::long_array& anIndexes = theSeq[theId].indexes; const SMESH::long_array& anIndexes = theSeq[theId].indexes;
CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number; CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number;
if(5*aNbElems != anIndexes.length()) if(5*aNbElems != anIndexes.length())
@ -198,7 +195,6 @@ namespace{
SMESH::log_array_var& theSeq, SMESH::log_array_var& theSeq,
CORBA::Long theId) CORBA::Long theId)
{ {
const SMESH::double_array& aCoords = theSeq[theId].coords;
const SMESH::long_array& anIndexes = theSeq[theId].indexes; const SMESH::long_array& anIndexes = theSeq[theId].indexes;
CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number; CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number;
if(6*aNbElems != anIndexes.length()) if(6*aNbElems != anIndexes.length())
@ -220,7 +216,6 @@ namespace{
SMESH::log_array_var& theSeq, SMESH::log_array_var& theSeq,
CORBA::Long theId) CORBA::Long theId)
{ {
const SMESH::double_array& aCoords = theSeq[theId].coords;
const SMESH::long_array& anIndexes = theSeq[theId].indexes; const SMESH::long_array& anIndexes = theSeq[theId].indexes;
CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number; CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number;
if(7*aNbElems != anIndexes.length()) if(7*aNbElems != anIndexes.length())
@ -243,7 +238,6 @@ namespace{
SMESH::log_array_var& theSeq, SMESH::log_array_var& theSeq,
CORBA::Long theId) CORBA::Long theId)
{ {
const SMESH::double_array& aCoords = theSeq[theId].coords;
const SMESH::long_array& anIndexes = theSeq[theId].indexes; const SMESH::long_array& anIndexes = theSeq[theId].indexes;
CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number; CORBA::Long anElemId = 0, aNbElems = theSeq[theId].number;
if(9*aNbElems != anIndexes.length()) if(9*aNbElems != anIndexes.length())
@ -406,7 +400,6 @@ void SMESH_VisualObj::buildNodePrs()
{ {
vtkPoints* aPoints = vtkPoints::New(); vtkPoints* aPoints = vtkPoints::New();
createPoints( aPoints ); createPoints( aPoints );
int nbPoints = aPoints->GetNumberOfPoints();
myGrid->SetPoints( aPoints ); myGrid->SetPoints( aPoints );
aPoints->Delete(); aPoints->Delete();
@ -414,6 +407,7 @@ void SMESH_VisualObj::buildNodePrs()
// Create cells // Create cells
/* /*
int nbPoints = aPoints->GetNumberOfPoints();
vtkIdList *anIdList = vtkIdList::New(); vtkIdList *anIdList = vtkIdList::New();
anIdList->SetNumberOfIds( 1 ); anIdList->SetNumberOfIds( 1 );
@ -650,7 +644,6 @@ void SMESH_MeshObj::Update( int theIsClear )
const SMESH::double_array& aCoords = aSeq[anId].coords; const SMESH::double_array& aCoords = aSeq[anId].coords;
const SMESH::long_array& anIndexes = aSeq[anId].indexes; const SMESH::long_array& anIndexes = aSeq[anId].indexes;
CORBA::Long anElemId = 0, aNbElems = aSeq[anId].number; CORBA::Long anElemId = 0, aNbElems = aSeq[anId].number;
SMDS_MeshElement* anElem = NULL;
CORBA::Long aCommand = aSeq[anId].commandType; CORBA::Long aCommand = aSeq[anId].commandType;
switch(aCommand) switch(aCommand)

View File

@ -28,15 +28,14 @@
#include "SMESH_MeshEditor.hxx" #include "SMESH_MeshEditor.hxx"
#include "SMESH_ControlsDef.hxx"
#include "SMDS_FaceOfNodes.hxx" #include "SMDS_FaceOfNodes.hxx"
#include "SMDS_VolumeTool.hxx" #include "SMDS_VolumeTool.hxx"
#include "SMESHDS_Group.hxx" #include "SMESHDS_Group.hxx"
#include "SMESHDS_Mesh.hxx" #include "SMESHDS_Mesh.hxx"
#include "SMESH_subMesh.hxx" #include "SMESH_subMesh.hxx"
#include "utilities.h"
#include <TColgp_SequenceOfXYZ.hxx>
#include <TopTools_ListIteratorOfListOfShape.hxx> #include <TopTools_ListIteratorOfListOfShape.hxx>
#include <TopTools_ListOfShape.hxx> #include <TopTools_ListOfShape.hxx>
#include <gp_Vec.hxx> #include <gp_Vec.hxx>
@ -48,7 +47,10 @@
#include <map> #include <map>
#include "utilities.h"
using namespace std; using namespace std;
using namespace SMESH::Controls;
typedef map<const SMDS_MeshNode*, const SMDS_MeshNode*> TNodeNodeMap; typedef map<const SMDS_MeshNode*, const SMDS_MeshNode*> TNodeNodeMap;
typedef map<const SMDS_MeshNode*, list<const SMDS_MeshNode*> > TNodeOfNodeListMap; typedef map<const SMDS_MeshNode*, list<const SMDS_MeshNode*> > TNodeOfNodeListMap;
@ -493,7 +495,7 @@ bool SMESH_MeshEditor::Reorient (const SMDS_MeshElement * theFace)
static double getBadRate (const SMDS_MeshElement* theElem, static double getBadRate (const SMDS_MeshElement* theElem,
SMESH::Controls::NumericalFunctorPtr& theCrit) SMESH::Controls::NumericalFunctorPtr& theCrit)
{ {
TColgp_SequenceOfXYZ P; TSequenceOfXYZ P;
if ( !theElem || !theCrit->GetPoints( theElem, P )) if ( !theElem || !theCrit->GetPoints( theElem, P ))
return 1e100; return 1e100;
return theCrit->GetBadRate( theCrit->GetValue( P ), theElem->NbNodes() ); return theCrit->GetBadRate( theCrit->GetValue( P ), theElem->NbNodes() );
@ -649,7 +651,7 @@ double getAngle(const SMDS_MeshElement * tr1,
double angle = 2*PI; // bad angle double angle = 2*PI; // bad angle
// get normals // get normals
TColgp_SequenceOfXYZ P1, P2; TSequenceOfXYZ P1, P2;
if ( !SMESH::Controls::NumericalFunctor::GetPoints( tr1, P1 ) || if ( !SMESH::Controls::NumericalFunctor::GetPoints( tr1, P1 ) ||
!SMESH::Controls::NumericalFunctor::GetPoints( tr2, P2 )) !SMESH::Controls::NumericalFunctor::GetPoints( tr2, P2 ))
return angle; return angle;
@ -1315,13 +1317,13 @@ void centroidalSmooth(SMESHDS_Mesh * theMesh,
nbElems++; nbElems++;
gp_XYZ elemCenter(0.,0.,0.); gp_XYZ elemCenter(0.,0.,0.);
TColgp_SequenceOfXYZ aNodePoints; TSequenceOfXYZ aNodePoints;
SMDS_ElemIteratorPtr itN = elem->nodesIterator(); SMDS_ElemIteratorPtr itN = elem->nodesIterator();
while ( itN->more() ) while ( itN->more() )
{ {
const SMDS_MeshNode* aNode = static_cast<const SMDS_MeshNode*>( itN->next() ); const SMDS_MeshNode* aNode = static_cast<const SMDS_MeshNode*>( itN->next() );
gp_XYZ aP( aNode->X(), aNode->Y(), aNode->Z() ); gp_XYZ aP( aNode->X(), aNode->Y(), aNode->Z() );
aNodePoints.Append( aP ); aNodePoints.push_back( aP );
elemCenter += aP; elemCenter += aP;
} }
double elemArea = anAreaFunc.GetValue( aNodePoints ); double elemArea = anAreaFunc.GetValue( aNodePoints );
@ -1453,7 +1455,7 @@ void SMESH_MeshEditor::Smooth (set<const SMDS_MeshElement*> & theElems,
const SMDS_MeshElement* elem = (*itElem); const SMDS_MeshElement* elem = (*itElem);
if ( !elem || elem->GetType() != SMDSAbs_Face ) if ( !elem || elem->GetType() != SMDSAbs_Face )
continue; continue;
TColgp_SequenceOfXYZ aPoints; TSequenceOfXYZ aPoints;
if ( aQualityFunc.GetPoints( elem, aPoints )) { if ( aQualityFunc.GetPoints( elem, aPoints )) {
double aValue = aQualityFunc.GetValue( aPoints ); double aValue = aQualityFunc.GetValue( aPoints );
if ( aValue > maxRatio ) if ( aValue > maxRatio )

View File

@ -292,14 +292,12 @@ namespace{
switch(theCommandID){ switch(theCommandID){
case 1134:{ case 1134:{
SMESHGUI::GetSMESHGUI()->EmitSignalDeactivateDialog(); SMESHGUI::GetSMESHGUI()->EmitSignalDeactivateDialog();
SMESHGUI_ClippingDlg *aDlg = new SMESHGUI_ClippingDlg(QAD_Application::getDesktop(),"",false);
new SMESHGUI_ClippingDlg(QAD_Application::getDesktop(),"",false);
return; return;
} }
case 1133:{ case 1133:{
SMESHGUI::GetSMESHGUI()->EmitSignalDeactivateDialog(); SMESHGUI::GetSMESHGUI()->EmitSignalDeactivateDialog();
SMESHGUI_TransparencyDlg *aDlg = new SMESHGUI_TransparencyDlg(QAD_Application::getDesktop(),"",false);
new SMESHGUI_TransparencyDlg(QAD_Application::getDesktop(),"",false);
return; return;
}} }}
SALOME_ListIteratorOfListIO It(Sel->StoredIObjects()); SALOME_ListIteratorOfListIO It(Sel->StoredIObjects());
@ -530,6 +528,10 @@ namespace{
aTitle = QObject::tr( "ASPECTRATIO_ELEMENTS" ); aTitle = QObject::tr( "ASPECTRATIO_ELEMENTS" );
aControl = SMESH_Actor::eAspectRatio; aControl = SMESH_Actor::eAspectRatio;
break; break;
case 6017:
aTitle = QObject::tr( "ASPECTRATIO_3D_ELEMENTS" );
aControl = SMESH_Actor::eAspectRatio3D;
break;
case 6014: case 6014:
aTitle = QObject::tr( "MINIMUMANGLE_ELEMENTS" ); aTitle = QObject::tr( "MINIMUMANGLE_ELEMENTS" );
aControl = SMESH_Actor::eMinimumAngle; aControl = SMESH_Actor::eMinimumAngle;
@ -1076,7 +1078,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_NodesDlg *aDlg = new SMESHGUI_NodesDlg(parent, "", Sel); new SMESHGUI_NodesDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1092,7 +1094,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK )
{ {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SMESHGUI_FilterDlg *aDlg = new SMESHGUI_FilterDlg( parent, SMESH::EDGE ); new SMESHGUI_FilterDlg( parent, SMESH::EDGE );
} }
break; break;
} }
@ -1108,7 +1110,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if(checkLock(aStudy)) break; if(checkLock(aStudy)) break;
SALOME_Selection *Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() ); SALOME_Selection *Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() );
SMESHGUI_MoveNodesDlg *aDlg = new SMESHGUI_MoveNodesDlg( parent, Sel ); new SMESHGUI_MoveNodesDlg( parent, Sel );
break; break;
} }
@ -1216,7 +1218,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_AddSubMeshDlg *aDlg = new SMESHGUI_AddSubMeshDlg(parent, "", Sel); new SMESHGUI_AddSubMeshDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1231,7 +1233,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if(checkLock(aStudy)) break; if(checkLock(aStudy)) break;
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_InitMeshDlg *aDlg = new SMESHGUI_InitMeshDlg(parent, "", Sel); new SMESHGUI_InitMeshDlg(parent, "", Sel);
break; break;
} }
@ -1240,7 +1242,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if(checkLock(aStudy)) break; if(checkLock(aStudy)) break;
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_EditHypothesesDlg *aDlg = new SMESHGUI_EditHypothesesDlg(parent, "", Sel); new SMESHGUI_EditHypothesesDlg(parent, "", Sel);
break; break;
} }
@ -1249,7 +1251,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if(checkLock(aStudy)) break; if(checkLock(aStudy)) break;
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_EditHypothesesDlg *aDlg = new SMESHGUI_EditHypothesesDlg(parent, "", Sel); new SMESHGUI_EditHypothesesDlg(parent, "", Sel);
break; break;
} }
@ -1258,7 +1260,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if(checkLock(aStudy)) break; if(checkLock(aStudy)) break;
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_EditHypothesesDlg *aDlg = new SMESHGUI_EditHypothesesDlg(parent, "", Sel); new SMESHGUI_EditHypothesesDlg(parent, "", Sel);
break; break;
} }
@ -1331,7 +1333,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_SmoothingDlg *aDlg = new SMESHGUI_SmoothingDlg(parent, "", Sel); new SMESHGUI_SmoothingDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1346,7 +1348,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_ExtrusionDlg *aDlg = new SMESHGUI_ExtrusionDlg(parent, "", Sel); new SMESHGUI_ExtrusionDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1361,7 +1363,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_RevolutionDlg *aDlg = new SMESHGUI_RevolutionDlg(parent, "", Sel); new SMESHGUI_RevolutionDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1544,7 +1546,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
for ( ; It.More(); It.Next() ) { for ( ; It.More(); It.Next() ) {
Sel->ClearIObjects(); Sel->ClearIObjects();
Sel->AddIObject( It.Value() ); Sel->AddIObject( It.Value() );
SMESHGUI_MeshInfosDlg *aDlg = new SMESHGUI_MeshInfosDlg(parent, "", false); new SMESHGUI_MeshInfosDlg(parent, "", false);
} }
// restore selection // restore selection
Sel->ClearIObjects(); Sel->ClearIObjects();
@ -1552,7 +1554,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
Sel->AddIObject( It.Value() ); Sel->AddIObject( It.Value() );
} }
else else
SMESHGUI_MeshInfosDlg *aDlg = new SMESHGUI_MeshInfosDlg(parent, "", false); new SMESHGUI_MeshInfosDlg(parent, "", false);
break; break;
} }
@ -1567,7 +1569,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
for ( ; It.More(); It.Next() ) { for ( ; It.More(); It.Next() ) {
Sel->ClearIObjects(); Sel->ClearIObjects();
Sel->AddIObject( It.Value() ); Sel->AddIObject( It.Value() );
SMESHGUI_StandardMeshInfosDlg *aDlg = new SMESHGUI_StandardMeshInfosDlg(parent, "", false); new SMESHGUI_StandardMeshInfosDlg(parent, "", false);
} }
// restore selection // restore selection
Sel->ClearIObjects(); Sel->ClearIObjects();
@ -1575,7 +1577,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
Sel->AddIObject( It.Value() ); Sel->AddIObject( It.Value() );
} }
else else
SMESHGUI_StandardMeshInfosDlg *aDlg = new SMESHGUI_StandardMeshInfosDlg(parent, "", false); new SMESHGUI_StandardMeshInfosDlg(parent, "", false);
break; break;
} }
@ -1825,8 +1827,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
type = SMDSAbs_Volume; nbNodes = 8; break; type = SMDSAbs_Volume; nbNodes = 8; break;
default:; default:;
} }
SMESHGUI_AddMeshElementDlg *aDlg = new SMESHGUI_AddMeshElementDlg(parent, "", Sel, type, nbNodes);
new SMESHGUI_AddMeshElementDlg(parent, "", Sel, type, nbNodes);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1842,7 +1843,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_RemoveNodesDlg *aDlg = new SMESHGUI_RemoveNodesDlg(parent, "", Sel); new SMESHGUI_RemoveNodesDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1857,7 +1858,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_RemoveElementsDlg *aDlg = new SMESHGUI_RemoveElementsDlg(parent, "", Sel); new SMESHGUI_RemoveElementsDlg(parent, "", Sel);
} }
else else
{ {
@ -1873,7 +1874,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_RenumberingDlg *aDlg = new SMESHGUI_RenumberingDlg(parent, "", Sel, 0); new SMESHGUI_RenumberingDlg(parent, "", Sel, 0);
} }
else else
{ {
@ -1889,7 +1890,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_RenumberingDlg *aDlg = new SMESHGUI_RenumberingDlg(parent, "", Sel, 1); new SMESHGUI_RenumberingDlg(parent, "", Sel, 1);
} }
else else
{ {
@ -1905,7 +1906,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_TranslationDlg *aDlg = new SMESHGUI_TranslationDlg(parent, "", Sel); new SMESHGUI_TranslationDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1920,7 +1921,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_RotationDlg *aDlg = new SMESHGUI_RotationDlg(parent, "", Sel); new SMESHGUI_RotationDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1935,7 +1936,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_SymmetryDlg *aDlg = new SMESHGUI_SymmetryDlg(parent, "", Sel); new SMESHGUI_SymmetryDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1950,7 +1951,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_SewingDlg *aDlg = new SMESHGUI_SewingDlg(parent, "", Sel); new SMESHGUI_SewingDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1965,7 +1966,7 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) {
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection()); SALOME_Selection *Sel = SALOME_Selection::Selection(myActiveStudy->getSelection());
SMESHGUI_MergeNodesDlg *aDlg = new SMESHGUI_MergeNodesDlg(parent, "", Sel); new SMESHGUI_MergeNodesDlg(parent, "", Sel);
} }
else { else {
QAD_MessageBox::warn1(QAD_Application::getDesktop(), QAD_MessageBox::warn1(QAD_Application::getDesktop(),
@ -1980,16 +1981,14 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
{ {
if(checkLock(aStudy)) break; if(checkLock(aStudy)) break;
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SMESHGUI_CreateHypothesesDlg *aDlg = new SMESHGUI_CreateHypothesesDlg (parent, "", FALSE, false);
new SMESHGUI_CreateHypothesesDlg (parent, "", FALSE, false);
break; break;
} }
case 5010: // ALGO case 5010: // ALGO
{ {
if(checkLock(aStudy)) break; if(checkLock(aStudy)) break;
EmitSignalDeactivateDialog(); EmitSignalDeactivateDialog();
SMESHGUI_CreateHypothesesDlg *aDlg = new SMESHGUI_CreateHypothesesDlg (parent, "", FALSE, true);
new SMESHGUI_CreateHypothesesDlg (parent, "", FALSE, true);
break; break;
} }
@ -2007,7 +2006,8 @@ bool SMESHGUI::OnGUIEvent(int theCommandID, QAD_Desktop * parent)
} }
break; break;
case 6016: // CONTROLS case 6017: // CONTROLS
case 6016:
case 6015: case 6015:
case 6014: case 6014:
case 6013: case 6013:
@ -2332,13 +2332,13 @@ bool SMESHGUI::CustomPopup(QAD_Desktop* parent, QPopupMenu* popup, const QString
if ( mi && mi->popup() ) { if ( mi && mi->popup() ) {
int prType = ac->GetRepresentation(); int prType = ac->GetRepresentation();
// Display Mode / Wireframe // Display Mode / Wireframe
if(!aNbFaces && !aNbVolumes && !aNbEdges){ if(aNbVolumes == 0 && aNbFaces == 0 && aNbEdges == 0){
mi->popup()->removeItem( 211 ); mi->popup()->removeItem( 211 );
}else{ }else{
mi->popup()->setItemChecked( 211, prType == SMESH_Actor::eEdge ); mi->popup()->setItemChecked( 211, prType == SMESH_Actor::eEdge );
} }
// Display Mode / Shading // Display Mode / Shading
if(!aNbFaces && !aNbVolumes){ if(aNbFaces == 0 && aNbVolumes == 0){
mi->popup()->removeItem( 212 ); mi->popup()->removeItem( 212 );
}else{ }else{
mi->popup()->setItemChecked( 212, prType == SMESH_Actor::eSurface ); mi->popup()->setItemChecked( 212, prType == SMESH_Actor::eSurface );
@ -2374,6 +2374,8 @@ bool SMESHGUI::CustomPopup(QAD_Desktop* parent, QPopupMenu* popup, const QString
mi->popup()->setItemChecked( 6012, true ); break; mi->popup()->setItemChecked( 6012, true ); break;
case SMESH_Actor::eAspectRatio: case SMESH_Actor::eAspectRatio:
mi->popup()->setItemChecked( 6013, true ); break; mi->popup()->setItemChecked( 6013, true ); break;
case SMESH_Actor::eAspectRatio3D:
mi->popup()->setItemChecked( 6017, true ); break;
case SMESH_Actor::eMinimumAngle: case SMESH_Actor::eMinimumAngle:
mi->popup()->setItemChecked( 6014, true ); break; mi->popup()->setItemChecked( 6014, true ); break;
case SMESH_Actor::eWarping: case SMESH_Actor::eWarping:
@ -2387,12 +2389,12 @@ bool SMESHGUI::CustomPopup(QAD_Desktop* parent, QPopupMenu* popup, const QString
break; break;
} }
TVisualObjPtr aVisualObj = ac->GetObject(); TVisualObjPtr aVisualObj = ac->GetObject();
if(!aNbEdges){ if(aNbEdges == 0){
mi->popup()->removeItem( 6001 ); mi->popup()->removeItem( 6001 );
mi->popup()->removeItem( 6003 ); mi->popup()->removeItem( 6003 );
mi->popup()->removeItem( 6004 ); mi->popup()->removeItem( 6004 );
} }
if(!aNbFaces){ if(aNbFaces == 0){
mi->popup()->removeItem( 6002 ); mi->popup()->removeItem( 6002 );
mi->popup()->removeItem( 6011 ); mi->popup()->removeItem( 6011 );
mi->popup()->removeItem( 6012 ); mi->popup()->removeItem( 6012 );
@ -2401,7 +2403,10 @@ bool SMESHGUI::CustomPopup(QAD_Desktop* parent, QPopupMenu* popup, const QString
mi->popup()->removeItem( 6015 ); mi->popup()->removeItem( 6015 );
mi->popup()->removeItem( 6016 ); mi->popup()->removeItem( 6016 );
} }
if(!aNbFaces && !aNbEdges) if(aNbVolumes == 0){
mi->popup()->removeItem( 6017 );
}
if(aNbFaces == 0 && aNbEdges == 0 && aNbVolumes == 0)
popup->removeItem( 2000 ); // Scalar Bar popup->removeItem( 2000 ); // Scalar Bar
} }
} }

View File

@ -1107,6 +1107,9 @@ msgstr "Taper"
msgid "ASPECTRATIO_ELEMENTS" msgid "ASPECTRATIO_ELEMENTS"
msgstr "Aspect Ratio" msgstr "Aspect Ratio"
msgid "ASPECTRATIO_3D_ELEMENTS"
msgstr "Aspect Ratio 3D"
msgid "MINIMUMANGLE_ELEMENTS" msgid "MINIMUMANGLE_ELEMENTS"
msgstr "Minimum Angle" msgstr "Minimum Angle"

View File

@ -334,6 +334,22 @@ FunctorType AspectRatio_i::GetFunctorType()
} }
/*
Class : AspectRatio3D
Description : Functor for calculating aspect ratio 3D
*/
AspectRatio3D_i::AspectRatio3D_i()
{
myNumericalFunctorPtr.reset( new Controls::AspectRatio3D() );
myFunctorPtr = myNumericalFunctorPtr;
}
FunctorType AspectRatio3D_i::GetFunctorType()
{
return SMESH::FT_AspectRatio3D;
}
/* /*
Class : Warping_i Class : Warping_i
Description : Functor for calculating warping Description : Functor for calculating warping
@ -974,6 +990,14 @@ AspectRatio_ptr FilterManager_i::CreateAspectRatio()
} }
AspectRatio3D_ptr FilterManager_i::CreateAspectRatio3D()
{
SMESH::AspectRatio3D_i* aServant = new SMESH::AspectRatio3D_i();
SMESH::AspectRatio3D_var anObj = aServant->_this();
return anObj._retn();
}
Warping_ptr FilterManager_i::CreateWarping() Warping_ptr FilterManager_i::CreateWarping()
{ {
SMESH::Warping_i* aServant = new SMESH::Warping_i(); SMESH::Warping_i* aServant = new SMESH::Warping_i();
@ -1405,6 +1429,9 @@ CORBA::Boolean Filter_i::SetCriteria( const SMESH::Filter::Criteria& theCriteria
case SMESH::FT_AspectRatio: case SMESH::FT_AspectRatio:
aFunctor = aFilterMgr->CreateAspectRatio(); aFunctor = aFilterMgr->CreateAspectRatio();
break; break;
case SMESH::FT_AspectRatio3D:
aFunctor = aFilterMgr->CreateAspectRatio3D();
break;
case SMESH::FT_Warping: case SMESH::FT_Warping:
aFunctor = aFilterMgr->CreateWarping(); aFunctor = aFilterMgr->CreateWarping();
break; break;

View File

@ -35,7 +35,7 @@
#include <TopoDS_Shape.hxx> #include <TopoDS_Shape.hxx>
#include "SALOME_GenericObj_i.hh" #include "SALOME_GenericObj_i.hh"
#include "SMESH_Controls.hxx" #include "SMESH_ControlsDef.hxx"
class SMESHDS_Mesh; class SMESHDS_Mesh;
@ -141,6 +141,19 @@ public:
}; };
/*
Class : AspectRatio3D_i
Description : Functor for calculating aspect ratio for 3D
*/
class AspectRatio3D_i: public virtual POA_SMESH::AspectRatio3D,
public virtual NumericalFunctor_i
{
public:
AspectRatio3D_i();
FunctorType GetFunctorType();
};
/* /*
Class : Warping_i Class : Warping_i
Description : Functor for calculating warping Description : Functor for calculating warping
@ -583,6 +596,7 @@ public:
FilterManager_i(); FilterManager_i();
MinimumAngle_ptr CreateMinimumAngle(); MinimumAngle_ptr CreateMinimumAngle();
AspectRatio_ptr CreateAspectRatio(); AspectRatio_ptr CreateAspectRatio();
AspectRatio3D_ptr CreateAspectRatio3D();
Warping_ptr CreateWarping(); Warping_ptr CreateWarping();
Taper_ptr CreateTaper(); Taper_ptr CreateTaper();
Skew_ptr CreateSkew(); Skew_ptr CreateSkew();

View File

@ -41,18 +41,18 @@
#include "OpUtil.hxx" #include "OpUtil.hxx"
#include "TCollection_AsciiString.hxx" #include "TCollection_AsciiString.hxx"
#include <TColStd_MapOfInteger.hxx>
#include <TColStd_MapIteratorOfMapOfInteger.hxx>
#include <TColStd_SequenceOfInteger.hxx>
#include "SMESHDS_Command.hxx" #include "SMESHDS_Command.hxx"
#include "SMESHDS_CommandType.hxx" #include "SMESHDS_CommandType.hxx"
#include "SMESH_MeshEditor_i.hxx" #include "SMESH_MeshEditor_i.hxx"
#include "SMESH_Gen_i.hxx" #include "SMESH_Gen_i.hxx"
#include "DriverMED_R_SMESHDS_Mesh.h" #include "DriverMED_R_SMESHDS_Mesh.h"
#include <TColStd_MapOfInteger.hxx>
#include <TColStd_MapIteratorOfMapOfInteger.hxx>
#include <TColStd_SequenceOfInteger.hxx>
#include <string> #include <string>
#include <iostream> #include <iostream>
// _CS_gbo_050504 Ajout explicite du sstream pour ostringstream
#include <sstream> #include <sstream>
#ifdef _DEBUG_ #ifdef _DEBUG_