Merge from V6_2_BR 23/12/2010

This commit is contained in:
inv 2010-12-24 08:18:34 +00:00
parent d5dd413d3b
commit 2de294b09a
83 changed files with 4373 additions and 1089 deletions

View File

@ -41,7 +41,7 @@ SUBDIRS = idl adm_local resources src doc bin
DIST_SUBDIRS = idl adm_local resources src doc bin DIST_SUBDIRS = idl adm_local resources src doc bin
DISTCLEANFILES = a.out aclocal.m4 configure local-install.sh DISTCLEANFILES = a.out aclocal.m4 configure local-install.sh hack_libtool
salomeinclude_DATA = SMESH_version.h salomeinclude_DATA = SMESH_version.h

View File

@ -444,6 +444,9 @@ sed -i "s%^CC=\"\(.*\)\"%hack_libtool (){ \n\
$(pwd)/hack_libtool \1 \"\$[@]\" \n\ $(pwd)/hack_libtool \1 \"\$[@]\" \n\
}\n\ }\n\
CC=\"hack_libtool\"%g" libtool CC=\"hack_libtool\"%g" libtool
sed -i "s%\(\s*\)for searchdir in \$newlib_search_path \$lib_search_path \$sys_lib_search_path \$shlib_search_path; do%\1searchdirs=\"\$newlib_search_path \$lib_search_path \$sys_lib_search_path \$shlib_search_path\"\n\1for searchdir in \$searchdirs; do%g" libtool
sed -i "s%\(\s*\)searchdirs=\"\$newlib_search_path \$lib_search_path \(.*\)\"%\1searchdirs=\"\$newlib_search_path \$lib_search_path\"\n\1sss_beg=\"\"\n\1sss_end=\"\2\"%g" libtool
sed -i "s%\(\s*\)\(for searchdir in \$searchdirs; do\)%\1for sss in \$searchdirs; do\n\1 if ! test -d \$sss; then continue; fi\n\1 ssss=\$(cd \$sss; pwd)\n\1 if test \"\$ssss\" != \"\" \&\& test -d \$ssss; then\n\1 case \$ssss in\n\1 /usr/lib | /usr/lib64 ) ;;\n\1 * ) sss_beg=\"\$sss_beg \$ssss\" ;;\n\1 esac\n\1 fi\n\1done\n\1searchdirs=\"\$sss_beg \$sss_end\"\n\1\2%g" libtool
],[]) ],[])
# This list is initiated using autoscan and must be updated manually # This list is initiated using autoscan and must be updated manually
@ -460,6 +463,7 @@ AC_OUTPUT([ \
SMESH_version.h \ SMESH_version.h \
doc/Makefile \ doc/Makefile \
doc/docutils/Makefile \ doc/docutils/Makefile \
doc/docutils/conf.py \
doc/salome/Makefile \ doc/salome/Makefile \
doc/salome/gui/Makefile \ doc/salome/gui/Makefile \
doc/salome/gui/SMESH/Makefile \ doc/salome/gui/SMESH/Makefile \

View File

@ -47,7 +47,7 @@ htm:
mkdir -p html doctrees mkdir -p html doctrees
PYTHONPATH=$(SPHINX_PYTHONPATH):${PYTHONPATH} \ PYTHONPATH=$(SPHINX_PYTHONPATH):${PYTHONPATH} \
LD_LIBRARY_PATH=$(SPHINX_LD_LIBRARY_PATH):${LD_LIBRARY_PATH} \ LD_LIBRARY_PATH=$(SPHINX_LD_LIBRARY_PATH):${LD_LIBRARY_PATH} \
$(SPHINXBUILD) -W -b html $(ALLSPHINXOPTS) html $(SPHINXBUILD) -c $(top_builddir)/doc/docutils -W -b html $(ALLSPHINXOPTS) html
@echo @echo
@echo "Build finished. The HTML pages are in html." @echo "Build finished. The HTML pages are in html."
@ -55,7 +55,7 @@ latex:
mkdir -p latex doctrees mkdir -p latex doctrees
PYTHONPATH=$(SPHINX_PYTHONPATH):${PYTHONPATH} \ PYTHONPATH=$(SPHINX_PYTHONPATH):${PYTHONPATH} \
LD_LIBRARY_PATH=$(SPHINX_LD_LIBRARY_PATH):${LD_LIBRARY_PATH} \ LD_LIBRARY_PATH=$(SPHINX_LD_LIBRARY_PATH):${LD_LIBRARY_PATH} \
$(SPHINXBUILD) -W -b latex $(ALLSPHINXOPTS) latex $(SPHINXBUILD) -c $(top_builddir)/doc/docutils -W -b latex $(ALLSPHINXOPTS) latex
@echo @echo
@echo "Build finished; the LaTeX files are in latex." @echo "Build finished; the LaTeX files are in latex."
@echo "Run \`make all-pdf' or \`make all-ps' in that directory to" \ @echo "Run \`make all-pdf' or \`make all-ps' in that directory to" \
@ -71,9 +71,6 @@ RSTFILES= \
EXTRA_DIST+= $(RSTFILES) EXTRA_DIST+= $(RSTFILES)
EXTRA_DIST+= \
conf.py
install-data-local: html/index.html install-data-local: html/index.html
test -z $(pydocdir) || mkdir -p $(DESTDIR)$(pydocdir) test -z $(pydocdir) || mkdir -p $(DESTDIR)$(pydocdir)
if test -d "html"; then b=; else b="$(srcdir)/"; fi; \ if test -d "html"; then b=; else b="$(srcdir)/"; fi; \

View File

@ -54,9 +54,9 @@ copyright = '2010 EDF R&D'
# built documents. # built documents.
# #
# The short X.Y version. # The short X.Y version.
version = '6.2.0' version = '@VERSION@'
# The full version, including alpha/beta/rc tags. # The full version, including alpha/beta/rc tags.
release = '6.2.0' release = '@VERSION@'
# The language for content autogenerated by Sphinx. Refer to documentation # The language for content autogenerated by Sphinx. Refer to documentation
# for a list of supported languages. # for a list of supported languages.

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB

View File

@ -16,6 +16,9 @@ for example, a face.
Several created meshes can be \subpage building_compounds_page "combined into mesh compounds". Several created meshes can be \subpage building_compounds_page "combined into mesh compounds".
The whole mesh or it's part can be \subpage copy_mesh_page "copied"
into another mesh.
All created meshes and submeshes can be \subpage editing_meshes_page "edited". All created meshes and submeshes can be \subpage editing_meshes_page "edited".
Meshes can be also edited using the MESH functions destined for Meshes can be also edited using the MESH functions destined for

View File

@ -32,6 +32,8 @@ Edge quality controls:
Face quality controls: Face quality controls:
<ul> <ul>
<li>\subpage free_faces_page "Free faces"</li> <li>\subpage free_faces_page "Free faces"</li>
<li>\subpage bare_border_faces_page "Bare border faces"</li>
<li>\subpage over_constrained_faces_page "Over-constrained faces"</li>
<li>\subpage length_2d_page "Length 2D"</li> <li>\subpage length_2d_page "Length 2D"</li>
<li>\subpage borders_at_multi_connection_2d_page "Borders at multi-connection 2D"</li> <li>\subpage borders_at_multi_connection_2d_page "Borders at multi-connection 2D"</li>
<li>\subpage area_page "Area"</li> <li>\subpage area_page "Area"</li>
@ -40,14 +42,31 @@ Face quality controls:
<li>\subpage minimum_angle_page "Minimum angle"</li> <li>\subpage minimum_angle_page "Minimum angle"</li>
<li>\subpage warping_page "Warping"</li> <li>\subpage warping_page "Warping"</li>
<li>\subpage skew_page "Skew"</li> <li>\subpage skew_page "Skew"</li>
<li>\subpage max_element_length_2d_page "Max element length 2D"</li> <li>\subpage max_element_length_2d_page "Element Diameter 2D"</li>
</ul> </ul>
Volume quality controls: Volume quality controls:
<ul> <ul>
<li>\subpage aspect_ratio_3d_page "Aspect ratio 3D"</li> <li>\subpage aspect_ratio_3d_page "Aspect ratio 3D"</li>
<li>\subpage volume_page "Volume"</li> <li>\subpage volume_page "Volume"</li>
<li>\subpage max_element_length_3d_page "Max element length 3D"</li> <li>\subpage max_element_length_3d_page "Element Diameter 3D"</li>
<li>\subpage bare_border_volumes_page "Bare border volumes"</li>
<li>\subpage over_constrained_volumes_page "Over-constrained volumes"</li>
</ul> </ul>
To manage the quality controls call pop-up in the VTK viewer and select "Controls" sub-menu
\image html controls_popup.png
<ul>
<li> <b>Reset</b> switches off quality controls;</li>
<li> <b>Node Controls</b> provides access to the node quality controls;</li>
<li> <b>Edge Controls</b> provides access to the edge quality controls;</li>
<li> <b>Face Controls</b> provides access to the face quality controls;</li>
<li> <b>Volume Controls</b> provides access to the volume quality controls;</li>
<li> <b>Scalar Bar Properties</b> allows setting \subpage scalar_bar_dlg;</li>
<li> <b>Export Distribution...</b> allows saving the distribution of quality control values in the text file;</li>
<li> <b>Show Distribution</b> Shows/Hides the distribution histogram of the quality control values in the VTK Viewer.</li>
</ul>
*/ */

View File

@ -0,0 +1,15 @@
/*!
\page bare_border_faces_page Bare border faces
This mesh quality control highlights the faces having the border not
shared with other faces (free border) and missing an edge based on
nodes of the free border. The faces with bare border are shown with a
color different from the color of shared faces.
\image html bare_border_faces_smpl.png
\sa A sample TUI Script making a group of faces highlighted in the
picture is \ref tui_bare_border_faces "Bare border faces Control".
*/

View File

@ -0,0 +1,15 @@
/*!
\page bare_border_volumes_page Bare border volumes
This mesh quality control highlights the volumes having the border not
shared with other volumes (free border) and missing a face based on
nodes of the free border. The volumes with bare border are shown with a
color different from the color of shared volumes.
\image html bare_border_volumes_smpl.png
\sa A sample TUI Script making a group of volumes highlighted in the
picture is \ref tui_bare_border_volumes "Bare border volumes Control".
*/

View File

@ -0,0 +1,56 @@
/*!
\page copy_mesh_page Copy Mesh
\n A mesh can be created by copying a part of or the whole other mesh.
<em>To make a copy of a mesh:</em>
\par
From the \b Mesh menu select <b>Copy Mesh</b> or click <em>"Copy Mesh"</em>
button in the toolbar.
\image html copy_mesh_icon.png
<center><em>"Copy Mesh" button</em></center>
\par
The following dialog box will appear:
\image html copy_mesh_dlg.png
\par
In the dialog:
<ul>
<li>specify the part of mesh to copy:
<ul>
<li><b>Select the whole mesh, submesh or group</b> by mouse activating
this checkbox; or</li>
<li>choose mesh elements with the mouse in the 3D Viewer. It is
possible to select a whole area with a mouse frame; or</li>
<li>input the <b>Source Element IDs</b> directly in this field. The
selected elements will be highlighted in the viewer; or</li>
<li>apply Filters. <b>Set filter</b> button allows to apply a filter
to the selection of elements. See more about filters in the \ref
selection_filter_library_page "Selection filter library" page.</li>
</ul>
</li>
<li>specify the <b>New Mesh Name</b>;</li>
<li>specify the conditions of copying:
<ul>
<li>activate <b>Generate groups</b> checkbox to copy the groups of
elements of the source mesh to the newly created mesh.</li>
<li>activate <b>Preserve IDs of elements</b> checkbox to keep
the IDs of new nodes and elements the same as the IDs of source nodes
and elements.</li>
</ul>
</li>
<li>Click \b Apply or <b>Apply and Close</b> button to confirm the operation.</li>
</ul>
<b>See Also</b> a sample
\ref tui_copy_mesh "TUI Example of mesh copying."
*/

View File

@ -0,0 +1,14 @@
/*!
\page over_constrained_faces_page Over-constrained faces
\n This mesh quality control highlights faces sharing only one of its borders with other faces.
\image html over_constrained_faces.png
In this picture the over-constrained face is displayed in red.
<br><b>See Also</b> a sample TUI Script of a
\ref tui_over_constrained_faces "Over-constrained faces" filter.
*/

View File

@ -0,0 +1,14 @@
/*!
\page over_constrained_volumes_page Over-constrained volumes
\n This mesh quality control highlights volumes sharing only one of its borders with other volumes.
\image html over_constrained_volumes.png
In this picture the over-constrained volume is displayed in red.
<br><b>See Also</b> a sample TUI Script of a
\ref tui_over_constrained_volumes "Over-constrained volumes" filter.
*/

View File

@ -17,12 +17,13 @@ The following dialog box will appear:
\image html projection_1d.png \image html projection_1d.png
In this menu you can define the \b Name of the algorithm, the already In this menu you can define the \b Name of the algorithm, the already
meshed source \b Edge and the \b Mesh (optional, use it if there are several meshed source \b Edge and the \b Mesh (It can be omitted only when
different meshes on the same edge). It could also be necessary to projecting a submesh on another one from the same global Mesh).
define the orientation of edges, which is done by indicating the It could also be necessary to define the orientation of edges,
<b>Source Vertex</b> being the first point of the Source Edge and the which is done by indicating the <b>Source Vertex</b> being the first point
<b>Target Vertex</b> being the first point of the created \b Edge. For of the Source Edge and the <b>Target Vertex</b> being the first point of
a group of edges, <b>Source</b> and <b>Target</b> vertices should be the created \b Edge.
For a group of edges, <b>Source</b> and <b>Target</b> vertices should be
shared by only one edge of the group. If <b>Source</b> and shared by only one edge of the group. If <b>Source</b> and
<b>Target</b> vertices are specified, the elements of the group must be ajacent. <b>Target</b> vertices are specified, the elements of the group must be ajacent.
@ -42,17 +43,17 @@ following dialog box will appear:
\image html projection_2d.png \image html projection_2d.png
In this menu you can define the \b Name of the algorithm, the already In this menu you can define the \b Name of the algorithm, the already
meshed source \b Face and the \b Mesh (optional, use it if there are several meshed source \b Face and the \b Mesh (It can be omitted only when
different meshes on the same face). It could also be necessary to projecting a submesh on another one from the same global Mesh).
define the orientation of mesh on the face, which is done by It could also be necessary to define the orientation of mesh on the face
indicating two <b>Source Vertices</b>, which belong to the same edge of the , which is done by indicating two <b>Source Vertices</b>, which belong
source face, and two <b>Target Vertices</b>, which belong to the same edge of to the same edge of the source face, and two <b>Target Vertices</b>, which
the created \b Face. belong to the same edge of the created \b Face.
\n <b>Projection 3D</b> algorithm allows to define the mesh of a shape by \n <b>Projection 3D</b> algorithm allows to define the mesh of a shape by
the projection of another already meshed shape. This algorithm works the projection of another already meshed shape. This algorithm works
only if all faces and edges of the target face have been meshed as 1D only if all faces and edges of the target shape have been meshed as 1D-2D
Projections of the faces and edges of the source face. Another Projections of the faces and edges of the source shape. Another
limitation is that this algorithm currently works only on boxes. limitation is that this algorithm currently works only on boxes.
To apply this algorithm select the solid to be meshed (indicated in To apply this algorithm select the solid to be meshed (indicated in
@ -63,9 +64,9 @@ following dialog box will appear:
\image html projection_3d.png \image html projection_3d.png
In this menu you can define the \b Name of the algorithm, the already In this menu you can define the \b Name of the algorithm, the already
meshed source <b>3D shape</b> and the \b Mesh (optional, use it if there are meshed source <b>3D shape</b> and the \b Mesh (It can be omitted only when
several different meshes on the same shape). It could also be projecting a submesh on another one from the same global Mesh).
necessary to define the orientation of mesh on the shape, which is It could also be necessary to define the orientation of mesh on the shape, which is
done by indicating two <b>Source Vertices</b>, which belong to the same edge done by indicating two <b>Source Vertices</b>, which belong to the same edge
of the source <b>3D Shape</b>, and two <b>Target Vertices</b>, which belong to the of the source <b>3D Shape</b>, and two <b>Target Vertices</b>, which belong to the
same edge of the source <b>3D Shape</b>. same edge of the source <b>3D Shape</b>.

View File

@ -0,0 +1,40 @@
/*!
\page scalar_bar_dlg Scalar Bar properties
In this dialog you can specify the properties of the scalar bar
\image html scalar_bar_dlg.png
<ul>
<li><b>Scalar Range</b> in this menu you can specify
<b>Min value</b> and <b>Max value</b> of the <b>Scalar Bar</b> </li>
<li><b>Font</b> - in this menu you can set type, face and color for
the font of <b>Title</b> and <b>Labels</b> of the <b>Scalar
Bar</b></li>
<li><b>Colors & Labels</b> - in this menu you can set the <b>number of
colors</b> and the <b>number of labels</b> of the <b>Scalar
Bar</b></li>
<li><b>Orientation</b> - allows choosing between vertical and
horizontal orientation of the <b>Scalar Bar</b></li>.
<li><b>Origin & Size Vertical & Horizontal</b> - allows defining the
location (<b>X</b> and <b>Y</b>) and size (<b>Width</b> and
<b>Height</b>) of <b>Scalar Bar</b></li>
<ul>
<li><b>X</b>: abscissa of the origin (from the left
side)</li>
<li><b>Y</b>: ordinate of the origin (from the bottom)</li>
</ul>
<li><b>Distribution</b> in this menu you can Show/Hide distribution histogram of the values of the <b>Scalar Bar</b> and specify histogram properties</li>
<ul>
<li><b>Multicolor</b> the histogram is colored as <b>Scalar Bar</b></li>
<li><b>Monocolor</b> the histogram is colored as selected with <b>Distribution color</b> selector</li>
</ul>
</ul>
*/

View File

@ -144,7 +144,14 @@ Additional criteria to select mesh <b>Faces</b> are the following:
one element of mesh only. See also a one element of mesh only. See also a
\ref free_edges_page "Free Edges quality control". \ref free_edges_page "Free Edges quality control".
</li><li> </li><li>
<b>Free faces</b> selects 3D mesh elements wich belong to less than two volumes. <b>Free faces</b> selects 2D mesh elements wich belong to less than two volumes.
</li><li>
<b>Faces with bare border</b> selects 2D mesh elements having a free border without an edge on it.
See also \ref bare_border_faces_page "Bare border faces quality control".
</li><li>
<b>Over-constrained faces</b> selects 2D mesh elements having only one border shared
with other 2D elements.
See also \ref over_constrained_faces_page "Over-constrained faces quality control".
</li><li> </li><li>
<b>Borders at Multi-Connections 2D</b> selects cells consisting of edges belonging to <b>Borders at Multi-Connections 2D</b> selects cells consisting of edges belonging to
several elements of mesh. The number of mesh elements should be more, less or equal several elements of mesh. The number of mesh elements should be more, less or equal
@ -187,6 +194,13 @@ diagonals with a value of length, which is more, less or equal
</li><li> </li><li>
<b>Bad oriented volume</b> selects mesh volumes, which are incorrectly oriented from <b>Bad oriented volume</b> selects mesh volumes, which are incorrectly oriented from
the point of view of MED convention. the point of view of MED convention.
</li><li>
<b>Over-constrained volumes</b> selects mesh volumes having only one border shared
with other volumes.
See also \ref over_constrained_volumes_page "Over-constrained volumes quality control".
</li><li>
<b>Volumes with bare border</b> selects 3D mesh elements having a free border without a face on it.
See also \ref bare_border_volumes_page "Bare border volumes quality control".
</li> </li>
</ul> </ul>

View File

@ -249,4 +249,48 @@ demonstrating the resulting mesh.
\skipline import geompy \skipline import geompy
\until #end \until #end
<br>
\anchor tui_copy_mesh
<h2>Mesh Copying</h2>
\code
from smesh import *
SetCurrentStudy(salome.myStudy)
# make geometry of a box
box = geompy.MakeBoxDXDYDZ(100,100,100)
face = geompy.SubShapeAllSorted(box, geompy.ShapeType["FACE"])[0]
# generate 3D mesh
mesh = Mesh(box)
localAlgo = mesh.Triangle(face)
mesh.AutomaticHexahedralization()
# objects to copy
fGroup = mesh.GroupOnGeom( face, "2D on face")
nGroup = mesh.GroupOnGeom( face, "nodes on face", NODE)
subMesh = localAlgo.GetSubMesh()
# make a new mesh by copying different part of the mesh
# 1. copy the whole mesh
newMesh = CopyMesh( mesh, "whole mesh copy")
# 2. copy a group of 2D elements along with groups
newMesh = CopyMesh( fGroup, "face group copy with groups",toCopyGroups=True)
# 3. copy a group of nodes with preseving their ids
newMesh = CopyMesh( nGroup, "node group copy", toKeepIDs=True)
# 4. copy some faces
faceIds = fGroup.GetIDs()[-10:]
newMesh = CopyMesh( mesh.GetIDSource( faceIds, FACE ), "some faces copy")
# 5. copy some nodes
nodeIds = nGroup.GetIDs()[-10:]
newMesh = CopyMesh( mesh.GetIDSource( nodeIds, NODE), "some nodes copy")
# 6. copy a sub-mesh
newMesh = CopyMesh( subMesh, "submesh copy" )
\endcode
*/ */

View File

@ -90,7 +90,7 @@ Filter 2D mesh elements (faces) according to the minimum angle value:
# create mesh # create mesh
from SMESH_mechanic import * from SMESH_mechanic import *
# get faces with minimum angle > 75 # get faces with minimum angle > 75
filter = smesh.GetFilter(smesh.FACE, smesh.FT_MinimumAngle, smesh.FT_MoreThan, 75) filter = smesh.GetFilter(smesh.FACE, smesh.FT_MinimumAngle,">", 75)
ids = mesh.GetIdsFromFilter(filter) ids = mesh.GetIdsFromFilter(filter)
print "Number of faces with minimum angle > 75:", len(ids) print "Number of faces with minimum angle > 75:", len(ids)
\endcode \endcode
@ -237,7 +237,7 @@ from SMESH_mechanic import *
# add node # add node
mesh.AddNode(0,0,0) mesh.AddNode(0,0,0)
# get all free nodes # get all free nodes
filter = smesh.GetFilter(smesh.EDGE, smesh.FT_FreeNodes) filter = smesh.GetFilter(smesh.NODE, smesh.FT_FreeNodes)
ids = mesh.GetIdsFromFilter(filter) ids = mesh.GetIdsFromFilter(filter)
print "Number of free nodes:", len(ids) print "Number of free nodes:", len(ids)
\endcode \endcode
@ -255,13 +255,69 @@ Filter free faces:
# create mesh # create mesh
from SMESH_mechanic import * from SMESH_mechanic import *
# get all free faces # get all free faces
filter = smesh.GetFilter(smesh.EDGE, smesh.FT_FreeFaces) filter = smesh.GetFilter(smesh.FACE, smesh.FT_FreeFaces)
ids = mesh.GetIdsFromFilter(filter) ids = mesh.GetIdsFromFilter(filter)
print "Number of free faces:", len(ids) print "Number of free faces:", len(ids)
\endcode \endcode
\sa \ref tui_free_faces \sa \ref tui_free_faces
\section filter_bare_border_faces Bare border faces
Filter faces with bare borders:
- element type is \a smesh.FACE
- functor type is \a smesh.FT_BareBorderFace
- threshold value is not required
\code
# create mesh
from SMESH_mechanic import *
# remove some faces to have faces with bare borders
mesh.RemoveElements( mesh.GetElementsByType(FACE)[0:5] )
# get all faces bare borders
filter = smesh.GetFilter(smesh.FACE, smesh.FT_BareBorderFace)
ids = mesh.GetIdsFromFilter(filter)
print "Faces with bare borders:", ids
\endcode
\sa \ref tui_bare_border_faces
\section filter_coplanar_faces Coplanar faces
Filter faces with bare borders:
- element type is \a smesh.FACE
- functor type is \a smesh.FT_CoplanarFaces
- threshold value is the face ID
- tolerance is in degrees
\code
# create mesh
from SMESH_mechanic import *
faceID = mesh.GetElementsByType(FACE)[0]
# get all faces co-planar to the first face with tolerance 5 degrees
filter = smesh.GetFilter(smesh.FACE, smesh.FT_CoplanarFaces,faceID,Tolerance=5.0)
ids = mesh.GetIdsFromFilter(filter)
print "Number of faces coplanar with the first one:", len(ids)
\endcode
\section filter_over_constrained_faces Over-constrained faces
Filter over-constrained faces:
- element type is \a smesh.FACE
- functor type is \a smesh.FT_OverConstrainedFace
- threshold value is not required
\code
# create mesh
from SMESH_mechanic import *
# get all over-constrained faces
filter = smesh.GetFilter(smesh.FACE, smesh.FT_OverConstrainedFace)
ids = mesh.GetIdsFromFilter(filter)
print "Over-constrained faces:", ids
\endcode
\sa \ref tui_over_constrained_faces
\section filter_borders_multiconnection Borders at multi-connection \section filter_borders_multiconnection Borders at multi-connection
Filter border 1D mesh elements (edges) according to the specified number of Filter border 1D mesh elements (edges) according to the specified number of
@ -377,6 +433,48 @@ print "Number of volumes with maximum element length > 10:", len(ids)
\sa \ref tui_max_element_length_3d \sa \ref tui_max_element_length_3d
\section filter_bare_border_volumes Bare border volumes
Filter 3D mesh elements with bare borders:
- element type is \a smesh.VOLUME
- functor type is \a smesh.FT_BareBorderVolume
- threshold value is not required
\code
# create mesh
from SMESH_mechanic import *
mesh.Tetrahedron()
mesh.Compute()
# remove some volumes to have volumes with bare borders
mesh.RemoveElements( mesh.GetElementsByType(VOLUME)[0:5] )
# get all volumes with bare borders
filter = smesh.GetFilter(smesh.VOLUME, smesh.FT_BareBorderVolume)
ids = mesh.GetIdsFromFilter(filter)
print "Volumes with bare borders:", ids
\endcode
\sa \ref tui_bare_border_volumes
\section filter_over_constrained_volumes Over-constrained volumes
Filter over-constrained volumes:
- element type is \a smesh.VOLUME
- functor type is \a smesh.FT_OverConstrainedVolume
- threshold value is not required
\code
# create mesh
from SMESH_mechanic import *
mesh.Tetrahedron()
mesh.Compute()
# get all over-constrained volumes
filter = smesh.GetFilter(smesh.VOLUME, smesh.FT_OverConstrainedVolume)
ids = mesh.GetIdsFromFilter(filter)
print "Over-constrained volumes:", ids
\endcode
\sa \ref tui_over_constrained_faces
\section filter_belong_to_geom Belong to Geom \section filter_belong_to_geom Belong to Geom
Filter mesh entities (nodes or elements) which all nodes lie on the Filter mesh entities (nodes or elements) which all nodes lie on the

View File

@ -309,6 +309,90 @@ aGroup.Add(aFaceIds)
salome.sg.updateObjBrowser(1) salome.sg.updateObjBrowser(1)
\endcode \endcode
\section tui_bare_border_faces Bare border faces
\code
from smesh import *
SetCurrentStudy(salome.myStudy)
box = geompy.MakeBoxDXDYDZ(100, 100, 100)
geompy.addToStudy( box, "box" )
mesh = smesh.Mesh(box)
mesh.Segment().NumberOfSegments(3)
mesh.Quadrangle()
mesh.Compute()
# remove 2 faces
allFaces = mesh.GetElementsByType(FACE)
mesh.RemoveElements( allFaces[0:2])
bareGroup = mesh.MakeGroup("bare faces", FACE, FT_BareBorderFace)
assert(bareGroup.Size() == 3)
\endcode
\section tui_bare_border_volumes Bare border volumes
\code
from smesh import *
SetCurrentStudy(salome.myStudy)
box = geompy.MakeBoxDXDYDZ(100, 30, 10)
# the smallest face of the box
face = geompy.SubShapeAllSorted( box, geompy.ShapeType["FACE"])[0]
geompy.addToStudy( box, "box" )
geompy.addToStudyInFather( box, face, "face" )
mesh = Mesh(box)
mesh.AutomaticHexahedralization();
# remove half of mesh faces from the smallest face
faceFaces = mesh.GetSubMeshElementsId(face)
faceToRemove = faceFaces[: len(faceFaces)/2]
mesh.RemoveElements( faceToRemove )
# make a group of volumes missing the removed faces
bareGroup = mesh.MakeGroup("bare volumes", VOLUME, FT_BareBorderVolume)
assert(bareGroup.Size() == len( faceToRemove))
\endcode
\section tui_over_constrained_faces Over-constrained faces
\code
from smesh import *
SetCurrentStudy(salome.myStudy)
mesh = Mesh()
faceFilter = GetFilter(FACE,FT_OverConstrainedFace)
#make an edge
n1 = mesh.AddNode(0,0,0)
n2 = mesh.AddNode(10,0,0)
edge = mesh.AddEdge([n1,n2])
assert( not mesh.GetIdsFromFilter( faceFilter ))
# make faces
mesh.ExtrusionSweep([edge], MakeDirStruct(0,7,0), 5)
assert( 2 == len( mesh.GetIdsFromFilter( faceFilter )))
\endcode
\section tui_over_constrained_volumes Over-constrained volumes
\code
from smesh import *
SetCurrentStudy(salome.myStudy)
mesh = Mesh()
volumeFilter = GetFilter(VOLUME,FT_OverConstrainedVolume)
# make volumes by extrusion of one face
n1 = mesh.AddNode(0,0,0)
n2 = mesh.AddNode(10,0,0)
edge = mesh.AddEdge([n1,n2])
mesh.ExtrusionSweep([edge], MakeDirStruct(0,7,0), 1)
mesh.ExtrusionSweep( mesh.GetElementsByType(FACE), MakeDirStruct(0,0,5), 7)
assert( 2 == len( mesh.GetIdsFromFilter( volumeFilter )))
\endcode
\section tui_length_2d Length 2D \section tui_length_2d Length 2D
\code \code

View File

@ -64,6 +64,10 @@ module SMESH
FT_LyingOnGeom, FT_LyingOnGeom,
FT_RangeOfIds, FT_RangeOfIds,
FT_BadOrientedVolume, FT_BadOrientedVolume,
FT_BareBorderVolume,
FT_BareBorderFace,
FT_OverConstrainedVolume,
FT_OverConstrainedFace,
FT_LinearOrQuadratic, FT_LinearOrQuadratic,
FT_GroupColor, FT_GroupColor,
FT_ElemGeomType, FT_ElemGeomType,
@ -88,6 +92,7 @@ module SMESH
}; };
typedef sequence<HistogramRectangle> Histogram; typedef sequence<HistogramRectangle> Histogram;
/*! /*!
* Base interface for all functors ( i.e. numerical functors and predicates ) * Base interface for all functors ( i.e. numerical functors and predicates )
*/ */
@ -98,8 +103,6 @@ module SMESH
ElementType GetElementType(); 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
*/ */
@ -150,6 +153,7 @@ module SMESH
Values GetValues(); Values GetValues();
}; };
/*! /*!
* Predicates are intended for verification of criteria, * Predicates are intended for verification of criteria,
* must return bool value by mesh id * must return bool value by mesh id
@ -166,6 +170,29 @@ module SMESH
*/ */
interface BadOrientedVolume: Predicate {}; interface BadOrientedVolume: Predicate {};
/*!
* Logical functor (predicate) "Volumes with bare border".
* Verify whether a mesh volume has a free facet without a mesh face on it
*/
interface BareBorderVolume: Predicate {};
/*!
* Logical functor (predicate) "Faces with bare border".
* Verify whether a mesh face has a side not shared with another face
* and without a mesh edge on it
*/
interface BareBorderFace: Predicate {};
/*!
* Logical functor (predicate) "Over-constrained Volume"
* Verify whether a mesh volume has only one facet shared with other volumes
*/
interface OverConstrainedVolume: Predicate {};
/*!
* Logical functor (predicate) "Over-constrained Face".
* Verify whether a mesh face has only one border shared with other faces
*/
interface OverConstrainedFace: Predicate {};
/*! /*!
* Logical functor (predicate) "Belong To Geometry". * Logical functor (predicate) "Belong To Geometry".
* Verify whether mesh element or node belong to pointed Geom Object * Verify whether mesh element or node belong to pointed Geom Object
@ -503,6 +530,10 @@ module SMESH
RangeOfIds CreateRangeOfIds(); RangeOfIds CreateRangeOfIds();
BadOrientedVolume CreateBadOrientedVolume(); BadOrientedVolume CreateBadOrientedVolume();
BareBorderVolume CreateBareBorderVolume();
BareBorderFace CreateBareBorderFace();
OverConstrainedVolume CreateOverConstrainedVolume();
OverConstrainedFace CreateOverConstrainedFace();
LinearOrQuadratic CreateLinearOrQuadratic(); LinearOrQuadratic CreateLinearOrQuadratic();
GroupColor CreateGroupColor(); GroupColor CreateGroupColor();

View File

@ -221,10 +221,45 @@ module SMESH
raises ( SALOME::SALOME_Exception ); raises ( SALOME::SALOME_Exception );
/*! /*!
* Create a Mesh object, without a geometry shape reference * Create a mesh by copying a part of another mesh
* \param meshPart - a part of mesh to copy
* \param meshName - a name of the new mesh
* \param toCopyGroups - to create in the new mesh groups
* the copied elements belongs to
* \param toKeepIDs - to preserve IDs of the copied elements or not
*/ */
// SMESH_Mesh NewEmpty() SMESH_Mesh CopyMesh(in SMESH_IDSource meshPart,
// raises ( SALOME::SALOME_Exception ); in string meshName,
in boolean toCopyGroups,
in boolean toKeepIDs)
raises ( SALOME::SALOME_Exception );
/*!
* Concatenate the given meshes into one mesh.
* Union groups with the same name and type if
* theUniteIdenticalGroups flag is true.
* Merge coincident nodes and elements if
* theMergeNodesAndElements flag is true.
*/
SMESH_Mesh Concatenate(in mesh_array theMeshesArray,
in boolean theUniteIdenticalGroups,
in boolean theMergeNodesAndElements,
in double theMergeTolerance)
raises ( SALOME::SALOME_Exception );
/*!
* Concatenate the given meshes into one mesh.
* Union groups with the same name and type if
* theUniteIdenticalGroups flag is true.
* Merge coincident nodes and elements if
* theMergeNodesAndElements flag is true.
* Create the groups of all elements from initial meshes.
*/
SMESH_Mesh ConcatenateWithGroups(in mesh_array theMeshesArray,
in boolean theUniteIdenticalGroups,
in boolean theMergeNodesAndElements,
in double theMergeTolerance)
raises ( SALOME::SALOME_Exception );
/*! /*!
* Mesh a subShape. * Mesh a subShape.
@ -309,33 +344,6 @@ module SMESH
in long theElementID) in long theElementID)
raises ( SALOME::SALOME_Exception ); raises ( SALOME::SALOME_Exception );
/*!
* Concatenate the given meshes into one mesh.
* Union groups with the same name and type if
* theUniteIdenticalGroups flag is true.
* Merge coincident nodes and elements if
* theMergeNodesAndElements flag is true.
*/
SMESH_Mesh Concatenate(in mesh_array theMeshesArray,
in boolean theUniteIdenticalGroups,
in boolean theMergeNodesAndElements,
in double theMergeTolerance)
raises ( SALOME::SALOME_Exception );
/*!
* Concatenate the given meshes into one mesh.
* Union groups with the same name and type if
* theUniteIdenticalGroups flag is true.
* Merge coincident nodes and elements if
* theMergeNodesAndElements flag is true.
* Create the groups of all elements from initial meshes.
*/
SMESH_Mesh ConcatenateWithGroups(in mesh_array theMeshesArray,
in boolean theUniteIdenticalGroups,
in boolean theMergeNodesAndElements,
in double theMergeTolerance)
raises ( SALOME::SALOME_Exception );
/*! /*!
* \brief Return id of object, registered in current study context * \brief Return id of object, registered in current study context
* *

View File

@ -107,6 +107,10 @@ dist_salomeres_DATA = \
mesh_vertex_n.png \ mesh_vertex_n.png \
mesh_vertex.png \ mesh_vertex.png \
mesh_volume_3d.png \ mesh_volume_3d.png \
bare_border_volume.png \
bare_border_face.png \
over_constrained_volume.png \
over_constrained_face.png \
mesh_wireframe.png \ mesh_wireframe.png \
mesh_points.png \ mesh_points.png \
mesh_wrap.png \ mesh_wrap.png \
@ -173,6 +177,7 @@ dist_salomeres_DATA = \
mesh_tree_hypo_projection_3d.png \ mesh_tree_hypo_projection_3d.png \
mesh_tree_hypo_projection_2d.png \ mesh_tree_hypo_projection_2d.png \
mesh_build_compound.png \ mesh_build_compound.png \
copy_mesh.png \
mesh_node_to_point.png \ mesh_node_to_point.png \
mesh_tree_mesh_partial.png \ mesh_tree_mesh_partial.png \
mesh_extractGroup.png \ mesh_extractGroup.png \

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.3 KiB

BIN
resources/copy_mesh.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

View File

@ -310,12 +310,16 @@ double NumericalFunctor::GetValue( long theId )
* \param nbIntervals - number of intervals * \param nbIntervals - number of intervals
* \param nbEvents - number of mesh elements having values within i-th interval * \param nbEvents - number of mesh elements having values within i-th interval
* \param funValues - boundaries of intervals * \param funValues - boundaries of intervals
* \param elements - elements to check vulue of; empty list means "of all"
* \param minmax - boundaries of diapason of values to divide into intervals
*/ */
//================================================================================ //================================================================================
void NumericalFunctor::GetHistogram(int nbIntervals, void NumericalFunctor::GetHistogram(int nbIntervals,
std::vector<int>& nbEvents, std::vector<int>& nbEvents,
std::vector<double>& funValues) std::vector<double>& funValues,
const vector<int>& elements,
const double* minmax)
{ {
if ( nbIntervals < 1 || if ( nbIntervals < 1 ||
!myMesh || !myMesh ||
@ -326,13 +330,30 @@ void NumericalFunctor::GetHistogram(int nbIntervals,
// get all values sorted // get all values sorted
std::multiset< double > values; std::multiset< double > values;
if ( elements.empty() )
{
SMDS_ElemIteratorPtr elemIt = myMesh->elementsIterator(GetType()); SMDS_ElemIteratorPtr elemIt = myMesh->elementsIterator(GetType());
while ( elemIt->more() ) while ( elemIt->more() )
values.insert( GetValue( elemIt->next()->GetID() )); values.insert( GetValue( elemIt->next()->GetID() ));
}
else
{
vector<int>::const_iterator id = elements.begin();
for ( ; id != elements.end(); ++id )
values.insert( GetValue( *id ));
}
// case nbIntervals == 1 if ( minmax )
{
funValues[0] = minmax[0];
funValues[nbIntervals] = minmax[1];
}
else
{
funValues[0] = *values.begin(); funValues[0] = *values.begin();
funValues[nbIntervals] = *values.rbegin(); funValues[nbIntervals] = *values.rbegin();
}
// case nbIntervals == 1
if ( nbIntervals == 1 ) if ( nbIntervals == 1 )
{ {
nbEvents[0] = values.size(); nbEvents[0] = values.size();
@ -350,15 +371,21 @@ void NumericalFunctor::GetHistogram(int nbIntervals,
std::multiset< double >::iterator min = values.begin(), max; std::multiset< double >::iterator min = values.begin(), max;
for ( int i = 0; i < nbIntervals; ++i ) for ( int i = 0; i < nbIntervals; ++i )
{ {
// find end value of i-th interval
double r = (i+1) / double( nbIntervals ); double r = (i+1) / double( nbIntervals );
funValues[i+1] = funValues.front() * (1-r) + funValues.back() * r; funValues[i+1] = funValues.front() * (1-r) + funValues.back() * r;
// count values in the i-th interval if there are any
if ( min != values.end() && *min <= funValues[i+1] ) if ( min != values.end() && *min <= funValues[i+1] )
{ {
max = values.upper_bound( funValues[i+1] ); // greater than funValues[i+1], or end() // find the first value out of the interval
max = values.upper_bound( funValues[i+1] ); // max is greater than funValues[i+1], or end()
nbEvents[i] = std::distance( min, max ); nbEvents[i] = std::distance( min, max );
min = max; min = max;
} }
} }
// add values larger than minmax[1]
nbEvents.back() += std::distance( min, values.end() );
} }
//======================================================================= //=======================================================================
@ -1902,7 +1929,115 @@ SMDSAbs_ElementType BadOrientedVolume::GetType() const
return SMDSAbs_Volume; return SMDSAbs_Volume;
} }
/*
Class : BareBorderVolume
*/
bool BareBorderVolume::IsSatisfy(long theElementId )
{
SMDS_VolumeTool myTool;
if ( myTool.Set( myMesh->FindElement(theElementId)))
{
for ( int iF = 0; iF < myTool.NbFaces(); ++iF )
if ( myTool.IsFreeFace( iF ))
{
const SMDS_MeshNode** n = myTool.GetFaceNodes(iF);
vector< const SMDS_MeshNode*> nodes( n, n+myTool.NbFaceNodes(iF));
if ( !myMesh->FindElement( nodes, SMDSAbs_Face, /*Nomedium=*/false))
return true;
}
}
return false;
}
/*
Class : BareBorderFace
*/
bool BareBorderFace::IsSatisfy(long theElementId )
{
if ( const SMDS_MeshElement* face = myMesh->FindElement(theElementId))
if ( face->GetType() == SMDSAbs_Face )
{
int nbN = face->NbCornerNodes();
for ( int i = 0; i < nbN; ++i )
{
// check if a link is shared by another face
const SMDS_MeshNode* n1 = face->GetNode( i );
const SMDS_MeshNode* n2 = face->GetNode( (i+1)%nbN );
SMDS_ElemIteratorPtr fIt = n1->GetInverseElementIterator( SMDSAbs_Face );
bool isShared = false;
while ( !isShared && fIt->more() )
{
const SMDS_MeshElement* f = fIt->next();
isShared = ( f != face && f->GetNodeIndex(n2) != -1 );
}
if ( !isShared )
{
myLinkNodes.resize( 2 + face->IsQuadratic());
myLinkNodes[0] = n1;
myLinkNodes[1] = n2;
if ( face->IsQuadratic() )
myLinkNodes[2] = face->GetNode( i+nbN );
return !myMesh->FindElement( myLinkNodes, SMDSAbs_Edge, /*noMedium=*/false);
}
}
}
return false;
}
/*
Class : OverConstrainedVolume
*/
bool OverConstrainedVolume::IsSatisfy(long theElementId )
{
// An element is over-constrained if it has N-1 free borders where
// N is the number of edges/faces for a 2D/3D element.
SMDS_VolumeTool myTool;
if ( myTool.Set( myMesh->FindElement(theElementId)))
{
int nbSharedFaces = 0;
for ( int iF = 0; iF < myTool.NbFaces(); ++iF )
if ( !myTool.IsFreeFace( iF ) && ++nbSharedFaces > 1 )
break;
return ( nbSharedFaces == 1 );
}
return false;
}
/*
Class : OverConstrainedFace
*/
bool OverConstrainedFace::IsSatisfy(long theElementId )
{
// An element is over-constrained if it has N-1 free borders where
// N is the number of edges/faces for a 2D/3D element.
if ( const SMDS_MeshElement* face = myMesh->FindElement(theElementId))
if ( face->GetType() == SMDSAbs_Face )
{
int nbSharedBorders = 0;
int nbN = face->NbCornerNodes();
for ( int i = 0; i < nbN; ++i )
{
// check if a link is shared by another face
const SMDS_MeshNode* n1 = face->GetNode( i );
const SMDS_MeshNode* n2 = face->GetNode( (i+1)%nbN );
SMDS_ElemIteratorPtr fIt = n1->GetInverseElementIterator( SMDSAbs_Face );
bool isShared = false;
while ( !isShared && fIt->more() )
{
const SMDS_MeshElement* f = fIt->next();
isShared = ( f != face && f->GetNodeIndex(n2) != -1 );
}
if ( isShared && ++nbSharedBorders > 1 )
break;
}
return ( nbSharedBorders == 1 );
}
return false;
}
/* /*
Class : FreeBorders Class : FreeBorders

View File

@ -129,7 +129,9 @@ namespace SMESH{
virtual double GetValue(const TSequenceOfXYZ& thePoints) { return -1.0;}; virtual double GetValue(const TSequenceOfXYZ& thePoints) { return -1.0;};
void GetHistogram(int nbIntervals, void GetHistogram(int nbIntervals,
std::vector<int>& nbEvents, std::vector<int>& nbEvents,
std::vector<double>& funValues); std::vector<double>& funValues,
const std::vector<int>& elements,
const double* minmax=0);
virtual SMDSAbs_ElementType GetType() const = 0; virtual SMDSAbs_ElementType GetType() const = 0;
virtual double GetBadRate( double Value, int nbNodes ) const = 0; virtual double GetBadRate( double Value, int nbNodes ) const = 0;
long GetPrecision() const; long GetPrecision() const;
@ -378,6 +380,67 @@ namespace SMESH{
const SMDS_Mesh* myMesh; const SMDS_Mesh* myMesh;
}; };
/*
BareBorderVolume
*/
class SMESHCONTROLS_EXPORT BareBorderVolume: public Predicate
{
public:
BareBorderVolume():myMesh(0) {}
virtual void SetMesh( const SMDS_Mesh* theMesh ) { myMesh = theMesh; }
virtual SMDSAbs_ElementType GetType() const { return SMDSAbs_Volume; }
virtual bool IsSatisfy( long theElementId );
protected:
const SMDS_Mesh* myMesh;
};
typedef boost::shared_ptr<BareBorderVolume> BareBorderVolumePtr;
/*
BareBorderFace
*/
class SMESHCONTROLS_EXPORT BareBorderFace: public Predicate
{
public:
BareBorderFace():myMesh(0) {}
virtual void SetMesh( const SMDS_Mesh* theMesh ) { myMesh = theMesh; }
virtual SMDSAbs_ElementType GetType() const { return SMDSAbs_Face; }
virtual bool IsSatisfy( long theElementId );
protected:
const SMDS_Mesh* myMesh;
std::vector< const SMDS_MeshNode* > myLinkNodes;
};
typedef boost::shared_ptr<BareBorderFace> BareBorderFacePtr;
/*
OverConstrainedVolume
*/
class SMESHCONTROLS_EXPORT OverConstrainedVolume: public Predicate
{
public:
OverConstrainedVolume():myMesh(0) {}
virtual void SetMesh( const SMDS_Mesh* theMesh ) { myMesh = theMesh; }
virtual SMDSAbs_ElementType GetType() const { return SMDSAbs_Volume; }
virtual bool IsSatisfy( long theElementId );
protected:
const SMDS_Mesh* myMesh;
};
typedef boost::shared_ptr<OverConstrainedVolume> OverConstrainedVolumePtr;
/*
OverConstrainedFace
*/
class SMESHCONTROLS_EXPORT OverConstrainedFace: public Predicate
{
public:
OverConstrainedFace():myMesh(0) {}
virtual void SetMesh( const SMDS_Mesh* theMesh ) { myMesh = theMesh; }
virtual SMDSAbs_ElementType GetType() const { return SMDSAbs_Face; }
virtual bool IsSatisfy( long theElementId );
protected:
const SMDS_Mesh* myMesh;
std::vector< const SMDS_MeshNode* > myLinkNodes;
};
typedef boost::shared_ptr<OverConstrainedFace> OverConstrainedFacePtr;
/* /*
Class : FreeEdges Class : FreeEdges

View File

@ -204,6 +204,25 @@ SMESH_ActorDef::SMESH_ActorDef()
aFilter->RegisterCellsWithType(VTK_POLYHEDRON); aFilter->RegisterCellsWithType(VTK_POLYHEDRON);
//#endif //#endif
my3DExtActor = SMESH_DeviceActor::New();
my3DExtActor->SetUserMatrix(aMatrix);
my3DExtActor->PickableOff();
my3DExtActor->SetProperty(my2DExtProp);
my3DExtActor->SetBackfaceProperty(my2DExtProp);
my3DExtActor->SetRepresentation(SMESH_DeviceActor::eSurface);
aFilter = my3DExtActor->GetExtractUnstructuredGrid();
aFilter->SetModeOfChanging(VTKViewer_ExtractUnstructuredGrid::eAdding);
aFilter->RegisterCellsWithType(VTK_TETRA);
aFilter->RegisterCellsWithType(VTK_VOXEL);
aFilter->RegisterCellsWithType(VTK_HEXAHEDRON);
aFilter->RegisterCellsWithType(VTK_WEDGE);
aFilter->RegisterCellsWithType(VTK_PYRAMID);
aFilter->RegisterCellsWithType(VTK_QUADRATIC_TETRA);
aFilter->RegisterCellsWithType(VTK_QUADRATIC_HEXAHEDRON);
aFilter->RegisterCellsWithType(VTK_QUADRATIC_WEDGE);
aFilter->RegisterCellsWithType(VTK_QUADRATIC_PYRAMID);
aFilter->RegisterCellsWithType(VTK_CONVEX_POINT_SET);
//Definition 1D device of the actor //Definition 1D device of the actor
//--------------------------------- //---------------------------------
myEdgeProp = vtkProperty::New(); myEdgeProp = vtkProperty::New();
@ -537,6 +556,7 @@ SMESH_ActorDef::~SMESH_ActorDef()
my2DExtProp->Delete(); my2DExtProp->Delete();
my2DExtActor->Delete(); my2DExtActor->Delete();
my3DActor->Delete(); my3DActor->Delete();
my3DExtActor->Delete();
myNodeActor->Delete(); myNodeActor->Delete();
myBaseActor->Delete(); myBaseActor->Delete();
@ -728,8 +748,8 @@ SetControlMode(eControl theMode,
bool anIsScalarVisible = theMode > eNone; bool anIsScalarVisible = theMode > eNone;
if(anIsScalarVisible){ if(anIsScalarVisible) {
switch(theMode){ switch(theMode) {
case eLength: case eLength:
{ {
SMESH::Controls::Length* aControl = new SMESH::Controls::Length(); SMESH::Controls::Length* aControl = new SMESH::Controls::Length();
@ -760,6 +780,14 @@ SetControlMode(eControl theMode,
myFunctor.reset(new SMESH::Controls::FreeFaces()); myFunctor.reset(new SMESH::Controls::FreeFaces());
myControlActor = my2DActor; myControlActor = my2DActor;
break; break;
case eBareBorderFace:
myFunctor.reset(new SMESH::Controls::BareBorderFace());
myControlActor = my2DActor;
break;
case eOverConstrainedFace:
myFunctor.reset(new SMESH::Controls::OverConstrainedFace());
myControlActor = my2DActor;
break;
case eMultiConnection: case eMultiConnection:
myFunctor.reset(new SMESH::Controls::MultiConnection()); myFunctor.reset(new SMESH::Controls::MultiConnection());
myControlActor = my1DActor; myControlActor = my1DActor;
@ -824,6 +852,18 @@ SetControlMode(eControl theMode,
myControlActor = my3DActor; myControlActor = my3DActor;
break; break;
} }
case eBareBorderVolume:
{
myFunctor.reset(new SMESH::Controls::BareBorderVolume());
myControlActor = my3DActor;
break;
}
case eOverConstrainedVolume:
{
myFunctor.reset(new SMESH::Controls::OverConstrainedVolume());
myControlActor = my3DActor;
break;
}
case eMinimumAngle: case eMinimumAngle:
{ {
SMESH::Controls::MinimumAngle* aControl = new SMESH::Controls::MinimumAngle(); SMESH::Controls::MinimumAngle* aControl = new SMESH::Controls::MinimumAngle();
@ -865,14 +905,22 @@ SetControlMode(eControl theMode,
my1DExtActor->SetExtControlMode(myFunctor); my1DExtActor->SetExtControlMode(myFunctor);
break; break;
case eFreeFaces: case eFreeFaces:
case eBareBorderFace:
case eOverConstrainedFace:
my2DExtActor->SetExtControlMode(myFunctor); my2DExtActor->SetExtControlMode(myFunctor);
break; break;
case eBareBorderVolume:
case eOverConstrainedVolume:
my3DExtActor->SetExtControlMode(myFunctor);
break;
case eLength2D: case eLength2D:
case eMultiConnection2D: case eMultiConnection2D:
my1DExtActor->SetExtControlMode(myFunctor,myScalarBarActor,myLookupTable); my1DExtActor->SetExtControlMode(myFunctor,myScalarBarActor,myLookupTable);
UpdateDistribution();
break; break;
default: default:
myControlActor->SetControlMode(myFunctor,myScalarBarActor,myLookupTable); myControlActor->SetControlMode(myFunctor,myScalarBarActor,myLookupTable);
UpdateDistribution();
} }
} }
@ -916,6 +964,7 @@ void SMESH_ActorDef::AddToRender(vtkRenderer* theRenderer){
theRenderer->AddActor(myNodeExtActor); theRenderer->AddActor(myNodeExtActor);
my3DActor->AddToRender(theRenderer); my3DActor->AddToRender(theRenderer);
my3DExtActor->AddToRender(theRenderer);
my2DActor->AddToRender(theRenderer); my2DActor->AddToRender(theRenderer);
my2DExtActor->AddToRender(theRenderer); my2DExtActor->AddToRender(theRenderer);
@ -959,6 +1008,7 @@ void SMESH_ActorDef::RemoveFromRender(vtkRenderer* theRenderer){
my2DActor->RemoveFromRender(theRenderer); my2DActor->RemoveFromRender(theRenderer);
my2DExtActor->RemoveFromRender(theRenderer); my2DExtActor->RemoveFromRender(theRenderer);
my3DActor->RemoveFromRender(theRenderer); my3DActor->RemoveFromRender(theRenderer);
my3DExtActor->RemoveFromRender(theRenderer);
theRenderer->RemoveActor(myScalarBarActor); theRenderer->RemoveActor(myScalarBarActor);
theRenderer->RemoveActor(myPointLabels); theRenderer->RemoveActor(myPointLabels);
@ -994,6 +1044,7 @@ bool SMESH_ActorDef::Init(TVisualObjPtr theVisualObj,
my2DActor->Init(myVisualObj,myImplicitBoolean); my2DActor->Init(myVisualObj,myImplicitBoolean);
my2DExtActor->Init(myVisualObj,myImplicitBoolean); my2DExtActor->Init(myVisualObj,myImplicitBoolean);
my3DActor->Init(myVisualObj,myImplicitBoolean); my3DActor->Init(myVisualObj,myImplicitBoolean);
my3DExtActor->Init(myVisualObj,myImplicitBoolean);
my0DActor->GetMapper()->SetLookupTable(myLookupTable); my0DActor->GetMapper()->SetLookupTable(myLookupTable);
//my0DExtActor->GetMapper()->SetLookupTable(myLookupTable); //my0DExtActor->GetMapper()->SetLookupTable(myLookupTable);
@ -1004,6 +1055,7 @@ bool SMESH_ActorDef::Init(TVisualObjPtr theVisualObj,
my2DActor->GetMapper()->SetLookupTable(myLookupTable); my2DActor->GetMapper()->SetLookupTable(myLookupTable);
my2DExtActor->GetMapper()->SetLookupTable(myLookupTable); my2DExtActor->GetMapper()->SetLookupTable(myLookupTable);
my3DActor->GetMapper()->SetLookupTable(myLookupTable); my3DActor->GetMapper()->SetLookupTable(myLookupTable);
my3DExtActor->GetMapper()->SetLookupTable(myLookupTable);
vtkFloatingPointType aFactor, aUnits; vtkFloatingPointType aFactor, aUnits;
my2DActor->GetPolygonOffsetParameters(aFactor,aUnits); my2DActor->GetPolygonOffsetParameters(aFactor,aUnits);
@ -1076,6 +1128,7 @@ void SMESH_ActorDef::SetTransform(VTKViewer_Transform* theTransform){
my2DActor->SetTransform(theTransform); my2DActor->SetTransform(theTransform);
my2DExtActor->SetTransform(theTransform); my2DExtActor->SetTransform(theTransform);
my3DActor->SetTransform(theTransform); my3DActor->SetTransform(theTransform);
my3DExtActor->SetTransform(theTransform);
Modified(); Modified();
} }
@ -1131,6 +1184,7 @@ void SMESH_ActorDef::SetShrinkFactor(vtkFloatingPointType theValue){
my2DActor->SetShrinkFactor(theValue); my2DActor->SetShrinkFactor(theValue);
my2DExtActor->SetShrinkFactor(theValue); my2DExtActor->SetShrinkFactor(theValue);
my3DActor->SetShrinkFactor(theValue); my3DActor->SetShrinkFactor(theValue);
my3DExtActor->SetShrinkFactor(theValue);
Modified(); Modified();
} }
@ -1146,6 +1200,7 @@ void SMESH_ActorDef::SetShrink(){
my2DActor->SetShrink(); my2DActor->SetShrink();
my2DExtActor->SetShrink(); my2DExtActor->SetShrink();
my3DActor->SetShrink(); my3DActor->SetShrink();
my3DExtActor->SetShrink();
myIsShrunk = true; myIsShrunk = true;
Modified(); Modified();
@ -1162,6 +1217,7 @@ void SMESH_ActorDef::UnShrink(){
my2DActor->UnShrink(); my2DActor->UnShrink();
my2DExtActor->UnShrink(); my2DExtActor->UnShrink();
my3DActor->UnShrink(); my3DActor->UnShrink();
my3DExtActor->UnShrink();
myIsShrunk = false; myIsShrunk = false;
Modified(); Modified();
@ -1208,6 +1264,7 @@ void SMESH_ActorDef::SetVisibility(int theMode, bool theIsUpdateRepersentation){
my2DActor->VisibilityOff(); my2DActor->VisibilityOff();
my2DExtActor->VisibilityOff(); my2DExtActor->VisibilityOff();
my3DActor->VisibilityOff(); my3DActor->VisibilityOff();
my3DExtActor->VisibilityOff();
myScalarBarActor->VisibilityOff(); myScalarBarActor->VisibilityOff();
myPointLabels->VisibilityOff(); myPointLabels->VisibilityOff();
@ -1227,8 +1284,14 @@ void SMESH_ActorDef::SetVisibility(int theMode, bool theIsUpdateRepersentation){
my1DExtActor->VisibilityOn(); my1DExtActor->VisibilityOn();
break; break;
case eFreeFaces: case eFreeFaces:
case eBareBorderFace:
case eOverConstrainedFace:
my2DExtActor->VisibilityOn(); my2DExtActor->VisibilityOn();
break; break;
case eBareBorderVolume:
case eOverConstrainedVolume:
my3DExtActor->VisibilityOn();
break;
case eLength2D: case eLength2D:
case eMultiConnection2D: case eMultiConnection2D:
my1DExtActor->VisibilityOn(); my1DExtActor->VisibilityOn();
@ -1467,6 +1530,7 @@ void SMESH_ActorDef::SetRepresentation (int theMode)
//my0DExtActor->SetVisibility(false); //my0DExtActor->SetVisibility(false);
my1DExtActor->SetVisibility(false); my1DExtActor->SetVisibility(false);
my2DExtActor->SetVisibility(false); my2DExtActor->SetVisibility(false);
my3DExtActor->SetVisibility(false);
// ??? // ???
//my0DActor->SetProperty(aProp); //my0DActor->SetProperty(aProp);
@ -1797,6 +1861,7 @@ SMESH_ActorDef::SetImplicitFunctionUsed(bool theIsImplicitFunctionUsed)
my2DActor->SetImplicitFunctionUsed(theIsImplicitFunctionUsed); my2DActor->SetImplicitFunctionUsed(theIsImplicitFunctionUsed);
my2DExtActor->SetImplicitFunctionUsed(theIsImplicitFunctionUsed); my2DExtActor->SetImplicitFunctionUsed(theIsImplicitFunctionUsed);
my3DActor->SetImplicitFunctionUsed(theIsImplicitFunctionUsed); my3DActor->SetImplicitFunctionUsed(theIsImplicitFunctionUsed);
my3DExtActor->SetImplicitFunctionUsed(theIsImplicitFunctionUsed);
} }
vtkIdType vtkIdType
@ -1968,6 +2033,27 @@ void SMESH_ActorDef::UpdateScalarBar()
} }
void SMESH_ActorDef::UpdateDistribution()
{
if(SMESH::Controls::NumericalFunctor* fun =
dynamic_cast<SMESH::Controls::NumericalFunctor*>(myFunctor.get()))
{
int nbIntervals = myScalarBarActor->GetMaximumNumberOfColors();
std::vector<int> nbEvents;
std::vector<double> funValues;
SMESH_VisualObjDef::TEntityList elems;
if ( ! dynamic_cast<SMESH_MeshObj*>(myVisualObj.get()))
dynamic_cast<SMESH_VisualObjDef*>(myVisualObj.get())->GetEntities( fun->GetType(), elems );
std::vector<int> elemIds;
for ( SMESH_VisualObjDef::TEntityList::iterator e = elems.begin(); e != elems.end(); ++e)
elemIds.push_back( (*e)->GetID());
vtkLookupTable* lookupTable = static_cast<vtkLookupTable*>(myScalarBarActor->GetLookupTable());
double * range = lookupTable->GetRange();
fun->GetHistogram(nbIntervals, nbEvents, funValues, elemIds, range);
myScalarBarActor->SetDistribution(nbEvents);
}
}
void SMESH_ActorDef::SetQuadratic2DRepresentation(EQuadratic2DRepresentation theMode) void SMESH_ActorDef::SetQuadratic2DRepresentation(EQuadratic2DRepresentation theMode)
{ {
switch(theMode) { switch(theMode) {

View File

@ -123,7 +123,8 @@ class SMESHOBJECT_EXPORT SMESH_Actor: public SALOME_Actor
enum eControl{eNone, eLength, eLength2D, eFreeBorders, eFreeEdges, eFreeNodes, enum eControl{eNone, eLength, eLength2D, eFreeBorders, eFreeEdges, eFreeNodes,
eFreeFaces, eMultiConnection, eArea, eTaper, eAspectRatio, eFreeFaces, eMultiConnection, eArea, eTaper, eAspectRatio,
eMinimumAngle, eWarping, eSkew, eAspectRatio3D, eMultiConnection2D, eVolume3D, eMinimumAngle, eWarping, eSkew, eAspectRatio3D, eMultiConnection2D, eVolume3D,
eMaxElementLength2D, eMaxElementLength3D}; eMaxElementLength2D, eMaxElementLength3D, eBareBorderFace, eBareBorderVolume,
eOverConstrainedFace, eOverConstrainedVolume};
virtual void SetControlMode(eControl theMode) = 0; virtual void SetControlMode(eControl theMode) = 0;
virtual eControl GetControlMode() = 0; virtual eControl GetControlMode() = 0;
virtual SMESH::Controls::FunctorPtr GetFunctor() = 0; virtual SMESH::Controls::FunctorPtr GetFunctor() = 0;
@ -141,6 +142,7 @@ class SMESHOBJECT_EXPORT SMESH_Actor: public SALOME_Actor
virtual long GetControlsPrecision() const = 0; virtual long GetControlsPrecision() const = 0;
virtual void UpdateScalarBar() = 0; virtual void UpdateScalarBar() = 0;
virtual void UpdateDistribution() = 0;
}; };

View File

@ -196,6 +196,7 @@ class SMESH_ActorDef : public SMESH_Actor
virtual long GetControlsPrecision() const { return myControlsPrecision; } virtual long GetControlsPrecision() const { return myControlsPrecision; }
virtual void UpdateScalarBar(); virtual void UpdateScalarBar();
virtual void UpdateDistribution();
virtual void SetQuadratic2DRepresentation(EQuadratic2DRepresentation); virtual void SetQuadratic2DRepresentation(EQuadratic2DRepresentation);
@ -234,6 +235,7 @@ class SMESH_ActorDef : public SMESH_Actor
SMESH_DeviceActor* my2DActor; SMESH_DeviceActor* my2DActor;
SMESH_DeviceActor* my2DExtActor; SMESH_DeviceActor* my2DExtActor;
SMESH_DeviceActor* my3DActor; SMESH_DeviceActor* my3DActor;
SMESH_DeviceActor* my3DExtActor;
SMESH_DeviceActor* myControlActor; SMESH_DeviceActor* myControlActor;
vtkProperty* myNodeExtProp; vtkProperty* myNodeExtProp;

View File

@ -310,12 +310,6 @@ SMESH_DeviceActor
double aValue = aNumericalFunctor->GetValue(anObjId); double aValue = aNumericalFunctor->GetValue(anObjId);
aScalars->SetValue(i,aValue); aScalars->SetValue(i,aValue);
} }
int nbIntervals = theScalarBarActor->GetMaximumNumberOfColors();
std::vector<int> nbEvents;
std::vector<double> funValues;
aNumericalFunctor->GetHistogram(nbIntervals, nbEvents, funValues);
theScalarBarActor->SetDistribution(nbEvents);
}else if(Predicate* aPredicate = dynamic_cast<Predicate*>(theFunctor.get())){ }else if(Predicate* aPredicate = dynamic_cast<Predicate*>(theFunctor.get())){
for(vtkIdType i = 0; i < aNbCells; i++){ for(vtkIdType i = 0; i < aNbCells; i++){
vtkIdType anId = myExtractUnstructuredGrid->GetInputId(i); vtkIdType anId = myExtractUnstructuredGrid->GetInputId(i);
@ -475,16 +469,6 @@ SMESH_DeviceActor
myMergeFilter->SetScalars(aDataSet); myMergeFilter->SetScalars(aDataSet);
aDataSet->Delete(); aDataSet->Delete();
} }
//Set Distribution
if(NumericalFunctor* aNumericalFunctor = dynamic_cast<NumericalFunctor*>(theFunctor.get())){
int nbIntervals = theScalarBarActor->GetMaximumNumberOfColors();
std::vector<int> nbEvents;
std::vector<double> funValues;
aNumericalFunctor->GetHistogram(nbIntervals, nbEvents, funValues);
theScalarBarActor->SetDistribution(nbEvents);
}
} }
GetMapper()->SetScalarVisibility(anIsInitialized); GetMapper()->SetScalarVisibility(anIsInitialized);
theScalarBarActor->SetVisibility(anIsInitialized); theScalarBarActor->SetVisibility(anIsInitialized);
@ -500,8 +484,13 @@ SMESH_DeviceActor
myVisualObj->UpdateFunctor(theFunctor); myVisualObj->UpdateFunctor(theFunctor);
using namespace SMESH::Controls; using namespace SMESH::Controls;
if ( dynamic_cast<FreeBorders*>(theFunctor.get()) || if ( dynamic_cast<FreeBorders *>(theFunctor.get()) ||
dynamic_cast<FreeFaces*>(theFunctor.get()) ) { dynamic_cast<FreeFaces *>(theFunctor.get()) ||
dynamic_cast<BareBorderVolume *>(theFunctor.get()) ||
dynamic_cast<BareBorderFace *>(theFunctor.get()) ||
dynamic_cast<OverConstrainedVolume*>(theFunctor.get()) ||
dynamic_cast<OverConstrainedFace *>(theFunctor.get()))
{
Predicate* aFreePredicate = dynamic_cast<Predicate*>(theFunctor.get()); Predicate* aFreePredicate = dynamic_cast<Predicate*>(theFunctor.get());
myExtractUnstructuredGrid->SetModeOfChanging(VTKViewer_ExtractUnstructuredGrid::eAdding); myExtractUnstructuredGrid->SetModeOfChanging(VTKViewer_ExtractUnstructuredGrid::eAdding);
vtkUnstructuredGrid* aGrid = myVisualObj->GetUnstructuredGrid(); vtkUnstructuredGrid* aGrid = myVisualObj->GetUnstructuredGrid();
@ -514,7 +503,9 @@ SMESH_DeviceActor
if(!myExtractUnstructuredGrid->IsCellsRegistered()) if(!myExtractUnstructuredGrid->IsCellsRegistered())
myExtractUnstructuredGrid->RegisterCell(-1); myExtractUnstructuredGrid->RegisterCell(-1);
SetUnstructuredGrid(myVisualObj->GetUnstructuredGrid()); SetUnstructuredGrid(myVisualObj->GetUnstructuredGrid());
}else if(FreeEdges* aFreeEdges = dynamic_cast<FreeEdges*>(theFunctor.get())){ }
else if(FreeEdges* aFreeEdges = dynamic_cast<FreeEdges*>(theFunctor.get()))
{
SMESH::Controls::FreeEdges::TBorders aBorders; SMESH::Controls::FreeEdges::TBorders aBorders;
aFreeEdges->GetBoreders(aBorders); aFreeEdges->GetBoreders(aBorders);
vtkUnstructuredGrid* aDataSet = vtkUnstructuredGrid::New(); vtkUnstructuredGrid* aDataSet = vtkUnstructuredGrid::New();
@ -561,7 +552,9 @@ SMESH_DeviceActor
SetUnstructuredGrid(aDataSet); SetUnstructuredGrid(aDataSet);
aDataSet->Delete(); aDataSet->Delete();
}else if(FreeNodes* aFreeNodes = dynamic_cast<FreeNodes*>(theFunctor.get())){ }
else if(FreeNodes* aFreeNodes = dynamic_cast<FreeNodes*>(theFunctor.get()))
{
myExtractUnstructuredGrid->SetModeOfChanging(VTKViewer_ExtractUnstructuredGrid::eAdding); myExtractUnstructuredGrid->SetModeOfChanging(VTKViewer_ExtractUnstructuredGrid::eAdding);
vtkIdType aNbNodes = myVisualObj->GetNbEntities(SMDSAbs_Node); vtkIdType aNbNodes = myVisualObj->GetNbEntities(SMDSAbs_Node);
for( vtkIdType i = 0; i < aNbNodes; i++ ){ for( vtkIdType i = 0; i < aNbNodes; i++ ){

View File

@ -101,7 +101,7 @@ bool SMESH_PreviewActorsCollection::Init( const TopoDS_Shape& theShape, TopAbs_S
int index = myMapOfShapes.FindIndex( exp.Current() ); int index = myMapOfShapes.FindIndex( exp.Current() );
if ( index && !myMapOfActors.contains( index ) ) { if ( index && !myMapOfActors.contains( index ) ) {
// create actor if the index is present // create actor if the index is present
if ( GEOM_Actor* anActor = createActor( exp.Current() )) { if ( GEOM_Actor* anActor = createActor( exp.Current().Oriented(TopAbs_FORWARD))) {
// Create new entry for actor // Create new entry for actor
QString aString = theEntry; QString aString = theEntry;
aString += QString("_%1").arg( index ); // add index to actor entry aString += QString("_%1").arg( index ); // add index to actor entry

View File

@ -35,13 +35,22 @@
using namespace std; using namespace std;
SMDS_MeshElement::SMDS_MeshElement(int ID):myID(ID), myMeshId(-1), myShapeId(0), myIdInShape(-1) SMDS_MeshElement::SMDS_MeshElement(int ID)
{ {
init(ID);
} }
SMDS_MeshElement::SMDS_MeshElement(int id, ShortType meshId, ShortType shapeId): SMDS_MeshElement::SMDS_MeshElement(int id, ShortType meshId, ShortType shapeId)
myID(id), myMeshId(meshId), myShapeId(shapeId), myIdInShape(-1)
{ {
init(id, meshId, shapeId);
}
void SMDS_MeshElement::init(int id, ShortType meshId, ShortType shapeId )
{
myID = id;
myMeshId = meshId;
myShapeId = shapeId;
myIdInShape = -1;
} }
void SMDS_MeshElement::Print(ostream & OS) const void SMDS_MeshElement::Print(ostream & OS) const

View File

@ -151,6 +151,7 @@ protected:
inline void setVtkId(int vtkId) { myVtkID = vtkId; }; inline void setVtkId(int vtkId) { myVtkID = vtkId; };
SMDS_MeshElement(int ID=-1); SMDS_MeshElement(int ID=-1);
SMDS_MeshElement(int id, ShortType meshId, ShortType shapeId = 0); SMDS_MeshElement(int id, ShortType meshId, ShortType shapeId = 0);
virtual void init(int id = -1, ShortType meshId = -1, ShortType shapeId = 0);
virtual void Print(std::ostream & OS) const; virtual void Print(std::ostream & OS) const;
//! Element index in vector SMDS_Mesh::myNodes or SMDS_Mesh::myCells //! Element index in vector SMDS_Mesh::myNodes or SMDS_Mesh::myCells

View File

@ -61,12 +61,9 @@ SMDS_MeshNode::SMDS_MeshNode(int id, int meshId, int shapeId, double x, double y
void SMDS_MeshNode::init(int id, int meshId, int shapeId, double x, double y, double z) void SMDS_MeshNode::init(int id, int meshId, int shapeId, double x, double y, double z)
{ {
SMDS_MeshElement::init(id, meshId, shapeId);
myVtkID = id -1; myVtkID = id -1;
assert(myVtkID >= 0); assert(myVtkID >= 0);
myID = id;
myMeshId = meshId;
myShapeId = shapeId;
myIdInShape = -1;
//MESSAGE("Node " << myID << " " << myVtkID << " (" << x << ", " << y << ", " << z << ")"); //MESSAGE("Node " << myID << " " << myVtkID << " (" << x << ", " << y << ", " << z << ")");
SMDS_Mesh* mesh = SMDS_Mesh::_meshList[myMeshId]; SMDS_Mesh* mesh = SMDS_Mesh::_meshList[myMeshId];
SMDS_UnstructuredGrid * grid = mesh->getGrid(); SMDS_UnstructuredGrid * grid = mesh->getGrid();
@ -312,9 +309,12 @@ vtkIdType SMDS_MeshNode::GetVtkType() const
//======================================================================= //=======================================================================
void SMDS_MeshNode::AddInverseElement(const SMDS_MeshElement* ME) void SMDS_MeshNode::AddInverseElement(const SMDS_MeshElement* ME)
{ {
const SMDS_MeshCell *cell = dynamic_cast<const SMDS_MeshCell*>(ME); const SMDS_MeshCell *cell = dynamic_cast<const SMDS_MeshCell*> (ME);
assert(cell); assert(cell);
SMDS_Mesh::_meshList[myMeshId]->getGrid()->AddReferenceToCell(myVtkID, cell->getVtkId()); SMDS_UnstructuredGrid* grid = SMDS_Mesh::_meshList[myMeshId]->getGrid();
vtkCellLinks *Links = grid->GetCellLinks();
Links->ResizeCellList(myVtkID, 1);
Links->AddCellReference(cell->getVtkId(), myVtkID);
} }
//======================================================================= //=======================================================================

View File

@ -40,6 +40,7 @@ public:
friend class SMESHDS_Mesh; friend class SMESHDS_Mesh;
friend class SMDS_Mesh; friend class SMDS_Mesh;
friend class ObjectPool<SMDS_MeshNode>; friend class ObjectPool<SMDS_MeshNode>;
friend class SMDS_VtkFace;
void Print(std::ostream & OS) const; void Print(std::ostream & OS) const;
double X() const; double X() const;

View File

@ -25,8 +25,8 @@ SMDS_VtkEdge::~SMDS_VtkEdge()
void SMDS_VtkEdge::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh) void SMDS_VtkEdge::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh)
{ {
SMDS_MeshEdge::init();
vtkUnstructuredGrid* grid = mesh->getGrid(); vtkUnstructuredGrid* grid = mesh->getGrid();
myIdInShape = -1;
myMeshId = mesh->getMeshId(); myMeshId = mesh->getMeshId();
vtkIdType aType = VTK_LINE; vtkIdType aType = VTK_LINE;
if (nodeIds.size() == 3) if (nodeIds.size() == 3)

View File

@ -24,8 +24,8 @@ SMDS_VtkFace::~SMDS_VtkFace()
void SMDS_VtkFace::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh) void SMDS_VtkFace::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh)
{ {
SMDS_MeshFace::init();
vtkUnstructuredGrid* grid = mesh->getGrid(); vtkUnstructuredGrid* grid = mesh->getGrid();
myIdInShape = -1;
myMeshId = mesh->getMeshId(); myMeshId = mesh->getMeshId();
vtkIdType aType = VTK_TRIANGLE; vtkIdType aType = VTK_TRIANGLE;
switch (nodeIds.size()) switch (nodeIds.size())
@ -53,8 +53,8 @@ void SMDS_VtkFace::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh)
void SMDS_VtkFace::initPoly(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh) void SMDS_VtkFace::initPoly(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh)
{ {
SMDS_MeshFace::init();
vtkUnstructuredGrid* grid = mesh->getGrid(); vtkUnstructuredGrid* grid = mesh->getGrid();
myIdInShape = -1;
myMeshId = mesh->getMeshId(); myMeshId = mesh->getMeshId();
myVtkID = grid->InsertNextLinkedCell(VTK_POLYGON, nodeIds.size(), &nodeIds[0]); myVtkID = grid->InsertNextLinkedCell(VTK_POLYGON, nodeIds.size(), &nodeIds[0]);
mesh->setMyModified(); mesh->setMyModified();
@ -249,7 +249,7 @@ SMDS_ElemIteratorPtr SMDS_VtkFace::interlacedNodesElemIterator() const
} }
//! change only the first node, used for temporary triangles in quadrangle to triangle adaptor //! change only the first node, used for temporary triangles in quadrangle to triangle adaptor
void SMDS_VtkFace::ChangeApex(const SMDS_MeshNode* node) void SMDS_VtkFace::ChangeApex(SMDS_MeshNode* node)
{ {
vtkUnstructuredGrid* grid = SMDS_Mesh::_meshList[myMeshId]->getGrid(); vtkUnstructuredGrid* grid = SMDS_Mesh::_meshList[myMeshId]->getGrid();
vtkIdType npts = 0; vtkIdType npts = 0;
@ -257,6 +257,6 @@ void SMDS_VtkFace::ChangeApex(const SMDS_MeshNode* node)
grid->GetCellPoints(myVtkID, npts, pts); grid->GetCellPoints(myVtkID, npts, pts);
grid->RemoveReferenceToCell(pts[0], myVtkID); grid->RemoveReferenceToCell(pts[0], myVtkID);
pts[0] = node->getVtkId(); pts[0] = node->getVtkId();
grid->AddReferenceToCell(pts[0], myVtkID); node->AddInverseElement(this),
SMDS_Mesh::_meshList[myMeshId]->setMyModified(); SMDS_Mesh::_meshList[myMeshId]->setMyModified();
} }

View File

@ -16,7 +16,7 @@ public:
void init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh); void init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh);
void initPoly(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh); void initPoly(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh);
bool ChangeNodes(const SMDS_MeshNode* nodes[], const int nbNodes); bool ChangeNodes(const SMDS_MeshNode* nodes[], const int nbNodes);
void ChangeApex(const SMDS_MeshNode* node); // to use only for tmp triangles void ChangeApex(SMDS_MeshNode* node); // to use only for tmp triangles
void Print(std::ostream & OS) const; void Print(std::ostream & OS) const;
int NbEdges() const; int NbEdges() const;
int NbFaces() const; int NbFaces() const;

View File

@ -21,8 +21,8 @@ SMDS_VtkVolume::SMDS_VtkVolume(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh)
*/ */
void SMDS_VtkVolume::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh) void SMDS_VtkVolume::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh)
{ {
SMDS_MeshVolume::init();
vtkUnstructuredGrid* grid = mesh->getGrid(); vtkUnstructuredGrid* grid = mesh->getGrid();
myIdInShape = -1;
myMeshId = mesh->getMeshId(); myMeshId = mesh->getMeshId();
vtkIdType aType = VTK_TETRA; vtkIdType aType = VTK_TETRA;
switch (nodeIds.size()) switch (nodeIds.size())
@ -63,6 +63,7 @@ void SMDS_VtkVolume::init(std::vector<vtkIdType> nodeIds, SMDS_Mesh* mesh)
//#ifdef VTK_HAVE_POLYHEDRON //#ifdef VTK_HAVE_POLYHEDRON
void SMDS_VtkVolume::initPoly(std::vector<vtkIdType> nodeIds, std::vector<int> nbNodesPerFace, SMDS_Mesh* mesh) void SMDS_VtkVolume::initPoly(std::vector<vtkIdType> nodeIds, std::vector<int> nbNodesPerFace, SMDS_Mesh* mesh)
{ {
SMDS_MeshVolume::init();
//MESSAGE("SMDS_VtkVolume::initPoly"); //MESSAGE("SMDS_VtkVolume::initPoly");
SMDS_UnstructuredGrid* grid = mesh->getGrid(); SMDS_UnstructuredGrid* grid = mesh->getGrid();
double center[3]; double center[3];

View File

@ -60,6 +60,7 @@ salomeinclude_HEADERS = \
lib_LTLIBRARIES = libSMESHimpl.la lib_LTLIBRARIES = libSMESHimpl.la
dist_libSMESHimpl_la_SOURCES = \ dist_libSMESHimpl_la_SOURCES = \
memoire.h \
SMESH_Gen.cxx \ SMESH_Gen.cxx \
SMESH_Mesh.cxx \ SMESH_Mesh.cxx \
SMESH_subMesh.cxx \ SMESH_subMesh.cxx \

View File

@ -105,6 +105,23 @@ SMESH_Mesh::SMESH_Mesh(int theLocalId,
_myMeshDS->ShapeToMesh( PseudoShape() ); _myMeshDS->ShapeToMesh( PseudoShape() );
} }
//================================================================================
/*!
* \brief Constructor of SMESH_Mesh being a base of some descendant class
*/
//================================================================================
SMESH_Mesh::SMESH_Mesh():
_groupId( 0 ), _nbSubShapes( 0 )
{
_myMeshDS = 0;
_isShapeToMesh = false;
_isAutoColor = false;
_isModified = false;
_shapeDiagonal = 0.0;
_rmGroupCallUp = 0;
}
//============================================================================= //=============================================================================
/*! /*!
* *
@ -265,14 +282,12 @@ void SMESH_Mesh::Clear()
_myMeshDS->ClearMesh(); _myMeshDS->ClearMesh();
// update compute state of submeshes // update compute state of submeshes
if ( SMESH_subMesh *sm = GetSubMeshContaining( GetShapeToMesh() ) ) { if ( SMESH_subMesh *sm = GetSubMeshContaining( GetShapeToMesh() ) )
SMESH_subMeshIteratorPtr smIt = sm->getDependsOnIterator(/*includeSelf=*/true, {
/*complexShapeFirst=*/false);
while ( smIt->more() ) {
sm = smIt->next();
sm->ComputeStateEngine( SMESH_subMesh::CHECK_COMPUTE_STATE ); sm->ComputeStateEngine( SMESH_subMesh::CHECK_COMPUTE_STATE );
sm->ComputeSubMeshStateEngine( SMESH_subMesh::CHECK_COMPUTE_STATE );
sm->ComputeStateEngine( SMESH_subMesh::CLEAN ); // for event listeners (issue 0020918) sm->ComputeStateEngine( SMESH_subMesh::CLEAN ); // for event listeners (issue 0020918)
} sm->ComputeSubMeshStateEngine( SMESH_subMesh::CLEAN );
} }
_isModified = false; _isModified = false;
} }

View File

@ -332,7 +332,7 @@ protected:
TRmGroupCallUp* _rmGroupCallUp; TRmGroupCallUp* _rmGroupCallUp;
protected: protected:
SMESH_Mesh() {}; SMESH_Mesh();
SMESH_Mesh(const SMESH_Mesh&) {}; SMESH_Mesh(const SMESH_Mesh&) {};
}; };

View File

@ -132,22 +132,6 @@ SMESH_MeshEditor::AddElement(const vector<const SMDS_MeshNode*> & node,
int nbnode = node.size(); int nbnode = node.size();
SMESHDS_Mesh* mesh = GetMeshDS(); SMESHDS_Mesh* mesh = GetMeshDS();
switch ( type ) { switch ( type ) {
case SMDSAbs_0DElement:
if ( nbnode == 1 ) {
if ( ID >= 0 ) e = mesh->Add0DElementWithID(node[0], ID);
else e = mesh->Add0DElement (node[0] );
}
break;
case SMDSAbs_Edge:
if ( nbnode == 2 ) {
if ( ID >= 0 ) e = mesh->AddEdgeWithID(node[0], node[1], ID);
else e = mesh->AddEdge (node[0], node[1] );
}
else if ( nbnode == 3 ) {
if ( ID >= 0 ) e = mesh->AddEdgeWithID(node[0], node[1], node[2], ID);
else e = mesh->AddEdge (node[0], node[1], node[2] );
}
break;
case SMDSAbs_Face: case SMDSAbs_Face:
if ( !isPoly ) { if ( !isPoly ) {
if (nbnode == 3) { if (nbnode == 3) {
@ -175,6 +159,7 @@ SMESH_MeshEditor::AddElement(const vector<const SMDS_MeshNode*> & node,
else e = mesh->AddPolygonalFace (node ); else e = mesh->AddPolygonalFace (node );
} }
break; break;
case SMDSAbs_Volume: case SMDSAbs_Volume:
if ( !isPoly ) { if ( !isPoly ) {
if (nbnode == 4) { if (nbnode == 4) {
@ -240,6 +225,32 @@ SMESH_MeshEditor::AddElement(const vector<const SMDS_MeshNode*> & node,
node[16],node[17],node[18],node[19] ); node[16],node[17],node[18],node[19] );
} }
} }
break;
case SMDSAbs_Edge:
if ( nbnode == 2 ) {
if ( ID >= 0 ) e = mesh->AddEdgeWithID(node[0], node[1], ID);
else e = mesh->AddEdge (node[0], node[1] );
}
else if ( nbnode == 3 ) {
if ( ID >= 0 ) e = mesh->AddEdgeWithID(node[0], node[1], node[2], ID);
else e = mesh->AddEdge (node[0], node[1], node[2] );
}
break;
case SMDSAbs_0DElement:
if ( nbnode == 1 ) {
if ( ID >= 0 ) e = mesh->Add0DElementWithID(node[0], ID);
else e = mesh->Add0DElement (node[0] );
}
break;
case SMDSAbs_Node:
if ( ID >= 0 ) e = mesh->AddNodeWithID(node[0]->X(), node[0]->Y(), node[0]->Z(), ID);
else e = mesh->AddNode (node[0]->X(), node[0]->Y(), node[0]->Z());
break;
default:;
} }
if ( e ) myLastCreatedElems.Append( e ); if ( e ) myLastCreatedElems.Append( e );
return e; return e;
@ -3874,6 +3885,8 @@ void SMESH_MeshEditor::makeWalls (TNodeOfNodeListMap & mapNewNodes,
const SMDS_MeshElement* elem = itElem->first; const SMDS_MeshElement* elem = itElem->first;
vector<TNodeOfNodeListMapItr>& vecNewNodes = itElemNodes->second; vector<TNodeOfNodeListMapItr>& vecNewNodes = itElemNodes->second;
if(itElem->second.size()==0) continue;
if ( elem->GetType() == SMDSAbs_Edge ) { if ( elem->GetType() == SMDSAbs_Edge ) {
// create a ceiling edge // create a ceiling edge
if (!elem->IsQuadratic()) { if (!elem->IsQuadratic()) {
@ -3898,8 +3911,6 @@ void SMESH_MeshEditor::makeWalls (TNodeOfNodeListMap & mapNewNodes,
if ( elem->GetType() != SMDSAbs_Face ) if ( elem->GetType() != SMDSAbs_Face )
continue; continue;
if(itElem->second.size()==0) continue;
bool hasFreeLinks = false; bool hasFreeLinks = false;
TIDSortedElemSet avoidSet; TIDSortedElemSet avoidSet;

View File

@ -1700,7 +1700,7 @@ bool SMESH_subMesh::CheckComputeError(SMESH_Algo* theAlgo, const TopoDS_Shape& t
// Check my state // Check my state
if ( !_computeError || _computeError->IsOK() ) if ( !_computeError || _computeError->IsOK() )
{ {
_computeState = COMPUTE_OK; _computeState = IsMeshComputed() ? COMPUTE_OK : FAILED_TO_COMPUTE;
} }
else else
{ {

View File

@ -193,6 +193,7 @@ public:
void DumpAlgoState(bool isMain); void DumpAlgoState(bool isMain);
bool ComputeStateEngine(int event); bool ComputeStateEngine(int event);
void ComputeSubMeshStateEngine(int event);
bool Evaluate(MapShapeNbElems& aResMap); bool Evaluate(MapShapeNbElems& aResMap);
@ -250,7 +251,6 @@ protected:
void RemoveSubMeshElementsAndNodes(); void RemoveSubMeshElementsAndNodes();
void UpdateDependantsState(const compute_event theEvent); void UpdateDependantsState(const compute_event theEvent);
void UpdateSubMeshState(const compute_state theState); void UpdateSubMeshState(const compute_state theState);
void ComputeSubMeshStateEngine(int event);
void CleanDependants(); void CleanDependants();
void CleanDependsOn(); void CleanDependsOn();
void SetAlgoState(int state); void SetAlgoState(int state);

View File

@ -25,7 +25,6 @@
// Author : Nicolas REJNERI // Author : Nicolas REJNERI
// Project : SALOME // Project : SALOME
// Module : SMESH // Module : SMESH
// $Header$
// //
#ifndef SMESH_TYPE_HEADER #ifndef SMESH_TYPE_HEADER
#define SMESH_TYPE_HEADER #define SMESH_TYPE_HEADER
@ -57,7 +56,8 @@ enum MeshObjectType {
GROUP_FACE, GROUP_FACE,
GROUP_VOLUME, GROUP_VOLUME,
GROUP_0D, GROUP_0D,
COMPONENT COMPONENT,
IDSOURCE
}; };
#endif #endif

View File

@ -203,6 +203,12 @@ bool SMESH_TypeFilter::isOk (const SUIT_DataOwner* theDataOwner) const
Ok = true; Ok = true;
break; break;
} }
case IDSOURCE:
{
Ok = ( SMESH_TypeFilter(MESHorSUBMESH).isOk( theDataOwner ) ||
SMESH_TypeFilter(GROUP) .isOk( theDataOwner ));
break;
}
} }
} }
return Ok; return Ok;

View File

@ -94,6 +94,7 @@ salomeinclude_HEADERS = \
SMESHGUI_MeshOrderDlg.h \ SMESHGUI_MeshOrderDlg.h \
SMESHGUI_MeshOrderOp.h \ SMESHGUI_MeshOrderOp.h \
SMESHGUI_FileValidator.h \ SMESHGUI_FileValidator.h \
SMESHGUI_CopyMeshDlg.h \
SMESH_SMESHGUI.hxx SMESH_SMESHGUI.hxx
# Libraries targets # Libraries targets
@ -167,6 +168,7 @@ dist_libSMESH_la_SOURCES = \
SMESHGUI_FindElemByPointDlg.cxx \ SMESHGUI_FindElemByPointDlg.cxx \
SMESHGUI_MeshOrderDlg.cxx \ SMESHGUI_MeshOrderDlg.cxx \
SMESHGUI_MeshOrderOp.cxx \ SMESHGUI_MeshOrderOp.cxx \
SMESHGUI_CopyMeshDlg.cxx \
SMESHGUI_FileValidator.cxx SMESHGUI_FileValidator.cxx
MOC_FILES = \ MOC_FILES = \
@ -224,6 +226,7 @@ MOC_FILES = \
SMESHGUI_Make2DFrom3DOp_moc.cxx \ SMESHGUI_Make2DFrom3DOp_moc.cxx \
SMESHGUI_FindElemByPointDlg_moc.cxx \ SMESHGUI_FindElemByPointDlg_moc.cxx \
SMESHGUI_MeshOrderDlg_moc.cxx \ SMESHGUI_MeshOrderDlg_moc.cxx \
SMESHGUI_CopyMeshDlg_moc.cxx \
SMESHGUI_MeshOrderOp_moc.cxx SMESHGUI_MeshOrderOp_moc.cxx
nodist_libSMESH_la_SOURCES= \ nodist_libSMESH_la_SOURCES= \

View File

@ -76,6 +76,7 @@
#include "SMESHGUI_TransparencyDlg.h" #include "SMESHGUI_TransparencyDlg.h"
//#include "SMESHGUI_WhatIsDlg.h" //#include "SMESHGUI_WhatIsDlg.h"
#include "SMESHGUI_DuplicateNodesDlg.h" #include "SMESHGUI_DuplicateNodesDlg.h"
#include "SMESHGUI_CopyMeshDlg.h"
#include "SMESHGUI_Utils.h" #include "SMESHGUI_Utils.h"
#include "SMESHGUI_MeshUtils.h" #include "SMESHGUI_MeshUtils.h"
@ -141,6 +142,7 @@
#include <vtkRenderer.h> #include <vtkRenderer.h>
#include <vtkPlane.h> #include <vtkPlane.h>
#include <vtkCallbackCommand.h> #include <vtkCallbackCommand.h>
#include <vtkLookupTable.h>
// SALOME KERNEL includes // SALOME KERNEL includes
#include <SALOMEDS_Study.hxx> #include <SALOMEDS_Study.hxx>
@ -759,6 +761,14 @@
type = QObject::tr( "FREE_BORDERS" ); type = QObject::tr( "FREE_BORDERS" );
else if ( dynamic_cast< SMESH::Controls::FreeFaces* >( f.get() ) ) else if ( dynamic_cast< SMESH::Controls::FreeFaces* >( f.get() ) )
type = QObject::tr( "FREE_FACES" ); type = QObject::tr( "FREE_FACES" );
else if ( dynamic_cast< SMESH::Controls::BareBorderVolume* >( f.get() ) )
type = QObject::tr( "BARE_BORDER_VOLUME" );
else if ( dynamic_cast< SMESH::Controls::BareBorderFace* >( f.get() ) )
type = QObject::tr( "BARE_BORDER_FACE" );
else if ( dynamic_cast< SMESH::Controls::OverConstrainedVolume* >( f.get() ) )
type = QObject::tr( "OVER_CONSTRAINED_VOLUME" );
else if ( dynamic_cast< SMESH::Controls::OverConstrainedFace* >( f.get() ) )
type = QObject::tr( "OVER_CONSTRAINED_FACE" );
return type; return type;
} }
@ -779,10 +789,26 @@
if ( aScalarBarActor && aFunctor ) { if ( aScalarBarActor && aFunctor ) {
SMESH::Controls::NumericalFunctor* aNumFun = dynamic_cast<SMESH::Controls::NumericalFunctor*>( aFunctor.get() ); SMESH::Controls::NumericalFunctor* aNumFun = dynamic_cast<SMESH::Controls::NumericalFunctor*>( aFunctor.get() );
if ( aNumFun ) { if ( aNumFun ) {
int nbRanges = aScalarBarActor->GetMaximumNumberOfColors(); std::vector<int> elements;
SMESH::SMESH_Mesh_var mesh = SMESH::IObjectToInterface<SMESH::SMESH_Mesh>(anIO);
if ( mesh->_is_nil() ) {
SMESH::SMESH_IDSource_var idSource =
SMESH::IObjectToInterface<SMESH::SMESH_IDSource>(anIO);
if ( !idSource->_is_nil() )
{
SMESH::long_array_var ids = idSource->GetIDs();
elements.resize( ids->length() );
for ( unsigned i = 0; i < elements.size(); ++i )
elements[i] = ids[i];
}
}
int nbIntervals = aScalarBarActor->GetMaximumNumberOfColors();
vtkLookupTable* lookupTable =
static_cast<vtkLookupTable*>(aScalarBarActor->GetLookupTable());
double * minmax = lookupTable->GetRange();
std::vector<int> nbEvents; std::vector<int> nbEvents;
std::vector<double> funValues; std::vector<double> funValues;
aNumFun->GetHistogram( nbRanges, nbEvents, funValues ); aNumFun->GetHistogram( nbIntervals, nbEvents, funValues, elements, minmax );
QString anInitialPath = ""; QString anInitialPath = "";
if ( SUIT_FileDlg::getLastVisitedPath().isEmpty() ) if ( SUIT_FileDlg::getLastVisitedPath().isEmpty() )
anInitialPath = QDir::currentPath(); anInitialPath = QDir::currentPath();
@ -1178,6 +1204,18 @@
case 6023: case 6023:
aControl = SMESH_Actor::eMaxElementLength3D; aControl = SMESH_Actor::eMaxElementLength3D;
break; break;
case 6024:
aControl = SMESH_Actor::eBareBorderVolume;
break;
case 6025:
aControl = SMESH_Actor::eBareBorderFace;
break;
case 6026:
aControl = SMESH_Actor::eOverConstrainedVolume;
break;
case 6027:
aControl = SMESH_Actor::eOverConstrainedFace;
break;
} }
anActor->SetControlMode(aControl); anActor->SetControlMode(aControl);
anActor->GetScalarBarActor()->SetTitle( functorToString( anActor->GetFunctor() ).toLatin1().constData() ); anActor->GetScalarBarActor()->SetTitle( functorToString( anActor->GetFunctor() ).toLatin1().constData() );
@ -2024,6 +2062,13 @@ bool SMESHGUI::OnGUIEvent( int theCommandID )
case 704: // Edit mesh/sub-mesh case 704: // Edit mesh/sub-mesh
startOperation( theCommandID ); startOperation( theCommandID );
break; break;
case 705: // copy mesh
{
if (checkLock(aStudy)) break;
EmitSignalDeactivateDialog();
( new SMESHGUI_CopyMeshDlg( this ) )->show();
}
break;
case 710: // Build compound mesh case 710: // Build compound mesh
{ {
if (checkLock(aStudy)) break; if (checkLock(aStudy)) break;
@ -2973,6 +3018,10 @@ bool SMESHGUI::OnGUIEvent( int theCommandID )
case 6021: case 6021:
case 6022: case 6022:
case 6023: case 6023:
case 6024:
case 6025:
case 6026:
case 6027:
if ( vtkwnd ) { if ( vtkwnd ) {
LightApp_SelectionMgr* mgr = selectionMgr(); LightApp_SelectionMgr* mgr = selectionMgr();
@ -3189,6 +3238,7 @@ void SMESHGUI::initialize( CAM_Application* app )
createSMESHAction( 702, "CREATE_MESH", "ICON_DLG_INIT_MESH" ); createSMESHAction( 702, "CREATE_MESH", "ICON_DLG_INIT_MESH" );
createSMESHAction( 703, "CREATE_SUBMESH", "ICON_DLG_ADD_SUBMESH" ); createSMESHAction( 703, "CREATE_SUBMESH", "ICON_DLG_ADD_SUBMESH" );
createSMESHAction( 704, "EDIT_MESHSUBMESH","ICON_DLG_EDIT_MESH" ); createSMESHAction( 704, "EDIT_MESHSUBMESH","ICON_DLG_EDIT_MESH" );
createSMESHAction( 705, "COPY_MESH", "ICON_COPY_MESH" );
createSMESHAction( 710, "BUILD_COMPOUND", "ICON_BUILD_COMPOUND" ); createSMESHAction( 710, "BUILD_COMPOUND", "ICON_BUILD_COMPOUND" );
createSMESHAction( 711, "PRECOMPUTE", "ICON_PRECOMPUTE" ); createSMESHAction( 711, "PRECOMPUTE", "ICON_PRECOMPUTE" );
createSMESHAction( 712, "EVALUATE", "ICON_COMPUTE" ); createSMESHAction( 712, "EVALUATE", "ICON_COMPUTE" );
@ -3214,6 +3264,10 @@ void SMESHGUI::initialize( CAM_Application* app )
createSMESHAction( 6021, "FREE_FACES", "ICON_FREE_FACES", 0, true ); createSMESHAction( 6021, "FREE_FACES", "ICON_FREE_FACES", 0, true );
createSMESHAction( 6022, "MAX_ELEMENT_LENGTH_2D", "ICON_MAX_ELEMENT_LENGTH_2D", 0, true ); createSMESHAction( 6022, "MAX_ELEMENT_LENGTH_2D", "ICON_MAX_ELEMENT_LENGTH_2D", 0, true );
createSMESHAction( 6023, "MAX_ELEMENT_LENGTH_3D", "ICON_MAX_ELEMENT_LENGTH_3D", 0, true ); createSMESHAction( 6023, "MAX_ELEMENT_LENGTH_3D", "ICON_MAX_ELEMENT_LENGTH_3D", 0, true );
createSMESHAction( 6024, "BARE_BORDER_VOLUME","ICON_BARE_BORDER_VOLUME", 0, true );
createSMESHAction( 6025, "BARE_BORDER_FACE","ICON_BARE_BORDER_FACE", 0, true );
createSMESHAction( 6026, "OVER_CONSTRAINED_VOLUME","ICON_OVER_CONSTRAINED_VOLUME", 0, true );
createSMESHAction( 6027, "OVER_CONSTRAINED_FACE","ICON_OVER_CONSTRAINED_FACE", 0, true );
createSMESHAction( 6003, "FREE_BORDER", "ICON_FREE_EDGE_2D", 0, true ); createSMESHAction( 6003, "FREE_BORDER", "ICON_FREE_EDGE_2D", 0, true );
createSMESHAction( 6004, "CONNECTION", "ICON_CONNECTION", 0, true ); createSMESHAction( 6004, "CONNECTION", "ICON_CONNECTION", 0, true );
createSMESHAction( 6005, "FREE_NODE", "ICON_FREE_NODE", 0, true ); createSMESHAction( 6005, "FREE_NODE", "ICON_FREE_NODE", 0, true );
@ -3353,6 +3407,7 @@ void SMESHGUI::initialize( CAM_Application* app )
createMenu( 703, meshId, -1 ); createMenu( 703, meshId, -1 );
createMenu( 704, meshId, -1 ); createMenu( 704, meshId, -1 );
createMenu( 710, meshId, -1 ); createMenu( 710, meshId, -1 );
createMenu( 705, meshId, -1 );
createMenu( separator(), meshId, -1 ); createMenu( separator(), meshId, -1 );
createMenu( 701, meshId, -1 ); createMenu( 701, meshId, -1 );
createMenu( 711, meshId, -1 ); createMenu( 711, meshId, -1 );
@ -3371,8 +3426,6 @@ void SMESHGUI::initialize( CAM_Application* app )
createMenu( separator(), meshId, -1 ); createMenu( separator(), meshId, -1 );
createMenu( 814, meshId, -1 ); createMenu( 814, meshId, -1 );
createMenu( separator(), meshId, -1 ); createMenu( separator(), meshId, -1 );
createMenu( 813, meshId, -1 );
createMenu( separator(), meshId, -1 );
createMenu( 900, meshId, -1 ); createMenu( 900, meshId, -1 );
//createMenu( 902, meshId, -1 ); //createMenu( 902, meshId, -1 );
createMenu( 903, meshId, -1 ); createMenu( 903, meshId, -1 );
@ -3385,6 +3438,8 @@ void SMESHGUI::initialize( CAM_Application* app )
createMenu( 6001, edgeId, -1 ); createMenu( 6001, edgeId, -1 );
createMenu( 6004, edgeId, -1 ); createMenu( 6004, edgeId, -1 );
createMenu( 6021, faceId, -1 ); createMenu( 6021, faceId, -1 );
createMenu( 6025, faceId, -1 );
createMenu( 6027, faceId, -1 );
createMenu( 6018, faceId, -1 ); createMenu( 6018, faceId, -1 );
createMenu( 6019, faceId, -1 ); createMenu( 6019, faceId, -1 );
createMenu( 6011, faceId, -1 ); createMenu( 6011, faceId, -1 );
@ -3397,6 +3452,8 @@ void SMESHGUI::initialize( CAM_Application* app )
createMenu( 6017, volumeId, -1 ); createMenu( 6017, volumeId, -1 );
createMenu( 6009, volumeId, -1 ); createMenu( 6009, volumeId, -1 );
createMenu( 6023, volumeId, -1 ); createMenu( 6023, volumeId, -1 );
createMenu( 6024, volumeId, -1 );
createMenu( 6026, volumeId, -1 );
createMenu( 4000, addId, -1 ); createMenu( 4000, addId, -1 );
createMenu( 4009, addId, -1 ); createMenu( 4009, addId, -1 );
@ -3420,6 +3477,8 @@ void SMESHGUI::initialize( CAM_Application* app )
createMenu( 4042, removeId, -1 ); createMenu( 4042, removeId, -1 );
createMenu( 4044, removeId, -1 ); createMenu( 4044, removeId, -1 );
createMenu( separator(), removeId, -1 ); createMenu( separator(), removeId, -1 );
createMenu( 813, removeId, -1 );
createMenu( separator(), removeId, -1 );
createMenu( 4043, removeId, -1 ); createMenu( 4043, removeId, -1 );
createMenu( 4051, renumId, -1 ); createMenu( 4051, renumId, -1 );
@ -3464,6 +3523,7 @@ void SMESHGUI::initialize( CAM_Application* app )
createTool( 703, meshTb ); createTool( 703, meshTb );
createTool( 704, meshTb ); createTool( 704, meshTb );
createTool( 710, meshTb ); createTool( 710, meshTb );
createTool( 705, meshTb );
createTool( separator(), meshTb ); createTool( separator(), meshTb );
createTool( 701, meshTb ); createTool( 701, meshTb );
createTool( 711, meshTb ); createTool( 711, meshTb );
@ -3490,6 +3550,8 @@ void SMESHGUI::initialize( CAM_Application* app )
createTool( 6004, ctrlTb ); createTool( 6004, ctrlTb );
createTool( separator(), ctrlTb ); createTool( separator(), ctrlTb );
createTool( 6021, ctrlTb ); createTool( 6021, ctrlTb );
createTool( 6025, ctrlTb );
createTool( 6027, ctrlTb );
createTool( 6018, ctrlTb ); createTool( 6018, ctrlTb );
createTool( 6019, ctrlTb ); createTool( 6019, ctrlTb );
createTool( 6011, ctrlTb ); createTool( 6011, ctrlTb );
@ -3503,6 +3565,8 @@ void SMESHGUI::initialize( CAM_Application* app )
createTool( 6017, ctrlTb ); createTool( 6017, ctrlTb );
createTool( 6009, ctrlTb ); createTool( 6009, ctrlTb );
createTool( 6023, ctrlTb ); createTool( 6023, ctrlTb );
createTool( 6024, ctrlTb );
createTool( 6026, ctrlTb );
createTool( separator(), ctrlTb ); createTool( separator(), ctrlTb );
createTool( 4000, addRemTb ); createTool( 4000, addRemTb );
@ -3805,50 +3869,58 @@ void SMESHGUI::initialize( CAM_Application* app )
aSubId = popupMgr()->insert( tr( "MEN_FACE_CTRL" ), anId, -1 ); // FACE CONTROLS aSubId = popupMgr()->insert( tr( "MEN_FACE_CTRL" ), anId, -1 ); // FACE CONTROLS
popupMgr()->insert( action( 6021 ), aSubId, -1 ); // FREE_FACE popupMgr()->insert ( action( 6021 ), aSubId, -1 ); // FREE_FACE
popupMgr()->setRule( action( 6021 ), aMeshInVtkHasFaces /*aMeshInVtkHasVolumes*/, popupMgr()->setRule( action( 6021 ), aMeshInVtkHasFaces /*aMeshInVtkHasVolumes*/,
QtxPopupMgr::VisibleRule ); QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6021 ), "controlMode = 'eFreeFaces'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6021 ), "controlMode = 'eFreeFaces'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6018 ), aSubId, -1 ); // LENGTH_2D popupMgr()->insert ( action( 6018 ), aSubId, -1 ); // LENGTH_2D
popupMgr()->setRule( action( 6018 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6018 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6018 ), "controlMode = 'eLength2D'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6018 ), "controlMode = 'eLength2D'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6019 ), aSubId, -1 ); // CONNECTION_2D popupMgr()->insert ( action( 6019 ), aSubId, -1 ); // CONNECTION_2D
popupMgr()->setRule( action( 6019 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6019 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6019 ), "controlMode = 'eMultiConnection2D'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6019 ), "controlMode = 'eMultiConnection2D'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6011 ), aSubId, -1 ); // AREA popupMgr()->insert ( action( 6011 ), aSubId, -1 ); // AREA
popupMgr()->setRule( action( 6011 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6011 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6011 ), "controlMode = 'eArea'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6011 ), "controlMode = 'eArea'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6012 ), aSubId, -1 ); // TAPER popupMgr()->insert ( action( 6012 ), aSubId, -1 ); // TAPER
popupMgr()->setRule( action( 6012 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6012 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6012 ), "controlMode = 'eTaper'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6012 ), "controlMode = 'eTaper'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6013 ), aSubId, -1 ); // ASPECT popupMgr()->insert ( action( 6013 ), aSubId, -1 ); // ASPECT
popupMgr()->setRule( action( 6013 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6013 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6013 ), "controlMode = 'eAspectRatio'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6013 ), "controlMode = 'eAspectRatio'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6014 ), aSubId, -1 ); // MIN_ANG popupMgr()->insert ( action( 6014 ), aSubId, -1 ); // MIN_ANG
popupMgr()->setRule( action( 6014 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6014 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6014 ), "controlMode = 'eMinimumAngle'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6014 ), "controlMode = 'eMinimumAngle'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6015 ), aSubId, -1 ); // WARP popupMgr()->insert ( action( 6015 ), aSubId, -1 ); // WARP
popupMgr()->setRule( action( 6015 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6015 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6015 ), "controlMode = 'eWarping'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6015 ), "controlMode = 'eWarping'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6016 ), aSubId, -1 ); // SKEW popupMgr()->insert ( action( 6016 ), aSubId, -1 ); // SKEW
popupMgr()->setRule( action( 6016 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6016 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6016 ), "controlMode = 'eSkew'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6016 ), "controlMode = 'eSkew'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6022 ), aSubId, -1 ); // MAX_ELEMENT_LENGTH_2D popupMgr()->insert ( action( 6022 ), aSubId, -1 ); // MAX_ELEMENT_LENGTH_2D
popupMgr()->setRule( action( 6022 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6022 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6022 ), "controlMode = 'eMaxElementLength2D'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6022 ), "controlMode = 'eMaxElementLength2D'", QtxPopupMgr::ToggleRule );
popupMgr()->insert ( action( 6025 ), aSubId, -1 ); // BARE_BORDER_FACE
popupMgr()->setRule( action( 6025 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6025 ), "controlMode = 'eBareBorderFace'", QtxPopupMgr::ToggleRule );
popupMgr()->insert ( action( 6027 ), aSubId, -1 ); // OVER_CONSTRAINED_FACE
popupMgr()->setRule( action( 6027 ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6027 ), "controlMode = 'eOverConstrainedFace'", QtxPopupMgr::ToggleRule );
aSubId = popupMgr()->insert( tr( "MEN_VOLUME_CTRL" ), anId, -1 ); // VOLUME CONTROLS aSubId = popupMgr()->insert( tr( "MEN_VOLUME_CTRL" ), anId, -1 ); // VOLUME CONTROLS
popupMgr()->insert( action( 6017 ), aSubId, -1 ); // ASPECT_3D popupMgr()->insert ( action( 6017 ), aSubId, -1 ); // ASPECT_3D
popupMgr()->setRule( action( 6017 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6017 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6017 ), "controlMode = 'eAspectRatio3D'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6017 ), "controlMode = 'eAspectRatio3D'", QtxPopupMgr::ToggleRule );
@ -3856,10 +3928,18 @@ void SMESHGUI::initialize( CAM_Application* app )
popupMgr()->setRule( action( 6009 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6009 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6009 ), "controlMode = 'eVolume3D'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6009 ), "controlMode = 'eVolume3D'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( action( 6023 ), aSubId, -1 ); // MAX_ELEMENT_LENGTH_3D popupMgr()->insert ( action( 6023 ), aSubId, -1 ); // MAX_ELEMENT_LENGTH_3D
popupMgr()->setRule( action( 6023 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule ); popupMgr()->setRule( action( 6023 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6023 ), "controlMode = 'eMaxElementLength3D'", QtxPopupMgr::ToggleRule ); popupMgr()->setRule( action( 6023 ), "controlMode = 'eMaxElementLength3D'", QtxPopupMgr::ToggleRule );
popupMgr()->insert ( action( 6024 ), aSubId, -1 ); // BARE_BORDER_VOLUME
popupMgr()->setRule( action( 6024 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6024 ), "controlMode = 'eBareBorderVolume'", QtxPopupMgr::ToggleRule );
popupMgr()->insert ( action( 6026 ), aSubId, -1 ); // OVER_CONSTRAINED_VOLUME
popupMgr()->setRule( action( 6026 ), aMeshInVtkHasVolumes, QtxPopupMgr::VisibleRule );
popupMgr()->setRule( action( 6026 ), "controlMode = 'eOverConstrainedVolume'", QtxPopupMgr::ToggleRule );
popupMgr()->insert( separator(), anId, -1 ); popupMgr()->insert( separator(), anId, -1 );
popupMgr()->insert( action( 201 ), anId, -1 ); // SCALAR_BAR_PROP popupMgr()->insert( action( 201 ), anId, -1 ); // SCALAR_BAR_PROP
@ -5359,7 +5439,15 @@ void SMESHGUI::restoreVisualParameters (int savePoint)
aPlaneInfo.PlaneId = aPlaneId; aPlaneInfo.PlaneId = aPlaneId;
aPlaneInfo.ActorList.push_back( aSmeshActor ); aPlaneInfo.ActorList.push_back( aSmeshActor );
aPlaneInfo.ViewManager = vman; aPlaneInfo.ViewManager = vman;
aPlaneInfoList.push_back( aPlaneInfo );
// to make the list sorted by plane id
anIter = aPlaneInfoList.begin();
for( ; anIter != aPlaneInfoList.end(); anIter++ ) {
const TPlaneInfo& aPlaneInfoRef = *anIter;
if( aPlaneInfoRef.PlaneId > aPlaneId )
break;
}
aPlaneInfoList.insert( anIter, aPlaneInfo );
} }
} }
} }
@ -5370,6 +5458,52 @@ void SMESHGUI::restoreVisualParameters (int savePoint)
} // for names/parameters iterator } // for names/parameters iterator
} // for entries iterator } // for entries iterator
// take into account planes with empty list of actors referred to them
QList<SUIT_ViewManager*> aVMList;
getApp()->viewManagers(SVTK_Viewer::Type(), aVMList);
TPlaneDataMap::const_iterator aPlaneDataIter = aPlaneDataMap.begin();
for( ; aPlaneDataIter != aPlaneDataMap.end(); aPlaneDataIter++ ) {
int aViewId = aPlaneDataIter->first;
if( aViewId >= 0 && aViewId < aVMList.count() ) {
SUIT_ViewManager* aViewManager = aVMList.at( aViewId );
const TPlaneDataList& aPlaneDataList = aPlaneDataIter->second;
TPlaneInfoList& aPlaneInfoList = aPlaneInfoMap[ aViewId ];
TPlaneDataList::const_iterator anIter2 = aPlaneDataList.begin();
for( ; anIter2 != aPlaneDataList.end(); anIter2++ ) {
const TPlaneData& aPlaneData = *anIter2;
int aPlaneId = aPlaneData.Id;
bool anIsFound = false;
TPlaneInfoList::const_iterator anIter3 = aPlaneInfoList.begin();
for( ; anIter3 != aPlaneInfoList.end(); anIter3++ ) {
const TPlaneInfo& aPlaneInfo = *anIter3;
if( aPlaneInfo.PlaneId == aPlaneId ) {
anIsFound = true;
break;
}
}
if( !anIsFound ) {
TPlaneInfo aPlaneInfo; // ActorList field is empty
aPlaneInfo.PlaneId = aPlaneId;
aPlaneInfo.ViewManager = aViewManager;
// to make the list sorted by plane id
TPlaneInfoList::iterator anIter4 = aPlaneInfoList.begin();
for( ; anIter4 != aPlaneInfoList.end(); anIter4++ ) {
const TPlaneInfo& aPlaneInfoRef = *anIter4;
if( aPlaneInfoRef.PlaneId > aPlaneId )
break;
}
aPlaneInfoList.insert( anIter4, aPlaneInfo );
}
}
}
}
// add clipping planes to actors according to the restored parameters // add clipping planes to actors according to the restored parameters
// and update the clipping plane map // and update the clipping plane map
TPlaneInfoMap::const_iterator anIter1 = aPlaneInfoMap.begin(); TPlaneInfoMap::const_iterator anIter1 = aPlaneInfoMap.begin();

View File

@ -194,7 +194,8 @@ private:
struct TSetVisibility { struct TSetVisibility {
TSetVisibility(int theIsVisible): myIsVisible(theIsVisible){} TSetVisibility(int theIsVisible): myIsVisible(theIsVisible){}
void operator()(SMESH::TPlaneData& thePlaneData){ void operator()(SMESH::TPlaneData& thePlaneData){
thePlaneData.Plane.GetPointer()->myActor->SetVisibility(myIsVisible); bool anIsEmpty = thePlaneData.ActorList.empty();
thePlaneData.Plane.GetPointer()->myActor->SetVisibility(myIsVisible && !anIsEmpty);
} }
int myIsVisible; int myIsVisible;
}; };
@ -261,7 +262,18 @@ SMESH::OrientedPlane* SMESHGUI_ClippingDlg::AddPlane (SMESH::TActorList
vtkFloatingPointType aBounds[6]; vtkFloatingPointType aBounds[6];
vtkFloatingPointType anOrigin[3]; vtkFloatingPointType anOrigin[3];
bool anIsOk = SMESH::ComputeClippingPlaneParameters( theActorList,
bool anIsOk = false;
if( theActorList.empty() ) {
// to support planes with empty actor list we should create
// a nullified plane that will be initialized later
anOrigin[0] = anOrigin[1] = anOrigin[2] = 0;
aBounds[0] = aBounds[2] = aBounds[4] = 0;
aBounds[1] = aBounds[3] = aBounds[5] = 0;
anIsOk = true;
}
else
anIsOk = SMESH::ComputeClippingPlaneParameters( theActorList,
aNormal, aNormal,
theDistance, theDistance,
aBounds, aBounds,
@ -545,8 +557,10 @@ void SMESHGUI_ClippingDlg::ClickOnApply()
SMESH::TPlaneData aPlaneData = *anIter2; SMESH::TPlaneData aPlaneData = *anIter2;
SMESH::TPlane aPlane = aPlaneData.Plane; SMESH::TPlane aPlane = aPlaneData.Plane;
SMESH::TActorList anActorList = aPlaneData.ActorList; SMESH::TActorList anActorList = aPlaneData.ActorList;
if( anActorList.empty() )
continue; // the check is disabled to support planes with empty actor list
//if( anActorList.empty() )
// continue;
SMESH::OrientedPlane* anOrientedPlane = SMESH::OrientedPlane::New(myViewWindow); SMESH::OrientedPlane* anOrientedPlane = SMESH::OrientedPlane::New(myViewWindow);
anOrientedPlane->ShallowCopy(aPlane.GetPointer()); anOrientedPlane->ShallowCopy(aPlane.GetPointer());

View File

@ -0,0 +1,667 @@
// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
//
// SMESH SMESHGUI : GUI for SMESH component
// File : SMESHGUI_CopyMeshDlg.cxx
#include "SMESHGUI_CopyMeshDlg.h"
#include "SMESHGUI.h"
#include "SMESHGUI_SpinBox.h"
#include "SMESHGUI_Utils.h"
#include "SMESHGUI_VTKUtils.h"
#include "SMESHGUI_MeshUtils.h"
#include "SMESHGUI_IdValidator.h"
#include "SMESHGUI_FilterDlg.h"
#include <SMESH_Actor.h>
#include <SMESH_TypeFilter.hxx>
#include <SMDS_Mesh.hxx>
// SALOME GUI includes
#include <SUIT_Desktop.h>
#include <SUIT_ResourceMgr.h>
#include <SUIT_Session.h>
#include <SUIT_MessageBox.h>
#include <SUIT_OverrideCursor.h>
#include <LightApp_Application.h>
#include <LightApp_SelectionMgr.h>
#include <SVTK_ViewModel.h>
#include <SVTK_ViewWindow.h>
#include <SALOME_ListIO.hxx>
// SALOME KERNEL includes
#include <SALOMEDSClient_SObject.hxx>
// OCCT includes
#include <TColStd_MapOfInteger.hxx>
// Qt includes
#include <QApplication>
#include <QButtonGroup>
#include <QGroupBox>
#include <QLabel>
#include <QLineEdit>
#include <QPushButton>
#include <QRadioButton>
#include <QCheckBox>
#include <QHBoxLayout>
#include <QVBoxLayout>
#include <QGridLayout>
#include <QSpinBox>
#include <QKeyEvent>
// IDL includes
#include <SALOMEconfig.h>
#include CORBA_SERVER_HEADER(SMESH_Group)
#include CORBA_SERVER_HEADER(SMESH_MeshEditor)
/*!
\class BusyLocker
\brief Simple 'busy state' flag locker.
\internal
*/
namespace
{
class BusyLocker
{
public:
//! Constructor. Sets passed boolean flag to \c true.
BusyLocker( bool& busy ) : myBusy( busy ) { myBusy = true; }
//! Destructor. Clear external boolean flag passed as parameter to the constructor to \c false.
~BusyLocker() { myBusy = false; }
private:
bool& myBusy; //! External 'busy state' boolean flag
};
}
#define SPACING 6
#define MARGIN 11
//To disable automatic genericobj management, the following line should be commented.
//Otherwise, it should be uncommented. Refer to KERNEL_SRC/src/SALOMEDSImpl/SALOMEDSImpl_AttributeIOR.cxx
#define WITHGENERICOBJ
//================================================================================
/*!
* \brief Constructor
*/
//================================================================================
SMESHGUI_CopyMeshDlg::SMESHGUI_CopyMeshDlg( SMESHGUI* theModule )
: QDialog( SMESH::GetDesktop( theModule ) ),
mySMESHGUI( theModule ),
mySelectionMgr( SMESH::GetSelectionMgr( theModule ) ),
myFilterDlg(0),
mySelectedObject(SMESH::SMESH_IDSource::_nil())
{
QPixmap image (SMESH::GetResourceMgr( mySMESHGUI )->loadPixmap("SMESH", tr("ICON_COPY_MESH")));
setModal(false);
setAttribute(Qt::WA_DeleteOnClose, true);
setWindowTitle(tr("SMESH_COPY_MESH_TITLE"));
setSizeGripEnabled(true);
QVBoxLayout* SMESHGUI_CopyMeshDlgLayout = new QVBoxLayout(this);
SMESHGUI_CopyMeshDlgLayout->setSpacing(SPACING);
SMESHGUI_CopyMeshDlgLayout->setMargin(MARGIN);
/***************************************************************/
ConstructorsBox = new QGroupBox(tr("SMESH_COPY_MESH_TITLE"), this);
QButtonGroup* GroupConstructors = new QButtonGroup(this);
QHBoxLayout* ConstructorsBoxLayout = new QHBoxLayout(ConstructorsBox);
ConstructorsBoxLayout->setSpacing(SPACING);
ConstructorsBoxLayout->setMargin(MARGIN);
QRadioButton* RadioButton1= new QRadioButton(ConstructorsBox);
RadioButton1->setIcon(image);
GroupConstructors->addButton(RadioButton1, 0);
ConstructorsBoxLayout->addWidget(RadioButton1);
RadioButton1->setChecked(true);
GroupConstructors->addButton(RadioButton1, 0);
/***************************************************************/
GroupArguments = new QGroupBox(tr("SMESH_ARGUMENTS"), this);
QGridLayout* GroupArgumentsLayout = new QGridLayout(GroupArguments);
GroupArgumentsLayout->setSpacing(SPACING);
GroupArgumentsLayout->setMargin(MARGIN);
myIdValidator = new SMESHGUI_IdValidator(this);
// Controls for idSource/elements selection
myTextLabelElements = new QLabel(tr("OBJECT_NAME"), GroupArguments);
myLineEditElements = new QLineEdit(GroupArguments);
myLineEditElements->setValidator(myIdValidator);
myLineEditElements->setMaxLength(-1);
myFilterBtn = new QPushButton( tr( "SMESH_BUT_FILTER" ), GroupArguments );
connect(myFilterBtn, SIGNAL(clicked()), this, SLOT(setFilters()));
// Control for the mesh objects selection
myIdSourceCheck = new QCheckBox(tr("SMESH_SELECT_WHOLE_MESH"), GroupArguments);
// Name of a mesh to create
QLabel* meshNameLabel = new QLabel(tr("NEW_NAME"), GroupArguments);
myMeshNameEdit = new QLineEdit(GroupArguments);
// CheckBox for copying groups
myCopyGroupsCheck = new QCheckBox(tr("SMESH_MAKE_GROUPS"), GroupArguments);
myCopyGroupsCheck->setChecked(false);
// CheckBox for keeping ids
myKeepIdsCheck = new QCheckBox(tr("SMESH_KEEP_IDS"), GroupArguments);
myKeepIdsCheck->setChecked(true);
// layout
GroupArgumentsLayout->addWidget(myTextLabelElements, 0, 0);
GroupArgumentsLayout->addWidget(myLineEditElements, 0, 1, 1, 5);
GroupArgumentsLayout->addWidget(myFilterBtn, 0, 6);
GroupArgumentsLayout->addWidget(myIdSourceCheck, 1, 0, 1, 6);
GroupArgumentsLayout->addWidget(meshNameLabel, 2, 0);
GroupArgumentsLayout->addWidget(myMeshNameEdit, 2, 1, 1, 5);
GroupArgumentsLayout->addWidget(myCopyGroupsCheck, 3, 0, 1, 6);
GroupArgumentsLayout->addWidget(myKeepIdsCheck, 4, 0, 1, 6);
/***************************************************************/
GroupButtons = new QGroupBox(this);
QHBoxLayout* GroupButtonsLayout = new QHBoxLayout(GroupButtons);
GroupButtonsLayout->setSpacing(SPACING);
GroupButtonsLayout->setMargin(MARGIN);
buttonOk = new QPushButton(tr("SMESH_BUT_APPLY_AND_CLOSE"), GroupButtons);
buttonOk->setAutoDefault(true);
buttonOk->setDefault(true);
buttonApply = new QPushButton(tr("SMESH_BUT_APPLY"), GroupButtons);
buttonApply->setAutoDefault(true);
buttonCancel = new QPushButton(tr("SMESH_BUT_CLOSE"), GroupButtons);
buttonCancel->setAutoDefault(true);
buttonHelp = new QPushButton(tr("SMESH_BUT_HELP"), GroupButtons);
buttonHelp->setAutoDefault(true);
GroupButtonsLayout->addWidget(buttonOk);
GroupButtonsLayout->addSpacing(10);
GroupButtonsLayout->addWidget(buttonApply);
GroupButtonsLayout->addSpacing(10);
GroupButtonsLayout->addStretch();
GroupButtonsLayout->addWidget(buttonCancel);
GroupButtonsLayout->addWidget(buttonHelp);
/***************************************************************/
SMESHGUI_CopyMeshDlgLayout->addWidget(ConstructorsBox);
SMESHGUI_CopyMeshDlgLayout->addWidget(GroupArguments);
SMESHGUI_CopyMeshDlgLayout->addWidget(GroupButtons);
/* Initialisations */
mySelector = (SMESH::GetViewWindow( mySMESHGUI ))->GetSelector();
mySMESHGUI->SetActiveDialogBox((QDialog*)this);
// Selection filter
myIdSourceFilter = new SMESH_TypeFilter( IDSOURCE );
myHelpFileName = "copy_mesh_page.html";
Init();
/* signals and slots connections */
connect(buttonOk, SIGNAL(clicked()), this, SLOT(ClickOnOk()));
connect(buttonCancel, SIGNAL(clicked()), this, SLOT(ClickOnCancel()));
connect(buttonApply, SIGNAL(clicked()), this, SLOT(ClickOnApply()));
connect(buttonHelp, SIGNAL(clicked()), this, SLOT(ClickOnHelp()));
connect(mySMESHGUI, SIGNAL (SignalDeactivateActiveDialog()),
this, SLOT (DeactivateActiveDialog()));
connect(mySelectionMgr, SIGNAL (currentSelectionChanged()),
this, SLOT (SelectionIntoArgument()));
connect(mySMESHGUI, SIGNAL (SignalCloseAllDialogs()),/* to close dialog if study change */
this, SLOT (ClickOnCancel()));
connect(myLineEditElements, SIGNAL(textChanged(const QString&)),
this, SLOT (onTextChange(const QString&)));
connect(myIdSourceCheck, SIGNAL(toggled(bool)),
this, SLOT (onSelectIdSource(bool)));
SelectionIntoArgument();
}
//=================================================================================
// function : ~SMESHGUI_CopyMeshDlg()
// purpose : Destroys the object and frees any allocated resources
//=================================================================================
SMESHGUI_CopyMeshDlg::~SMESHGUI_CopyMeshDlg()
{
if ( myFilterDlg )
{
myFilterDlg->setParent( 0 );
delete myFilterDlg; myFilterDlg = 0;
}
if ( myIdSourceFilter )
{
if ( mySelectionMgr )
mySelectionMgr->removeFilter( myIdSourceFilter );
delete myIdSourceFilter; myIdSourceFilter=0;
}
}
//=================================================================================
// function : Init()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::Init (bool ResetControls)
{
myBusy = false;
myMeshNameEdit->setText( SMESH::UniqueMeshName("Mesh"));
if ( ResetControls )
{
myLineEditElements->clear();
//myElementsId = "";
myNbOkElements = 0;
buttonOk->setEnabled(false);
buttonApply->setEnabled(false);
myActor = 0;
myMesh = SMESH::SMESH_Mesh::_nil();
myIdSourceCheck->setChecked(true);
myCopyGroupsCheck->setChecked(false);
myKeepIdsCheck->setChecked(false);
onSelectIdSource( myIdSourceCheck->isChecked() );
}
}
//=================================================================================
// function : ClickOnApply()
// purpose :
//=================================================================================
bool SMESHGUI_CopyMeshDlg::ClickOnApply()
{
if (mySMESHGUI->isActiveStudyLocked())
return false;
if( !isValid() )
return false;
try
{
SUIT_OverrideCursor aWaitCursor;
SMESH::SMESH_IDSource_var aPartToCopy;
if ( myIdSourceCheck->isChecked())
{
aPartToCopy = mySelectedObject;
}
else
{
QStringList aListElementsId = myLineEditElements->text().split(" ", QString::SkipEmptyParts);
SMESH::long_array_var anElementsId = new SMESH::long_array;
anElementsId->length(aListElementsId.count());
for (int i = 0; i < aListElementsId.count(); i++)
anElementsId[i] = aListElementsId[i].toInt();
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
aPartToCopy = aMeshEditor->MakeIDSource( anElementsId, SMESH::ALL );
}
QByteArray meshName = myMeshNameEdit->text().toLatin1();
bool toCopyGroups = ( myCopyGroupsCheck->isChecked() );
bool toKeepIDs = ( myKeepIdsCheck->isChecked() );
SMESH::SMESH_Gen_var gen = SMESHGUI::GetSMESHGen();
SMESH::SMESH_Mesh_var newMesh =
gen->CopyMesh(aPartToCopy, meshName.constData(), toCopyGroups, toKeepIDs);
#ifdef WITHGENERICOBJ
// obj has been published in study. Its refcount has been incremented.
// It is safe to decrement its refcount
// so that it will be destroyed when the entry in study will be removed
newMesh->Destroy();
#endif
} catch (...) {
}
mySMESHGUI->updateObjBrowser(true);
SMESHGUI::Modified();
Init(false);
mySelectedObject = SMESH::SMESH_IDSource::_nil();
SelectionIntoArgument();
return true;
}
//=================================================================================
// function : ClickOnOk()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::ClickOnOk()
{
if( ClickOnApply() )
ClickOnCancel();
}
//=================================================================================
// function : ClickOnCancel()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::ClickOnCancel()
{
disconnect(mySelectionMgr, 0, this, 0);
if ( mySelectionMgr )
mySelectionMgr->removeFilter( myIdSourceFilter );
if ( SVTK_ViewWindow* aViewWindow = SMESH::GetViewWindow( mySMESHGUI ))
aViewWindow->SetSelectionMode( ActorSelection );
mySMESHGUI->ResetState();
reject();
}
//=================================================================================
// function : ClickOnHelp()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::ClickOnHelp()
{
LightApp_Application* app = (LightApp_Application*)(SUIT_Session::session()->activeApplication());
if (app)
app->onHelpContextModule(mySMESHGUI ? app->moduleName(mySMESHGUI->moduleName()) : QString(""), myHelpFileName);
else {
QString platform;
#ifdef WIN32
platform = "winapplication";
#else
platform = "application";
#endif
SUIT_MessageBox::warning(this, tr("WRN_WARNING"),
tr("EXTERNAL_BROWSER_CANNOT_SHOW_PAGE").
arg(app->resourceMgr()->stringValue("ExternalBrowser",
platform)).
arg(myHelpFileName));
}
}
//=======================================================================
// function : onTextChange()
// purpose :
//=======================================================================
void SMESHGUI_CopyMeshDlg::onTextChange (const QString& theNewText)
{
QLineEdit* send = (QLineEdit*)sender();
if (myBusy) return;
BusyLocker lock( myBusy );
//if (send == myLineEditElements)
myNbOkElements = 0;
buttonOk->setEnabled(false);
buttonApply->setEnabled(false);
// hilight entered elements
SMDS_Mesh* aMesh = 0;
if (myActor)
aMesh = myActor->GetObject()->GetMesh();
QStringList aListId = theNewText.split(" ", QString::SkipEmptyParts);
if (myActor && aMesh)
{
TColStd_MapOfInteger newIndices;
if (send == myLineEditElements) {
for (int i = 0; i < aListId.count(); i++)
if ( const SMDS_MeshElement * e = aMesh->FindElement(aListId[ i ].toInt()))
{
newIndices.Add(e->GetID());
}
}
myNbOkElements = newIndices.Extent();
Handle(SALOME_InteractiveObject) anIO = myActor->getIO();
mySelector->AddOrRemoveIndex( anIO, newIndices, false );
if ( SVTK_ViewWindow* aViewWindow = SMESH::GetViewWindow( mySMESHGUI ))
aViewWindow->highlight( anIO, true, true );
}
else
{
myNbOkElements = aListId.count();
}
if (myNbOkElements) {
buttonOk->setEnabled(true);
buttonApply->setEnabled(true);
}
}
//=================================================================================
// function : SelectionIntoArgument()
// purpose : Called when selection as changed or other case
//=================================================================================
void SMESHGUI_CopyMeshDlg::SelectionIntoArgument()
{
if (myBusy) return;
BusyLocker lock( myBusy );
// clear
myActor = 0;
QString aString = "";
myLineEditElements->setText(aString);
myNbOkElements = 0;
buttonOk->setEnabled(false);
buttonApply->setEnabled(false);
myFilterBtn->setEnabled(false);
// get selected mesh
SALOME_ListIO aList;
mySelectionMgr->selectedObjects(aList,SVTK_Viewer::Type());
int nbSel = aList.Extent();
if (nbSel != 1)
return;
Handle(SALOME_InteractiveObject) IO = aList.First();
mySelectedObject = SMESH::IObjectToInterface<SMESH::SMESH_IDSource>( IO );
if ( mySelectedObject->_is_nil() )
return;
myMesh = SMESH::GetMeshByIO(IO);
if (myMesh->_is_nil())
return;
myActor = SMESH::FindActorByEntry(IO->getEntry());
if (!myActor)
myActor = SMESH::FindActorByObject(myMesh);
if (myIdSourceCheck->isChecked())
{
SMESH::GetNameOfSelectedIObjects( mySelectionMgr, aString );
if ( aString.isEmpty() ) aString = " ";
}
else
{
SMESH::GetNameOfSelectedElements( mySelector, IO, aString );
myNbOkElements = aString.size();
myFilterBtn->setEnabled(true);
}
myLineEditElements->setText( aString );
bool ok = !aString.isEmpty();
buttonOk->setEnabled(ok);
buttonApply->setEnabled(ok);
}
//=======================================================================
//function : onSelectIdSource
//purpose :
//=======================================================================
void SMESHGUI_CopyMeshDlg::onSelectIdSource (bool toSelectMesh)
{
if (toSelectMesh)
myTextLabelElements->setText(tr("OBJECT_NAME"));
else
myTextLabelElements->setText(tr("ELEM_IDS"));
if (toSelectMesh) {
myLineEditElements->clear();
}
mySelectionMgr->clearFilters();
mySelectionMgr->installFilter(myIdSourceFilter);
SMESH::SetPointRepresentation(false);
if (toSelectMesh) {
if ( SVTK_ViewWindow* aViewWindow = SMESH::GetViewWindow( mySMESHGUI ))
aViewWindow->SetSelectionMode( ActorSelection );
myLineEditElements->setReadOnly(true);
myLineEditElements->setValidator(0);
}
else
{
if ( SVTK_ViewWindow* aViewWindow = SMESH::GetViewWindow( mySMESHGUI ))
aViewWindow->SetSelectionMode( CellSelection );
myLineEditElements->setReadOnly(false);
myLineEditElements->setValidator(myIdValidator);
onTextChange(myLineEditElements->text());
}
SelectionIntoArgument();
}
//=================================================================================
// function : isValid
// purpose :
//=================================================================================
bool SMESHGUI_CopyMeshDlg::isValid()
{
if ( myIdSourceCheck->isChecked() )
return !mySelectedObject->_is_nil();
return myNbOkElements > 0;
}
//=================================================================================
// function : DeactivateActiveDialog()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::DeactivateActiveDialog()
{
if (ConstructorsBox->isEnabled()) {
ConstructorsBox->setEnabled(false);
GroupArguments->setEnabled(false);
GroupButtons->setEnabled(false);
mySMESHGUI->ResetState();
mySMESHGUI->SetActiveDialogBox(0);
if ( mySelectionMgr )
mySelectionMgr->removeFilter( myIdSourceFilter );
}
}
//=================================================================================
// function : ActivateThisDialog()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::ActivateThisDialog()
{
/* Emit a signal to deactivate the active dialog */
mySMESHGUI->EmitSignalDeactivateDialog();
ConstructorsBox->setEnabled(true);
GroupArguments->setEnabled(true);
GroupButtons->setEnabled(true);
mySMESHGUI->SetActiveDialogBox((QDialog*)this);
onSelectIdSource( myIdSourceCheck->isChecked() );
SelectionIntoArgument();
}
//=================================================================================
// function : enterEvent()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::enterEvent (QEvent*)
{
if (!ConstructorsBox->isEnabled())
ActivateThisDialog();
}
//=================================================================================
// function : closeEvent()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::closeEvent (QCloseEvent*)
{
/* same than click on cancel button */
ClickOnCancel();
}
//=======================================================================
//function : hideEvent
//purpose : caused by ESC key
//=======================================================================
void SMESHGUI_CopyMeshDlg::hideEvent (QHideEvent*)
{
if (!isMinimized())
ClickOnCancel();
}
//=================================================================================
// function : keyPressEvent()
// purpose :
//=================================================================================
void SMESHGUI_CopyMeshDlg::keyPressEvent( QKeyEvent* e )
{
QDialog::keyPressEvent( e );
if ( e->isAccepted() )
return;
if ( e->key() == Qt::Key_F1 ) {
e->accept();
ClickOnHelp();
}
}
//=================================================================================
// function : setFilters()
// purpose : SLOT. Called when "Filter" button pressed.
//=================================================================================
void SMESHGUI_CopyMeshDlg::setFilters()
{
if(myMesh->_is_nil()) {
SUIT_MessageBox::critical(this,
tr("SMESH_ERROR"),
tr("NO_MESH_SELECTED"));
return;
}
if ( !myFilterDlg )
myFilterDlg = new SMESHGUI_FilterDlg( mySMESHGUI, SMESH::ALL );
myFilterDlg->SetSelection();
myFilterDlg->SetMesh( myMesh );
myFilterDlg->SetSourceWg( myLineEditElements );
myFilterDlg->show();
}

View File

@ -0,0 +1,125 @@
// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
//
// SMESH SMESHGUI : GUI for SMESH component
// File : SMESHGUI_CopyMeshDlg.h
//
#ifndef SMESHGUI_CopyMeshDLG_H
#define SMESHGUI_CopyMeshDLG_H
// SMESH includes
#include "SMESH_SMESHGUI.hxx"
// Qt includes
#include <QDialog>
// IDL includes
#include <SALOMEconfig.h>
#include CORBA_SERVER_HEADER(SMESH_Mesh)
class QCheckBox;
class QGroupBox;
class QLabel;
class QLineEdit;
class QPushButton;
class SMESHGUI;
class SMESHGUI_IdValidator;
class SMESHGUI_FilterDlg;
class SMESH_Actor;
class SVTK_Selector;
class LightApp_SelectionMgr;
class SUIT_SelectionFilter;
//=================================================================================
// class : SMESHGUI_CopyMeshDlg
// purpose : copy some elements or a mesh object into a new mesh
//=================================================================================
class SMESHGUI_EXPORT SMESHGUI_CopyMeshDlg : public QDialog
{
Q_OBJECT
public:
SMESHGUI_CopyMeshDlg( SMESHGUI* );
~SMESHGUI_CopyMeshDlg();
private:
void Init( bool = true );
void closeEvent( QCloseEvent* );
void enterEvent( QEvent* ); /* mouse enter the QWidget */
void hideEvent( QHideEvent* ); /* ESC key */
void keyPressEvent( QKeyEvent* );
int GetConstructorId();
void setNewMeshName();
bool isValid();
SMESHGUI* mySMESHGUI; /* Current SMESHGUI object */
SMESHGUI_IdValidator* myIdValidator;
LightApp_SelectionMgr* mySelectionMgr; /* User shape selection */
int myNbOkElements; /* to check when elements are defined */
SVTK_Selector* mySelector;
bool myBusy;
SMESH::SMESH_Mesh_var myMesh;
SMESH_Actor* myActor;
SUIT_SelectionFilter* myIdSourceFilter;
SMESH::SMESH_IDSource_var mySelectedObject;
QGroupBox* ConstructorsBox;
QGroupBox* GroupArguments;
QGroupBox* GroupButtons;
QPushButton* buttonOk;
QPushButton* buttonCancel;
QPushButton* buttonApply;
QPushButton* buttonHelp;
QLabel* myTextLabelElements;
QLineEdit* myLineEditElements;
QLineEdit* myMeshNameEdit;
QCheckBox* myIdSourceCheck;
QCheckBox* myCopyGroupsCheck;
QCheckBox* myKeepIdsCheck;
QPushButton* myFilterBtn;
SMESHGUI_FilterDlg* myFilterDlg;
QString myHelpFileName;
private slots:
void ClickOnOk();
void ClickOnCancel();
bool ClickOnApply();
void ClickOnHelp();
void SelectionIntoArgument();
void DeactivateActiveDialog();
void ActivateThisDialog();
void onTextChange( const QString& );
void onSelectIdSource( bool );
void setFilters();
};
#endif // SMESHGUI_CopyMeshDLG_H

View File

@ -1180,6 +1180,10 @@ void SMESHGUI_FilterTable::SetCriterion (const int theRow,
theCriterion.Type != SMESH::FT_FreeNodes && theCriterion.Type != SMESH::FT_FreeNodes &&
theCriterion.Type != SMESH::FT_FreeFaces && theCriterion.Type != SMESH::FT_FreeFaces &&
theCriterion.Type != SMESH::FT_BadOrientedVolume && theCriterion.Type != SMESH::FT_BadOrientedVolume &&
theCriterion.Type != SMESH::FT_BareBorderFace &&
theCriterion.Type != SMESH::FT_BareBorderVolume &&
theCriterion.Type != SMESH::FT_OverConstrainedFace &&
theCriterion.Type != SMESH::FT_OverConstrainedVolume &&
theCriterion.Type != SMESH::FT_LinearOrQuadratic) theCriterion.Type != SMESH::FT_LinearOrQuadratic)
{ {
aTable->item( theRow, 2 )->setText(QString("%1").arg(theCriterion.Threshold, 0, 'g', 15)); aTable->item( theRow, 2 )->setText(QString("%1").arg(theCriterion.Threshold, 0, 'g', 15));
@ -1341,7 +1345,11 @@ void SMESHGUI_FilterTable::updateAdditionalWidget()
aCriterion != SMESH::FT_RangeOfIds && aCriterion != SMESH::FT_RangeOfIds &&
aCriterion != SMESH::FT_FreeEdges && aCriterion != SMESH::FT_FreeEdges &&
aCriterion != SMESH::FT_FreeFaces && aCriterion != SMESH::FT_FreeFaces &&
aCriterion != SMESH::FT_BadOrientedVolume) aCriterion != SMESH::FT_BadOrientedVolume &&
aCriterion != SMESH::FT_BareBorderFace &&
aCriterion != SMESH::FT_BareBorderVolume &&
aCriterion != SMESH::FT_OverConstrainedFace &&
aCriterion != SMESH::FT_OverConstrainedVolume)
|| ||
aCriterion == SMESH::FT_CoplanarFaces); aCriterion == SMESH::FT_CoplanarFaces);
@ -1520,9 +1528,13 @@ void SMESHGUI_FilterTable::onCriterionChanged (const int row, const int col, con
if ((aType == SMESH::NODE && aCriterionType == SMESH::FT_FreeNodes ) || if ((aType == SMESH::NODE && aCriterionType == SMESH::FT_FreeNodes ) ||
(aType == SMESH::EDGE && aCriterionType == SMESH::FT_FreeBorders ) || (aType == SMESH::EDGE && aCriterionType == SMESH::FT_FreeBorders ) ||
(aType == SMESH::FACE && (aCriterionType == SMESH::FT_FreeEdges || (aType == SMESH::FACE && (aCriterionType == SMESH::FT_BareBorderFace ||
aCriterionType == SMESH::FT_OverConstrainedFace ||
aCriterionType == SMESH::FT_FreeEdges ||
aCriterionType == SMESH::FT_FreeFaces)) || aCriterionType == SMESH::FT_FreeFaces)) ||
(aType == SMESH::VOLUME && aCriterionType == SMESH::FT_BadOrientedVolume) || (aType == SMESH::VOLUME && (aCriterionType == SMESH::FT_BadOrientedVolume ||
aCriterionType == SMESH::FT_OverConstrainedVolume ||
aCriterionType == SMESH::FT_BareBorderVolume)) ||
aCriterionType == SMESH::FT_LinearOrQuadratic || aCriterionType == SMESH::FT_LinearOrQuadratic ||
aCriterionType == SMESH::FT_GroupColor || aCriterionType == SMESH::FT_GroupColor ||
aCriterionType == SMESH::FT_ElemGeomType || aCriterionType == SMESH::FT_ElemGeomType ||
@ -1808,6 +1820,8 @@ const QMap<int, QString>& SMESHGUI_FilterTable::getCriteria (const int theType)
aCriteria[ SMESH::FT_Length2D ] = tr("LENGTH2D"); aCriteria[ SMESH::FT_Length2D ] = tr("LENGTH2D");
aCriteria[ SMESH::FT_MultiConnection2D ] = tr("MULTI2D_BORDERS"); aCriteria[ SMESH::FT_MultiConnection2D ] = tr("MULTI2D_BORDERS");
aCriteria[ SMESH::FT_FreeFaces ] = tr("FREE_FACES"); aCriteria[ SMESH::FT_FreeFaces ] = tr("FREE_FACES");
aCriteria[ SMESH::FT_BareBorderFace ] = tr("BARE_BORDER_FACE");
aCriteria[ SMESH::FT_OverConstrainedFace] = tr("OVER_CONSTRAINED_FACE");
aCriteria[ SMESH::FT_LinearOrQuadratic ] = tr("LINEAR"); aCriteria[ SMESH::FT_LinearOrQuadratic ] = tr("LINEAR");
aCriteria[ SMESH::FT_GroupColor ] = tr("GROUP_COLOR"); aCriteria[ SMESH::FT_GroupColor ] = tr("GROUP_COLOR");
aCriteria[ SMESH::FT_ElemGeomType ] = tr("GEOM_TYPE"); aCriteria[ SMESH::FT_ElemGeomType ] = tr("GEOM_TYPE");
@ -1825,6 +1839,8 @@ const QMap<int, QString>& SMESHGUI_FilterTable::getCriteria (const int theType)
aCriteria[ SMESH::FT_BelongToGeom ] = tr("BELONG_TO_GEOM"); aCriteria[ SMESH::FT_BelongToGeom ] = tr("BELONG_TO_GEOM");
aCriteria[ SMESH::FT_LyingOnGeom ] = tr("LYING_ON_GEOM"); aCriteria[ SMESH::FT_LyingOnGeom ] = tr("LYING_ON_GEOM");
aCriteria[ SMESH::FT_BadOrientedVolume ] = tr("BAD_ORIENTED_VOLUME"); aCriteria[ SMESH::FT_BadOrientedVolume ] = tr("BAD_ORIENTED_VOLUME");
aCriteria[ SMESH::FT_BareBorderVolume ] = tr("BARE_BORDER_VOLUME");
aCriteria[ SMESH::FT_OverConstrainedVolume] = tr("OVER_CONSTRAINED_VOLUME");
aCriteria[ SMESH::FT_Volume3D ] = tr("VOLUME_3D"); aCriteria[ SMESH::FT_Volume3D ] = tr("VOLUME_3D");
aCriteria[ SMESH::FT_MaxElementLength3D ] = tr("MAX_ELEMENT_LENGTH_3D"); aCriteria[ SMESH::FT_MaxElementLength3D ] = tr("MAX_ELEMENT_LENGTH_3D");
aCriteria[ SMESH::FT_LinearOrQuadratic ] = tr("LINEAR"); aCriteria[ SMESH::FT_LinearOrQuadratic ] = tr("LINEAR");

View File

@ -309,7 +309,7 @@ void SMESHGUI_GenericHypothesisCreator::onDialogFinished( int result )
disconnect( myDlg, SIGNAL( finished( int ) ), this, SLOT( onDialogFinished( int ) ) ); disconnect( myDlg, SIGNAL( finished( int ) ), this, SLOT( onDialogFinished( int ) ) );
myDlg->close(); myDlg->close();
//delete myDlg; //delete myDlg; since WA_DeleteOnClose==true
myDlg = 0; myDlg = 0;
emit finished( result ); emit finished( result );
} }
@ -557,6 +557,8 @@ QString SMESHGUI_GenericHypothesisCreator::helpPage() const
aHelpFileName = "segments_around_vertex_algo_page.html"; aHelpFileName = "segments_around_vertex_algo_page.html";
else if ( aHypType == "QuadrangleParams") else if ( aHypType == "QuadrangleParams")
aHelpFileName = "a2d_meshing_hypo_page.html#hypo_quad_params_anchor"; aHelpFileName = "a2d_meshing_hypo_page.html#hypo_quad_params_anchor";
else if ( aHypType == "ImportSource1D" || aHypType == "ImportSource2D")
aHelpFileName = "import_algos_page.html";
return aHelpFileName; return aHelpFileName;
} }

View File

@ -62,6 +62,7 @@
const int SPACING = 6; const int SPACING = 6;
const int MARGIN = 9; const int MARGIN = 9;
const int MAXITEMS = 10;
/*! /*!
\class SMESHGUI_MeshInfo \class SMESHGUI_MeshInfo
@ -465,8 +466,29 @@ void SMESHGUI_MeshInfo::setFieldsVisible( int start, int end, bool on )
\param parent parent widget \param parent parent widget
*/ */
SMESHGUI_ElemInfo::SMESHGUI_ElemInfo( QWidget* parent ) SMESHGUI_ElemInfo::SMESHGUI_ElemInfo( QWidget* parent )
: QWidget( parent ), myActor( 0 ), myID( 0 ), myIsElement( -1 ) : QWidget( parent ), myActor( 0 ), myIsElement( -1 )
{ {
myFrame = new QWidget( this );
myExtra = new QWidget( this );
myCurrent = new QLabel( "10/43 items shown", myExtra );
myCurrent->setAlignment( Qt::AlignRight | Qt::AlignVCenter );
myPrev = new QPushButton( tr( "<<" ), myExtra );
myNext = new QPushButton( tr( ">>" ), myExtra );
QHBoxLayout* hbl = new QHBoxLayout( myExtra );
hbl->setContentsMargins( 0, SPACING, 0, 0 );
hbl->setSpacing( SPACING );
hbl->addStretch();
hbl->addWidget( myCurrent );
hbl->addWidget( myPrev );
hbl->addWidget( myNext );
QVBoxLayout* vbl = new QVBoxLayout( this );
vbl->setMargin( 0 );
vbl->setSpacing( 0 );
vbl->addWidget( myFrame );
vbl->addWidget( myExtra );
connect( myPrev, SIGNAL( clicked() ), this, SLOT( showPrevious() ) );
connect( myNext, SIGNAL( clicked() ), this, SLOT( showNext() ) );
clear();
} }
/*! /*!
@ -484,7 +506,6 @@ void SMESHGUI_ElemInfo::setSource( SMESH_Actor* actor )
{ {
if ( myActor != actor ) { if ( myActor != actor ) {
myActor = actor; myActor = actor;
myID = 0;
myIsElement = -1; myIsElement = -1;
clear(); clear();
} }
@ -492,19 +513,87 @@ void SMESHGUI_ElemInfo::setSource( SMESH_Actor* actor )
/*! /*!
\brief Show mesh element information \brief Show mesh element information
\param long id mesh node / element ID \param id mesh node / element ID
\param isElem show mesh element information if \c true or mesh node information if \c false \param isElem show mesh element information if \c true or mesh node information if \c false
*/ */
void SMESHGUI_ElemInfo::showInfo( long id, bool isElem ) void SMESHGUI_ElemInfo::showInfo( long id, bool isElem )
{ {
myID = id; QSet<long> ids;
myIsElement = isElem; ids << id;
showInfo( ids, isElem );
}
/*!
\brief Show mesh element information
\param ids mesh nodes / elements identifiers
\param isElem show mesh element information if \c true or mesh node information if \c false
*/
void SMESHGUI_ElemInfo::showInfo( QSet<long> ids, bool isElem )
{
QList<long> newIds = ids.toList();
qSort( newIds );
if ( myIDs == newIds && myIsElement == isElem ) return;
myIDs = newIds;
myIsElement = isElem;
myIndex = 0;
updateControls();
information( myIDs.mid( myIndex*MAXITEMS, MAXITEMS ) );
} }
/*! /*!
\fn void SMESHGUI_ElemInfo::clear()
\brief Clear mesh element information widget \brief Clear mesh element information widget
*/ */
void SMESHGUI_ElemInfo::clear()
{
myIDs.clear();
myIndex = 0;
clearInternal();
updateControls();
}
/*!
\brief Get central area widget
\return central widget
*/
QWidget* SMESHGUI_ElemInfo::frame() const
{
return myFrame;
}
/*!
\brief Get actor
\return actor being used
*/
SMESH_Actor* SMESHGUI_ElemInfo::actor() const
{
return myActor;
}
/*!
\brief Get current info mode.
\return \c true if mesh element information is shown or \c false if node information is shown
*/
bool SMESHGUI_ElemInfo::isElements() const
{
return myIsElement;
}
/*!
\fn void SMESHGUI_ElemInfo::information( const QList<long>& ids )
\brief Show information on the specified nodes / elements
This function is to be redefined in sub-classes.
\param ids nodes / elements identifiers information is to be shown on
*/
/*!
\brief Internal clean-up (reset widget)
*/
void SMESHGUI_ElemInfo::clearInternal()
{
}
/*! /*!
\brief Get node connectivity \brief Get node connectivity
@ -560,6 +649,39 @@ SMESHGUI_ElemInfo::XYZ SMESHGUI_ElemInfo::gravityCenter( const SMDS_MeshElement*
return xyz; return xyz;
} }
/*!
\brief This slot is called from "Show Previous" button click.
Shows information on the previous group of the items.
*/
void SMESHGUI_ElemInfo::showPrevious()
{
myIndex = qMax( 0, myIndex-1 );
updateControls();
information( myIDs.mid( myIndex*MAXITEMS, MAXITEMS ) );
}
/*!
\brief This slot is called from "Show Next" button click.
Shows information on the next group of the items.
*/
void SMESHGUI_ElemInfo::showNext()
{
myIndex = qMin( myIndex+1, myIDs.count() / MAXITEMS );
updateControls();
information( myIDs.mid( myIndex*MAXITEMS, MAXITEMS ) );
}
/*!
\brief Update widgets state
*/
void SMESHGUI_ElemInfo::updateControls()
{
myExtra->setVisible( myIDs.count() > MAXITEMS );
myCurrent->setText( tr( "X_FROM_Y_ITEMS_SHOWN" ).arg( myIndex*MAXITEMS+1 ).arg(qMin(myIndex*MAXITEMS+MAXITEMS, myIDs.count())).arg( myIDs.count() ) );
myPrev->setEnabled( myIndex > 0 );
myNext->setEnabled( (myIndex+1)*MAXITEMS < myIDs.count() );
}
/*! /*!
\class SMESHGUI_SimpleElemInfo \class SMESHGUI_SimpleElemInfo
\brief Represents mesh element information in the simple text area. \brief Represents mesh element information in the simple text area.
@ -572,32 +694,28 @@ SMESHGUI_ElemInfo::XYZ SMESHGUI_ElemInfo::gravityCenter( const SMDS_MeshElement*
SMESHGUI_SimpleElemInfo::SMESHGUI_SimpleElemInfo( QWidget* parent ) SMESHGUI_SimpleElemInfo::SMESHGUI_SimpleElemInfo( QWidget* parent )
: SMESHGUI_ElemInfo( parent ) : SMESHGUI_ElemInfo( parent )
{ {
myInfo = new QTextBrowser( this ); myInfo = new QTextBrowser( frame() );
QVBoxLayout* l = new QVBoxLayout( this ); QVBoxLayout* l = new QVBoxLayout( frame() );
l->setMargin( 0 ); l->setMargin( 0 );
l->addWidget( myInfo ); l->addWidget( myInfo );
} }
/*! /*!
\brief Show mesh element information \brief Show mesh element information
\param long id mesh node / element ID \param ids mesh nodes / elements identifiers
\param isElem show mesh element information if \c true or mesh node information if \c false
*/ */
void SMESHGUI_SimpleElemInfo::showInfo( long id, bool isElem ) void SMESHGUI_SimpleElemInfo::information( const QList<long>& ids )
{ {
if ( myID == id && myIsElement == isElem ) return; clearInternal();
SMESHGUI_ElemInfo::showInfo( id, isElem ); if ( actor() ) {
clear();
if ( myActor ) {
int precision = SMESHGUI::resourceMgr()->integerValue( "SMESH", "length_precision", 6 ); int precision = SMESHGUI::resourceMgr()->integerValue( "SMESH", "length_precision", 6 );
if ( !isElem ) { foreach ( long id, ids ) {
if ( !isElements() ) {
// //
// show node info // show node info
// //
const SMDS_MeshElement* e = myActor->GetObject()->GetMesh()->FindNode( id ); const SMDS_MeshElement* e = actor()->GetObject()->GetMesh()->FindNode( id );
if ( !e ) return; if ( !e ) return;
const SMDS_MeshNode* node = static_cast<const SMDS_MeshNode*>( e ); const SMDS_MeshNode* node = static_cast<const SMDS_MeshNode*>( e );
@ -637,7 +755,7 @@ void SMESHGUI_SimpleElemInfo::showInfo( long id, bool isElem )
// //
// show element info // show element info
// //
const SMDS_MeshElement* e = myActor->GetObject()->GetMesh()->FindElement( id ); const SMDS_MeshElement* e = actor()->GetObject()->GetMesh()->FindElement( id );
if ( !e ) return; if ( !e ) return;
// element ID && type // element ID && type
@ -733,7 +851,12 @@ void SMESHGUI_SimpleElemInfo::showInfo( long id, bool isElem )
else { else {
myInfo->append( QString( "<b>%1</b>" ).arg( tr( "FREE_NODE" ) ).arg( id ) ); myInfo->append( QString( "<b>%1</b>" ).arg( tr( "FREE_NODE" ) ).arg( id ) );
} }
}
}
// separator // separator
if ( ids.count() > 1 ) {
myInfo->append( "" );
myInfo->append( "------" );
myInfo->append( "" ); myInfo->append( "" );
} }
} }
@ -741,9 +864,9 @@ void SMESHGUI_SimpleElemInfo::showInfo( long id, bool isElem )
} }
/*! /*!
\brief Clear mesh element information widget \brief Internal clean-up (reset widget)
*/ */
void SMESHGUI_SimpleElemInfo::clear() void SMESHGUI_SimpleElemInfo::clearInternal()
{ {
myInfo->clear(); myInfo->clear();
} }
@ -791,37 +914,33 @@ QWidget* SMESHGUI_TreeElemInfo::ItemDelegate::createEditor( QWidget* parent, con
SMESHGUI_TreeElemInfo::SMESHGUI_TreeElemInfo( QWidget* parent ) SMESHGUI_TreeElemInfo::SMESHGUI_TreeElemInfo( QWidget* parent )
: SMESHGUI_ElemInfo( parent ) : SMESHGUI_ElemInfo( parent )
{ {
myInfo = new QTreeWidget( this ); myInfo = new QTreeWidget( frame() );
myInfo->setColumnCount( 2 ); myInfo->setColumnCount( 2 );
myInfo->setHeaderLabels( QStringList() << tr( "PROPERTY" ) << tr( "VALUE" ) ); myInfo->setHeaderLabels( QStringList() << tr( "PROPERTY" ) << tr( "VALUE" ) );
myInfo->header()->setStretchLastSection( true ); myInfo->header()->setStretchLastSection( true );
myInfo->header()->setResizeMode( 0, QHeaderView::ResizeToContents ); myInfo->header()->setResizeMode( 0, QHeaderView::ResizeToContents );
myInfo->setItemDelegate( new ItemDelegate( myInfo ) ); myInfo->setItemDelegate( new ItemDelegate( myInfo ) );
QVBoxLayout* l = new QVBoxLayout( this ); QVBoxLayout* l = new QVBoxLayout( frame() );
l->setMargin( 0 ); l->setMargin( 0 );
l->addWidget( myInfo ); l->addWidget( myInfo );
} }
/*! /*!
\brief Show mesh element information \brief Show mesh element information
\param long id mesh node / element ID \param ids mesh nodes / elements identifiers
\param isElem show mesh element information if \c true or mesh node information if \c false
*/ */
void SMESHGUI_TreeElemInfo::showInfo( long id, bool isElem ) void SMESHGUI_TreeElemInfo::information( const QList<long>& ids )
{ {
if ( myID == id && myIsElement == isElem ) return; clearInternal();
SMESHGUI_ElemInfo::showInfo( id, isElem ); if ( actor() ) {
clear();
if ( myActor ) {
int precision = SMESHGUI::resourceMgr()->integerValue( "SMESH", "length_precision", 6 ); int precision = SMESHGUI::resourceMgr()->integerValue( "SMESH", "length_precision", 6 );
if ( !isElem ) { foreach ( long id, ids ) {
if ( !isElements() ) {
// //
// show node info // show node info
// //
const SMDS_MeshElement* e = myActor->GetObject()->GetMesh()->FindNode( id ); const SMDS_MeshElement* e = actor()->GetObject()->GetMesh()->FindNode( id );
if ( !e ) return; if ( !e ) return;
const SMDS_MeshNode* node = static_cast<const SMDS_MeshNode*>( e ); const SMDS_MeshNode* node = static_cast<const SMDS_MeshNode*>( e );
@ -882,7 +1001,7 @@ void SMESHGUI_TreeElemInfo::showInfo( long id, bool isElem )
// //
// show element info // show element info
// //
const SMDS_MeshElement* e = myActor->GetObject()->GetMesh()->FindElement( id ); const SMDS_MeshElement* e = actor()->GetObject()->GetMesh()->FindElement( id );
if ( !e ) return; if ( !e ) return;
// element ID && type // element ID && type
@ -1019,12 +1138,13 @@ void SMESHGUI_TreeElemInfo::showInfo( long id, bool isElem )
} }
} }
} }
}
} }
/*! /*!
\brief Clear mesh element information widget \brief Internal clean-up (reset widget)
*/ */
void SMESHGUI_TreeElemInfo::clear() void SMESHGUI_TreeElemInfo::clearInternal()
{ {
myInfo->clear(); myInfo->clear();
myInfo->repaint(); myInfo->repaint();
@ -1092,7 +1212,7 @@ SMESHGUI_MeshInfoDlg::SMESHGUI_MeshInfoDlg( QWidget* parent, int page )
myMode->addButton( new QRadioButton( tr( "ELEM_MODE" ), w ), ElemMode ); myMode->addButton( new QRadioButton( tr( "ELEM_MODE" ), w ), ElemMode );
myMode->button( NodeMode )->setChecked( true ); myMode->button( NodeMode )->setChecked( true );
myID = new QLineEdit( w ); myID = new QLineEdit( w );
myID->setValidator( new SMESHGUI_IdValidator( this, 1 ) ); myID->setValidator( new SMESHGUI_IdValidator( this ) );
int mode = SMESHGUI::resourceMgr()->integerValue( "SMESH", "mesh_elem_info", 1 ); int mode = SMESHGUI::resourceMgr()->integerValue( "SMESH", "mesh_elem_info", 1 );
mode = qMin( 1, qMax( 0, mode ) ); mode = qMin( 1, qMax( 0, mode ) );
@ -1173,10 +1293,14 @@ void SMESHGUI_MeshInfoDlg::showInfo( const Handle(SALOME_InteractiveObject)& IO
SMESH::GetNameOfSelectedElements( selector, IO, ID ) : SMESH::GetNameOfSelectedElements( selector, IO, ID ) :
SMESH::GetNameOfSelectedNodes( selector, IO, ID ); SMESH::GetNameOfSelectedNodes( selector, IO, ID );
} }
if ( nb == 1 ) {
myID->setText( ID.trimmed() );
myElemInfo->setSource( myActor ) ; myElemInfo->setSource( myActor ) ;
myElemInfo->showInfo( ID.toLong(), myMode->checkedId() == ElemMode ); if ( nb > 0 ) {
myID->setText( ID.trimmed() );
QSet<long> ids;
QStringList idTxt = ID.split( " ", QString::SkipEmptyParts );
foreach ( ID, idTxt )
ids << ID.trimmed().toLong();
myElemInfo->showInfo( ids, myMode->checkedId() == ElemMode );
} }
else { else {
myID->clear(); myID->clear();
@ -1247,15 +1371,15 @@ void SMESHGUI_MeshInfoDlg::updateSelection()
} }
} }
int oldID = myID->text().toLong(); QString oldID = myID->text().trimmed();
SMESH_Actor* oldActor = myActor; SMESH_Actor* oldActor = myActor;
myID->clear(); myID->clear();
connect( selMgr, SIGNAL( currentSelectionChanged() ), this, SLOT( updateInfo() ) ); connect( selMgr, SIGNAL( currentSelectionChanged() ), this, SLOT( updateInfo() ) );
updateInfo(); updateInfo();
if ( oldActor == myActor && myActor && oldID ) { if ( oldActor == myActor && myActor && !oldID.isEmpty() ) {
myID->setText( QString::number( oldID ) ); myID->setText( oldID );
idChanged(); idChanged();
} }
} }
@ -1328,10 +1452,21 @@ void SMESHGUI_MeshInfoDlg::idChanged()
if ( myActor && selector ) { if ( myActor && selector ) {
Handle(SALOME_InteractiveObject) IO = myActor->getIO(); Handle(SALOME_InteractiveObject) IO = myActor->getIO();
TColStd_MapOfInteger ID; TColStd_MapOfInteger ID;
ID.Add( myID->text().toLong() ); QSet<long> ids;
QStringList idTxt = myID->text().split( " ", QString::SkipEmptyParts );
foreach ( QString tid, idTxt ) {
long id = tid.trimmed().toLong();
const SMDS_MeshElement* e = myMode->checkedId() == ElemMode ?
myActor->GetObject()->GetMesh()->FindElement( id ) :
myActor->GetObject()->GetMesh()->FindNode( id );
if ( e ) {
ID.Add( id );
ids << id;
}
}
selector->AddOrRemoveIndex( IO, ID, false ); selector->AddOrRemoveIndex( IO, ID, false );
if ( SVTK_ViewWindow* aViewWindow = SMESH::GetViewWindow() ) if ( SVTK_ViewWindow* aViewWindow = SMESH::GetViewWindow() )
aViewWindow->highlight( IO, true, true ); aViewWindow->highlight( IO, true, true );
myElemInfo->showInfo( myID->text().toLong(), myMode->checkedId() == ElemMode ); myElemInfo->showInfo( ids, myMode->checkedId() == ElemMode );
} }
} }

View File

@ -32,6 +32,7 @@
#include <QDialog> #include <QDialog>
#include <QList> #include <QList>
#include <QMap> #include <QMap>
#include <QSet>
#include <QVector> #include <QVector>
#include <SALOMEconfig.h> #include <SALOMEconfig.h>
@ -40,6 +41,7 @@
class QButtonGroup; class QButtonGroup;
class QLabel; class QLabel;
class QLineEdit; class QLineEdit;
class QPushButton;
class QTabWidget; class QTabWidget;
class QTextBrowser; class QTextBrowser;
class QTreeWidget; class QTreeWidget;
@ -121,8 +123,9 @@ public:
~SMESHGUI_ElemInfo(); ~SMESHGUI_ElemInfo();
void setSource( SMESH_Actor* ); void setSource( SMESH_Actor* );
virtual void showInfo( long, bool ); void showInfo( long, bool );
virtual void clear() = 0; void showInfo( QSet<long>, bool );
void clear();
protected: protected:
struct XYZ struct XYZ
@ -137,14 +140,32 @@ protected:
}; };
typedef QMap< int, QList<int> > Connectivity; typedef QMap< int, QList<int> > Connectivity;
QWidget* frame() const;
SMESH_Actor* actor() const;
bool isElements() const;
virtual void information( const QList<long>& ) = 0;
virtual void clearInternal();
Connectivity nodeConnectivity( const SMDS_MeshNode* ); Connectivity nodeConnectivity( const SMDS_MeshNode* );
QString formatConnectivity( Connectivity, int ); QString formatConnectivity( Connectivity, int );
XYZ gravityCenter( const SMDS_MeshElement* ); XYZ gravityCenter( const SMDS_MeshElement* );
protected: private slots:
void showPrevious();
void showNext();
void updateControls();
private:
SMESH_Actor* myActor; SMESH_Actor* myActor;
long myID; QList<long> myIDs;
int myIsElement; int myIsElement;
QWidget* myFrame;
QWidget* myExtra;
QLabel* myCurrent;
QPushButton* myPrev;
QPushButton* myNext;
int myIndex;
}; };
class SMESHGUI_EXPORT SMESHGUI_SimpleElemInfo : public SMESHGUI_ElemInfo class SMESHGUI_EXPORT SMESHGUI_SimpleElemInfo : public SMESHGUI_ElemInfo
@ -152,8 +173,9 @@ class SMESHGUI_EXPORT SMESHGUI_SimpleElemInfo : public SMESHGUI_ElemInfo
public: public:
SMESHGUI_SimpleElemInfo( QWidget* = 0 ); SMESHGUI_SimpleElemInfo( QWidget* = 0 );
void showInfo( long, bool ); protected:
void clear(); void information( const QList<long>& );
void clearInternal();
private: private:
QTextBrowser* myInfo; QTextBrowser* myInfo;
@ -166,8 +188,9 @@ class SMESHGUI_EXPORT SMESHGUI_TreeElemInfo : public SMESHGUI_ElemInfo
public: public:
SMESHGUI_TreeElemInfo( QWidget* = 0 ); SMESHGUI_TreeElemInfo( QWidget* = 0 );
void showInfo( long, bool ); protected:
void clear(); void information( const QList<long>& );
void clearInternal();
private: private:
QTreeWidgetItem* createItem( QTreeWidgetItem* = 0, int = 100 ); QTreeWidgetItem* createItem( QTreeWidgetItem* = 0, int = 100 );

View File

@ -509,18 +509,6 @@ bool SMESHGUI_Preferences_ScalarBarDlg::onApply()
myScalarBarActor->SetLabelTextProperty( aLabelsTextPrp ); myScalarBarActor->SetLabelTextProperty( aLabelsTextPrp );
myScalarBarActor->SetNumberOfLabels( myLabelsSpin->value() ); myScalarBarActor->SetNumberOfLabels( myLabelsSpin->value() );
if( myColorsSpin->value() != myScalarBarActor->GetMaximumNumberOfColors() ) {
myScalarBarActor->SetMaximumNumberOfColors( myColorsSpin->value() );
SMESH::Controls::FunctorPtr fn = myActor->GetFunctor();
SMESH::Controls::NumericalFunctor* aNumericalFunctor = dynamic_cast<SMESH::Controls::NumericalFunctor*>(fn.get());
if( aNumericalFunctor ) {
int nbIntervals = myColorsSpin->value();
std::vector<int> nbEvents;
std::vector<double> funValues;
aNumericalFunctor->GetHistogram(nbIntervals, nbEvents, funValues);
myScalarBarActor->SetDistribution(nbEvents);
}
}
if ( myHorizRadioBtn->isChecked() ) if ( myHorizRadioBtn->isChecked() )
myScalarBarActor->SetOrientationToHorizontal(); myScalarBarActor->SetOrientationToHorizontal();
@ -550,9 +538,22 @@ bool SMESHGUI_Preferences_ScalarBarDlg::onApply()
double aMax = myMaxEdit->text().toDouble(); double aMax = myMaxEdit->text().toDouble();
vtkLookupTable* myLookupTable = vtkLookupTable* myLookupTable =
static_cast<vtkLookupTable*>(myScalarBarActor->GetLookupTable()); static_cast<vtkLookupTable*>(myScalarBarActor->GetLookupTable());
double oldMinMax[2] = { myLookupTable->GetRange()[0], myLookupTable->GetRange()[1] };
bool rangeChanges = ( fabs( oldMinMax[0] - aMin ) + fabs( oldMinMax[1] - aMax ) >
0.001 * ( aMax-aMin + oldMinMax[1]-oldMinMax[0] ));
bool nbColorsChanged = (myColorsSpin->value() != myScalarBarActor->GetMaximumNumberOfColors());
if(nbColorsChanged)
myScalarBarActor->SetMaximumNumberOfColors(myColorsSpin->value());
myLookupTable->SetRange( aMin, aMax ); myLookupTable->SetRange( aMin, aMax );
myLookupTable->SetNumberOfTableValues(myColorsSpin->value()); myLookupTable->SetNumberOfTableValues(myColorsSpin->value());
myLookupTable->Build(); myLookupTable->Build();
if( nbColorsChanged || rangeChanges)
myActor->UpdateDistribution();
SMESH::RepaintCurrentView(); SMESH::RepaintCurrentView();
return true; return true;
} }

View File

@ -53,6 +53,10 @@
<source>ICON_BUILD_COMPOUND</source> <source>ICON_BUILD_COMPOUND</source>
<translation>mesh_build_compound.png</translation> <translation>mesh_build_compound.png</translation>
</message> </message>
<message>
<source>ICON_COPY_MESH</source>
<translation>copy_mesh.png</translation>
</message>
<message> <message>
<source>ICON_COMPUTE</source> <source>ICON_COMPUTE</source>
<translation>mesh_compute.png</translation> <translation>mesh_compute.png</translation>
@ -109,6 +113,10 @@
<source>ICON_DLG_BUILD_COMPOUND_MESH</source> <source>ICON_DLG_BUILD_COMPOUND_MESH</source>
<translation>mesh_build_compound.png</translation> <translation>mesh_build_compound.png</translation>
</message> </message>
<message>
<source>ICON_DLG_COPY_MESH</source>
<translation>copy_mesh.png</translation>
</message>
<message> <message>
<source>ICON_DLG_ELEM0D</source> <source>ICON_DLG_ELEM0D</source>
<translation>mesh_vertex.png</translation> <translation>mesh_vertex.png</translation>
@ -457,6 +465,22 @@
<source>ICON_VOLUME_3D</source> <source>ICON_VOLUME_3D</source>
<translation>mesh_volume_3d.png</translation> <translation>mesh_volume_3d.png</translation>
</message> </message>
<message>
<source>ICON_BARE_BORDER_VOLUME</source>
<translation>bare_border_volume.png</translation>
</message>
<message>
<source>ICON_BARE_BORDER_FACE</source>
<translation>bare_border_face.png</translation>
</message>
<message>
<source>ICON_OVER_CONSTRAINED_VOLUME</source>
<translation>over_constrained_volume.png</translation>
</message>
<message>
<source>ICON_OVER_CONSTRAINED_FACE</source>
<translation>over_constrained_face.png</translation>
</message>
<message> <message>
<source>ICON_WARP</source> <source>ICON_WARP</source>
<translation>mesh_wrap.png</translation> <translation>mesh_wrap.png</translation>

View File

@ -187,6 +187,10 @@
<source>MEN_BUILD_COMPOUND</source> <source>MEN_BUILD_COMPOUND</source>
<translation>Build Compound</translation> <translation>Build Compound</translation>
</message> </message>
<message>
<source>MEN_COPY_MESH</source>
<translation>Copy Mesh</translation>
</message>
<message> <message>
<source>MEN_CLIP</source> <source>MEN_CLIP</source>
<translation>Clipping</translation> <translation>Clipping</translation>
@ -395,6 +399,22 @@
<source>STB_FIND_ELEM</source> <source>STB_FIND_ELEM</source>
<translation>Find Element by Point</translation> <translation>Find Element by Point</translation>
</message> </message>
<message>
<source>MEN_BARE_BORDER_VOLUME</source>
<translation>Volumes with bare border</translation>
</message>
<message>
<source>MEN_BARE_BORDER_FACE</source>
<translation>Faces with bare border</translation>
</message>
<message>
<source>MEN_OVER_CONSTRAINED_VOLUME</source>
<translation>Over-constrained volumes</translation>
</message>
<message>
<source>MEN_OVER_CONSTRAINED_FACE</source>
<translation>Over-constrained faces</translation>
</message>
<message> <message>
<source>MEN_FREE_BORDER</source> <source>MEN_FREE_BORDER</source>
<translation>Free Borders</translation> <translation>Free Borders</translation>
@ -1040,6 +1060,14 @@ Please enter correct values and try again</translation>
<source>SMESH_BUILD_COMPOUND_TITLE</source> <source>SMESH_BUILD_COMPOUND_TITLE</source>
<translation>Create a Compound</translation> <translation>Create a Compound</translation>
</message> </message>
<message>
<source>SMESH_COPY_MESH_TITLE</source>
<translation>Copy Mesh</translation>
</message>
<message>
<source>SMESH_KEEP_IDS</source>
<translation>Preserve IDs of elements</translation>
</message>
<message> <message>
<source>SMESH_BUT_ADD</source> <source>SMESH_BUT_ADD</source>
<translation>A&amp;dd</translation> <translation>A&amp;dd</translation>
@ -1451,7 +1479,8 @@ add the exported data to its contents?</translation>
</message> </message>
<message> <message>
<source>SMESH_HYP_12</source> <source>SMESH_HYP_12</source>
<translation>Geometry mismatches algorithm&apos;s expectation\nCheck algorithm documentation for supported geometry</translation> <translation>Geometry mismatches algorithm&apos;s expectation
Check algorithm documentation for supported geometry</translation>
</message> </message>
<message> <message>
<source>SMESH_HYP_13</source> <source>SMESH_HYP_13</source>
@ -2274,6 +2303,10 @@ Please check preferences of Mesh module.
<source>STB_BUILD_COMPOUND</source> <source>STB_BUILD_COMPOUND</source>
<translation>Build Compound Mesh</translation> <translation>Build Compound Mesh</translation>
</message> </message>
<message>
<source>STB_COPY_MESH</source>
<translation>Copy Mesh</translation>
</message>
<message> <message>
<source>STB_CLIP</source> <source>STB_CLIP</source>
<translation>Clipping</translation> <translation>Clipping</translation>
@ -2434,6 +2467,22 @@ Please check preferences of Mesh module.
<source>STB_FACES</source> <source>STB_FACES</source>
<translation>Faces</translation> <translation>Faces</translation>
</message> </message>
<message>
<source>STB_BARE_BORDER_VOLUME</source>
<translation>Volumes with bare border</translation>
</message>
<message>
<source>STB_BARE_BORDER_FACE</source>
<translation>Faces with bare border</translation>
</message>
<message>
<source>STB_OVER_CONSTRAINED_VOLUME</source>
<translation>Over-constrained volumes</translation>
</message>
<message>
<source>STB_OVER_CONSTRAINED_FACE</source>
<translation>Over-constrained faces</translation>
</message>
<message> <message>
<source>STB_FREE_BORDER</source> <source>STB_FREE_BORDER</source>
<translation>Free Borders</translation> <translation>Free Borders</translation>
@ -2810,6 +2859,10 @@ Please check preferences of Mesh module.
<source>TOP_BUILD_COMPOUND</source> <source>TOP_BUILD_COMPOUND</source>
<translation>Build Compound Mesh</translation> <translation>Build Compound Mesh</translation>
</message> </message>
<message>
<source>TOP_COPY_MESH</source>
<translation>Copy Mesh</translation>
</message>
<message> <message>
<source>TOP_CLIP</source> <source>TOP_CLIP</source>
<translation>Clipping</translation> <translation>Clipping</translation>
@ -2970,6 +3023,22 @@ Please check preferences of Mesh module.
<source>TOP_FACES</source> <source>TOP_FACES</source>
<translation>Faces</translation> <translation>Faces</translation>
</message> </message>
<message>
<source>TOP_BARE_BORDER_VOLUME</source>
<translation>Volumes with bare border</translation>
</message>
<message>
<source>TOP_BARE_BORDER_FACE</source>
<translation>Faces with bare border</translation>
</message>
<message>
<source>TOP_OVER_CONSTRAINED_VOLUME</source>
<translation>Over-constrained volumes</translation>
</message>
<message>
<source>TOP_OVER_CONSTRAINED_FACE</source>
<translation>Over-constrained faces</translation>
</message>
<message> <message>
<source>TOP_FREE_BORDER</source> <source>TOP_FREE_BORDER</source>
<translation>Free Borders</translation> <translation>Free Borders</translation>
@ -4320,6 +4389,22 @@ Please check input data and try again</translation>
<source>BAD_ORIENTED_VOLUME</source> <source>BAD_ORIENTED_VOLUME</source>
<translation>Bad oriented volume</translation> <translation>Bad oriented volume</translation>
</message> </message>
<message>
<source>BARE_BORDER_VOLUME</source>
<translation>Volumes with bare border</translation>
</message>
<message>
<source>BARE_BORDER_FACE</source>
<translation>Faces with bare border</translation>
</message>
<message>
<source>OVER_CONSTRAINED_VOLUME</source>
<translation>Over-constrained volumes</translation>
</message>
<message>
<source>OVER_CONSTRAINED_FACE</source>
<translation>Over-constrained faces</translation>
</message>
<message> <message>
<source>BELONG_TO_CYLINDER</source> <source>BELONG_TO_CYLINDER</source>
<translation>Belong to Cylinder</translation> <translation>Belong to Cylinder</translation>
@ -5607,7 +5692,7 @@ It is impossible to read point coordinates from file</translation>
</message> </message>
<message> <message>
<source>QUADRANGLES_LAB</source> <source>QUADRANGLES_LAB</source>
<translation>Quadrandgles:</translation> <translation>Quadrangles:</translation>
</message> </message>
<message> <message>
<source>POLYGONS_LAB</source> <source>POLYGONS_LAB</source>
@ -5795,10 +5880,6 @@ It is impossible to read point coordinates from file</translation>
<source>NO</source> <source>NO</source>
<translation>No</translation> <translation>No</translation>
</message> </message>
<message>
<source>GRAVITY_CENTER</source>
<translation>GRAVITY CENTER</translation>
</message>
<message> <message>
<source>PROPERTY</source> <source>PROPERTY</source>
<translation>Property</translation> <translation>Property</translation>
@ -5807,6 +5888,10 @@ It is impossible to read point coordinates from file</translation>
<source>VALUE</source> <source>VALUE</source>
<translation>Value</translation> <translation>Value</translation>
</message> </message>
<message>
<source>X_FROM_Y_ITEMS_SHOWN</source>
<translation>%1-%2 from %3 items shown</translation>
</message>
</context> </context>
<context> <context>
<name>SMESHGUI_MinDistance</name> <name>SMESHGUI_MinDistance</name>
@ -5847,6 +5932,21 @@ It is impossible to read point coordinates from file</translation>
<translation>Distance</translation> <translation>Distance</translation>
</message> </message>
</context> </context>
<context>
<name>SMESHGUI_CopyMeshDlg</name>
<message>
<source>OBJECT_NAME</source>
<translation>Source Object</translation>
</message>
<message>
<source>ELEM_IDS</source>
<translation>Source Element IDs</translation>
</message>
<message>
<source>NEW_NAME</source>
<translation>New Mesh Name</translation>
</message>
</context>
<context> <context>
<name>SMESHGUI_MeasureDlg</name> <name>SMESHGUI_MeasureDlg</name>
<message> <message>

View File

@ -3,6 +3,42 @@
<TS version="2.0" language="fr_FR"> <TS version="2.0" language="fr_FR">
<context> <context>
<name>@default</name> <name>@default</name>
<message>
<source>SMESH_EXPORT_MESH</source>
<translation>Exporter le maillage</translation>
</message>
<message>
<source>MED_FILES_FILTER</source>
<translation>Fichiers MED</translation>
</message>
<message>
<source>IDEAS_FILES_FILTER</source>
<translation>Fichiers IDEAS</translation>
</message>
<message>
<source>DAT_FILES_FILTER</source>
<translation>Fichiers DAT</translation>
</message>
<message>
<source>TEXT_FILES_FILTER</source>
<translation>Fichiers TXT</translation>
</message>
<message>
<source>MED_VX_FILES_FILTER</source>
<translation>Fichiers MED %1</translation>
</message>
<message>
<source>STL_ASCII_FILES_FILTER</source>
<translation>Fichiers STL ASCII</translation>
</message>
<message>
<source>STL_BIN_FILES_FILTER</source>
<translation>Fichiers STL binaires</translation>
</message>
<message>
<source>ALL_FILES_FILTER</source>
<translation>Tous les fichiers</translation>
</message>
<message> <message>
<source>AREA_ELEMENTS</source> <source>AREA_ELEMENTS</source>
<translation>Aire</translation> <translation>Aire</translation>
@ -107,6 +143,14 @@
<source>LOCAL_ALGO</source> <source>LOCAL_ALGO</source>
<translation>Local</translation> <translation>Local</translation>
</message> </message>
<message>
<source>MAX_ELEMENT_LENGTH_2D</source>
<translation>Diamètre d&apos;éléments 2D</translation>
</message>
<message>
<source>MAX_ELEMENT_LENGTH_3D</source>
<translation>Diamètre d&apos;éléments 3D</translation>
</message>
<message> <message>
<source>MEN_ADD</source> <source>MEN_ADD</source>
<translation>Ajouter</translation> <translation>Ajouter</translation>
@ -143,6 +187,10 @@
<source>MEN_BUILD_COMPOUND</source> <source>MEN_BUILD_COMPOUND</source>
<translation>Construire un assemblage</translation> <translation>Construire un assemblage</translation>
</message> </message>
<message>
<source>MEN_COPY_MESH</source>
<translation>Copier le maillage</translation>
</message>
<message> <message>
<source>MEN_CLIP</source> <source>MEN_CLIP</source>
<translation>Plan de coupe</translation> <translation>Plan de coupe</translation>
@ -207,6 +255,22 @@
<source>MEN_CTRL</source> <source>MEN_CTRL</source>
<translation>Contrôles</translation> <translation>Contrôles</translation>
</message> </message>
<message>
<source>MEN_NODE_CTRL</source>
<translation>Contrôles des nœuds</translation>
</message>
<message>
<source>MEN_EDGE_CTRL</source>
<translation>Contrôles des arêtes</translation>
</message>
<message>
<source>MEN_FACE_CTRL</source>
<translation>Contrôles des faces</translation>
</message>
<message>
<source>MEN_VOLUME_CTRL</source>
<translation>Contrôles des volumes</translation>
</message>
<message> <message>
<source>MEN_CUT</source> <source>MEN_CUT</source>
<translation>Découpe des quadrangles</translation> <translation>Découpe des quadrangles</translation>
@ -335,6 +399,22 @@
<source>STB_FIND_ELEM</source> <source>STB_FIND_ELEM</source>
<translation>Trouver un élément par un point</translation> <translation>Trouver un élément par un point</translation>
</message> </message>
<message>
<source>MEN_BARE_BORDER_VOLUME</source>
<translation>Volumes avec frontière libre</translation>
</message>
<message>
<source>MEN_BARE_BORDER_FACE</source>
<translation>Faces avec frontière libre</translation>
</message>
<message>
<source>MEN_OVER_CONSTRAINED_VOLUME</source>
<translation>Volumes sur-contraints</translation>
</message>
<message>
<source>MEN_OVER_CONSTRAINED_FACE</source>
<translation>Faces sur-contraintes</translation>
</message>
<message> <message>
<source>MEN_FREE_BORDER</source> <source>MEN_FREE_BORDER</source>
<translation>Frontières libres</translation> <translation>Frontières libres</translation>
@ -391,6 +471,14 @@
<source>MEN_MAP</source> <source>MEN_MAP</source>
<translation>Projection de motif</translation> <translation>Projection de motif</translation>
</message> </message>
<message>
<source>MEN_MAX_ELEMENT_LENGTH_2D</source>
<translation>Diamètre des éléments 2D</translation>
</message>
<message>
<source>MEN_MAX_ELEMENT_LENGTH_3D</source>
<translation>Diamètre des éléments 3D</translation>
</message>
<message> <message>
<source>MEN_MED</source> <source>MEN_MED</source>
<translation>Fichier MED</translation> <translation>Fichier MED</translation>
@ -423,6 +511,34 @@
<source>MEN_MODIFY</source> <source>MEN_MODIFY</source>
<translation>Modification</translation> <translation>Modification</translation>
</message> </message>
<message>
<source>MEN_MEASURE</source>
<translation>Outils de mesure</translation>
</message>
<message>
<source>MEN_MEASURE_MIN_DIST</source>
<translation>Distance minimale</translation>
</message>
<message>
<source>STB_MEASURE_MIN_DIST</source>
<translation>Calculate minimum distance between two objects</translation>
</message>
<message>
<source>TOP_MEASURE_MIN_DIST</source>
<translation>Minimum distance</translation>
</message>
<message>
<source>MEN_MEASURE_BND_BOX</source>
<translation>Boîte englobante</translation>
</message>
<message>
<source>STB_MEASURE_BND_BOX</source>
<translation>Calculate bounding box for the selected object(s)</translation>
</message>
<message>
<source>TOP_MEASURE_BND_BOX</source>
<translation>Bounding box</translation>
</message>
<message> <message>
<source>MEN_MOVE</source> <source>MEN_MOVE</source>
<translation>Déplacer un nœud</translation> <translation>Déplacer un nœud</translation>
@ -539,6 +655,14 @@
<source>MEN_RESET</source> <source>MEN_RESET</source>
<translation>Restaurer</translation> <translation>Restaurer</translation>
</message> </message>
<message>
<source>MEN_SAVE_DISTRIBUTION</source>
<translation>Exporter la distribution...</translation>
</message>
<message>
<source>MEN_SHOW_DISTRIBUTION</source>
<translation>Afficher la distribution</translation>
</message>
<message> <message>
<source>MEN_REVOLUTION</source> <source>MEN_REVOLUTION</source>
<translation>Révolution</translation> <translation>Révolution</translation>
@ -936,6 +1060,14 @@ Merci de les corriger, puis essayez de nouveau</translation>
<source>SMESH_BUILD_COMPOUND_TITLE</source> <source>SMESH_BUILD_COMPOUND_TITLE</source>
<translation>Créer un assemblage</translation> <translation>Créer un assemblage</translation>
</message> </message>
<message>
<source>SMESH_COPY_MESH_TITLE</source>
<translation>Copier le maillage</translation>
</message>
<message>
<source>SMESH_KEEP_IDS</source>
<translation>Conserver les IDs des éléments</translation>
</message>
<message> <message>
<source>SMESH_BUT_ADD</source> <source>SMESH_BUT_ADD</source>
<translation>A&amp;jouter</translation> <translation>A&amp;jouter</translation>
@ -1200,13 +1332,15 @@ Voulez-vous continuer ?</translation>
</message> </message>
<message> <message>
<source>SMESH_EXPORT_MED_V2_1</source> <source>SMESH_EXPORT_MED_V2_1</source>
<translation>Les éléments polygonaux et polyèdriques seront omis dans le cas d&apos;exportation du maillage &quot;%1&quot; à MED 2.1 <translation>Les éléments polygonaux et polyèdriques seront omis
dans le cas d&apos;exportation du maillage &quot;%1&quot; à MED 2.1
Utilisez MED 2.2 pour l&apos;exportation correcte. Utilisez MED 2.2 pour l&apos;exportation correcte.
Voulez-vous effectuer l&apos;exportation à MED 2.1 ?</translation> Voulez-vous effectuer l&apos;exportation à MED 2.1 ?</translation>
</message> </message>
<message> <message>
<source>SMESH_EXPORT_MED_VERSION_COLLISION</source> <source>SMESH_EXPORT_MED_VERSION_COLLISION</source>
<translation>La version MED du fichier &quot;%1&quot; n&apos;est pas connue ou ne correspond pas à la version choisie. <translation>La version MED du fichier &quot;%1&quot; n&apos;est pas connue
ou ne correspond pas à la version choisie.
Réécrire le fichier ?</translation> Réécrire le fichier ?</translation>
</message> </message>
<message> <message>
@ -1226,7 +1360,8 @@ Réécrire le fichier ?</translation>
</message> </message>
<message> <message>
<source>SMESH_EXPORT_UNV</source> <source>SMESH_EXPORT_UNV</source>
<translation>Les éléments pyramides seront omis au cours de l&apos;exportation du maillage &quot;%1&quot; dans le fichier UNV</translation> <translation>Les éléments pyramides seront omis au cours de l&apos;exportation
du maillage &quot;%1&quot; dans le fichier UNV</translation>
</message> </message>
<message> <message>
<source>SMESH_EXTRUSION</source> <source>SMESH_EXTRUSION</source>
@ -1255,7 +1390,8 @@ Réécrire le fichier ?</translation>
<message> <message>
<source>SMESH_FILE_EXISTS</source> <source>SMESH_FILE_EXISTS</source>
<translation>Le fichier &quot;%1&quot; existe déjà. <translation>Le fichier &quot;%1&quot; existe déjà.
Voulez-vous le réécrire ou y ajouter les données exportées ?</translation> Voulez-vous le réécrire ou y ajouter
les données exportées ?</translation>
</message> </message>
<message> <message>
<source>SMESH_FONT_ARIAL</source> <source>SMESH_FONT_ARIAL</source>
@ -1742,6 +1878,14 @@ Référez-vous à la documentation sur l&apos;algorithme et la géométrie suppo
<source>SMESH_POSITION_SIZE_SCALARBAR</source> <source>SMESH_POSITION_SIZE_SCALARBAR</source>
<translation>Origine &amp;&amp; Taille</translation> <translation>Origine &amp;&amp; Taille</translation>
</message> </message>
<message>
<source>SMESH_DISTRIBUTION_SCALARBAR</source>
<translation>Distribution</translation>
</message>
<message>
<source>SMESH_SHOW_DISTRIBUTION_SCALARBAR</source>
<translation>Afficher la distribution</translation>
</message>
<message> <message>
<source>SMESH_PRECISION</source> <source>SMESH_PRECISION</source>
<translation>Précision</translation> <translation>Précision</translation>
@ -1987,6 +2131,22 @@ Référez-vous à la documentation sur l&apos;algorithme et la géométrie suppo
<source>SMESH_VERTICAL</source> <source>SMESH_VERTICAL</source>
<translation>Verticale</translation> <translation>Verticale</translation>
</message> </message>
<message>
<source>SMESH_DISTRIBUTION_COLORING_TYPE</source>
<translation>Type de coloration</translation>
</message>
<message>
<source>SMESH_MONOCOLOR</source>
<translation>Monocouleur</translation>
</message>
<message>
<source>SMESH_DISTRIBUTION_COLOR</source>
<translation>Couleur de la distribution:</translation>
</message>
<message>
<source>SMESH_MULTICOLOR</source>
<translation>Multicouleur</translation>
</message>
<message> <message>
<source>SMESH_VISU_PROBLEM</source> <source>SMESH_VISU_PROBLEM</source>
<translation>Impossible de visualiser le maillage, probablement à cause d&apos;un manque de mémoire</translation> <translation>Impossible de visualiser le maillage, probablement à cause d&apos;un manque de mémoire</translation>
@ -2143,6 +2303,10 @@ Vérifiez la limite dans les préférences du module Mesh.
<source>STB_BUILD_COMPOUND</source> <source>STB_BUILD_COMPOUND</source>
<translation>Construire un maillage assemblé</translation> <translation>Construire un maillage assemblé</translation>
</message> </message>
<message>
<source>STB_COPY_MESH</source>
<translation>Copie le maillage</translation>
</message>
<message> <message>
<source>STB_CLIP</source> <source>STB_CLIP</source>
<translation>Pan de coupe</translation> <translation>Pan de coupe</translation>
@ -2823,6 +2987,22 @@ Vérifiez la limite dans les préférences du module Mesh.
<source>TOP_FACES</source> <source>TOP_FACES</source>
<translation>Faces</translation> <translation>Faces</translation>
</message> </message>
<message>
<source>TOP_BARE_BORDER_VOLUME</source>
<translation>Volumes avec frontière libre</translation>
</message>
<message>
<source>TOP_BARE_BORDER_FACE</source>
<translation>Faces avec frontière libre</translation>
</message>
<message>
<source>TOP_OVER_CONSTRAINED_VOLUME</source>
<translation>Volumes sur-contraints</translation>
</message>
<message>
<source>TOP_OVER_CONSTRAINED_FACE</source>
<translation>Faces sur-contraintes</translation>
</message>
<message> <message>
<source>TOP_FREE_BORDER</source> <source>TOP_FREE_BORDER</source>
<translation>Frontières libres</translation> <translation>Frontières libres</translation>
@ -2871,6 +3051,14 @@ Vérifiez la limite dans les préférences du module Mesh.
<source>TOP_MAP</source> <source>TOP_MAP</source>
<translation>Projection de motif</translation> <translation>Projection de motif</translation>
</message> </message>
<message>
<source>TOP_MAX_ELEMENT_LENGTH_2D</source>
<translation>Diamètre des éléments 2D</translation>
</message>
<message>
<source>TOP_MAX_ELEMENT_LENGTH_3D</source>
<translation>Diamètre des éléments 3D</translation>
</message>
<message> <message>
<source>TOP_MED</source> <source>TOP_MED</source>
<translation>Importer un fichier MED</translation> <translation>Importer un fichier MED</translation>
@ -2991,6 +3179,14 @@ Vérifiez la limite dans les préférences du module Mesh.
<source>TOP_RESET</source> <source>TOP_RESET</source>
<translation>Restaurer</translation> <translation>Restaurer</translation>
</message> </message>
<message>
<source>TOP_SAVE_DISTRIBUTION</source>
<translation>Exporter la distribution</translation>
</message>
<message>
<source>TOP_SHOW_DISTRIBUTION</source>
<translation>Afficher la distribution</translation>
</message>
<message> <message>
<source>TOP_REVOLUTION</source> <source>TOP_REVOLUTION</source>
<translation>Révolution</translation> <translation>Révolution</translation>
@ -3123,6 +3319,10 @@ Vérifiez la limite dans les préférences du module Mesh.
<source>TOP_WIRE</source> <source>TOP_WIRE</source>
<translation>Contours</translation> <translation>Contours</translation>
</message> </message>
<message>
<source>UNKNOWN_CONTROL</source>
<translation>Inconnu</translation>
</message>
<message> <message>
<source>VOLUME_3D_ELEMENTS</source> <source>VOLUME_3D_ELEMENTS</source>
<translation>Aire</translation> <translation>Aire</translation>
@ -3225,6 +3425,10 @@ avec le paramètre &apos;%1&apos; des préférences du module Mesh.</translation
<source>NB_NODES_REMOVED</source> <source>NB_NODES_REMOVED</source>
<translation>%1 nœud(s) supprimés.</translation> <translation>%1 nœud(s) supprimés.</translation>
</message> </message>
<message>
<source>SMESH_SAVE_DISTRIBUTION</source>
<translation>Exporter la distribution</translation>
</message>
<message> <message>
<source>SMESH_PLUGINS_OTHER</source> <source>SMESH_PLUGINS_OTHER</source>
<translation>Extensions SMESH</translation> <translation>Extensions SMESH</translation>
@ -3317,6 +3521,30 @@ Ouvrez une fenêtre VTK et essayez de nouveau</translation>
<source>PREF_NOTIFY_MODE</source> <source>PREF_NOTIFY_MODE</source>
<translation>Montrer la notification sur le résultat de calcul</translation> <translation>Montrer la notification sur le résultat de calcul</translation>
</message> </message>
<message>
<source>PREF_NOTIFY_NEVER</source>
<translation>Jamais</translation>
</message>
<message>
<source>PREF_NOTIFY_ERROR</source>
<translation>Erreurs uniquement</translation>
</message>
<message>
<source>PREF_NOTIFY_ALWAYS</source>
<translation>Toujours</translation>
</message>
<message>
<source>PREF_ELEM_INFO</source>
<translation>Information des éléments du maillage</translation>
</message>
<message>
<source>PREF_ELEM_INFO_SIMPLE</source>
<translation>Simple</translation>
</message>
<message>
<source>PREF_ELEM_INFO_TREE</source>
<translation>Arbre</translation>
</message>
<message> <message>
<source>SMESH_PREF_GROUP_PRECISION</source> <source>SMESH_PREF_GROUP_PRECISION</source>
<translation>Précision des champs d&apos;entrée</translation> <translation>Précision des champs d&apos;entrée</translation>
@ -3365,6 +3593,10 @@ Ouvrez une fenêtre VTK et essayez de nouveau</translation>
<source>PREF_GROUP_SELECTION</source> <source>PREF_GROUP_SELECTION</source>
<translation>Sélection</translation> <translation>Sélection</translation>
</message> </message>
<message>
<source>PREF_GROUP_INFO</source>
<translation>Information du maillage</translation>
</message>
<message> <message>
<source>PREF_HIGHLIGHT_COLOR</source> <source>PREF_HIGHLIGHT_COLOR</source>
<translation>Couleur de sélection</translation> <translation>Couleur de sélection</translation>
@ -4121,6 +4353,22 @@ Vérifiez la validité des informations données</translation>
<source>BAD_ORIENTED_VOLUME</source> <source>BAD_ORIENTED_VOLUME</source>
<translation>Volume mal orienté</translation> <translation>Volume mal orienté</translation>
</message> </message>
<message>
<source>BARE_BORDER_VOLUME</source>
<translation>Volumes avec frontière libre</translation>
</message>
<message>
<source>BARE_BORDER_FACE</source>
<translation>Faces avec frontière libre</translation>
</message>
<message>
<source>OVER_CONSTRAINED_VOLUME</source>
<translation>Volumes sur-contraints</translation>
</message>
<message>
<source>OVER_CONSTRAINED_FACE</source>
<translation>Faces sur-contraintes</translation>
</message>
<message> <message>
<source>BELONG_TO_CYLINDER</source> <source>BELONG_TO_CYLINDER</source>
<translation>Appartient au cylindre</translation> <translation>Appartient au cylindre</translation>
@ -5173,6 +5421,14 @@ Il y a trop peu de points dans le fichier </translation>
<source>CLIP_PLANES</source> <source>CLIP_PLANES</source>
<translation>Plans de découpe</translation> <translation>Plans de découpe</translation>
</message> </message>
<message>
<source>MESHES_SUBMESHES_GROUPS</source>
<translation>Maillages, sous-maillages et groupes</translation>
</message>
<message>
<source>SELECT_ALL</source>
<translation>Tout sélectionner</translation>
</message>
<message> <message>
<source>ROTATION_AROUND_X_Y2Z</source> <source>ROTATION_AROUND_X_Y2Z</source>
<translation>Rotation autour de X (Y à Z):</translation> <translation>Rotation autour de X (Y à Z):</translation>
@ -5343,4 +5599,361 @@ Il y a trop peu de points dans le fichier </translation>
<translation>Le nom du groupe n&apos;est pas indiqué</translation> <translation>Le nom du groupe n&apos;est pas indiqué</translation>
</message> </message>
</context> </context>
<context>
<name>SMESHGUI_MeshInfo</name>
<message>
<source>NAME_LAB</source>
<translation>Nom:</translation>
</message>
<message>
<source>OBJECT_LAB</source>
<translation>Objet:</translation>
</message>
<message>
<source>NODES_LAB</source>
<translation>Nœuds:</translation>
</message>
<message>
<source>ELEMENTS_LAB</source>
<translation>Eléments:</translation>
</message>
<message>
<source>TOTAL_LAB</source>
<translation>Total</translation>
</message>
<message>
<source>LINEAR_LAB</source>
<translation>Linéaire</translation>
</message>
<message>
<source>QUADRATIC_LAB</source>
<translation>Quadratique</translation>
</message>
<message>
<source>0D_LAB</source>
<translation>0D:</translation>
</message>
<message>
<source>1D_LAB</source>
<translation>1D (arêtes):</translation>
</message>
<message>
<source>2D_LAB</source>
<translation>2D (faces):</translation>
</message>
<message>
<source>TRIANGLES_LAB</source>
<translation>Triangles:</translation>
</message>
<message>
<source>QUADRANGLES_LAB</source>
<translation>Quadrangles:</translation>
</message>
<message>
<source>POLYGONS_LAB</source>
<translation>Polygones:</translation>
</message>
<message>
<source>3D_LAB</source>
<translation>3D (volumes):</translation>
</message>
<message>
<source>TETRAHEDRONS_LAB</source>
<translation>Tétrahédrons:</translation>
</message>
<message>
<source>HEXAHEDONRS_LAB</source>
<translation>Hexahédrons:</translation>
</message>
<message>
<source>PYRAMIDS_LAB</source>
<translation>Pyramides:</translation>
</message>
<message>
<source>PRISMS_LAB</source>
<translation>Prismes:</translation>
</message>
<message>
<source>POLYHEDRONS_LAB</source>
<translation>Polyhédrons:</translation>
</message>
<message>
<source>OBJECT_MESH</source>
<translation>Maillage</translation>
</message>
<message>
<source>OBJECT_SUBMESH</source>
<translation>Sous-maillage</translation>
</message>
<message>
<source>OBJECT_GROUP</source>
<translation>Groupe</translation>
</message>
<message>
<source>OBJECT_GROUP_NODES</source>
<translation>Groupe de nœuds</translation>
</message>
<message>
<source>OBJECT_GROUP_EDGES</source>
<translation>Groupe d&apos;arêtes</translation>
</message>
<message>
<source>OBJECT_GROUP_FACES</source>
<translation>Groupe de faces</translation>
</message>
<message>
<source>OBJECT_GROUP_VOLUMES</source>
<translation>Groupe de volumes</translation>
</message>
<message>
<source>OBJECT_GROUP_0DELEMS</source>
<translation>Groupe d&apos;éléments 0D</translation>
</message>
</context>
<context>
<name>SMESHGUI_MeshInfoDlg</name>
<message>
<source>MESH_INFO</source>
<translation>Infiormations de maillage</translation>
</message>
<message>
<source>BASE_INFO</source>
<translation>Informations de base</translation>
</message>
<message>
<source>ELEM_INFO</source>
<translation>Informations des éléments</translation>
</message>
<message>
<source>NODE_MODE</source>
<translation>Nœud</translation>
</message>
<message>
<source>ELEM_MODE</source>
<translation>Elément</translation>
</message>
</context>
<context>
<name>SMESHGUI_ElemInfo</name>
<message>
<source>COORDINATES</source>
<translation>COORDONNÉES</translation>
</message>
<message>
<source>CONNECTIVITY</source>
<translation>CONNECTIVITÉ</translation>
</message>
<message>
<source>GRAVITY_CENTER</source>
<translation>CENTRE DE GRAVITÉ</translation>
</message>
<message>
<source>NODE</source>
<translation>Nœud</translation>
</message>
<message>
<source>0D_ELEMENT</source>
<translation>ELÉMENTS 0D</translation>
</message>
<message>
<source>0D_ELEMENTS</source>
<translation>ELÉMENTS 0D</translation>
</message>
<message>
<source>EDGE</source>
<translation>ARÊTE</translation>
</message>
<message>
<source>EDGES</source>
<translation>ARÊTES</translation>
</message>
<message>
<source>FACE</source>
<translation>FACE</translation>
</message>
<message>
<source>FACES</source>
<translation>FACES</translation>
</message>
<message>
<source>VOLUME</source>
<translation>VOLUME</translation>
</message>
<message>
<source>VOLUMES</source>
<translation>VOLUMES</translation>
</message>
<message>
<source>FREE_NODE</source>
<translation>Nœud libre (pas de connectivité)</translation>
</message>
<message>
<source>TYPE</source>
<translation>TYPE</translation>
</message>
<message>
<source>TRIANGLE</source>
<translation>Triangle</translation>
</message>
<message>
<source>QUADRANGLE</source>
<translation>Quadrangle</translation>
</message>
<message>
<source>POLYGON</source>
<translation>Polygône</translation>
</message>
<message>
<source>TETRAHEDRON</source>
<translation>Tétrahédron</translation>
</message>
<message>
<source>HEXAHEDRON</source>
<translation>Hexahédron</translation>
</message>
<message>
<source>PYRAMID</source>
<translation>Pyramide</translation>
</message>
<message>
<source>PRISM</source>
<translation>Prisme</translation>
</message>
<message>
<source>POLYHEDRON</source>
<translation>Polyhédron</translation>
</message>
<message>
<source>QUADRATIC</source>
<translation>QUADRATIQUE</translation>
</message>
<message>
<source>YES</source>
<translation>Oui</translation>
</message>
<message>
<source>NO</source>
<translation>Non</translation>
</message>
<message>
<source>PROPERTY</source>
<translation>Propriété</translation>
</message>
<message>
<source>VALUE</source>
<translation>Valeur</translation>
</message>
<message>
<source>X_FROM_Y_ITEMS_SHOWN</source>
<translation>%1-%2 sur %3 éléments affichés</translation>
</message>
</context>
<context>
<name>SMESHGUI_MinDistance</name>
<message>
<source>FIRST_TARGET</source>
<translation>Premier élément</translation>
</message>
<message>
<source>SECOND_TARGET</source>
<translation>Deuxième élément</translation>
</message>
<message>
<source>NODE</source>
<translation>Nœud</translation>
</message>
<message>
<source>ELEMENT</source>
<translation>Elément</translation>
</message>
<message>
<source>OBJECT</source>
<translation>Objet</translation>
</message>
<message>
<source>ORIGIN</source>
<translation>Origine</translation>
</message>
<message>
<source>COMPUTE</source>
<translation>Calculer</translation>
</message>
<message>
<source>RESULT</source>
<translation>Distance entre les éléments</translation>
</message>
<message>
<source>DISTANCE</source>
<translation>Distance</translation>
</message>
</context>
<context>
<name>SMESHGUI_CopyMeshDlg</name>
<message>
<source>OBJECT_NAME</source>
<translation>Objet source</translation>
</message>
<message>
<source>ELEM_IDS</source>
<translation>IDs des éléments sources</translation>
</message>
<message>
<source>NEW_NAME</source>
<translation>Nom du nouveau maillage</translation>
</message>
</context>
<context>
<name>SMESHGUI_MeasureDlg</name>
<message>
<source>MEASUREMENTS</source>
<translation>Outils de mesure</translation>
</message>
<message>
<source>MIN_DIST</source>
<translation>Distance minimale</translation>
</message>
<message>
<source>BND_BOX</source>
<translation>Boîte englobante</translation>
</message>
</context>
<context>
<name>SMESHGUI_BoundingBox</name>
<message>
<source>SOURCE</source>
<translation>Source</translation>
</message>
<message>
<source>OBJECTS</source>
<translation>Objets</translation>
</message>
<message>
<source>NODES</source>
<translation>Nœuds</translation>
</message>
<message>
<source>ELEMENTS</source>
<translation>Eléments</translation>
</message>
<message>
<source>COMPUTE</source>
<translation>Calculer</translation>
</message>
<message>
<source>RESULT</source>
<translation>Boîte englobante</translation>
</message>
<message>
<source>SELECTED_NB_OBJ</source>
<translation>%1 %2 sélectionnés</translation>
</message>
<message>
<source>NB_NODES</source>
<translation>nœuds</translation>
</message>
<message>
<source>NB_ELEMENTS</source>
<translation>éléments</translation>
</message>
</context>
</TS> </TS>

View File

@ -247,7 +247,8 @@ Handle(_pyCommand) _pyGen::AddCommand( const TCollection_AsciiString& theCommand
// SMESH_Mesh method? // SMESH_Mesh method?
map< _pyID, Handle(_pyMesh) >::iterator id_mesh = myMeshes.find( objID ); map< _pyID, Handle(_pyMesh) >::iterator id_mesh = myMeshes.find( objID );
if ( id_mesh != myMeshes.end() ) { if ( id_mesh != myMeshes.end() )
{
// check for mesh editor object // check for mesh editor object
if ( aCommand->GetMethod() == "GetMeshEditor" ) { // MeshEditor creation if ( aCommand->GetMethod() == "GetMeshEditor" ) { // MeshEditor creation
_pyID editorID = aCommand->GetResultValue(); _pyID editorID = aCommand->GetResultValue();
@ -268,7 +269,8 @@ Handle(_pyCommand) _pyGen::AddCommand( const TCollection_AsciiString& theCommand
// SMESH_MeshEditor method? // SMESH_MeshEditor method?
map< _pyID, Handle(_pyMeshEditor) >::iterator id_editor = myMeshEditors.find( objID ); map< _pyID, Handle(_pyMeshEditor) >::iterator id_editor = myMeshEditors.find( objID );
if ( id_editor != myMeshEditors.end() ) { if ( id_editor != myMeshEditors.end() )
{
id_editor->second->Process( aCommand ); id_editor->second->Process( aCommand );
TCollection_AsciiString processedCommand = aCommand->GetString(); TCollection_AsciiString processedCommand = aCommand->GetString();
// some commands of SMESH_MeshEditor create meshes // some commands of SMESH_MeshEditor create meshes
@ -277,6 +279,15 @@ Handle(_pyCommand) _pyGen::AddCommand( const TCollection_AsciiString& theCommand
aCommand->GetString() = processedCommand; // discard changes made by _pyMesh aCommand->GetString() = processedCommand; // discard changes made by _pyMesh
myMeshes.insert( make_pair( mesh->GetID(), mesh )); myMeshes.insert( make_pair( mesh->GetID(), mesh ));
} }
if ( aCommand->GetMethod() == "MakeBoundaryMesh") {
_pyID meshID = aCommand->GetResultValue(0);
if ( !myMeshes.count( meshID ) )
{
Handle(_pyMesh) mesh = new _pyMesh( aCommand, meshID );
aCommand->GetString() = processedCommand; // discard changes made by _pyMesh
myMeshes.insert( make_pair( meshID, mesh ));
}
}
return aCommand; return aCommand;
} }
// SMESH_Hypothesis method? // SMESH_Hypothesis method?
@ -352,7 +363,7 @@ void _pyGen::Process( const Handle(_pyCommand)& theCommand )
myMeshes.insert( make_pair( mesh->GetID(), mesh )); myMeshes.insert( make_pair( mesh->GetID(), mesh ));
return; return;
} }
if ( method == "CreateMeshesFromUNV" || method == "CreateMeshesFromSTL") if ( method == "CreateMeshesFromUNV" || method == "CreateMeshesFromSTL" || method == "CopyMesh" )
{ {
Handle(_pyMesh) mesh = new _pyMesh( theCommand, theCommand->GetResultValue() ); Handle(_pyMesh) mesh = new _pyMesh( theCommand, theCommand->GetResultValue() );
myMeshes.insert( make_pair( mesh->GetID(), mesh )); myMeshes.insert( make_pair( mesh->GetID(), mesh ));
@ -1118,14 +1129,15 @@ void _pyMeshEditor::Process( const Handle(_pyCommand)& theCommand)
"ConvertToQuadratic","ConvertFromQuadratic","RenumberNodes","RenumberElements", "ConvertToQuadratic","ConvertFromQuadratic","RenumberNodes","RenumberElements",
"RotationSweep","RotationSweepObject","RotationSweepObject1D","RotationSweepObject2D", "RotationSweep","RotationSweepObject","RotationSweepObject1D","RotationSweepObject2D",
"ExtrusionSweep","AdvancedExtrusion","ExtrusionSweepObject","ExtrusionSweepObject1D","ExtrusionSweepObject2D", "ExtrusionSweep","AdvancedExtrusion","ExtrusionSweepObject","ExtrusionSweepObject1D","ExtrusionSweepObject2D",
"ExtrusionAlongPath","ExtrusionAlongPathObject","ExtrusionAlongPathObject1D","ExtrusionAlongPathObject2D", "ExtrusionAlongPath","ExtrusionAlongPathObject","ExtrusionAlongPathX",
"ExtrusionAlongPathObject1D","ExtrusionAlongPathObject2D",
"Mirror","MirrorObject","Translate","TranslateObject","Rotate","RotateObject", "Mirror","MirrorObject","Translate","TranslateObject","Rotate","RotateObject",
"FindCoincidentNodes",/*"FindCoincidentNodesOnPart",*/"MergeNodes","FindEqualElements", "FindCoincidentNodes",/*"FindCoincidentNodesOnPart",*/"MergeNodes","FindEqualElements",
"MergeElements","MergeEqualElements","SewFreeBorders","SewConformFreeBorders", "MergeElements","MergeEqualElements","SewFreeBorders","SewConformFreeBorders",
"SewBorderToSide","SewSideElements","ChangeElemNodes","GetLastCreatedNodes", "SewBorderToSide","SewSideElements","ChangeElemNodes","GetLastCreatedNodes",
"GetLastCreatedElems", "GetLastCreatedElems",
"MirrorMakeMesh","MirrorObjectMakeMesh","TranslateMakeMesh", "MirrorMakeMesh","MirrorObjectMakeMesh","TranslateMakeMesh",
"TranslateObjectMakeMesh","RotateMakeMesh","RotateObjectMakeMesh" "TranslateObjectMakeMesh","RotateMakeMesh","RotateObjectMakeMesh","MakeBoundaryMesh"
,"" }; // <- mark of the end ,"" }; // <- mark of the end
sameMethods.Insert( names ); sameMethods.Insert( names );
} }
@ -1166,6 +1178,13 @@ void _pyMeshEditor::Process( const Handle(_pyCommand)& theCommand)
} }
} }
// set "ExtrusionAlongPathX()" instead of "ExtrusionAlongPathObjX()"
if ( !isPyMeshMethod && method == "ExtrusionAlongPathObjX")
{
isPyMeshMethod=true;
theCommand->SetMethod("ExtrusionAlongPathX");
}
// set "FindCoincidentNodesOnPart()" instead of "FindCoincidentNodesOnPartBut()" // set "FindCoincidentNodesOnPart()" instead of "FindCoincidentNodesOnPartBut()"
if ( !isPyMeshMethod && method == "FindCoincidentNodesOnPartBut") if ( !isPyMeshMethod && method == "FindCoincidentNodesOnPartBut")
{ {

View File

@ -232,7 +232,10 @@ namespace SMESH
if(!aSObject->_is_nil() || CORBA::is_nil( theArg )) if(!aSObject->_is_nil() || CORBA::is_nil( theArg ))
return *this << aSObject; return *this << aSObject;
SMESH::long_array_var anElementsId = theArg->GetIDs(); SMESH::long_array_var anElementsId = theArg->GetIDs();
return *this << anElementsId; SMESH::SMESH_Mesh_var mesh = theArg->GetMesh();
SMESH::array_of_ElementType_var types = theArg->GetTypes();
SMESH::ElementType type = types->length() ? types[0] : SMESH::ALL;
return *this << mesh << ".GetIDSource(" << anElementsId << ", " << type << ")";
} }
TPythonDump& TPythonDump&
@ -274,25 +277,29 @@ namespace SMESH
case FT_Skew: myStream<< "aSkew"; break; case FT_Skew: myStream<< "aSkew"; break;
case FT_Area: myStream<< "aArea"; break; case FT_Area: myStream<< "aArea"; break;
case FT_Volume3D: myStream<< "aVolume3D"; break; case FT_Volume3D: myStream<< "aVolume3D"; break;
case FT_MaxElementLength2D:myStream<< "aMaxElementLength2D";break; case FT_MaxElementLength2D: myStream<< "aMaxElementLength2D"; break;
case FT_MaxElementLength3D:myStream<< "aMaxElementLength3D";break; case FT_MaxElementLength3D: myStream<< "aMaxElementLength3D"; break;
case FT_FreeBorders: myStream<< "aFreeBorders"; break; case FT_FreeBorders: myStream<< "aFreeBorders"; break;
case FT_FreeEdges: myStream<< "aFreeEdges"; break; case FT_FreeEdges: myStream<< "aFreeEdges"; break;
case FT_FreeNodes: myStream<< "aFreeNodes"; break; case FT_FreeNodes: myStream<< "aFreeNodes"; break;
case FT_FreeFaces: myStream<< "aFreeFaces"; break; case FT_FreeFaces: myStream<< "aFreeFaces"; break;
case FT_MultiConnection: myStream<< "aMultiConnection"; break; case FT_MultiConnection: myStream<< "aMultiConnection"; break;
case FT_MultiConnection2D:myStream<< "aMultiConnection2D";break; case FT_MultiConnection2D: myStream<< "aMultiConnection2D"; break;
case FT_Length: myStream<< "aLength"; break; case FT_Length: myStream<< "aLength"; break;
case FT_Length2D: myStream<< "aLength"; break; case FT_Length2D: myStream<< "aLength2D"; break;
case FT_BelongToGeom: myStream<< "aBelongToGeom"; break; case FT_BelongToGeom: myStream<< "aBelongToGeom"; break;
case FT_BelongToPlane: myStream<< "aBelongToPlane"; break; case FT_BelongToPlane: myStream<< "aBelongToPlane"; break;
case FT_BelongToCylinder: myStream<< "aBelongToCylinder"; break; case FT_BelongToCylinder: myStream<< "aBelongToCylinder"; break;
case FT_BelongToGenSurface:myStream<<"aBelongToGenSurface";break; case FT_BelongToGenSurface: myStream<< "aBelongToGenSurface"; break;
case FT_LyingOnGeom: myStream<< "aLyingOnGeom"; break; case FT_LyingOnGeom: myStream<< "aLyingOnGeom"; break;
case FT_CoplanarFaces: myStream<< "aCoplanarFaces"; break; case FT_CoplanarFaces: myStream<< "aCoplanarFaces"; break;
case FT_RangeOfIds: myStream<< "aRangeOfIds"; break; case FT_RangeOfIds: myStream<< "aRangeOfIds"; break;
case FT_BadOrientedVolume:myStream<< "aBadOrientedVolume";break; case FT_BadOrientedVolume: myStream<< "aBadOrientedVolume"; break;
case FT_LinearOrQuadratic:myStream<< "aLinearOrQuadratic";break; case FT_BareBorderVolume: myStream<< "aBareBorderVolume"; break;
case FT_BareBorderFace: myStream<< "aBareBorderFace"; break;
case FT_OverConstrainedVolume: myStream<< "aOverConstrainedVolume"; break;
case FT_OverConstrainedFace: myStream<< "aOverConstrainedFace"; break;
case FT_LinearOrQuadratic: myStream<< "aLinearOrQuadratic"; break;
case FT_GroupColor: myStream<< "aGroupColor"; break; case FT_GroupColor: myStream<< "aGroupColor"; break;
case FT_ElemGeomType: myStream<< "anElemGeomType"; break; case FT_ElemGeomType: myStream<< "anElemGeomType"; break;
case FT_LessThan: myStream<< "aLessThan"; break; case FT_LessThan: myStream<< "aLessThan"; break;

View File

@ -34,6 +34,7 @@
#include "SMDS_MeshNode.hxx" #include "SMDS_MeshNode.hxx"
#include "SMDS_MeshElement.hxx" #include "SMDS_MeshElement.hxx"
#include "SMDS_ElemIterator.hxx" #include "SMDS_ElemIterator.hxx"
#include "SMDS_VolumeTool.hxx"
#include "SMESHDS_Mesh.hxx" #include "SMESHDS_Mesh.hxx"
@ -600,7 +601,8 @@ SMESH::Histogram* NumericalFunctor_i::GetHistogram(CORBA::Short nbIntervals)
{ {
std::vector<int> nbEvents; std::vector<int> nbEvents;
std::vector<double> funValues; std::vector<double> funValues;
myNumericalFunctorPtr->GetHistogram(nbIntervals,nbEvents,funValues); std::vector<int> elements;
myNumericalFunctorPtr->GetHistogram(nbIntervals,nbEvents,funValues,elements);
nbIntervals = CORBA::Short( std::min( nbEvents.size(), funValues.size() - 1)); nbIntervals = CORBA::Short( std::min( nbEvents.size(), funValues.size() - 1));
SMESH::Histogram_var histogram = new SMESH::Histogram; SMESH::Histogram_var histogram = new SMESH::Histogram;
@ -937,6 +939,66 @@ FunctorType BadOrientedVolume_i::GetFunctorType()
return SMESH::FT_BadOrientedVolume; return SMESH::FT_BadOrientedVolume;
} }
/*
Class : BareBorderVolume_i
Description : Verify whether a mesh volume has a free facet without a face on it
*/
BareBorderVolume_i::BareBorderVolume_i()
{
Controls::PredicatePtr control( new Controls::BareBorderVolume() );
myFunctorPtr = myPredicatePtr = control;
};
FunctorType BareBorderVolume_i::GetFunctorType()
{
return SMESH::FT_BareBorderVolume;
}
/*
Class : BareBorderFace_i
Description : Verify whether a mesh face has a free border without an edge on it
*/
BareBorderFace_i::BareBorderFace_i()
{
Controls::PredicatePtr control( new Controls::BareBorderFace() );
myFunctorPtr = myPredicatePtr = control;
};
FunctorType BareBorderFace_i::GetFunctorType()
{
return SMESH::FT_BareBorderFace;
}
/*
Class : OverConstrainedVolume_i
Description : Verify whether a mesh volume has only one facet shared with other volumes
*/
OverConstrainedVolume_i::OverConstrainedVolume_i()
{
Controls::PredicatePtr control( new Controls::OverConstrainedVolume() );
myFunctorPtr = myPredicatePtr = control;
};
FunctorType OverConstrainedVolume_i::GetFunctorType()
{
return SMESH::FT_OverConstrainedVolume;
}
/*
Class : OverConstrainedFace_i
Description : Verify whether a mesh face has only one border shared with other faces
*/
OverConstrainedFace_i::OverConstrainedFace_i()
{
Controls::PredicatePtr control( new Controls::OverConstrainedFace() );
myFunctorPtr = myPredicatePtr = control;
};
FunctorType OverConstrainedFace_i::GetFunctorType()
{
return SMESH::FT_OverConstrainedFace;
}
/* /*
Class : BelongToGeom_i Class : BelongToGeom_i
Description : Predicate for selection on geometrical support Description : Predicate for selection on geometrical support
@ -2036,6 +2098,38 @@ BadOrientedVolume_ptr FilterManager_i::CreateBadOrientedVolume()
return anObj._retn(); return anObj._retn();
} }
BareBorderVolume_ptr FilterManager_i::CreateBareBorderVolume()
{
SMESH::BareBorderVolume_i* aServant = new SMESH::BareBorderVolume_i();
SMESH::BareBorderVolume_var anObj = aServant->_this();
TPythonDump()<<aServant<<" = "<<this<<".CreateBareBorderVolume()";
return anObj._retn();
}
BareBorderFace_ptr FilterManager_i::CreateBareBorderFace()
{
SMESH::BareBorderFace_i* aServant = new SMESH::BareBorderFace_i();
SMESH::BareBorderFace_var anObj = aServant->_this();
TPythonDump()<<aServant<<" = "<<this<<".CreateBareBorderFace()";
return anObj._retn();
}
OverConstrainedVolume_ptr FilterManager_i::CreateOverConstrainedVolume()
{
SMESH::OverConstrainedVolume_i* aServant = new SMESH::OverConstrainedVolume_i();
SMESH::OverConstrainedVolume_var anObj = aServant->_this();
TPythonDump()<<aServant<<" = "<<this<<".CreateOverConstrainedVolume()";
return anObj._retn();
}
OverConstrainedFace_ptr FilterManager_i::CreateOverConstrainedFace()
{
SMESH::OverConstrainedFace_i* aServant = new SMESH::OverConstrainedFace_i();
SMESH::OverConstrainedFace_var anObj = aServant->_this();
TPythonDump()<<aServant<<" = "<<this<<".CreateOverConstrainedFace()";
return anObj._retn();
}
LessThan_ptr FilterManager_i::CreateLessThan() LessThan_ptr FilterManager_i::CreateLessThan()
{ {
SMESH::LessThan_i* aServant = new SMESH::LessThan_i(); SMESH::LessThan_i* aServant = new SMESH::LessThan_i();
@ -2476,6 +2570,62 @@ static inline bool getCriteria( Predicate_i* thePred,
theCriteria[ i ].Type = FT_BadOrientedVolume; theCriteria[ i ].Type = FT_BadOrientedVolume;
theCriteria[ i ].TypeOfElement = aPred->GetElementType(); theCriteria[ i ].TypeOfElement = aPred->GetElementType();
return true;
}
case FT_BareBorderVolume:
{
BareBorderVolume_i* aPred = dynamic_cast<BareBorderVolume_i*>( thePred );
CORBA::ULong i = theCriteria->length();
theCriteria->length( i + 1 );
theCriteria[ i ] = createCriterion();
theCriteria[ i ].Type = FT_BareBorderVolume;
theCriteria[ i ].TypeOfElement = aPred->GetElementType();
return true;
}
case FT_BareBorderFace:
{
BareBorderFace_i* aPred = dynamic_cast<BareBorderFace_i*>( thePred );
CORBA::ULong i = theCriteria->length();
theCriteria->length( i + 1 );
theCriteria[ i ] = createCriterion();
theCriteria[ i ].Type = FT_BareBorderFace;
theCriteria[ i ].TypeOfElement = aPred->GetElementType();
return true;
}
case FT_OverConstrainedVolume:
{
OverConstrainedVolume_i* aPred = dynamic_cast<OverConstrainedVolume_i*>( thePred );
CORBA::ULong i = theCriteria->length();
theCriteria->length( i + 1 );
theCriteria[ i ] = createCriterion();
theCriteria[ i ].Type = FT_OverConstrainedVolume;
theCriteria[ i ].TypeOfElement = aPred->GetElementType();
return true;
}
case FT_OverConstrainedFace:
{
OverConstrainedFace_i* aPred = dynamic_cast<OverConstrainedFace_i*>( thePred );
CORBA::ULong i = theCriteria->length();
theCriteria->length( i + 1 );
theCriteria[ i ] = createCriterion();
theCriteria[ i ].Type = FT_OverConstrainedFace;
theCriteria[ i ].TypeOfElement = aPred->GetElementType();
return true; return true;
} }
case FT_LessThan: case FT_LessThan:
@ -2723,6 +2873,26 @@ CORBA::Boolean Filter_i::SetCriteria( const SMESH::Filter::Criteria& theCriteria
aPredicate = aFilterMgr->CreateBadOrientedVolume(); aPredicate = aFilterMgr->CreateBadOrientedVolume();
} }
break; break;
case SMESH::FT_BareBorderVolume:
{
aPredicate = aFilterMgr->CreateBareBorderVolume();
}
break;
case SMESH::FT_BareBorderFace:
{
aPredicate = aFilterMgr->CreateBareBorderFace();
}
break;
case SMESH::FT_OverConstrainedVolume:
{
aPredicate = aFilterMgr->CreateOverConstrainedVolume();
}
break;
case SMESH::FT_OverConstrainedFace:
{
aPredicate = aFilterMgr->CreateOverConstrainedFace();
}
break;
case SMESH::FT_LinearOrQuadratic: case SMESH::FT_LinearOrQuadratic:
{ {
SMESH::LinearOrQuadratic_ptr tmpPred = aFilterMgr->CreateLinearOrQuadratic(); SMESH::LinearOrQuadratic_ptr tmpPred = aFilterMgr->CreateLinearOrQuadratic();
@ -2963,7 +3133,11 @@ static inline LDOMString toString( CORBA::Long theType )
case FT_BelongToCylinder: return "Belong to Cylinder"; case FT_BelongToCylinder: return "Belong to Cylinder";
case FT_BelongToGenSurface: return "Belong to Generic Surface"; case FT_BelongToGenSurface: return "Belong to Generic Surface";
case FT_LyingOnGeom : return "Lying on Geom"; case FT_LyingOnGeom : return "Lying on Geom";
case FT_BadOrientedVolume: return "Bad Oriented Volume"; case FT_BadOrientedVolume:return "Bad Oriented Volume";
case FT_BareBorderVolume: return "Volumes with bare border";
case FT_BareBorderFace : return "Faces with bare border";
case FT_OverConstrainedVolume: return "Over-constrained Volumes";
case FT_OverConstrainedFace : return "Over-constrained Faces";
case FT_RangeOfIds : return "Range of IDs"; case FT_RangeOfIds : return "Range of IDs";
case FT_FreeBorders : return "Free borders"; case FT_FreeBorders : return "Free borders";
case FT_FreeEdges : return "Free edges"; case FT_FreeEdges : return "Free edges";
@ -3017,6 +3191,10 @@ static inline SMESH::FunctorType toFunctorType( const LDOMString& theStr )
// else if ( theStr.equals( "Length2D" ) ) return FT_Length2D; // else if ( theStr.equals( "Length2D" ) ) return FT_Length2D;
else if ( theStr.equals( "Range of IDs" ) ) return FT_RangeOfIds; else if ( theStr.equals( "Range of IDs" ) ) return FT_RangeOfIds;
else if ( theStr.equals( "Bad Oriented Volume" ) ) return FT_BadOrientedVolume; else if ( theStr.equals( "Bad Oriented Volume" ) ) return FT_BadOrientedVolume;
else if ( theStr.equals( "Volumes with bare border" ) ) return FT_BareBorderVolume;
else if ( theStr.equals( "Faces with bare border" ) ) return FT_BareBorderFace;
else if ( theStr.equals( "Over-constrained Volumes" ) ) return FT_OverConstrainedVolume;
else if ( theStr.equals( "Over-constrained Faces" ) ) return FT_OverConstrainedFace;
else if ( theStr.equals( "Less than" ) ) return FT_LessThan; else if ( theStr.equals( "Less than" ) ) return FT_LessThan;
else if ( theStr.equals( "More than" ) ) return FT_MoreThan; else if ( theStr.equals( "More than" ) ) return FT_MoreThan;
else if ( theStr.equals( "Equal to" ) ) return FT_EqualTo; else if ( theStr.equals( "Equal to" ) ) return FT_EqualTo;

View File

@ -44,6 +44,7 @@ class SMESHDS_Mesh;
namespace SMESH namespace SMESH
{ {
// ================================================================================
namespace Controls namespace Controls
{ {
@ -123,8 +124,10 @@ namespace SMESH
Controls::ElementsOnShapePtr myElementsOnShapePtr; // only if myIsSubshape == false Controls::ElementsOnShapePtr myElementsOnShapePtr; // only if myIsSubshape == false
}; };
typedef boost::shared_ptr<LyingOnGeom> LyingOnGeomPtr; typedef boost::shared_ptr<LyingOnGeom> LyingOnGeomPtr;
}
} // namespace Controls
// ================================================================================
/* /*
FUNCTORS FUNCTORS
*/ */
@ -387,6 +390,54 @@ namespace SMESH
FunctorType GetFunctorType(); FunctorType GetFunctorType();
}; };
/*
Class : BareBorderVolume_i
Description : Verify whether a mesh volume has a free facet without a face on it
*/
class SMESH_I_EXPORT BareBorderVolume_i: public virtual POA_SMESH::BareBorderVolume,
public virtual Predicate_i
{
public:
BareBorderVolume_i();
FunctorType GetFunctorType();
};
/*
Class : BareBorderFace_i
Description : Verify whether a mesh face has a free border without an edge on it
*/
class SMESH_I_EXPORT BareBorderFace_i: public virtual POA_SMESH::BareBorderFace,
public virtual Predicate_i
{
public:
BareBorderFace_i();
FunctorType GetFunctorType();
};
/*
Class : OverConstrainedVolume_i
Description : Verify whether a mesh volume has only one facet shared with other volumes
*/
class SMESH_I_EXPORT OverConstrainedVolume_i: public virtual POA_SMESH::OverConstrainedVolume,
public virtual Predicate_i
{
public:
OverConstrainedVolume_i();
FunctorType GetFunctorType();
};
/*
Class : OverConstrainedFace_i
Description : Verify whether a mesh face has only one border shared with other faces
*/
class SMESH_I_EXPORT OverConstrainedFace_i: public virtual POA_SMESH::OverConstrainedFace,
public virtual Predicate_i
{
public:
OverConstrainedFace_i();
FunctorType GetFunctorType();
};
/* /*
Class : BelongToGeom_i Class : BelongToGeom_i
Description : Predicate for selection on geometrical support Description : Predicate for selection on geometrical support
@ -954,6 +1005,10 @@ namespace SMESH
RangeOfIds_ptr CreateRangeOfIds(); RangeOfIds_ptr CreateRangeOfIds();
BadOrientedVolume_ptr CreateBadOrientedVolume(); BadOrientedVolume_ptr CreateBadOrientedVolume();
BareBorderFace_ptr CreateBareBorderFace();
BareBorderVolume_ptr CreateBareBorderVolume();
OverConstrainedFace_ptr CreateOverConstrainedFace();
OverConstrainedVolume_ptr CreateOverConstrainedVolume();
LinearOrQuadratic_ptr CreateLinearOrQuadratic(); LinearOrQuadratic_ptr CreateLinearOrQuadratic();
GroupColor_ptr CreateGroupColor(); GroupColor_ptr CreateGroupColor();
ElemGeomType_ptr CreateElemGeomType(); ElemGeomType_ptr CreateElemGeomType();

View File

@ -91,9 +91,10 @@
#include "SMDS_EdgePosition.hxx" #include "SMDS_EdgePosition.hxx"
#include "SMDS_FacePosition.hxx" #include "SMDS_FacePosition.hxx"
#include "SMDS_VertexPosition.hxx"
#include "SMDS_SpacePosition.hxx"
#include "SMDS_PolyhedralVolumeOfNodes.hxx" #include "SMDS_PolyhedralVolumeOfNodes.hxx"
#include "SMDS_SetIterator.hxx"
#include "SMDS_SpacePosition.hxx"
#include "SMDS_VertexPosition.hxx"
#include CORBA_SERVER_HEADER(SMESH_Group) #include CORBA_SERVER_HEADER(SMESH_Group)
#include CORBA_SERVER_HEADER(SMESH_Filter) #include CORBA_SERVER_HEADER(SMESH_Filter)
@ -901,7 +902,7 @@ SMESH::SMESH_Mesh_ptr SMESH_Gen_i::CreateMeshesFromUNV( const char* theFileName
aServant->ImportUNVFile( theFileName ); aServant->ImportUNVFile( theFileName );
// Dump creation of groups // Dump creation of groups
aServant->GetGroups(); SMESH::ListOfGroups_var groups = aServant->GetGroups();
aServant->GetImpl().GetMeshDS()->Modified(); aServant->GetImpl().GetMeshDS()->Modified();
return aMesh._retn(); return aMesh._retn();
@ -982,7 +983,7 @@ SMESH::mesh_array* SMESH_Gen_i::CreateMeshesFromMED( const char* theFileName,
} }
// Dump creation of groups // Dump creation of groups
for ( int i = 0; i < aResult->length(); ++i ) for ( int i = 0; i < aResult->length(); ++i )
aResult[ i ]->GetGroups(); SMESH::ListOfGroups_var groups = aResult[ i ]->GetGroups();
return aResult._retn(); return aResult._retn();
} }
@ -2026,6 +2027,22 @@ SMESH_Gen_i::ConcatenateCommon(const SMESH::mesh_array& theMeshesArray,
} }
}//elems loop }//elems loop
// copy orphan nodes
SMDS_NodeIteratorPtr itNodes = anInitMeshDS->nodesIterator();
while ( itNodes->more() )
{
const SMDS_MeshNode* aNode = itNodes->next();
if ( aNode->NbInverseElements() == 0 )
{
const SMDS_MeshNode* aNewNode =
aNewMeshDS->AddNode(aNode->X(), aNode->Y(), aNode->Z());
nodesMap.insert( make_pair(aNode->GetID(), aNewNode->GetID()) );
if( theCommonGroups )
anIDsNodes[anNbNodes++] = aNewNode->GetID();
}
}
aListOfGroups = anInitImpl->GetGroups(); aListOfGroups = anInitImpl->GetGroups();
SMESH::SMESH_GroupBase_ptr aGroup; SMESH::SMESH_GroupBase_ptr aGroup;
@ -2211,6 +2228,212 @@ SMESH_Gen_i::ConcatenateCommon(const SMESH::mesh_array& theMeshesArray,
return aNewMesh._retn(); return aNewMesh._retn();
} }
//================================================================================
/*!
* \brief Create a mesh by copying a part of another mesh
* \param meshPart - a part of mesh to copy
* \param toCopyGroups - to create in the new mesh groups
* the copied elements belongs to
* \param toKeepIDs - to preserve IDs of the copied elements or not
* \retval SMESH::SMESH_Mesh_ptr - the new mesh
*/
//================================================================================
SMESH::SMESH_Mesh_ptr SMESH_Gen_i::CopyMesh(SMESH::SMESH_IDSource_ptr meshPart,
const char* meshName,
CORBA::Boolean toCopyGroups,
CORBA::Boolean toKeepIDs)
{
Unexpect aCatch(SALOME_SalomeException);
TPythonDump* pyDump = new TPythonDump; // prevent dump from CreateMesh()
// 1. Get source mesh
if ( CORBA::is_nil( meshPart ))
THROW_SALOME_CORBA_EXCEPTION( "bad IDSource", SALOME::BAD_PARAM );
SMESH::SMESH_Mesh_var srcMesh = meshPart->GetMesh();
SMESH_Mesh_i* srcMesh_i = SMESH::DownCast<SMESH_Mesh_i*>( srcMesh );
if ( !srcMesh_i )
THROW_SALOME_CORBA_EXCEPTION( "bad mesh of IDSource", SALOME::BAD_PARAM );
SMESHDS_Mesh* srcMeshDS = srcMesh_i->GetImpl().GetMeshDS();
// 2. Make a new mesh
SMESH::SMESH_Mesh_var newMesh = CreateMesh(GEOM::GEOM_Object::_nil());
SMESH_Mesh_i* newMesh_i = SMESH::DownCast<SMESH_Mesh_i*>( newMesh );
if ( !newMesh_i )
THROW_SALOME_CORBA_EXCEPTION( "can't create a mesh", SALOME::INTERNAL_ERROR );
SALOMEDS::SObject_var meshSO = ObjectToSObject(myCurrentStudy, newMesh );
if ( !meshSO->_is_nil() )
{
SetName( meshSO, meshName, "Mesh" );
SetPixMap( meshSO, "ICON_SMESH_TREE_MESH_IMPORTED");
}
SMESHDS_Mesh* newMeshDS = newMesh_i->GetImpl().GetMeshDS();
::SMESH_MeshEditor editor( &newMesh_i->GetImpl() );
// 3. Get elements to copy
SMDS_ElemIteratorPtr srcElemIt;
TIDSortedElemSet srcElems;
SMESH::array_of_ElementType_var srcElemTypes = meshPart->GetTypes();
if ( SMESH::DownCast<SMESH_Mesh_i*>( meshPart ))
{
srcElemIt = srcMeshDS->elementsIterator();
}
else
{
SMESH::long_array_var ids = meshPart->GetIDs();
if ( srcElemTypes->length() == 1 && srcElemTypes[0] == SMESH::NODE ) // group of nodes
{
for (int i=0; i < ids->length(); i++)
if ( const SMDS_MeshElement * elem = srcMeshDS->FindNode( ids[i] ))
srcElems.insert( elem );
}
else
{
for (int i=0; i < ids->length(); i++)
if ( const SMDS_MeshElement * elem = srcMeshDS->FindElement( ids[i] ))
srcElems.insert( elem );
}
if ( srcElems.empty() )
return newMesh._retn();
typedef SMDS_SetIterator< SMDS_pElement, TIDSortedElemSet::const_iterator > ElIter;
srcElemIt = SMDS_ElemIteratorPtr( new ElIter( srcElems.begin(), srcElems.end() ));
}
// 4. Copy elements
typedef map<SMDS_pElement, SMDS_pElement, TIDCompare> TE2EMap;
TE2EMap e2eMapByType[ SMDSAbs_NbElementTypes ];
TE2EMap& n2nMap = e2eMapByType[ SMDSAbs_Node ];
int iN;
const SMDS_MeshNode *nSrc, *nTgt;
vector< const SMDS_MeshNode* > nodes;
while ( srcElemIt->more() )
{
const SMDS_MeshElement * elem = srcElemIt->next();
nodes.resize( elem->NbNodes());
SMDS_ElemIteratorPtr nIt = elem->nodesIterator();
if ( toKeepIDs ) {
for ( iN = 0; nIt->more(); ++iN )
{
nSrc = static_cast<const SMDS_MeshNode*>( nIt->next() );
nTgt = newMeshDS->FindNode( nSrc->GetID());
if ( !nTgt )
nTgt = newMeshDS->AddNodeWithID( nSrc->X(), nSrc->Y(), nSrc->Z(), nSrc->GetID());
nodes[ iN ] = nTgt;
}
}
else {
for ( iN = 0; nIt->more(); ++iN )
{
nSrc = static_cast<const SMDS_MeshNode*>( nIt->next() );
TE2EMap::iterator n2n = n2nMap.insert( make_pair( nSrc, SMDS_pNode(0) )).first;
if ( !n2n->second )
n2n->second = newMeshDS->AddNode( nSrc->X(), nSrc->Y(), nSrc->Z() );
nodes[ iN ] = (const SMDS_MeshNode*) n2n->second;
}
}
if ( elem->GetType() != SMDSAbs_Node )
{
int ID = toKeepIDs ? elem->GetID() : 0;
const SMDS_MeshElement * newElem = editor.AddElement( nodes,
elem->GetType(),
elem->IsPoly(),
ID);
if ( toCopyGroups && !toKeepIDs )
e2eMapByType[ elem->GetType() ].insert( make_pair( elem, newElem ));
}
}
// 5. Copy groups
int nbNewGroups = 0;
if ( toCopyGroups )
{
SMESH_Mesh::GroupIteratorPtr gIt = srcMesh_i->GetImpl().GetGroups();
while ( gIt->more() )
{
SMESH_Group* group = gIt->next();
const SMESHDS_GroupBase* groupDS = group->GetGroupDS();
// Check group type. We copy nodal groups containing nodes of copied element
SMDSAbs_ElementType groupType = groupDS->GetType();
if ( groupType != SMDSAbs_Node &&
newMeshDS->GetMeshInfo().NbElements( groupType ) == 0 )
continue; // group type differs from types of meshPart
// Find copied elements in the group
vector< const SMDS_MeshElement* > groupElems;
SMDS_ElemIteratorPtr eIt = groupDS->GetElements();
if ( toKeepIDs )
{
const SMDS_MeshElement* foundElem;
if ( groupType == SMDSAbs_Node )
{
while ( eIt->more() )
if (( foundElem = newMeshDS->FindNode( eIt->next()->GetID() )))
groupElems.push_back( foundElem );
}
else
{
while ( eIt->more() )
if (( foundElem = newMeshDS->FindElement( eIt->next()->GetID() )))
groupElems.push_back( foundElem );
}
}
else
{
TE2EMap & e2eMap = e2eMapByType[ groupDS->GetType() ];
if ( e2eMap.empty() ) continue;
int minID = e2eMap.begin()->first->GetID();
int maxID = e2eMap.rbegin()->first->GetID();
TE2EMap::iterator e2e;
while ( eIt->more() && groupElems.size() < e2eMap.size())
{
const SMDS_MeshElement* e = eIt->next();
if ( e->GetID() < minID || e->GetID() > maxID ) continue;
if ((e2e = e2eMap.find( e )) != e2eMap.end())
groupElems.push_back( e2e->second );
}
}
// Make a new group
if ( !groupElems.empty() )
{
SMESH::SMESH_Group_var newGroupObj =
newMesh->CreateGroup( SMESH::ElementType(groupType), group->GetName() );
if ( SMESH_GroupBase_i* newGroup_i = SMESH::DownCast<SMESH_GroupBase_i*>( newGroupObj))
{
SMESHDS_GroupBase * newGroupDS = newGroup_i->GetGroupDS();
SMDS_MeshGroup& smdsGroup = ((SMESHDS_Group*)newGroupDS)->SMDSGroup();
for ( unsigned i = 0; i < groupElems.size(); ++i )
smdsGroup.Add( groupElems[i] );
nbNewGroups++;
}
}
}
}
*pyDump << newMesh << " = " << this
<< ".CopyMesh( " << meshPart << ", "
<< "'" << meshName << "', "
<< toCopyGroups << ", "
<< toKeepIDs << ")";
delete pyDump; pyDump = 0; // allow dump in GetGroups()
if ( nbNewGroups > 0 ) // dump created groups
SMESH::ListOfGroups_var groups = newMesh->GetGroups();
return newMesh._retn();
}
//================================================================================ //================================================================================
/*! /*!
* SMESH_Gen_i::GetMEDVersion * SMESH_Gen_i::GetMEDVersion

View File

@ -236,6 +236,12 @@ public:
SMESH::SMESH_Mesh_ptr CreateMeshesFromSTL( const char* theFileName ) SMESH::SMESH_Mesh_ptr CreateMeshesFromSTL( const char* theFileName )
throw ( SALOME::SALOME_Exception ); throw ( SALOME::SALOME_Exception );
// Copy a part of mesh
SMESH::SMESH_Mesh_ptr CopyMesh(SMESH::SMESH_IDSource_ptr meshPart,
const char* meshName,
CORBA::Boolean toCopyGroups,
CORBA::Boolean toKeepIDs);
// Compute mesh on a shape // Compute mesh on a shape
CORBA::Boolean Compute( SMESH::SMESH_Mesh_ptr theMesh, CORBA::Boolean Compute( SMESH::SMESH_Mesh_ptr theMesh,
GEOM::GEOM_Object_ptr theShapeObject ) GEOM::GEOM_Object_ptr theShapeObject )

View File

@ -2685,6 +2685,8 @@ ExtrusionAlongPathObjX(SMESH::SMESH_IDSource_ptr Object,
SMESH::ElementType ElemType, SMESH::ElementType ElemType,
SMESH::SMESH_MeshEditor::Extrusion_Error& Error) SMESH::SMESH_MeshEditor::Extrusion_Error& Error)
{ {
TPythonDump aPythonDump; // it is here to prevent dump of GetGroups()
SMESH::long_array_var anElementsId = Object->GetIDs(); SMESH::long_array_var anElementsId = Object->GetIDs();
SMESH::ListOfGroups * aGroups = extrusionAlongPathX(anElementsId, SMESH::ListOfGroups * aGroups = extrusionAlongPathX(anElementsId,
Path, Path,
@ -2698,16 +2700,12 @@ ExtrusionAlongPathObjX(SMESH::SMESH_IDSource_ptr Object,
(SMDSAbs_ElementType)ElemType, (SMDSAbs_ElementType)ElemType,
Error); Error);
if ( !myPreviewMode ) { if (!myPreviewMode) {
bool isDumpGroups = aGroups && aGroups->length() > 0; bool isDumpGroups = aGroups && aGroups->length() > 0;
TPythonDump aPythonDump; if (isDumpGroups)
if(isDumpGroups) { aPythonDump << "(" << *aGroups << ", error)";
aPythonDump << "("<<aGroups;
}
if(isDumpGroups)
aPythonDump << ", error)";
else else
aPythonDump <<"error"; aPythonDump << "error";
aPythonDump << " = " << this << ".ExtrusionAlongPathObjX( " aPythonDump << " = " << this << ".ExtrusionAlongPathObjX( "
<< Object << ", " << Object << ", "
@ -2745,6 +2743,8 @@ ExtrusionAlongPathX(const SMESH::long_array& IDsOfElements,
SMESH::ElementType ElemType, SMESH::ElementType ElemType,
SMESH::SMESH_MeshEditor::Extrusion_Error& Error) SMESH::SMESH_MeshEditor::Extrusion_Error& Error)
{ {
TPythonDump aPythonDump; // it is here to prevent dump of GetGroups()
SMESH::ListOfGroups * aGroups = extrusionAlongPathX(IDsOfElements, SMESH::ListOfGroups * aGroups = extrusionAlongPathX(IDsOfElements,
Path, Path,
NodeStart, NodeStart,
@ -2757,14 +2757,10 @@ ExtrusionAlongPathX(const SMESH::long_array& IDsOfElements,
(SMDSAbs_ElementType)ElemType, (SMDSAbs_ElementType)ElemType,
Error); Error);
if ( !myPreviewMode ) { if (!myPreviewMode) {
bool isDumpGroups = aGroups && aGroups->length() > 0; bool isDumpGroups = aGroups && aGroups->length() > 0;
TPythonDump aPythonDump; if (isDumpGroups)
if(isDumpGroups) { aPythonDump << "(" << *aGroups << ", error)";
aPythonDump << "("<<aGroups;
}
if(isDumpGroups)
aPythonDump << ", error)";
else else
aPythonDump <<"error"; aPythonDump <<"error";
@ -2780,6 +2776,7 @@ ExtrusionAlongPathX(const SMESH::long_array& IDsOfElements,
<< ( HasRefPoint ? RefPoint.x : 0 ) << ", " << ( HasRefPoint ? RefPoint.x : 0 ) << ", "
<< ( HasRefPoint ? RefPoint.y : 0 ) << ", " << ( HasRefPoint ? RefPoint.y : 0 ) << ", "
<< ( HasRefPoint ? RefPoint.z : 0 ) << " ), " << ( HasRefPoint ? RefPoint.z : 0 ) << " ), "
<< MakeGroups << ", "
<< ElemType << " )"; << ElemType << " )";
} }
return aGroups; return aGroups;
@ -5353,7 +5350,7 @@ SMESH_MeshEditor_i::MakeBoundaryMesh(SMESH::SMESH_IDSource_ptr idSource,
SMESH_Group* smesh_group = 0; SMESH_Group* smesh_group = 0;
if ( strlen(groupName) ) if ( strlen(groupName) )
{ {
group_var = mesh_i->CreateGroup( SMESH::ElementType(elemType),groupName); group_var = mesh_i->CreateGroup( SMESH::ElementType(int(elemType)-1),groupName);
if ( SMESH_GroupBase_i* group_i = SMESH::DownCast<SMESH_GroupBase_i*>( group_var )) if ( SMESH_GroupBase_i* group_i = SMESH::DownCast<SMESH_GroupBase_i*>( group_var ))
smesh_group = group_i->GetSmeshGroup(); smesh_group = group_i->GetSmeshGroup();
} }
@ -5369,6 +5366,8 @@ SMESH_MeshEditor_i::MakeBoundaryMesh(SMESH::SMESH_IDSource_ptr idSource,
storeResult( aMeshEditor ); storeResult( aMeshEditor );
} }
const char* dimName[] = { "BND_2DFROM3D", "BND_1DFROM3D", "BND_1DFROM2D" };
// result of MakeBoundaryMesh() is a tuple (mesh, group) // result of MakeBoundaryMesh() is a tuple (mesh, group)
if ( mesh_var->_is_nil() ) if ( mesh_var->_is_nil() )
pyDump << myMesh_i->_this() << ", "; pyDump << myMesh_i->_this() << ", ";
@ -5380,9 +5379,9 @@ SMESH_MeshEditor_i::MakeBoundaryMesh(SMESH::SMESH_IDSource_ptr idSource,
pyDump << group_var << " = "; pyDump << group_var << " = ";
pyDump << this << ".MakeBoundaryMesh( " pyDump << this << ".MakeBoundaryMesh( "
<< idSource << ", " << idSource << ", "
<< dim << ", " << "SMESH." << dimName[int(dim)] << ", "
<< groupName << ", " << "'" << groupName << "', "
<< meshName<< ", " << "'" << meshName<< "', "
<< toCopyElements << ", " << toCopyElements << ", "
<< toCopyExistingBondary << ")"; << toCopyExistingBondary << ")";

View File

@ -76,17 +76,13 @@ f4 = MakePlane(sphere_centre, MakeVectorDXDYDZ( 1, 0, -1), plan_trim)
#sphere_decoupee = MakePartition(solids, sphere_outils, [], [], ShapeType["SOLID"]) #sphere_decoupee = MakePartition(solids, sphere_outils, [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(sphere_troue,geompy.ShapeType["SOLID"])
sphere_decoupee = MakePartition(solids, [f1], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(sphere_decoupee,geompy.ShapeType["SOLID"])
sphere_decoupee = MakePartition(solids, [f2], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(sphere_decoupee,geompy.ShapeType["SOLID"])
sphere_decoupee = MakePartition(solids, [f3], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(sphere_decoupee,geompy.ShapeType["SOLID"])
sphere_decoupee = MakePartition(solids, [f4], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(sphere_decoupee,geompy.ShapeType["SOLID"])
sphere_partie = geompy.MakeCompound(solids) sphere_decoupee = MakePartition([sphere_troue], [f1], [], [], ShapeType["SOLID"])
sphere_decoupee = MakePartition([sphere_decoupee], [f2], [], [], ShapeType["SOLID"])
sphere_decoupee = MakePartition([sphere_decoupee], [f3], [], [], ShapeType["SOLID"])
sphere_decoupee = MakePartition([sphere_decoupee], [f4], [], [], ShapeType["SOLID"])
sphere_partie = geompy.MakeCompound([sphere_decoupee])
sphere_partie = GetBlockNearPoint(sphere_decoupee, MakeVertex(-sphere_rayon, 0, 0)) sphere_partie = GetBlockNearPoint(sphere_decoupee, MakeVertex(-sphere_rayon, 0, 0))
sphere_bloc = RemoveExtraEdges(sphere_partie) sphere_bloc = RemoveExtraEdges(sphere_partie)
@ -113,17 +109,12 @@ cube_plein = MakeBox(-cube_cote, -cube_cote, -cube_cote, +cube_cote, +cube_co
cube_trou = MakeCut(cube_plein, sphere_pleine) cube_trou = MakeCut(cube_plein, sphere_pleine)
#cube_decoupe = MakePartition([cube_trou], sphere_outils, [], [], ShapeType["SOLID"]) #cube_decoupe = MakePartition([cube_trou], sphere_outils, [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(cube_trou,geompy.ShapeType["SOLID"]) cube_decoupe = MakePartition([cube_trou], [f1], [], [], ShapeType["SOLID"])
cube_decoupe = MakePartition(solids, [f1], [], [], ShapeType["SOLID"]) cube_decoupe = MakePartition([cube_decoupe], [f2], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(cube_decoupe,geompy.ShapeType["SOLID"]) cube_decoupe = MakePartition([cube_decoupe], [f3], [], [], ShapeType["SOLID"])
cube_decoupe = MakePartition(solids, [f2], [], [], ShapeType["SOLID"]) cube_decoupe = MakePartition([cube_decoupe], [f4], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(cube_decoupe,geompy.ShapeType["SOLID"])
cube_decoupe = MakePartition(solids, [f3], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(cube_decoupe,geompy.ShapeType["SOLID"])
cube_decoupe = MakePartition(solids, [f4], [], [], ShapeType["SOLID"])
solids = geompy.SubShapeAll(cube_decoupe,geompy.ShapeType["SOLID"])
cube_decoupe = geompy.MakeCompound(solids) cube_decoupe = geompy.MakeCompound([cube_decoupe])
cube_partie = GetBlockNearPoint(cube_decoupe, MakeVertex(-cube_cote, 0, 0)) cube_partie = GetBlockNearPoint(cube_decoupe, MakeVertex(-cube_cote, 0, 0))

View File

@ -17,11 +17,10 @@
# #
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
# #
# File : smesh.py # File : smesh.py
# Author : Francis KLOSS, OCC # Author : Francis KLOSS, OCC
# Module : SMESH # Module : SMESH
#
""" """
\namespace smesh \namespace smesh
\brief Module smesh \brief Module smesh
@ -570,7 +569,7 @@ class smeshDC(SMESH._objref_SMESH_Gen):
# @return SMESH.AxisStruct # @return SMESH.AxisStruct
# @ingroup l1_auxiliary # @ingroup l1_auxiliary
def GetAxisStruct(self,theObj): def GetAxisStruct(self,theObj):
edges = self.geompyD.SubShapeAll( theObj, geompyDC.ShapeType["EDGE"] ) edges = self.geompyD.ExtractShapes( theObj, geompyDC.ShapeType["EDGE"] )
if len(edges) > 1: if len(edges) > 1:
vertex1, vertex2 = self.geompyD.SubShapeAll( edges[0], geompyDC.ShapeType["VERTEX"] ) vertex1, vertex2 = self.geompyD.SubShapeAll( edges[0], geompyDC.ShapeType["VERTEX"] )
vertex3, vertex4 = self.geompyD.SubShapeAll( edges[1], geompyDC.ShapeType["VERTEX"] ) vertex3, vertex4 = self.geompyD.SubShapeAll( edges[1], geompyDC.ShapeType["VERTEX"] )
@ -663,27 +662,6 @@ class smeshDC(SMESH._objref_SMESH_Gen):
aMesh = Mesh(self, self.geompyD, aSmeshMesh) aMesh = Mesh(self, self.geompyD, aSmeshMesh)
return aMesh return aMesh
## From SMESH_Gen interface
# @return the list of integer values
# @ingroup l1_auxiliary
def GetSubShapesId( self, theMainObject, theListOfSubObjects ):
return SMESH._objref_SMESH_Gen.GetSubShapesId(self,theMainObject, theListOfSubObjects)
## From SMESH_Gen interface. Creates a pattern
# @return an instance of SMESH_Pattern
#
# <a href="../tui_modifying_meshes_page.html#tui_pattern_mapping">Example of Patterns usage</a>
# @ingroup l2_modif_patterns
def GetPattern(self):
return SMESH._objref_SMESH_Gen.GetPattern(self)
## Sets number of segments per diagonal of boundary box of geometry by which
# default segment length of appropriate 1D hypotheses is defined.
# Default value is 10
# @ingroup l1_auxiliary
def SetBoundaryBoxSegmentation(self, nbSegments):
SMESH._objref_SMESH_Gen.SetBoundaryBoxSegmentation(self,nbSegments)
## Concatenate the given meshes into one mesh. ## Concatenate the given meshes into one mesh.
# @return an instance of Mesh class # @return an instance of Mesh class
# @param meshes the meshes to combine into one mesh # @param meshes the meshes to combine into one mesh
@ -707,6 +685,41 @@ class smeshDC(SMESH._objref_SMESH_Gen):
aMesh = Mesh(self, self.geompyD, aSmeshMesh) aMesh = Mesh(self, self.geompyD, aSmeshMesh)
return aMesh return aMesh
## Create a mesh by copying a part of another mesh.
# @param meshPart a part of mesh to copy, either a Mesh, a sub-mesh or a group;
# to copy nodes or elements not contained in any mesh object,
# pass result of Mesh.GetIDSource( list_of_ids, type ) as meshPart
# @param meshName a name of the new mesh
# @param toCopyGroups to create in the new mesh groups the copied elements belongs to
# @param toKeepIDs to preserve IDs of the copied elements or not
# @return an instance of Mesh class
def CopyMesh( self, meshPart, meshName, toCopyGroups=False, toKeepIDs=False):
if (isinstance( meshPart, Mesh )):
meshPart = meshPart.GetMesh()
mesh = SMESH._objref_SMESH_Gen.CopyMesh( self,meshPart,meshName,toCopyGroups,toKeepIDs )
return Mesh(self, self.geompyD, mesh)
## From SMESH_Gen interface
# @return the list of integer values
# @ingroup l1_auxiliary
def GetSubShapesId( self, theMainObject, theListOfSubObjects ):
return SMESH._objref_SMESH_Gen.GetSubShapesId(self,theMainObject, theListOfSubObjects)
## From SMESH_Gen interface. Creates a pattern
# @return an instance of SMESH_Pattern
#
# <a href="../tui_modifying_meshes_page.html#tui_pattern_mapping">Example of Patterns usage</a>
# @ingroup l2_modif_patterns
def GetPattern(self):
return SMESH._objref_SMESH_Gen.GetPattern(self)
## Sets number of segments per diagonal of boundary box of geometry by which
# default segment length of appropriate 1D hypotheses is defined.
# Default value is 10
# @ingroup l1_auxiliary
def SetBoundaryBoxSegmentation(self, nbSegments):
SMESH._objref_SMESH_Gen.SetBoundaryBoxSegmentation(self,nbSegments)
# Filtering. Auxiliary functions: # Filtering. Auxiliary functions:
# ------------------------------ # ------------------------------
@ -735,6 +748,8 @@ class smeshDC(SMESH._objref_SMESH_Gen):
# @param UnaryOp FT_LogicalNOT or FT_Undefined # @param UnaryOp FT_LogicalNOT or FT_Undefined
# @param BinaryOp a binary logical operation FT_LogicalAND, FT_LogicalOR or # @param BinaryOp a binary logical operation FT_LogicalAND, FT_LogicalOR or
# FT_Undefined (must be for the last criterion of all criteria) # FT_Undefined (must be for the last criterion of all criteria)
# @param Tolerance the tolerance used by FT_BelongToGeom, FT_BelongToSurface,
# FT_LyingOnGeom, FT_CoplanarFaces criteria
# @return SMESH.Filter.Criterion # @return SMESH.Filter.Criterion
# @ingroup l1_controls # @ingroup l1_controls
def GetCriterion(self,elementType, def GetCriterion(self,elementType,
@ -742,10 +757,12 @@ class smeshDC(SMESH._objref_SMESH_Gen):
Compare = FT_EqualTo, Compare = FT_EqualTo,
Treshold="", Treshold="",
UnaryOp=FT_Undefined, UnaryOp=FT_Undefined,
BinaryOp=FT_Undefined): BinaryOp=FT_Undefined,
Tolerance=1e-07):
aCriterion = self.GetEmptyCriterion() aCriterion = self.GetEmptyCriterion()
aCriterion.TypeOfElement = elementType aCriterion.TypeOfElement = elementType
aCriterion.Type = self.EnumToLong(CritType) aCriterion.Type = self.EnumToLong(CritType)
aCriterion.Tolerance = Tolerance
aTreshold = Treshold aTreshold = Treshold
@ -810,7 +827,9 @@ class smeshDC(SMESH._objref_SMESH_Gen):
return None return None
pass pass
elif CritType in [FT_FreeBorders, FT_FreeEdges, FT_BadOrientedVolume, FT_FreeNodes, elif CritType in [FT_FreeBorders, FT_FreeEdges, FT_BadOrientedVolume, FT_FreeNodes,
FT_FreeFaces, FT_LinearOrQuadratic]: FT_FreeFaces, FT_LinearOrQuadratic,
FT_BareBorderFace, FT_BareBorderVolume,
FT_OverConstrainedFace, FT_OverConstrainedVolume]:
# At this point the treshold is unnecessary # At this point the treshold is unnecessary
if aTreshold == FT_LogicalNOT: if aTreshold == FT_LogicalNOT:
aCriterion.UnaryOp = self.EnumToLong(FT_LogicalNOT) aCriterion.UnaryOp = self.EnumToLong(FT_LogicalNOT)
@ -845,14 +864,17 @@ class smeshDC(SMESH._objref_SMESH_Gen):
# @param Compare belongs to {FT_LessThan, FT_MoreThan, FT_EqualTo} # @param Compare belongs to {FT_LessThan, FT_MoreThan, FT_EqualTo}
# @param Treshold the threshold value (range of id ids as string, shape, numeric) # @param Treshold the threshold value (range of id ids as string, shape, numeric)
# @param UnaryOp FT_LogicalNOT or FT_Undefined # @param UnaryOp FT_LogicalNOT or FT_Undefined
# @param Tolerance the tolerance used by FT_BelongToGeom, FT_BelongToSurface,
# FT_LyingOnGeom, FT_CoplanarFaces criteria
# @return SMESH_Filter # @return SMESH_Filter
# @ingroup l1_controls # @ingroup l1_controls
def GetFilter(self,elementType, def GetFilter(self,elementType,
CritType=FT_Undefined, CritType=FT_Undefined,
Compare=FT_EqualTo, Compare=FT_EqualTo,
Treshold="", Treshold="",
UnaryOp=FT_Undefined): UnaryOp=FT_Undefined,
aCriterion = self.GetCriterion(elementType, CritType, Compare, Treshold, UnaryOp, FT_Undefined) Tolerance=1e-07):
aCriterion = self.GetCriterion(elementType, CritType, Compare, Treshold, UnaryOp, FT_Undefined,Tolerance)
aFilterMgr = self.CreateFilterManager() aFilterMgr = self.CreateFilterManager()
aFilter = aFilterMgr.CreateFilter() aFilter = aFilterMgr.CreateFilter()
aCriteria = [] aCriteria = []
@ -1330,8 +1352,8 @@ class Mesh:
shape = geom shape = geom
if shape==0: if shape==0:
shape = self.geom shape = self.geom
nbSolids = len( self.geompyD.SubShapeAll( shape, geompyDC.ShapeType["SOLID"] )) nbSolids = len( self.geompyD.ExtractShapes( shape, geompyDC.ShapeType["SOLID"] ))
nbShells = len( self.geompyD.SubShapeAll( shape, geompyDC.ShapeType["SHELL"] )) nbShells = len( self.geompyD.ExtractShapes( shape, geompyDC.ShapeType["SHELL"] ))
if nbSolids == 0 or nbSolids == nbShells: if nbSolids == 0 or nbSolids == nbShells:
return Mesh_Prism3D(self, geom) return Mesh_Prism3D(self, geom)
return Mesh_RadialPrism3D(self, geom) return Mesh_RadialPrism3D(self, geom)
@ -1744,6 +1766,8 @@ class Mesh:
# @param Compare belongs to {FT_LessThan, FT_MoreThan, FT_EqualTo} # @param Compare belongs to {FT_LessThan, FT_MoreThan, FT_EqualTo}
# @param Treshold the threshold value (range of id ids as string, shape, numeric) # @param Treshold the threshold value (range of id ids as string, shape, numeric)
# @param UnaryOp FT_LogicalNOT or FT_Undefined # @param UnaryOp FT_LogicalNOT or FT_Undefined
# @param Tolerance the tolerance used by FT_BelongToGeom, FT_BelongToSurface,
# FT_LyingOnGeom, FT_CoplanarFaces criteria
# @return SMESH_Group # @return SMESH_Group
# @ingroup l2_grps_create # @ingroup l2_grps_create
def MakeGroup(self, def MakeGroup(self,
@ -1752,8 +1776,9 @@ class Mesh:
CritType=FT_Undefined, CritType=FT_Undefined,
Compare=FT_EqualTo, Compare=FT_EqualTo,
Treshold="", Treshold="",
UnaryOp=FT_Undefined): UnaryOp=FT_Undefined,
aCriterion = self.smeshpyD.GetCriterion(elementType, CritType, Compare, Treshold, UnaryOp, FT_Undefined) Tolerance=1e-07):
aCriterion = self.smeshpyD.GetCriterion(elementType, CritType, Compare, Treshold, UnaryOp, FT_Undefined,Tolerance)
group = self.MakeGroupByCriterion(groupName, aCriterion) group = self.MakeGroupByCriterion(groupName, aCriterion)
return group return group
@ -1969,6 +1994,13 @@ class Mesh:
def GetMeshEditor(self): def GetMeshEditor(self):
return self.mesh.GetMeshEditor() return self.mesh.GetMeshEditor()
## Wrap a list of IDs of elements or nodes into SMESH_IDSource which
# can be passed as argument to accepting mesh, group or sub-mesh
# @return an instance of SMESH_IDSource
# @ingroup l1_auxiliary
def GetIDSource(self, ids, elemType):
return self.GetMeshEditor().MakeIDSource(ids, elemType)
## Gets MED Mesh ## Gets MED Mesh
# @return an instance of SALOME_MED::MESH # @return an instance of SALOME_MED::MESH
# @ingroup l1_auxiliary # @ingroup l1_auxiliary
@ -3213,7 +3245,7 @@ class Mesh:
## Generates new elements by extrusion of the elements with given ids ## Generates new elements by extrusion of the elements with given ids
# @param IDsOfElements the list of elements ids for extrusion # @param IDsOfElements the list of elements ids for extrusion
# @param StepVector vector, defining the direction and value of extrusion # @param StepVector vector or DirStruct, defining the direction and value of extrusion
# @param NbOfSteps the number of steps # @param NbOfSteps the number of steps
# @param MakeGroups forces the generation of new groups from existing ones # @param MakeGroups forces the generation of new groups from existing ones
# @return the list of created groups (SMESH_GroupBase) if MakeGroups=True, empty list otherwise # @return the list of created groups (SMESH_GroupBase) if MakeGroups=True, empty list otherwise
@ -3347,7 +3379,10 @@ class Mesh:
Parameters = AnglesParameters + var_separator + RefPointParameters Parameters = AnglesParameters + var_separator + RefPointParameters
self.mesh.SetParameters(Parameters) self.mesh.SetParameters(Parameters)
if isinstance(Base,list): if (isinstance(Path, Mesh)):
Path = Path.GetMesh()
if isinstance(Base, list):
IDsOfElements = [] IDsOfElements = []
if Base == []: IDsOfElements = self.GetElementsId() if Base == []: IDsOfElements = self.GetElementsId()
else: IDsOfElements = Base else: IDsOfElements = Base
@ -3355,7 +3390,8 @@ class Mesh:
HasAngles, Angles, LinearVariation, HasAngles, Angles, LinearVariation,
HasRefPoint, RefPoint, MakeGroups, ElemType) HasRefPoint, RefPoint, MakeGroups, ElemType)
else: else:
if isinstance(Base,Mesh): if isinstance(Base, Mesh): Base = Base.GetMesh()
if isinstance(Base, SMESH._objref_SMESH_Mesh) or isinstance(Base, SMESH._objref_SMESH_Group) or isinstance(Base, SMESH._objref_SMESH_subMesh):
return self.editor.ExtrusionAlongPathObjX(Base, Path, NodeStart, return self.editor.ExtrusionAlongPathObjX(Base, Path, NodeStart,
HasAngles, Angles, LinearVariation, HasAngles, Angles, LinearVariation,
HasRefPoint, RefPoint, MakeGroups, ElemType) HasRefPoint, RefPoint, MakeGroups, ElemType)
@ -3700,7 +3736,7 @@ class Mesh:
if ( isinstance( theObject, Mesh )): if ( isinstance( theObject, Mesh )):
theObject = theObject.GetMesh() theObject = theObject.GetMesh()
if ( isinstance( theObject, list )): if ( isinstance( theObject, list )):
theObject = self.editor.MakeIDSource(theObject, SMESH.ALL) theObject = self.GetIDSource(theObject, SMESH.ALL)
thePoint, Parameters = ParsePointStruct(thePoint) thePoint, Parameters = ParsePointStruct(thePoint)
self.mesh.SetParameters(Parameters) self.mesh.SetParameters(Parameters)
@ -3721,7 +3757,7 @@ class Mesh:
if (isinstance(theObject, Mesh)): if (isinstance(theObject, Mesh)):
theObject = theObject.GetMesh() theObject = theObject.GetMesh()
if ( isinstance( theObject, list )): if ( isinstance( theObject, list )):
theObject = self.editor.MakeIDSource(theObject,SMESH.ALL) theObject = self.GetIDSource(theObject,SMESH.ALL)
mesh = self.editor.ScaleMakeMesh(theObject, thePoint, theScaleFact, mesh = self.editor.ScaleMakeMesh(theObject, thePoint, theScaleFact,
MakeGroups, NewMeshName) MakeGroups, NewMeshName)
@ -3855,7 +3891,7 @@ class Mesh:
if not isinstance( exceptNodes, list): if not isinstance( exceptNodes, list):
exceptNodes = [ exceptNodes ] exceptNodes = [ exceptNodes ]
if exceptNodes and isinstance( exceptNodes[0], int): if exceptNodes and isinstance( exceptNodes[0], int):
exceptNodes = [ self.editor.MakeIDSource( exceptNodes, SMESH.NODE)] exceptNodes = [ self.GetIDSource( exceptNodes, SMESH.NODE)]
return self.editor.FindCoincidentNodesOnPartBut(SubMeshOrGroup, Tolerance,exceptNodes) return self.editor.FindCoincidentNodesOnPartBut(SubMeshOrGroup, Tolerance,exceptNodes)
## Merges nodes ## Merges nodes
@ -4340,8 +4376,11 @@ class Mesh_Algorithm:
pass pass
self.mesh.smeshpyD.SetName(hypo, hyp + a) self.mesh.smeshpyD.SetName(hypo, hyp + a)
pass pass
geomName=""
if self.geom:
geomName = GetName(self.geom)
status = self.mesh.mesh.AddHypothesis(self.geom, hypo) status = self.mesh.mesh.AddHypothesis(self.geom, hypo)
TreatHypoStatus( status, GetName(hypo), GetName(self.geom), 0 ) TreatHypoStatus( status, GetName(hypo), geomName, 0 )
return hypo return hypo
## Returns entry of the shape to mesh in the study ## Returns entry of the shape to mesh in the study
@ -4625,7 +4664,7 @@ class Mesh_Segment(Mesh_Algorithm):
store_geom = self.geom store_geom = self.geom
if type(vertex) is types.IntType: if type(vertex) is types.IntType:
if vertex == 0 or vertex == 1: if vertex == 0 or vertex == 1:
vertex = self.mesh.geompyD.SubShapeAllSorted(self.geom, geompyDC.ShapeType["VERTEX"])[vertex] vertex = self.mesh.geompyD.ExtractShapes(self.geom, geompyDC.ShapeType["VERTEX"],True)[vertex]
self.geom = vertex self.geom = vertex
pass pass
pass pass
@ -4884,20 +4923,31 @@ class Mesh_Triangle(Mesh_Algorithm):
self.Parameters().SetOptionValue(optionName,level) self.Parameters().SetOptionValue(optionName,level)
## Sets QuadAllowed flag. ## Sets QuadAllowed flag.
# Only for algoType == NETGEN || NETGEN_2D || BLSURF # Only for algoType == NETGEN(NETGEN_1D2D) || NETGEN_2D || BLSURF
# @ingroup l3_hypos_netgen l3_hypos_blsurf # @ingroup l3_hypos_netgen l3_hypos_blsurf
def SetQuadAllowed(self, toAllow=True): def SetQuadAllowed(self, toAllow=True):
if self.algoType == NETGEN_2D: if self.algoType == NETGEN_2D:
if toAllow: # add QuadranglePreference if not self.params:
self.Hypothesis("QuadranglePreference", UseExisting=1, CompareMethod=self.CompareEqualHyp) # use simple hyps
else: # remove QuadranglePreference hasSimpleHyps = False
simpleHyps = ["QuadranglePreference","LengthFromEdges","MaxElementArea"]
for hyp in self.mesh.GetHypothesisList( self.geom ): for hyp in self.mesh.GetHypothesisList( self.geom ):
if hyp.GetName() in simpleHyps:
hasSimpleHyps = True
if hyp.GetName() == "QuadranglePreference": if hyp.GetName() == "QuadranglePreference":
if not toAllow: # remove QuadranglePreference
self.mesh.RemoveHypothesis( self.geom, hyp ) self.mesh.RemoveHypothesis( self.geom, hyp )
pass pass
return
pass pass
pass pass
if hasSimpleHyps:
if toAllow: # add QuadranglePreference
self.Hypothesis("QuadranglePreference", UseExisting=1, CompareMethod=self.CompareEqualHyp)
pass
return return
pass
pass
if self.Parameters(): if self.Parameters():
self.params.SetQuadAllowed(toAllow) self.params.SetQuadAllowed(toAllow)
return return
@ -4906,8 +4956,7 @@ class Mesh_Triangle(Mesh_Algorithm):
# #
# @ingroup l3_hypos_netgen # @ingroup l3_hypos_netgen
def Parameters(self, which=SOLE): def Parameters(self, which=SOLE):
if self.params: if not self.params:
return self.params
if self.algoType == NETGEN: if self.algoType == NETGEN:
if which == SIMPLE: if which == SIMPLE:
self.params = self.Hypothesis("NETGEN_SimpleParameters_2D", [], self.params = self.Hypothesis("NETGEN_SimpleParameters_2D", [],
@ -4915,21 +4964,17 @@ class Mesh_Triangle(Mesh_Algorithm):
else: else:
self.params = self.Hypothesis("NETGEN_Parameters_2D", [], self.params = self.Hypothesis("NETGEN_Parameters_2D", [],
"libNETGENEngine.so", UseExisting=0) "libNETGENEngine.so", UseExisting=0)
return self.params
elif self.algoType == MEFISTO: elif self.algoType == MEFISTO:
print "Mefisto algo support no multi-parameter hypothesis" print "Mefisto algo support no multi-parameter hypothesis"
return None
elif self.algoType == NETGEN_2D: elif self.algoType == NETGEN_2D:
print "NETGEN_2D_ONLY algo support no multi-parameter hypothesis" self.params = self.Hypothesis("NETGEN_Parameters_2D_ONLY", [],
print "NETGEN_2D_ONLY uses 'MaxElementArea' and 'LengthFromEdges' ones" "libNETGENEngine.so", UseExisting=0)
return None
elif self.algoType == BLSURF: elif self.algoType == BLSURF:
self.params = self.Hypothesis("BLSURF_Parameters", [], self.params = self.Hypothesis("BLSURF_Parameters", [],
"libBLSURFEngine.so", UseExisting=0) "libBLSURFEngine.so", UseExisting=0)
return self.params
else: else:
print "Mesh_Triangle with algo type %s does not have such a parameter, check algo type"%self.algoType print "Mesh_Triangle with algo type %s does not have such a parameter, check algo type"%self.algoType
return None return self.params
## Sets MaxSize ## Sets MaxSize
# #
@ -5166,8 +5211,7 @@ class Mesh_Tetrahedron(Mesh_Algorithm):
# #
# @ingroup l3_hypos_netgen # @ingroup l3_hypos_netgen
def Parameters(self, which=SOLE): def Parameters(self, which=SOLE):
if self.params: if not self.params:
return self.params
if self.algoType == FULL_NETGEN: if self.algoType == FULL_NETGEN:
if which == SIMPLE: if which == SIMPLE:
@ -5176,23 +5220,25 @@ class Mesh_Tetrahedron(Mesh_Algorithm):
else: else:
self.params = self.Hypothesis("NETGEN_Parameters", [], self.params = self.Hypothesis("NETGEN_Parameters", [],
"libNETGENEngine.so", UseExisting=0) "libNETGENEngine.so", UseExisting=0)
return self.params
if self.algoType == GHS3D: if self.algoType == NETGEN:
self.params = self.Hypothesis("NETGEN_Parameters_3D", [],
"libNETGENEngine.so", UseExisting=0)
elif self.algoType == GHS3D:
self.params = self.Hypothesis("GHS3D_Parameters", [], self.params = self.Hypothesis("GHS3D_Parameters", [],
"libGHS3DEngine.so", UseExisting=0) "libGHS3DEngine.so", UseExisting=0)
return self.params
if self.algoType == GHS3DPRL: elif self.algoType == GHS3DPRL:
self.params = self.Hypothesis("GHS3DPRL_Parameters", [], self.params = self.Hypothesis("GHS3DPRL_Parameters", [],
"libGHS3DPRLEngine.so", UseExisting=0) "libGHS3DPRLEngine.so", UseExisting=0)
else:
print "Algo supports no multi-parameter hypothesis"
return self.params return self.params
print "Algo supports no multi-parameter hypothesis"
return None
## Sets MaxSize ## Sets MaxSize
# Parameter of FULL_NETGEN # Parameter of FULL_NETGEN and NETGEN
# @ingroup l3_hypos_netgen # @ingroup l3_hypos_netgen
def SetMaxSize(self, theSize): def SetMaxSize(self, theSize):
self.Parameters().SetMaxSize(theSize) self.Parameters().SetMaxSize(theSize)
@ -5204,7 +5250,7 @@ class Mesh_Tetrahedron(Mesh_Algorithm):
self.Parameters().SetSecondOrder(theVal) self.Parameters().SetSecondOrder(theVal)
## Sets Optimize flag ## Sets Optimize flag
# Parameter of FULL_NETGEN # Parameter of FULL_NETGEN and NETGEN
# @ingroup l3_hypos_netgen # @ingroup l3_hypos_netgen
def SetOptimize(self, theVal): def SetOptimize(self, theVal):
self.Parameters().SetOptimize(theVal) self.Parameters().SetOptimize(theVal)

View File

@ -120,6 +120,7 @@ namespace // INTERNAL STUFF
enum _ListenerDataType enum _ListenerDataType
{ {
WAIT_HYP_MODIF=1, // data indicating awaiting for valid parameters of src hyp WAIT_HYP_MODIF=1, // data indicating awaiting for valid parameters of src hyp
LISTEN_SRC_MESH, // data storing submesh depending on source mesh state
SRC_HYP // data storing ImportSource hyp SRC_HYP // data storing ImportSource hyp
}; };
//================================================================================ //================================================================================
@ -130,10 +131,29 @@ namespace // INTERNAL STUFF
struct _ListenerData : public SMESH_subMeshEventListenerData struct _ListenerData : public SMESH_subMeshEventListenerData
{ {
const StdMeshers_ImportSource1D* _srcHyp; const StdMeshers_ImportSource1D* _srcHyp;
_ListenerData(const StdMeshers_ImportSource1D* h): _ListenerData(const StdMeshers_ImportSource1D* h, _ListenerDataType type=SRC_HYP):
SMESH_subMeshEventListenerData(/*isDeletable=*/true), _srcHyp(h) SMESH_subMeshEventListenerData(/*isDeletable=*/true), _srcHyp(h)
{ {
myType = SRC_HYP; myType = type;
}
};
//================================================================================
/*!
* \brief Comparator of sub-meshes
*/
struct _SubLess
{
bool operator()(const SMESH_subMesh* sm1, const SMESH_subMesh* sm2 ) const
{
if ( sm1 == sm2 ) return false;
if ( !sm1 || !sm2 ) return sm1 < sm2;
const TopoDS_Shape& s1 = sm1->GetSubShape();
const TopoDS_Shape& s2 = sm2->GetSubShape();
TopAbs_ShapeEnum t1 = s1.IsNull() ? TopAbs_SHAPE : s1.ShapeType();
TopAbs_ShapeEnum t2 = s2.IsNull() ? TopAbs_SHAPE : s2.ShapeType();
if ( t1 == t2)
return (sm1 < sm2);
return t1 < t2; // to have: face < edge
} }
}; };
//================================================================================ //================================================================================
@ -146,10 +166,10 @@ namespace // INTERNAL STUFF
StdMeshers_Import_1D::TNodeNodeMap _n2n; StdMeshers_Import_1D::TNodeNodeMap _n2n;
StdMeshers_Import_1D::TElemElemMap _e2e; StdMeshers_Import_1D::TElemElemMap _e2e;
set< SMESH_subMesh*> _subM; // submeshes relating to this srcMesh set< SMESH_subMesh*, _SubLess > _subM; // submeshes relating to this srcMesh
set< SMESH_subMesh*> _copyMeshSubM; // submeshes requesting mesh copying set< SMESH_subMesh*, _SubLess > _copyMeshSubM; // submeshes requesting mesh copying
set< SMESH_subMesh*> _copyGroupSubM; // submeshes requesting mesh copying set< SMESH_subMesh*, _SubLess > _copyGroupSubM; // submeshes requesting mesh copying
set< SMESH_subMesh*> _computedSubM; set< SMESH_subMesh*, _SubLess > _computedSubM;
SMESHDS_SubMesh* _importMeshSubDS; // submesh storing a copy of _srcMesh SMESHDS_SubMesh* _importMeshSubDS; // submesh storing a copy of _srcMesh
int _importMeshSubID; // id of _importMeshSubDS int _importMeshSubID; // id of _importMeshSubDS
@ -196,10 +216,30 @@ namespace // INTERNAL STUFF
if ( toCopyGroups ) _copyGroupSubM.insert( sm ); if ( toCopyGroups ) _copyGroupSubM.insert( sm );
else _copyGroupSubM.erase( sm ); else _copyGroupSubM.erase( sm );
} }
void addComputed( SMESH_subMesh* sm )
{
SMESH_subMeshIteratorPtr smIt = sm->getDependsOnIterator(/*includeSelf=*/true,
/*complexShapeFirst=*/true);
while ( smIt->more() )
{
sm = smIt->next();
switch ( sm->GetSubShape().ShapeType() )
{
case TopAbs_EDGE:
case TopAbs_FACE:
_subM.insert( sm );
if ( !sm->IsEmpty() )
_computedSubM.insert( sm );
case TopAbs_VERTEX:
break;
default:;
}
}
}
}; };
//================================================================================ //================================================================================
/*! /*!
* Listener notified on events of an imported submesh * Listener notified on events relating to imported submesh
*/ */
class _Listener : public SMESH_subMeshEventListener class _Listener : public SMESH_subMeshEventListener
{ {
@ -212,11 +252,32 @@ namespace // INTERNAL STUFF
// return poiter to a static listener // return poiter to a static listener
static _Listener* get() { static _Listener theListener; return &theListener; } static _Listener* get() { static _Listener theListener; return &theListener; }
static _ImportData* getImportData(const SMESH_Mesh* srcMesh, SMESH_Mesh* tgtMesh);
static void storeImportSubmesh(SMESH_subMesh* importSub,
const SMESH_Mesh* srcMesh,
const StdMeshers_ImportSource1D* srcHyp);
virtual void ProcessEvent(const int event,
const int eventType,
SMESH_subMesh* subMesh,
SMESH_subMeshEventListenerData* data,
const SMESH_Hypothesis* hyp);
void removeSubmesh( SMESH_subMesh* sm, _ListenerData* data );
void clearSubmesh ( SMESH_subMesh* sm, _ListenerData* data, bool clearAllSub );
// mark sm as missing src hyp with valid groups
static void waitHypModification(SMESH_subMesh* sm)
{
sm->SetEventListener
(get(), SMESH_subMeshEventListenerData::MakeData( sm, WAIT_HYP_MODIF ), sm);
}
};
//-------------------------------------------------------------------------------- //--------------------------------------------------------------------------------
/*! /*!
* \brief Find or create ImportData for given meshes * \brief Find or create ImportData for given meshes
*/ */
static _ImportData* getImportData(const SMESH_Mesh* srcMesh, _ImportData* _Listener::getImportData(const SMESH_Mesh* srcMesh,
SMESH_Mesh* tgtMesh) SMESH_Mesh* tgtMesh)
{ {
list< _ImportData >& dList = get()->_tgtMesh2ImportData[tgtMesh]; list< _ImportData >& dList = get()->_tgtMesh2ImportData[tgtMesh];
@ -230,13 +291,12 @@ namespace // INTERNAL STUFF
//-------------------------------------------------------------------------------- //--------------------------------------------------------------------------------
/*! /*!
* \brief Remember an imported mesh and groups * \brief Remember an imported sub-mesh and set needed even listeners
* \param smDS - submesh DS holding the imported mesh * \param importSub - submesh computed by Import algo
* \param sm - submesh computed by Import algo * \param srcMesh - source mesh
* \param srcMeshDS - source mesh
* \param srcHyp - ImportSource hypothesis * \param srcHyp - ImportSource hypothesis
*/ */
static _ImportData* storeImportSubmesh(SMESH_subMesh* importSub, void _Listener::storeImportSubmesh(SMESH_subMesh* importSub,
const SMESH_Mesh* srcMesh, const SMESH_Mesh* srcMesh,
const StdMeshers_ImportSource1D* srcHyp) const StdMeshers_ImportSource1D* srcHyp)
{ {
@ -246,46 +306,28 @@ namespace // INTERNAL STUFF
// set a listener to hear events of the source mesh // set a listener to hear events of the source mesh
SMESH_subMesh* smToNotify = importSub; SMESH_subMesh* smToNotify = importSub;
SMESH_subMesh* smToListen = srcMesh->GetSubMeshContaining(1); SMESH_subMesh* smToListen = srcMesh->GetSubMeshContaining(1);
importSub->SetEventListener SMESH_subMeshEventListenerData* data = new _ListenerData(srcHyp, LISTEN_SRC_MESH);
( new SMESH_subMeshEventListener(/*isDeletable=*/true), data->mySubMeshes.push_back( smToNotify );
SMESH_subMeshEventListenerData::MakeData( smToNotify ), importSub->SetEventListener( get(), data, smToListen );
smToListen );
// remeber the submesh // remeber the submesh importSub and its sub-submeshes
_ImportData* iData = _Listener::getImportData( srcMesh, importSub->GetFather()); _ImportData* iData = _Listener::getImportData( srcMesh, importSub->GetFather());
iData->_subM.insert( importSub );
iData->trackHypParams( importSub, srcHyp ); iData->trackHypParams( importSub, srcHyp );
if ( !importSub->IsEmpty() ) iData->addComputed( importSub );
iData->_computedSubM.insert( importSub );
if ( !iData->_copyMeshSubM.empty() && iData->_importMeshSubID < 1 ) if ( !iData->_copyMeshSubM.empty() && iData->_importMeshSubID < 1 )
{ {
SMESH_Mesh* tgtMesh = importSub->GetFather(); SMESH_Mesh* tgtMesh = importSub->GetFather();
iData->_importMeshSubID = getSubmeshIDForCopiedMesh( srcMesh->GetMeshDS(),tgtMesh); iData->_importMeshSubID = getSubmeshIDForCopiedMesh( srcMesh->GetMeshDS(),tgtMesh);
iData->_importMeshSubDS = tgtMesh->GetMeshDS()->NewSubMesh( iData->_importMeshSubID ); iData->_importMeshSubDS = tgtMesh->GetMeshDS()->NewSubMesh( iData->_importMeshSubID );
} }
if ( !importSub->IsEmpty() )
iData->_computedSubM.insert( importSub );
return iData;
} }
//-------------------------------------------------------------------------------- //--------------------------------------------------------------------------------
/*! /*!
* \brief mark sm as missing src hyp with valid groups * \brief Remove imported mesh and/or groups if needed
*/
static void waitHypModification(SMESH_subMesh* sm)
{
sm->SetEventListener
(get(), SMESH_subMeshEventListenerData::MakeData( sm, WAIT_HYP_MODIF ), sm);
}
//--------------------------------------------------------------------------------
/*!
* \brief Remove imported mesh and/or groups as soon as no more imported submeshes
* remain computed
* \param sm - submesh loosing Import algo * \param sm - submesh loosing Import algo
* \param data - data holding imported groups * \param data - data holding imported groups
*/ */
void removeSubmesh( SMESH_subMesh* sm, _ListenerData* data ) void _Listener::removeSubmesh( SMESH_subMesh* sm, _ListenerData* data )
{ {
list< _ImportData > & dList = _tgtMesh2ImportData[ sm->GetFather() ]; list< _ImportData > & dList = _tgtMesh2ImportData[ sm->GetFather() ];
list< _ImportData >::iterator d = dList.begin(); list< _ImportData >::iterator d = dList.begin();
@ -303,12 +345,11 @@ namespace // INTERNAL STUFF
} }
//-------------------------------------------------------------------------------- //--------------------------------------------------------------------------------
/*! /*!
* \brief Remove imported mesh and/or groups and * \brief Clear submeshes and remove imported mesh and/or groups if necessary
* clear all submeshes with common source mesh
* \param sm - cleared submesh * \param sm - cleared submesh
* \param data - data holding imported groups * \param data - data holding imported groups
*/ */
void clearSubmesh( SMESH_subMesh* sm, _ListenerData* data ) void _Listener::clearSubmesh(SMESH_subMesh* sm, _ListenerData* data, bool clearAllSub)
{ {
list< _ImportData > & dList = _tgtMesh2ImportData[ sm->GetFather() ]; list< _ImportData > & dList = _tgtMesh2ImportData[ sm->GetFather() ];
list< _ImportData >::iterator d = dList.begin(); list< _ImportData >::iterator d = dList.begin();
@ -318,12 +359,18 @@ namespace // INTERNAL STUFF
if ( (*d)._computedSubM.erase( sm ) ) if ( (*d)._computedSubM.erase( sm ) )
{ {
bool copyMesh = !d->_copyMeshSubM.empty(); bool copyMesh = !d->_copyMeshSubM.empty();
if ( copyMesh ) if ( copyMesh || clearAllSub )
{ {
// clear submeshes // remove imported mesh and groups
d->removeImportedMesh( sm->GetFather()->GetMeshDS() );
if ( data )
d->removeGroups( sm, data->_srcHyp );
// clear the rest submeshes
if ( !d->_computedSubM.empty() ) if ( !d->_computedSubM.empty() )
{ {
set< SMESH_subMesh*> subs; set< SMESH_subMesh*, _SubLess> subs;
subs.swap( d->_computedSubM ); // avoid recursion via events subs.swap( d->_computedSubM ); // avoid recursion via events
while ( !subs.empty() ) while ( !subs.empty() )
{ {
@ -333,14 +380,14 @@ namespace // INTERNAL STUFF
d->removeGroups( sm, hypData->_srcHyp ); d->removeGroups( sm, hypData->_srcHyp );
subM->ComputeStateEngine( SMESH_subMesh::CLEAN ); subM->ComputeStateEngine( SMESH_subMesh::CLEAN );
if ( subM->GetSubShape().ShapeType() == TopAbs_FACE )
subM->ComputeSubMeshStateEngine( SMESH_subMesh::CLEAN );
} }
} }
// remove imported mesh and groups
d->removeImportedMesh( sm->GetFather()->GetMeshDS() );
if ( data )
d->removeGroups( sm, data->_srcHyp );
} }
sm->ComputeStateEngine( SMESH_subMesh::CLEAN );
if ( sm->GetSubShape().ShapeType() == TopAbs_FACE )
sm->ComputeSubMeshStateEngine( SMESH_subMesh::CLEAN );
} }
if ( data ) if ( data )
d->trackHypParams( sm, data->_srcHyp ); d->trackHypParams( sm, data->_srcHyp );
@ -352,7 +399,7 @@ namespace // INTERNAL STUFF
/*! /*!
* \brief Remove imported mesh and/or groups * \brief Remove imported mesh and/or groups
*/ */
virtual void ProcessEvent(const int event, void _Listener::ProcessEvent(const int event,
const int eventType, const int eventType,
SMESH_subMesh* subMesh, SMESH_subMesh* subMesh,
SMESH_subMeshEventListenerData* data, SMESH_subMeshEventListenerData* data,
@ -360,29 +407,73 @@ namespace // INTERNAL STUFF
{ {
if ( data && data->myType == WAIT_HYP_MODIF ) if ( data && data->myType == WAIT_HYP_MODIF )
{ {
// event of Import submesh
if ( SMESH_subMesh::MODIF_HYP == event && if ( SMESH_subMesh::MODIF_HYP == event &&
SMESH_subMesh::ALGO_EVENT == eventType ) SMESH_subMesh::ALGO_EVENT == eventType )
{ {
// re-call SetEventListener() to take into account valid parameters
// of ImportSource hypothesis
SMESH_Gen* gen = subMesh->GetFather()->GetGen(); SMESH_Gen* gen = subMesh->GetFather()->GetGen();
if ( SMESH_Algo* algo = gen->GetAlgo(*subMesh->GetFather(), subMesh->GetSubShape())) if ( SMESH_Algo* algo = gen->GetAlgo(*subMesh->GetFather(), subMesh->GetSubShape()))
algo->SetEventListener( subMesh ); algo->SetEventListener( subMesh );
} }
} }
else else if ( data && data->myType == LISTEN_SRC_MESH )
{
// event of source mesh
if ( SMESH_subMesh::COMPUTE_EVENT == eventType )
{
switch ( event ) {
case SMESH_subMesh::CLEAN:
// source mesh cleaned -> clean target mesh
clearSubmesh( data->mySubMeshes.front(), (_ListenerData*) data, /*all=*/true );
break;
case SMESH_subMesh::SUBMESH_COMPUTED: {
// source mesh computed -> reset FAILED state of Import submeshes to
// READY_TO_COMPUTE
SMESH_Mesh* srcMesh = subMesh->GetFather();
if ( srcMesh->NbEdges() > 0 || srcMesh->NbFaces() > 0 )
{
SMESH_Mesh* m = data->mySubMeshes.front()->GetFather();
if ( SMESH_subMesh* sm1 = m->GetSubMeshContaining(1))
{
sm1->ComputeStateEngine(SMESH_subMesh::SUBMESH_COMPUTED );
sm1->ComputeSubMeshStateEngine( SMESH_subMesh::SUBMESH_COMPUTED );
}
}
break;
}
default:;
}
}
}
else // event of Import submesh
{
// find out what happens: import hyp modified or removed
bool removeImport = false, modifHyp = false;
if ( SMESH_subMesh::ALGO_EVENT == eventType )
modifHyp = true;
if ( subMesh->GetAlgoState() != SMESH_subMesh::HYP_OK )
{
removeImport = true;
}
else if ( SMESH_subMesh::REMOVE_ALGO == event ||
SMESH_subMesh::REMOVE_FATHER_ALGO == event )
{ {
SMESH_Gen* gen = subMesh->GetFather()->GetGen(); SMESH_Gen* gen = subMesh->GetFather()->GetGen();
SMESH_Algo* algo = gen->GetAlgo(*subMesh->GetFather(),subMesh->GetSubShape() ); SMESH_Algo* algo = gen->GetAlgo(*subMesh->GetFather(),subMesh->GetSubShape() );
removeImport = ( strncmp( "Import", algo->GetName(), 6 ) != 0 );
}
if ( subMesh->GetAlgoState() != SMESH_subMesh::HYP_OK || if ( removeImport )
strncmp( "Import", algo->GetName(), 6 ) != 0 )
{ {
// treate removal of Import algo from subMesh // treate removal of Import algo from subMesh
removeSubmesh( subMesh, (_ListenerData*) data ); removeSubmesh( subMesh, (_ListenerData*) data );
} }
else if ( subMesh->IsEmpty() ) else if ( modifHyp )
{ {
// treate modification of ImportSource hypothesis // treate modification of ImportSource hypothesis
clearSubmesh( subMesh, (_ListenerData*) data ); clearSubmesh( subMesh, (_ListenerData*) data, /*all=*/false );
} }
else if ( SMESH_subMesh::CHECK_COMPUTE_STATE == event && else if ( SMESH_subMesh::CHECK_COMPUTE_STATE == event &&
SMESH_subMesh::COMPUTE_EVENT == eventType ) SMESH_subMesh::COMPUTE_EVENT == eventType )
@ -403,7 +494,6 @@ namespace // INTERNAL STUFF
} }
} }
} }
}; // class _Listener
//================================================================================ //================================================================================
/*! /*!
@ -495,7 +585,7 @@ namespace // INTERNAL STUFF
_ImportData* iData = _Listener::getImportData(srcMesh,tgtMesh); _ImportData* iData = _Listener::getImportData(srcMesh,tgtMesh);
SMESH_subMesh* importedSM = tgtMesh->GetSubMesh( tgtShape ); SMESH_subMesh* importedSM = tgtMesh->GetSubMesh( tgtShape );
iData->_computedSubM.insert( importedSM ); iData->addComputed( importedSM );
if ( iData->_computedSubM.size() != iData->_subM.size() ) if ( iData->_computedSubM.size() != iData->_subM.size() )
return 0; // not all submeshes computed yet return 0; // not all submeshes computed yet

View File

@ -153,8 +153,8 @@ bool StdMeshers_Import_1D2D::Compute(SMESH_Mesh & theMesh, const TopoDS_Shape &
const bool toCheckOri = (helper.NbAncestors( geomFace, theMesh, TopAbs_SOLID ) == 1 ); const bool toCheckOri = (helper.NbAncestors( geomFace, theMesh, TopAbs_SOLID ) == 1 );
Handle(Geom_Surface) surface = BRep_Tool::Surface( geomFace ); Handle(Geom_Surface) surface = BRep_Tool::Surface( geomFace );
if ( helper.GetSubShapeOri( tgtMesh->ShapeToMesh(), geomFace) == TopAbs_REVERSED ) const bool reverse =
surface->UReverse(); ( helper.GetSubShapeOri( tgtMesh->ShapeToMesh(), geomFace) == TopAbs_REVERSED );
gp_Pnt p; gp_Vec du, dv; gp_Pnt p; gp_Vec du, dv;
set<int> subShapeIDs; set<int> subShapeIDs;
@ -262,7 +262,7 @@ bool StdMeshers_Import_1D2D::Compute(SMESH_Mesh & theMesh, const TopoDS_Shape &
{ {
uv = helper.GetNodeUV( geomFace, newNodes[++iNode] ); uv = helper.GetNodeUV( geomFace, newNodes[++iNode] );
surface->D1( uv.X(),uv.Y(), p, du,dv ); surface->D1( uv.X(),uv.Y(), p, du,dv );
geomNorm = du ^ dv; geomNorm = reverse ? dv^du : du^dv;
} }
while ( geomNorm.SquareMagnitude() < 1e-6 && iNode+1 < face->NbCornerNodes()); while ( geomNorm.SquareMagnitude() < 1e-6 && iNode+1 < face->NbCornerNodes());
@ -341,7 +341,7 @@ bool StdMeshers_Import_1D2D::Compute(SMESH_Mesh & theMesh, const TopoDS_Shape &
int nbFaces = link2Nb->second; int nbFaces = link2Nb->second;
if ( nbFaces == 1 ) if ( nbFaces == 1 )
{ {
// check if the link lie on face boundary // check if a not shared link lie on face boundary
bool nodesOnBoundary = true; bool nodesOnBoundary = true;
list< TopoDS_Shape > bndShapes; list< TopoDS_Shape > bndShapes;
for ( int is1stN = 0; is1stN < 2 && nodesOnBoundary; ++is1stN ) for ( int is1stN = 0; is1stN < 2 && nodesOnBoundary; ++is1stN )
@ -356,6 +356,7 @@ bool StdMeshers_Import_1D2D::Compute(SMESH_Mesh & theMesh, const TopoDS_Shape &
if ( Abs(u-f) < 2 * faceTol || Abs(u-l) < 2 * faceTol ) if ( Abs(u-f) < 2 * faceTol || Abs(u-l) < 2 * faceTol )
// duplicated node on vertex // duplicated node on vertex
return error("Source elements overlap one another"); return error("Source elements overlap one another");
tgtSM->RemoveNode( n, /*isNodeDeleted=*/false );
tgtMesh->SetNodeOnEdge( (SMDS_MeshNode*)n, edges[iE], u ); tgtMesh->SetNodeOnEdge( (SMDS_MeshNode*)n, edges[iE], u );
break; break;
} }
@ -371,10 +372,10 @@ bool StdMeshers_Import_1D2D::Compute(SMESH_Mesh & theMesh, const TopoDS_Shape &
} }
} }
if ( !nodesOnBoundary ) if ( !nodesOnBoundary )
break; // free internal link break; // error: free internal link
if ( bndShapes.front().ShapeType() == TopAbs_EDGE && if ( bndShapes.front().ShapeType() == TopAbs_EDGE &&
bndShapes.front() != bndShapes.back() ) bndShapes.front() != bndShapes.back() )
break; // link nodes on different geom edges break; // error: link nodes on different geom edges
// find geom edge the link is on // find geom edge the link is on
if ( bndShapes.back().ShapeType() != TopAbs_EDGE ) if ( bndShapes.back().ShapeType() != TopAbs_EDGE )
@ -389,7 +390,7 @@ bool StdMeshers_Import_1D2D::Compute(SMESH_Mesh & theMesh, const TopoDS_Shape &
geomEdge.Nullify(); geomEdge.Nullify();
} }
if ( geomEdge.IsNull() ) if ( geomEdge.IsNull() )
break; // vertices belong to different edges -> free internal link break; // vertices belong to different edges -> error: free internal link
bndShapes.push_back( geomEdge ); bndShapes.push_back( geomEdge );
} }
@ -407,15 +408,13 @@ bool StdMeshers_Import_1D2D::Compute(SMESH_Mesh & theMesh, const TopoDS_Shape &
TopoDS_Edge geomEdge = TopoDS::Edge(bndShapes.back()); TopoDS_Edge geomEdge = TopoDS::Edge(bndShapes.back());
helper.CheckNodeU( geomEdge, link._medium, u, 10*faceTol, /*force=*/true ); helper.CheckNodeU( geomEdge, link._medium, u, 10*faceTol, /*force=*/true );
tgtSM->RemoveNode( link._medium, /*isNodeDeleted=*/false );
tgtMesh->SetNodeOnEdge( (SMDS_MeshNode*)link._medium, geomEdge, u ); tgtMesh->SetNodeOnEdge( (SMDS_MeshNode*)link._medium, geomEdge, u );
} }
else else
{ {
edge = tgtMesh->AddEdge( newNodes[0], newNodes[1]); edge = tgtMesh->AddEdge( newNodes[0], newNodes[1]);
} }
// remove nodes from submesh of theShape
for ( unsigned i = 0; i < newNodes.size(); ++i )
tgtSM->RemoveNode( newNodes[i], /*isNodeDeleted=*/false );
if ( !edge ) if ( !edge )
return false; return false;

View File

@ -1082,6 +1082,7 @@ bool StdMeshers_ProjectionUtils::FindSubShapeAssociation(const TopoDS_Shape& the
TopTools_IndexedMapOfShape vMap1, vMap2; TopTools_IndexedMapOfShape vMap1, vMap2;
TopExp::MapShapes( theShape1, TopAbs_VERTEX, vMap1 ); TopExp::MapShapes( theShape1, TopAbs_VERTEX, vMap1 );
TopExp::MapShapes( theShape2, TopAbs_VERTEX, vMap2 ); TopExp::MapShapes( theShape2, TopAbs_VERTEX, vMap2 );
TopoDS_Vertex VV1[2], VV2[2];
if ( vMap1.Extent() != vMap2.Extent() ) if ( vMap1.Extent() != vMap2.Extent() )
RETURN_BAD_RESULT("Different nb of vertices"); RETURN_BAD_RESULT("Different nb of vertices");
@ -1095,6 +1096,32 @@ bool StdMeshers_ProjectionUtils::FindSubShapeAssociation(const TopoDS_Shape& the
return FindSubShapeAssociation( theShape1, theMesh1, theShape2, theMesh2, theMap); return FindSubShapeAssociation( theShape1, theMesh1, theShape2, theMesh2, theMap);
} }
// Try to associate by common vertices of an edge
for ( int i = 1; i <= vMap1.Extent(); ++i )
{
const TopoDS_Shape& v1 = vMap1(i);
if ( vMap2.Contains( v1 ))
{
// find an egde sharing v1 and sharing at the same time another common vertex
PShapeIteratorPtr edgeIt = SMESH_MesherHelper::GetAncestors( v1, *theMesh1, TopAbs_EDGE);
bool edgeFound = false;
while ( edgeIt->more() && !edgeFound )
{
TopoDS_Edge edge = TopoDS::Edge( edgeIt->next()->Oriented(TopAbs_FORWARD));
TopExp::Vertices(edge, VV1[0], VV1[1]);
if ( !VV1[0].IsSame( VV1[1] ))
edgeFound = ( vMap2.Contains( VV1[ v1.IsSame(VV1[0]) ? 1:0]));
}
if ( edgeFound )
{
InsertAssociation( VV1[0], VV1[0], theMap, bidirect );
InsertAssociation( VV1[1], VV1[1], theMap, bidirect );
if (FindSubShapeAssociation( theShape1, theMesh1, theShape2, theMesh2, theMap ))
return true;
}
}
}
// Find transformation to make the shapes be of similar size at same location // Find transformation to make the shapes be of similar size at same location
Bnd_Box box[2]; Bnd_Box box[2];
@ -1116,7 +1143,6 @@ bool StdMeshers_ProjectionUtils::FindSubShapeAssociation(const TopoDS_Shape& the
// Find 2 closest vertices // Find 2 closest vertices
TopoDS_Vertex VV1[2], VV2[2];
// get 2 linked vertices of shape 1 not belonging to an inner wire of a face // get 2 linked vertices of shape 1 not belonging to an inner wire of a face
TopoDS_Shape edge = theShape1; TopoDS_Shape edge = theShape1;
TopExp_Explorer expF( theShape1, TopAbs_FACE ), expE; TopExp_Explorer expF( theShape1, TopAbs_FACE ), expE;

View File

@ -82,10 +82,10 @@ namespace
SMESH_MeshEditor::TNodeXYZ Pj( Nrem ); SMESH_MeshEditor::TNodeXYZ Pj( Nrem );
// an apex node to make common to all merged pyramids // an apex node to make common to all merged pyramids
if (PrmI->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
SMDS_MeshNode* CommonNode = const_cast<SMDS_MeshNode*>(PrmI->GetNode(4)); SMDS_MeshNode* CommonNode = const_cast<SMDS_MeshNode*>(PrmI->GetNode(4));
if ( CommonNode == Nrem ) return; // already merged if ( CommonNode == Nrem ) return; // already merged
int nbI = CommonNode->NbInverseElements( SMDSAbs_Volume ); int nbI = CommonNode->NbInverseElements( SMDSAbs_Volume );
//cerr << __LINE__ << " " << nbI << " " << nbJ << endl;
SMESH_MeshEditor::TNodeXYZ Pi( CommonNode ); SMESH_MeshEditor::TNodeXYZ Pi( CommonNode );
gp_XYZ Pnew = ( nbI*Pi + nbJ*Pj ) / (nbI+nbJ); gp_XYZ Pnew = ( nbI*Pi + nbJ*Pj ) / (nbI+nbJ);
CommonNode->setXYZ( Pnew.X(), Pnew.Y(), Pnew.Z() ); CommonNode->setXYZ( Pnew.X(), Pnew.Y(), Pnew.Z() );
@ -116,7 +116,6 @@ namespace
} }
// set the common apex node to pyramids and triangles merged with J // set the common apex node to pyramids and triangles merged with J
//cerr << __LINE__ << " NbInverseElements " << Nrem->NbInverseElements() << endl;
SMDS_ElemIteratorPtr itJ = Nrem->GetInverseElementIterator(); SMDS_ElemIteratorPtr itJ = Nrem->GetInverseElementIterator();
while ( itJ->more() ) while ( itJ->more() )
{ {
@ -124,22 +123,15 @@ namespace
if ( elem->GetType() == SMDSAbs_Volume ) // pyramid if ( elem->GetType() == SMDSAbs_Volume ) // pyramid
{ {
vector< const SMDS_MeshNode* > nodes( elem->begin_nodes(), elem->end_nodes() ); vector< const SMDS_MeshNode* > nodes( elem->begin_nodes(), elem->end_nodes() );
//cerr << __LINE__ << " volId " << elem->GetID() << " nbNodes " << nodes.size() << endl;
nodes[4] = CommonNode; nodes[4] = CommonNode;
MESSAGE("ChangeElementNodes"); MESSAGE("ChangeElementNodes");
meshDS->ChangeElementNodes( elem, &nodes[0], nodes.size()); meshDS->ChangeElementNodes( elem, &nodes[0], nodes.size());
} }
else if ( tempTrias.count(elem) ) // tmp triangles else if ( tempTrias.count(elem) ) // tmp triangles
{ {
//cerr << __LINE__ << " triaId " << elem->GetID() << endl;
((SMDS_VtkFace*) elem )->ChangeApex( CommonNode ); ((SMDS_VtkFace*) elem )->ChangeApex( CommonNode );
} }
// else
// {
// cerr << __LINE__ << " other " << elem->GetVtkType() << endl;
// }
} }
//cerr << __LINE__ << " NbInverseElements " << Nrem->NbInverseElements() << endl;
ASSERT( Nrem->NbInverseElements() == 0 ); ASSERT( Nrem->NbInverseElements() == 0 );
meshDS->RemoveFreeNode( Nrem, meshDS->RemoveFreeNode( Nrem,
meshDS->MeshElements( Nrem->getshapeId()), meshDS->MeshElements( Nrem->getshapeId()),
@ -157,6 +149,8 @@ namespace
const SMDS_MeshElement* PrmJ, const SMDS_MeshElement* PrmJ,
const bool hasShape) const bool hasShape)
{ {
if (PrmI->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
if (PrmJ->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
const SMDS_MeshNode* nApexI = PrmI->GetNode(4); const SMDS_MeshNode* nApexI = PrmI->GetNode(4);
const SMDS_MeshNode* nApexJ = PrmJ->GetNode(4); const SMDS_MeshNode* nApexJ = PrmJ->GetNode(4);
if ( nApexI == nApexJ || if ( nApexI == nApexJ ||
@ -264,6 +258,7 @@ namespace
TRemTrias & tempTrias, TRemTrias & tempTrias,
set<const SMDS_MeshNode*>& nodesToMove) set<const SMDS_MeshNode*>& nodesToMove)
{ {
if (PrmI->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
TIDSortedElemSet adjacentPyrams, mergedPyrams; TIDSortedElemSet adjacentPyrams, mergedPyrams;
for(int k=0; k<4; k++) // loop on 4 base nodes of PrmI for(int k=0; k<4; k++) // loop on 4 base nodes of PrmI
{ {
@ -302,6 +297,8 @@ namespace
StdMeshers_QuadToTriaAdaptor::StdMeshers_QuadToTriaAdaptor(): StdMeshers_QuadToTriaAdaptor::StdMeshers_QuadToTriaAdaptor():
myElemSearcher(0), myNbTriangles(0) myElemSearcher(0), myNbTriangles(0)
{ {
myResMap.clear();
myTempTriangles.clear();
} }
//================================================================================ //================================================================================
@ -1003,6 +1000,7 @@ bool StdMeshers_QuadToTriaAdaptor::Compute2ndPart(SMESH_Mesh& aMesh)
return true; return true;
SMESHDS_Mesh * meshDS = aMesh.GetMeshDS(); SMESHDS_Mesh * meshDS = aMesh.GetMeshDS();
if (myPyramids[0]->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
int i, j, k, myShapeID = myPyramids[0]->GetNode(4)->getshapeId(); int i, j, k, myShapeID = myPyramids[0]->GetNode(4)->getshapeId();
if ( !myElemSearcher ) if ( !myElemSearcher )
@ -1016,6 +1014,7 @@ bool StdMeshers_QuadToTriaAdaptor::Compute2ndPart(SMESH_Mesh& aMesh)
for ( i = 0; i < myPyramids.size(); ++i ) for ( i = 0; i < myPyramids.size(); ++i )
{ {
const SMDS_MeshElement* PrmI = myPyramids[i]; const SMDS_MeshElement* PrmI = myPyramids[i];
if (PrmI->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
MergeAdjacent( PrmI, aMesh, myTempTriangles, nodesToMove ); MergeAdjacent( PrmI, aMesh, myTempTriangles, nodesToMove );
} }
@ -1023,6 +1022,7 @@ bool StdMeshers_QuadToTriaAdaptor::Compute2ndPart(SMESH_Mesh& aMesh)
for ( i = 0; i < myPyramids.size(); ++i ) for ( i = 0; i < myPyramids.size(); ++i )
{ {
const SMDS_MeshElement* PrmI = myPyramids[i]; const SMDS_MeshElement* PrmI = myPyramids[i];
if (PrmI->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
// compare PrmI with all the rest pyramids // compare PrmI with all the rest pyramids
@ -1051,6 +1051,7 @@ bool StdMeshers_QuadToTriaAdaptor::Compute2ndPart(SMESH_Mesh& aMesh)
for ( j = 0; j < suspectPyrams.size(); ++j ) for ( j = 0; j < suspectPyrams.size(); ++j )
{ {
const SMDS_MeshElement* PrmJ = suspectPyrams[j]; const SMDS_MeshElement* PrmJ = suspectPyrams[j];
//if (PrmJ->GetVtkType() != VTK_PYRAMID) throw SALOME_Exception(LOCALIZED("not a pyramid"));
if ( PrmJ == PrmI || PrmJ->NbCornerNodes() != 5 ) if ( PrmJ == PrmI || PrmJ->NbCornerNodes() != 5 )
continue; continue;
if ( myShapeID != PrmJ->GetNode(4)->getshapeId()) if ( myShapeID != PrmJ->GetNode(4)->getshapeId())
@ -1135,12 +1136,12 @@ bool StdMeshers_QuadToTriaAdaptor::Compute2ndPart(SMESH_Mesh& aMesh)
} // loop on all pyramids } // loop on all pyramids
if( !nodesToMove.empty() && !meshDS->IsEmbeddedMode() ) // if( !nodesToMove.empty() && !meshDS->IsEmbeddedMode() )
{ // {
set<const SMDS_MeshNode*>::iterator n = nodesToMove.begin(); // set<const SMDS_MeshNode*>::iterator n = nodesToMove.begin();
for ( ; n != nodesToMove.end(); ++n ) // for ( ; n != nodesToMove.end(); ++n )
meshDS->MoveNode( *n, (*n)->X(), (*n)->Y(), (*n)->Z() ); // meshDS->MoveNode( *n, (*n)->X(), (*n)->Y(), (*n)->Z() );
} // }
// rebind triangles of pyramids sharing the same base quadrangle to the first // rebind triangles of pyramids sharing the same base quadrangle to the first
// entrance of the base quadrangle // entrance of the base quadrangle
@ -1148,31 +1149,30 @@ bool StdMeshers_QuadToTriaAdaptor::Compute2ndPart(SMESH_Mesh& aMesh)
for ( ++q2t; q2t != myResMap.end(); ++q2t, ++q2tPrev ) for ( ++q2t; q2t != myResMap.end(); ++q2t, ++q2tPrev )
{ {
if ( q2t->first == q2tPrev->first ) if ( q2t->first == q2tPrev->first )
{
//cerr << __LINE__ << " splice" << endl;
q2tPrev->second.splice( q2tPrev->second.end(), q2t->second ); q2tPrev->second.splice( q2tPrev->second.end(), q2t->second );
} }
}
// delete removed triangles and count resulting nb of triangles // delete removed triangles and count resulting nb of triangles
for (q2t = myResMap.begin(); q2t != myResMap.end(); ++q2t) for (q2t = myResMap.begin(); q2t != myResMap.end(); ++q2t)
{ {
TTriaList & trias = q2t->second; TTriaList & trias = q2t->second;
vector<const SMDS_MeshFace*> faceToErase; set<const SMDS_MeshFace*> faceToErase;
faceToErase.clear(); faceToErase.clear();
//cerr << __LINE__ << " " << trias.size() << endl;
for (TTriaList::iterator tri = trias.begin(); tri != trias.end(); ++tri) for (TTriaList::iterator tri = trias.begin(); tri != trias.end(); ++tri)
{ {
//cerr << " " << __LINE__ << endl;
const SMDS_MeshFace* face = *tri; const SMDS_MeshFace* face = *tri;
if (myTempTriangles.count(face) && (myTempTriangles[face] == false)) if (myTempTriangles.count(face) && (myTempTriangles[face] == false))
faceToErase.push_back(face); faceToErase.insert(face);
else else
myNbTriangles++; myNbTriangles++;
} }
for (vector<const SMDS_MeshFace*>::iterator it = faceToErase.begin(); it != faceToErase.end(); ++it) for (set<const SMDS_MeshFace*>::iterator it = faceToErase.begin(); it != faceToErase.end(); ++it)
{ {
const SMDS_MeshFace *face = dynamic_cast<const SMDS_MeshFace*>(*it); const SMDS_MeshFace *face = dynamic_cast<const SMDS_MeshFace*>(*it);
if (face) trias.remove(face); if (face)
{
trias.remove(face);
myTempTriangles.erase(face);
}
meshDS->RemoveFreeElement(face, 0, false); meshDS->RemoveFreeElement(face, 0, false);
} }
} }