mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-12 17:50:35 +05:00
0021746: EDF 2135 GEOM: Unification of Python documentations
This commit is contained in:
parent
05a2e86bac
commit
8e102c8ec4
@ -111,10 +111,8 @@ ENDIF()
|
|||||||
IF(SALOME_BUILD_DOC)
|
IF(SALOME_BUILD_DOC)
|
||||||
FIND_PACKAGE(SalomeDoxygen)
|
FIND_PACKAGE(SalomeDoxygen)
|
||||||
FIND_PACKAGE(SalomeGraphviz)
|
FIND_PACKAGE(SalomeGraphviz)
|
||||||
FIND_PACKAGE(SalomeSphinx)
|
|
||||||
SALOME_LOG_OPTIONAL_PACKAGE(Doxygen SALOME_BUILD_DOC)
|
SALOME_LOG_OPTIONAL_PACKAGE(Doxygen SALOME_BUILD_DOC)
|
||||||
SALOME_LOG_OPTIONAL_PACKAGE(Graphviz SALOME_BUILD_DOC)
|
SALOME_LOG_OPTIONAL_PACKAGE(Graphviz SALOME_BUILD_DOC)
|
||||||
SALOME_LOG_OPTIONAL_PACKAGE(Sphinx SALOME_BUILD_DOC)
|
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
# Find GUI (optional)
|
# Find GUI (optional)
|
||||||
|
@ -21,4 +21,3 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
ADD_SUBDIRECTORY(salome)
|
ADD_SUBDIRECTORY(salome)
|
||||||
ADD_SUBDIRECTORY(docutils)
|
|
||||||
|
@ -1,35 +0,0 @@
|
|||||||
# Copyright (C) 2012-2014 CEA/DEN, EDF R&D, OPEN CASCADE
|
|
||||||
#
|
|
||||||
# This library is free software; you can redistribute it and/or
|
|
||||||
# modify it under the terms of the GNU Lesser General Public
|
|
||||||
# License as published by the Free Software Foundation; either
|
|
||||||
# version 2.1 of the License, or (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This library is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
# Lesser General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU Lesser General Public
|
|
||||||
# License along with this library; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
#
|
|
||||||
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
|
||||||
#
|
|
||||||
|
|
||||||
SALOME_CONFIGURE_FILE(conf.py.in conf.py)
|
|
||||||
|
|
||||||
SET(_cmd_options -c ${CMAKE_CURRENT_BINARY_DIR} -b html -d doctrees -D latex_paper_size=a4 ${CMAKE_CURRENT_SOURCE_DIR} docutils)
|
|
||||||
|
|
||||||
# This macro mainly prepares the environment in which sphinx should run:
|
|
||||||
# this sets the PYTHONPATH and LD_LIBRARY_PATH to include OMNIORB, DOCUTILS, SETUPTOOLS, etc ...
|
|
||||||
SALOME_GENERATE_ENVIRONMENT_SCRIPT(_cmd env_script "${SPHINX_EXECUTABLE}" "${_cmd_options}")
|
|
||||||
|
|
||||||
ADD_CUSTOM_TARGET(html_docs COMMAND ${_cmd})
|
|
||||||
|
|
||||||
INSTALL(CODE "EXECUTE_PROCESS(COMMAND \"${CMAKE_COMMAND}\" --build ${PROJECT_BINARY_DIR} --target html_docs)")
|
|
||||||
INSTALL(DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/docutils DESTINATION ${SALOME_INSTALL_DOC}/tui/GEOM)
|
|
||||||
INSTALL(FILES ${PROJECT_SOURCE_DIR}/doc/salome/tui/images/head.png DESTINATION ${SALOME_INSTALL_DOC}/tui/GEOM)
|
|
||||||
|
|
||||||
SET(make_clean_files docutils doctrees)
|
|
||||||
SET_DIRECTORY_PROPERTIES(PROPERTIES ADDITIONAL_MAKE_CLEAN_FILES "${make_clean_files}")
|
|
@ -1,200 +0,0 @@
|
|||||||
# -*- coding: iso-8859-1 -*-
|
|
||||||
#
|
|
||||||
# yacs documentation build configuration file, created by
|
|
||||||
# sphinx-quickstart on Fri Aug 29 09:57:25 2008.
|
|
||||||
#
|
|
||||||
# This file is execfile()d with the current directory set to its containing dir.
|
|
||||||
#
|
|
||||||
# The contents of this file are pickled, so don't put values in the namespace
|
|
||||||
# that aren't pickleable (module imports are okay, they're removed automatically).
|
|
||||||
#
|
|
||||||
# All configuration values have a default; values that are commented out
|
|
||||||
# serve to show the default.
|
|
||||||
|
|
||||||
import sys, os
|
|
||||||
|
|
||||||
# If your extensions are in another directory, add it here. If the directory
|
|
||||||
# is relative to the documentation root, use os.path.abspath to make it
|
|
||||||
# absolute, like shown here.
|
|
||||||
#sys.path.append(os.path.abspath('.'))
|
|
||||||
|
|
||||||
# General configuration
|
|
||||||
# ---------------------
|
|
||||||
|
|
||||||
# Add any Sphinx extension module names here, as strings. They can be extensions
|
|
||||||
# coming with Sphinx (named 'sphinx.ext.*') or your custom ones.
|
|
||||||
extensions = ['sphinx.ext.autodoc']
|
|
||||||
|
|
||||||
# Uncomment the following line to build the links with Python documentation
|
|
||||||
# (you might need to set http_proxy environment variable for this to work)
|
|
||||||
#extensions += ['sphinx.ext.intersphinx']
|
|
||||||
|
|
||||||
# Intersphinx mapping to add links to modules and objects in the Python
|
|
||||||
# standard library documentation
|
|
||||||
intersphinx_mapping = {'http://docs.python.org': None}
|
|
||||||
|
|
||||||
# Add any paths that contain templates here, relative to this directory.
|
|
||||||
templates_path = ['_templates']
|
|
||||||
|
|
||||||
# The suffix of source filenames.
|
|
||||||
source_suffix = '.rst'
|
|
||||||
|
|
||||||
# The encoding of source files.
|
|
||||||
source_encoding = 'utf-8'
|
|
||||||
|
|
||||||
# The master toctree document.
|
|
||||||
master_doc = 'index'
|
|
||||||
|
|
||||||
# General information about the project.
|
|
||||||
project = 'GEOM python packages'
|
|
||||||
copyright = '2010-2014 EDF R&D'
|
|
||||||
|
|
||||||
# The version info for the project you're documenting, acts as replacement for
|
|
||||||
# |version| and |release|, also used in various other places throughout the
|
|
||||||
# built documents.
|
|
||||||
#
|
|
||||||
# The short X.Y version.
|
|
||||||
version = '@SALOMEGEOM_VERSION@'
|
|
||||||
# The full version, including alpha/beta/rc tags.
|
|
||||||
release = '@SALOMEGEOM_VERSION@'
|
|
||||||
|
|
||||||
# The language for content autogenerated by Sphinx. Refer to documentation
|
|
||||||
# for a list of supported languages.
|
|
||||||
language = 'en'
|
|
||||||
|
|
||||||
# There are two options for replacing |today|: either, you set today to some
|
|
||||||
# non-false value, then it is used:
|
|
||||||
#today = ''
|
|
||||||
# Else, today_fmt is used as the format for a strftime call.
|
|
||||||
#today_fmt = '%B %d, %Y'
|
|
||||||
|
|
||||||
# List of documents that shouldn't be included in the build.
|
|
||||||
#unused_docs = []
|
|
||||||
|
|
||||||
# List of directories, relative to source directory, that shouldn't be searched
|
|
||||||
# for source files.
|
|
||||||
exclude_trees = ['.build','ref','images','CVS','.svn']
|
|
||||||
|
|
||||||
# The reST default role (used for this markup: `text`) to use for all documents.
|
|
||||||
#default_role = None
|
|
||||||
|
|
||||||
# If true, '()' will be appended to :func: etc. cross-reference text.
|
|
||||||
#add_function_parentheses = True
|
|
||||||
|
|
||||||
# If true, the current module name will be prepended to all description
|
|
||||||
# unit titles (such as .. function::).
|
|
||||||
#add_module_names = True
|
|
||||||
|
|
||||||
# If true, sectionauthor and moduleauthor directives will be shown in the
|
|
||||||
# output. They are ignored by default.
|
|
||||||
#show_authors = False
|
|
||||||
|
|
||||||
# The name of the Pygments (syntax highlighting) style to use.
|
|
||||||
pygments_style = 'sphinx'
|
|
||||||
|
|
||||||
|
|
||||||
# Options for HTML output
|
|
||||||
# -----------------------
|
|
||||||
|
|
||||||
# The theme to use for HTML and HTML Help pages. Major themes that come with
|
|
||||||
# Sphinx are currently 'default' and 'sphinxdoc'.
|
|
||||||
html_theme = 'default'
|
|
||||||
#html_theme = 'nature'
|
|
||||||
#html_theme = 'agogo'
|
|
||||||
#html_theme = 'sphinxdoc'
|
|
||||||
#html_theme = 'omadoc'
|
|
||||||
|
|
||||||
# Add any paths that contain custom themes here, relative to this directory.
|
|
||||||
#html_theme_path = ['themes']
|
|
||||||
|
|
||||||
# The name for this set of Sphinx documents. If None, it defaults to
|
|
||||||
# "<project> v<release> documentation".
|
|
||||||
#html_title = None
|
|
||||||
|
|
||||||
# A shorter title for the navigation bar. Default is the same as html_title.
|
|
||||||
#html_short_title = None
|
|
||||||
|
|
||||||
# The name of an image file (relative to this directory) to place at the top
|
|
||||||
# of the sidebar.
|
|
||||||
#html_logo = None
|
|
||||||
|
|
||||||
# The name of an image file (within the static path) to use as favicon of the
|
|
||||||
# docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32
|
|
||||||
# pixels large.
|
|
||||||
#html_favicon = None
|
|
||||||
|
|
||||||
# Add any paths that contain custom static files (such as style sheets) here,
|
|
||||||
# relative to this directory. They are copied after the builtin static files,
|
|
||||||
# so a file named "default.css" will overwrite the builtin "default.css".
|
|
||||||
#html_static_path = ['_static']
|
|
||||||
|
|
||||||
# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,
|
|
||||||
# using the given strftime format.
|
|
||||||
#html_last_updated_fmt = '%b %d, %Y'
|
|
||||||
|
|
||||||
# If true, SmartyPants will be used to convert quotes and dashes to
|
|
||||||
# typographically correct entities.
|
|
||||||
#html_use_smartypants = True
|
|
||||||
|
|
||||||
# Custom sidebar templates, maps document names to template names.
|
|
||||||
#html_sidebars = {}
|
|
||||||
|
|
||||||
# Additional templates that should be rendered to pages, maps page names to
|
|
||||||
# template names.
|
|
||||||
#html_additional_pages = {}
|
|
||||||
|
|
||||||
# If false, no module index is generated.
|
|
||||||
html_use_modindex = False
|
|
||||||
|
|
||||||
# If false, no index is generated.
|
|
||||||
#html_use_index = True
|
|
||||||
|
|
||||||
# If true, the index is split into individual pages for each letter.
|
|
||||||
#html_split_index = False
|
|
||||||
|
|
||||||
# If true, the reST sources are included in the HTML build as _sources/<name>.
|
|
||||||
html_copy_source = True
|
|
||||||
|
|
||||||
# If true, an OpenSearch description file will be output, and all pages will
|
|
||||||
# contain a <link> tag referring to it. The value of this option must be the
|
|
||||||
# base URL from which the finished HTML is served.
|
|
||||||
#html_use_opensearch = ''
|
|
||||||
|
|
||||||
# If nonempty, this is the file name suffix for HTML files (e.g. ".xhtml").
|
|
||||||
#html_file_suffix = ''
|
|
||||||
|
|
||||||
# Output file base name for HTML help builder.
|
|
||||||
htmlhelp_basename = 'geompydoc'
|
|
||||||
|
|
||||||
|
|
||||||
# Options for LaTeX output
|
|
||||||
# ------------------------
|
|
||||||
|
|
||||||
# The paper size ('letter' or 'a4').
|
|
||||||
latex_paper_size = 'a4'
|
|
||||||
|
|
||||||
# The font size ('10pt', '11pt' or '12pt').
|
|
||||||
latex_font_size = '10pt'
|
|
||||||
|
|
||||||
# Grouping the document tree into LaTeX files. List of tuples
|
|
||||||
# (source start file, target name, title, author, document class [howto/manual]).
|
|
||||||
latex_documents = [
|
|
||||||
('index', 'geompy.tex', 'Documentation of the GEOM python packages', 'EDF R\&D', 'manual')
|
|
||||||
]
|
|
||||||
|
|
||||||
# The name of an image file (relative to this directory) to place at the top of
|
|
||||||
# the title page.
|
|
||||||
latex_logo = '@CMAKE_CURRENT_SOURCE_DIR@/../salome/tui/images/head.png'
|
|
||||||
|
|
||||||
# For "manual" documents, if this is true, then toplevel headings are parts,
|
|
||||||
# not chapters.
|
|
||||||
#latex_use_parts = True
|
|
||||||
|
|
||||||
# Additional stuff for the LaTeX preamble.
|
|
||||||
#latex_preamble = ''
|
|
||||||
|
|
||||||
# Documents to append as an appendix to all manuals.
|
|
||||||
#latex_appendices = []
|
|
||||||
|
|
||||||
# If false, no module index is generated.
|
|
||||||
latex_use_modindex = False
|
|
@ -1,52 +0,0 @@
|
|||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
||||||
Documentation of the programming interface (API)
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
||||||
|
|
||||||
This section describes the python packages and modules of the
|
|
||||||
``salome.geom`` python package. The main part is generated from the
|
|
||||||
code documentation included in source python files.
|
|
||||||
|
|
||||||
:mod:`salome.geom` -- Package containing the GEOM python utilities
|
|
||||||
==================================================================
|
|
||||||
|
|
||||||
:mod:`geomtools` -- Tools to access GEOM engine and objects
|
|
||||||
-----------------------------------------------------------
|
|
||||||
|
|
||||||
.. automodule:: salome.geom.geomtools
|
|
||||||
:members:
|
|
||||||
|
|
||||||
:mod:`sketcher` -- Wrapper to help the creation of simple sketches
|
|
||||||
------------------------------------------------------------------
|
|
||||||
|
|
||||||
.. automodule:: salome.geom.sketcher
|
|
||||||
:members:
|
|
||||||
|
|
||||||
.. autoclass:: Sketcher
|
|
||||||
:members:
|
|
||||||
|
|
||||||
:mod:`structelem` -- Structural elements package
|
|
||||||
------------------------------------------------
|
|
||||||
|
|
||||||
.. automodule:: salome.geom.structelem
|
|
||||||
|
|
||||||
.. autoclass:: StructuralElementManager
|
|
||||||
:members:
|
|
||||||
|
|
||||||
.. autoclass:: StructuralElement
|
|
||||||
:members:
|
|
||||||
|
|
||||||
:mod:`structelem.parts` -- Structural element parts
|
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
||||||
|
|
||||||
.. automodule:: salome.geom.structelem.parts
|
|
||||||
:members:
|
|
||||||
:undoc-members:
|
|
||||||
:show-inheritance:
|
|
||||||
|
|
||||||
:mod:`structelem.orientation` -- Structural element orientation
|
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
||||||
|
|
||||||
.. automodule:: salome.geom.structelem.orientation
|
|
||||||
:members:
|
|
||||||
:undoc-members:
|
|
@ -1,11 +0,0 @@
|
|||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
||||||
Documentation of the GEOM python package
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 3
|
|
||||||
|
|
||||||
overview.rst
|
|
||||||
docapi.rst
|
|
||||||
|
|
@ -1,75 +0,0 @@
|
|||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
||||||
General presentation of the GEOM python package
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
||||||
|
|
||||||
The GEOM python package essentially contains:
|
|
||||||
|
|
||||||
* Utility functions to handle GEOM items in Salome study (see ``geomtools.py``).
|
|
||||||
|
|
||||||
- add a shape to a study, remove from the study
|
|
||||||
- display a shape in a viewer, erase the shape from the viewers
|
|
||||||
- completly delete a shape (undisplay, unpublish, and destroy the shape)
|
|
||||||
- helper functions to manage the selection in the object browser
|
|
||||||
* Wrapping functions to help the usage of GEOM tools:
|
|
||||||
|
|
||||||
- a sketcher module to create sketches from the python API (see
|
|
||||||
``sketcher.py``)
|
|
||||||
* The visualization of structural elements: a function to create
|
|
||||||
geometrical 3D representations of mechanical models called
|
|
||||||
"structural elements" (see package ``structelem``)
|
|
||||||
|
|
||||||
The functions are distributed in the python package
|
|
||||||
``salome.geom``. The specification of the programming interface of
|
|
||||||
this package is detailled in the part :doc:`Documentation of the
|
|
||||||
programming interface (API)</docapi>` of this documentation.
|
|
||||||
|
|
||||||
.. note::
|
|
||||||
The main package ``salome`` contains other sub-packages that are
|
|
||||||
distributed with the other SALOME modules. For example, the KERNEL
|
|
||||||
module provides the python package ``salome.kernel`` and SMESH the
|
|
||||||
package ``salome.smesh``.
|
|
||||||
|
|
||||||
Visualization of structural elements (package ``structelem``)
|
|
||||||
-------------------------------------------------------------
|
|
||||||
|
|
||||||
The usage of the visualization of structural elements can be
|
|
||||||
appreciated with this set of instructions:
|
|
||||||
|
|
||||||
.. code-block:: python
|
|
||||||
|
|
||||||
from salome.geom.structelem import TEST_StructuralElement
|
|
||||||
TEST_StructuralElement()
|
|
||||||
|
|
||||||
This creates the geometrical objects displayed in the study below:
|
|
||||||
|
|
||||||
.. image:: /images/salome-geom-structuralelements.png
|
|
||||||
:align: center
|
|
||||||
|
|
||||||
Manipulate GEOM object in the study (module ``geomtools``)
|
|
||||||
----------------------------------------------------------
|
|
||||||
|
|
||||||
The usage of the ``geomtools`` module can be appreciated with this set
|
|
||||||
of instructions:
|
|
||||||
|
|
||||||
.. code-block:: python
|
|
||||||
|
|
||||||
from salome.geom.geomtools import TEST_createAndDeleteShape
|
|
||||||
TEST_createAndDeleteShape()
|
|
||||||
|
|
||||||
This test executes the following procedure:
|
|
||||||
|
|
||||||
* Create, publish, and display a cylinder
|
|
||||||
* Create, publish, and display a sphere
|
|
||||||
* Create a box, publish it in a folder "boxset", and display it with a
|
|
||||||
"pink" color.
|
|
||||||
* Erase the sphere from the viewer (the sphere still exists in the study)
|
|
||||||
* Delete the cylinder (the cylinder is no longer displayed and does
|
|
||||||
not exist any more, neither in the study nor the GEOM componet.
|
|
||||||
|
|
||||||
At the end of the execution of this test, you should have in the
|
|
||||||
SALOME session:
|
|
||||||
|
|
||||||
* the box, in a dedicated folder of the study, and displayed in the
|
|
||||||
viewer
|
|
||||||
* the sphere, in the standard place of the study, and not displayed
|
|
@ -33,6 +33,10 @@ ENDIF(WIN32)
|
|||||||
ADD_CUSTOM_TARGET(usr_docs ${CMAKE_COMMAND} -E make_directory tmp
|
ADD_CUSTOM_TARGET(usr_docs ${CMAKE_COMMAND} -E make_directory tmp
|
||||||
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/geomBuilder.py ${CMAKE_SOURCE_DIR}/src/GEOM_SWIG/geomBuilder.py
|
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/geomBuilder.py ${CMAKE_SOURCE_DIR}/src/GEOM_SWIG/geomBuilder.py
|
||||||
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/gsketcher.py ${CMAKE_SOURCE_DIR}/src/GEOM_SWIG/gsketcher.py
|
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/gsketcher.py ${CMAKE_SOURCE_DIR}/src/GEOM_SWIG/gsketcher.py
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/geomtools.py ${CMAKE_SOURCE_DIR}/src/GEOM_PY/geomtools.py
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/structelem.py ${CMAKE_SOURCE_DIR}/src/GEOM_PY/structelem/__init__.py
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/parts.py ${CMAKE_SOURCE_DIR}/src/GEOM_PY/structelem/parts.py
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} ${f} -o tmp/orientation.py ${CMAKE_SOURCE_DIR}/src/GEOM_PY/structelem/orientation.py
|
||||||
COMMAND ${DOXYGEN_EXECUTABLE} doxyfile_tui
|
COMMAND ${DOXYGEN_EXECUTABLE} doxyfile_tui
|
||||||
COMMAND ${DOXYGEN_EXECUTABLE} doxyfile_py
|
COMMAND ${DOXYGEN_EXECUTABLE} doxyfile_py
|
||||||
COMMAND ${DOXYGEN_EXECUTABLE} doxyfile
|
COMMAND ${DOXYGEN_EXECUTABLE} doxyfile
|
||||||
|
@ -99,7 +99,7 @@ EXAMPLE_RECURSIVE = NO
|
|||||||
#---------------------------------------------------------------------------
|
#---------------------------------------------------------------------------
|
||||||
#Input related options
|
#Input related options
|
||||||
#---------------------------------------------------------------------------
|
#---------------------------------------------------------------------------
|
||||||
INPUT = tmp/geomBuilder.py tmp/gsketcher.py @CMAKE_SOURCE_DIR@/idl/GEOM_Gen.idl
|
INPUT = tmp @CMAKE_SOURCE_DIR@/idl/GEOM_Gen.idl
|
||||||
FILE_PATTERNS =
|
FILE_PATTERNS =
|
||||||
IMAGE_PATH = @CMAKE_CURRENT_SOURCE_DIR@/images
|
IMAGE_PATH = @CMAKE_CURRENT_SOURCE_DIR@/images
|
||||||
EXAMPLE_PATH = @CMAKE_SOURCE_DIR@/src/GEOM_SWIG
|
EXAMPLE_PATH = @CMAKE_SOURCE_DIR@/src/GEOM_SWIG
|
||||||
|
Before Width: | Height: | Size: 140 KiB After Width: | Height: | Size: 140 KiB |
12
doc/salome/gui/GEOM/input/api_documentation.doc
Normal file
12
doc/salome/gui/GEOM/input/api_documentation.doc
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
/*!
|
||||||
|
|
||||||
|
\page api_documentation Documentation of the programming interface (API)
|
||||||
|
|
||||||
|
This section describes the python packages and modules of the \b salome.geom python package.
|
||||||
|
The main part is generated from the code documentation included in source python files.
|
||||||
|
|
||||||
|
<b>salome.geom</b> – Package containing the %GEOM python utilities:
|
||||||
|
- <a href="geompy_doc/group__geomtools.html">geomtools</a>
|
||||||
|
- <a href="geompy_doc/group__sketcher.html">sketcher</a>
|
||||||
|
- <a href="geompy_doc/group__structelem.html">structelem</a>
|
||||||
|
*/
|
@ -3,11 +3,11 @@
|
|||||||
\page geompy_page Python Interface geomBuilder.py
|
\page geompy_page Python Interface geomBuilder.py
|
||||||
|
|
||||||
\n Please, see
|
\n Please, see
|
||||||
<a href="geompy_doc/modules.html">structured documentation for geomBuilder.py</a>,
|
<a href="geompy_doc/group__geomBuilder.html">structured documentation for geomBuilder.py</a>,
|
||||||
where all package functionality is separated in groups by purpose.
|
where all package functionality is separated in groups by purpose.
|
||||||
|
|
||||||
\n Also you can find any function in the \ref geomBuilder
|
\n Also you can find any function in the <a href="geompy_doc/namespacegeomBuilder.html">
|
||||||
"linear documentation for geomBuilder.py".
|
linear documentation for geomBuilder.py</a>
|
||||||
|
|
||||||
\n With SALOME 7.2, the Python interface for Geometry has been slightly modified to offer new functionality,
|
\n With SALOME 7.2, the Python interface for Geometry has been slightly modified to offer new functionality,
|
||||||
\n You may have to modify your scripts generated with SALOME 6 or older versions.
|
\n You may have to modify your scripts generated with SALOME 6 or older versions.
|
||||||
|
@ -27,9 +27,7 @@ Geometry module preferences are described in the
|
|||||||
\subpage geometry_preferences_page section of SALOME Geometry Help.
|
\subpage geometry_preferences_page section of SALOME Geometry Help.
|
||||||
|
|
||||||
Almost all geometry module functionalities are accessible via
|
Almost all geometry module functionalities are accessible via
|
||||||
\subpage geompy_page "Geometry module Python Interface"
|
\subpage python_interface "Geometry module Python Interface"
|
||||||
|
|
||||||
Other functions are available in <a class="el" target="_new" href="../../tui/GEOM/docutils/index.html">salome.geom python package</a>.
|
|
||||||
|
|
||||||
You can find the answer to some Frequently Asked Questions in this page:
|
You can find the answer to some Frequently Asked Questions in this page:
|
||||||
- \subpage faq "Frequently Asked Questions"
|
- \subpage faq "Frequently Asked Questions"
|
||||||
|
30
doc/salome/gui/GEOM/input/manipulate_object.doc
Normal file
30
doc/salome/gui/GEOM/input/manipulate_object.doc
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
/*!
|
||||||
|
|
||||||
|
\page manipulate_object Manipulate GEOM object in the study (module geomtools)
|
||||||
|
|
||||||
|
The usage of the geomtools module can be appreciated with this set
|
||||||
|
of instructions:
|
||||||
|
|
||||||
|
\code
|
||||||
|
from salome.geom.geomtools import TEST_createAndDeleteShape
|
||||||
|
TEST_createAndDeleteShape()
|
||||||
|
\endcode
|
||||||
|
|
||||||
|
This test executes the following procedure:
|
||||||
|
|
||||||
|
- Create, publish, and display a cylinder
|
||||||
|
- Create, publish, and display a sphere
|
||||||
|
- Create a box, publish it in a folder "boxset", and display it with a
|
||||||
|
"pink" color.
|
||||||
|
- Erase the sphere from the viewer (the sphere still exists in the study)
|
||||||
|
- Delete the cylinder (the cylinder is no longer displayed and does
|
||||||
|
not exist any more, neither in the study nor the GEOM componet.
|
||||||
|
|
||||||
|
At the end of the execution of this test, you should have in the
|
||||||
|
SALOME session:
|
||||||
|
|
||||||
|
- the box, in a dedicated folder of the study, and displayed in the
|
||||||
|
viewer
|
||||||
|
- the sphere, in the standard place of the study, and not displayed
|
||||||
|
|
||||||
|
*/
|
35
doc/salome/gui/GEOM/input/python_interface.doc
Normal file
35
doc/salome/gui/GEOM/input/python_interface.doc
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
/*!
|
||||||
|
|
||||||
|
\page python_interface Geometry module Python Interface
|
||||||
|
|
||||||
|
The %GEOM python package essentially contains:
|
||||||
|
|
||||||
|
- \subpage geompy_page "Python Interface geomBuilder.py" to perform the following functions:
|
||||||
|
- Creating geometrical objects
|
||||||
|
- Importing/exporting geometrical objects
|
||||||
|
- Transforming geometrical objects
|
||||||
|
- Using measurement tools
|
||||||
|
- Field on Geometry
|
||||||
|
- Utility functions to handle %GEOM items in Salome study (geomtools.py).
|
||||||
|
See example - \subpage manipulate_object "Manipulate GEOM object in the study".
|
||||||
|
- add a shape to a study, remove from the study
|
||||||
|
- display a shape in a viewer, erase the shape from the viewers
|
||||||
|
- completly delete a shape (undisplay, unpublish, and destroy the shape)
|
||||||
|
- helper functions to manage the selection in the object browser
|
||||||
|
- Wrapping functions to help the usage of %GEOM tools:
|
||||||
|
- a sketcher module to create sketches from the python API (gsketcher.py)
|
||||||
|
- \subpage struct_elem_visualisation "The visualization of structural elements": a function to create
|
||||||
|
geometrical 3D representations of mechanical models called
|
||||||
|
"structural elements" (package \ref structelem.py "structelem")
|
||||||
|
|
||||||
|
The functions are distributed in the python package salome.geom.
|
||||||
|
The specification of the programming interface of this package
|
||||||
|
is detailled in the part \subpage api_documentation "Documentation of the programming interface (API)"
|
||||||
|
of this documentation.
|
||||||
|
|
||||||
|
|
||||||
|
\note The main package salome contains other sub-packages that are
|
||||||
|
distributed with the other SALOME modules. For example, the KERNEL
|
||||||
|
module provides the python package salome.kernel and SMESH the
|
||||||
|
package salome.smesh.
|
||||||
|
*/
|
17
doc/salome/gui/GEOM/input/struct_elem_visualisation.doc
Normal file
17
doc/salome/gui/GEOM/input/struct_elem_visualisation.doc
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
/*!
|
||||||
|
|
||||||
|
\page struct_elem_visualisation Visualization of structural elements (package structelem)
|
||||||
|
|
||||||
|
The usage of the visualization of structural elements can be
|
||||||
|
appreciated with this set of instructions:
|
||||||
|
|
||||||
|
\code
|
||||||
|
from salome.geom.structelem import TEST_StructuralElement
|
||||||
|
TEST_StructuralElement()
|
||||||
|
\endcode
|
||||||
|
|
||||||
|
This creates the geometrical objects displayed in the study below:
|
||||||
|
|
||||||
|
\image html salome-geom-structuralelements.png
|
||||||
|
|
||||||
|
*/
|
@ -18,6 +18,14 @@
|
|||||||
#
|
#
|
||||||
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
#
|
#
|
||||||
|
|
||||||
|
## \defgroup geomtools geomtools - Tools to access GEOM engine and objects
|
||||||
|
# \{
|
||||||
|
# \details
|
||||||
|
# This module provides tools to facilitate the use of geom engine and geom
|
||||||
|
# objects in Salome.
|
||||||
|
# \}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
This module provides tools to facilitate the use of geom engine and geom
|
This module provides tools to facilitate the use of geom engine and geom
|
||||||
objects in Salome.
|
objects in Salome.
|
||||||
@ -44,6 +52,10 @@ except:
|
|||||||
|
|
||||||
_geompys = {}
|
_geompys = {}
|
||||||
|
|
||||||
|
## Return an object behaving exactly like geompy module, except that it is
|
||||||
|
# associated with the study \em studyId. If \em studyId is \b None, return
|
||||||
|
# a pseudo geompy object for the current study.
|
||||||
|
# \ingroup geomtools
|
||||||
def getGeompy(studyId = None):
|
def getGeompy(studyId = None):
|
||||||
"""
|
"""
|
||||||
Return an object behaving exactly like geompy module, except that it is
|
Return an object behaving exactly like geompy module, except that it is
|
||||||
@ -68,6 +80,16 @@ ModeShading = 1
|
|||||||
DisplayMode=ModeShading
|
DisplayMode=ModeShading
|
||||||
PreviewColor=[236,163,255]
|
PreviewColor=[236,163,255]
|
||||||
|
|
||||||
|
## This class provides several methods to manipulate geom objects in Salome study.
|
||||||
|
# The parameter <em>studyEditor</em> defines a \b StudyEditor
|
||||||
|
# object used to access the study. If \b None, the method returns a
|
||||||
|
# \b StudyEditor object on the current study.
|
||||||
|
#
|
||||||
|
# \b editor
|
||||||
|
#
|
||||||
|
# This instance attribute contains the underlying \b StudyEditor object.
|
||||||
|
# It can be used to access the study but the attribute itself should not be modified.
|
||||||
|
# \ingroup geomtools
|
||||||
class GeomStudyTools:
|
class GeomStudyTools:
|
||||||
"""
|
"""
|
||||||
This class provides several methods to manipulate geom objects in Salome
|
This class provides several methods to manipulate geom objects in Salome
|
||||||
@ -95,6 +117,16 @@ class GeomStudyTools:
|
|||||||
# ======================================================================
|
# ======================================================================
|
||||||
# Helper functions to add/remove a geometrical shape in/from the study
|
# Helper functions to add/remove a geometrical shape in/from the study
|
||||||
# ======================================================================
|
# ======================================================================
|
||||||
|
## Add a GEOM shape in the study. It returns the associated entry
|
||||||
|
# that corresponds to the identifier of the entry in the study. This
|
||||||
|
# entry can be used to retrieve an object in the study. A folderName
|
||||||
|
# can be specified. In this case, a folder with this name is first
|
||||||
|
# created in the Geometry part of the study, and the shape study
|
||||||
|
# object is stored in this folder of the study.
|
||||||
|
#
|
||||||
|
# \param shape (GEOM object) the GEOM object defining the shape
|
||||||
|
# \param shapeName (string) the name for this shape in the study
|
||||||
|
# \param folderName (string) the name of a folder in the GEOM part of the study
|
||||||
def addShapeToStudy(self, shape,shapeName,folderName=None):
|
def addShapeToStudy(self, shape,shapeName,folderName=None):
|
||||||
"""
|
"""
|
||||||
Add a GEOM shape in the study. It returns the associated entry
|
Add a GEOM shape in the study. It returns the associated entry
|
||||||
@ -139,6 +171,10 @@ class GeomStudyTools:
|
|||||||
|
|
||||||
return entry
|
return entry
|
||||||
|
|
||||||
|
## This removes the specified entry from the study. Note that this
|
||||||
|
# operation does not destroy the underlying GEOM object, neither
|
||||||
|
# erase the drawing in the viewer.
|
||||||
|
# The underlying GEOM object is returned (so that it can be destroyed)
|
||||||
def removeFromStudy(self, shapeStudyEntry):
|
def removeFromStudy(self, shapeStudyEntry):
|
||||||
"""
|
"""
|
||||||
This removes the specified entry from the study. Note that this
|
This removes the specified entry from the study. Note that this
|
||||||
@ -163,6 +199,11 @@ class GeomStudyTools:
|
|||||||
# python source code).
|
# python source code).
|
||||||
# ======================================================================
|
# ======================================================================
|
||||||
|
|
||||||
|
## Display the geometrical shape whose name in the study is <em>shapeName</em>.
|
||||||
|
#
|
||||||
|
# \param shapeName (string) name of the geometrical shape
|
||||||
|
# \param color (tuple) RGB components of the color of the shape
|
||||||
|
# \return True if the shape was found, False otherwise
|
||||||
def displayShapeByName(self, shapeName, color = None, fit=True):
|
def displayShapeByName(self, shapeName, color = None, fit=True):
|
||||||
"""
|
"""
|
||||||
Display the geometrical shape whose name in the study is `shapeName`.
|
Display the geometrical shape whose name in the study is `shapeName`.
|
||||||
@ -187,6 +228,10 @@ class GeomStudyTools:
|
|||||||
return self.displayShapeByEntry(entry,color,fit)
|
return self.displayShapeByEntry(entry,color,fit)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
## Display the geometrical shape whose entry is given by \em entry.
|
||||||
|
# You should prefer use this function instead of the
|
||||||
|
# displayShapeByName() which can have an unpredictible behavior in
|
||||||
|
# the case where several objects exist with the same name in the study.
|
||||||
def displayShapeByEntry(self, shapeStudyEntry, color = None, fit=True):
|
def displayShapeByEntry(self, shapeStudyEntry, color = None, fit=True):
|
||||||
"""
|
"""
|
||||||
Display the geometrical shape whose entry is given by
|
Display the geometrical shape whose entry is given by
|
||||||
@ -205,6 +250,10 @@ class GeomStudyTools:
|
|||||||
geomgui.setColor(shapeStudyEntry, color[0], color[1], color[2])
|
geomgui.setColor(shapeStudyEntry, color[0], color[1], color[2])
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
## Erase the geometrical shape whose entry is given by \em entry.
|
||||||
|
# Please note that the shape is just erased from the
|
||||||
|
# viewer. The associated study object still exists in the study,
|
||||||
|
# and the geom object still exists in the GEOM engine.
|
||||||
def eraseShapeByEntry(self, shapeStudyEntry):
|
def eraseShapeByEntry(self, shapeStudyEntry):
|
||||||
"""
|
"""
|
||||||
Erase the geometrical shape whose entry is given by
|
Erase the geometrical shape whose entry is given by
|
||||||
@ -222,6 +271,13 @@ class GeomStudyTools:
|
|||||||
# Helper functions for a complete suppression of a shape from the
|
# Helper functions for a complete suppression of a shape from the
|
||||||
# SALOME session.
|
# SALOME session.
|
||||||
# ======================================================================
|
# ======================================================================
|
||||||
|
## This completly deletes a geom shape.
|
||||||
|
# \warning Please be aware that to delete a geom object,
|
||||||
|
# you have three operations to perform:
|
||||||
|
#
|
||||||
|
# 1. erase the shape from the viewers
|
||||||
|
# 2. remove the entry from the study
|
||||||
|
# 3. destroy the underlying geom object
|
||||||
def deleteShape(self,shapeStudyEntry):
|
def deleteShape(self,shapeStudyEntry):
|
||||||
"""
|
"""
|
||||||
This completly deletes a geom shape.
|
This completly deletes a geom shape.
|
||||||
@ -240,19 +296,22 @@ class GeomStudyTools:
|
|||||||
# ======================================================================
|
# ======================================================================
|
||||||
# Helper functions for interactivity with the object browser
|
# Helper functions for interactivity with the object browser
|
||||||
# ======================================================================
|
# ======================================================================
|
||||||
|
## Returns the GEOM object currently selected in the objects browser.
|
||||||
def getGeomObjectSelected(self):
|
def getGeomObjectSelected(self):
|
||||||
'''
|
"""
|
||||||
Returns the GEOM object currently selected in the objects browser.
|
Returns the GEOM object currently selected in the objects browser.
|
||||||
'''
|
"""
|
||||||
sobject, entry = guihelper.getSObjectSelected()
|
sobject, entry = guihelper.getSObjectSelected()
|
||||||
geomObject = self.getGeomObjectFromEntry(entry)
|
geomObject = self.getGeomObjectFromEntry(entry)
|
||||||
return geomObject
|
return geomObject
|
||||||
|
|
||||||
|
## Returns the GEOM object associated to the specified entry,
|
||||||
|
# (the entry is the identifier of an item in the active study)
|
||||||
def getGeomObjectFromEntry(self,entry):
|
def getGeomObjectFromEntry(self,entry):
|
||||||
'''
|
"""
|
||||||
Returns the GEOM object associated to the specified entry,
|
Returns the GEOM object associated to the specified entry,
|
||||||
(the entry is the identifier of an item in the active study)
|
(the entry is the identifier of an item in the active study)
|
||||||
'''
|
"""
|
||||||
if entry is None:
|
if entry is None:
|
||||||
return None
|
return None
|
||||||
geomObject=IDToObject(entry, self.editor.study)
|
geomObject=IDToObject(entry, self.editor.study)
|
||||||
@ -286,6 +345,13 @@ def TEST_getGeomObjectSelected():
|
|||||||
myGeomObject = tool.getGeomObjectSelected()
|
myGeomObject = tool.getGeomObjectSelected()
|
||||||
print myGeomObject
|
print myGeomObject
|
||||||
|
|
||||||
|
## This test is a simple use case that illustrates how to create a
|
||||||
|
# GEOM shape in a SALOME session (create the GEOM object, put in in
|
||||||
|
# the study, and display the shape in a viewer) and delete a shape
|
||||||
|
# from a SALOME session (erase the shape from the viewer, delete the
|
||||||
|
# entry from the study, and finally destroy the underlying GEOM
|
||||||
|
# object).
|
||||||
|
# \ingroup geomtools
|
||||||
def TEST_createAndDeleteShape():
|
def TEST_createAndDeleteShape():
|
||||||
"""
|
"""
|
||||||
This test is a simple use case that illustrates how to create a
|
This test is a simple use case that illustrates how to create a
|
||||||
|
@ -18,6 +18,45 @@
|
|||||||
#
|
#
|
||||||
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
#
|
#
|
||||||
|
|
||||||
|
## \defgroup structelem structelem - Structural elements package
|
||||||
|
# \{
|
||||||
|
# \details
|
||||||
|
# This package is used to create and visualize structural elements.
|
||||||
|
# It contains three modules:
|
||||||
|
# - This module \ref structelem "salome.geom.structelem" defines the main classes
|
||||||
|
# StructuralElement and StructuralElementManager that can be
|
||||||
|
# directly used to build structural elements.
|
||||||
|
# - The module \ref parts "salome.geom.structelem.parts" defines
|
||||||
|
# the classes corresponding to the different parts (beams, grids, etc.) that make up
|
||||||
|
# a structural element. It is used to build the geometric shapes in the structural element.
|
||||||
|
# - The module \ref orientation "salome.geom.structelem.orientation" defines
|
||||||
|
# the classes that are used to compute the orientation of the structural element parts
|
||||||
|
# and to build the corresponding markers.
|
||||||
|
#
|
||||||
|
# A structural element is a set of geometric shapes (beams, grids, etc.) that
|
||||||
|
# are built semi-automatically along a set of geometric primitives (edges for
|
||||||
|
# instance). They are visualized with the same color as their base primitives in
|
||||||
|
# the geom viewer.
|
||||||
|
# \n Structural elements are generally created by the StructuralElementManager class,
|
||||||
|
# from a list of commands describing the element to create.
|
||||||
|
#
|
||||||
|
# Example:
|
||||||
|
# \code
|
||||||
|
# commandList = [('VisuPoutreGenerale', {'Group_Maille': 'Edge_1'}),
|
||||||
|
# ('VisuBarreCercle', {'R': 30, 'Group_Maille': 'Edge_1', 'EP': 15}),
|
||||||
|
# ]
|
||||||
|
#
|
||||||
|
# structElemManager = StructuralElementManager()
|
||||||
|
# elem = structElemManager.createElement(commandList)
|
||||||
|
# elem.display()
|
||||||
|
# salome.sg.updateObjBrowser(True)
|
||||||
|
# \endcode
|
||||||
|
#
|
||||||
|
# \defgroup orientation
|
||||||
|
# \defgroup parts
|
||||||
|
# \}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
This package is used to create and visualize structural elements. It contains
|
This package is used to create and visualize structural elements. It contains
|
||||||
three modules:
|
three modules:
|
||||||
@ -70,6 +109,13 @@ from salome.geom.geomtools import getGeompy
|
|||||||
from salome.geom.structelem import parts
|
from salome.geom.structelem import parts
|
||||||
from salome.geom.structelem.parts import InvalidParameterError
|
from salome.geom.structelem.parts import InvalidParameterError
|
||||||
|
|
||||||
|
## This class manages the structural elements in the study. It is used to
|
||||||
|
# create a new structural element from a list of commands. The parameter
|
||||||
|
# \em studyId defines the ID of the study in which the manager will create
|
||||||
|
# structural elements. If it is \b None or not specified, it will use
|
||||||
|
# the ID of the current study as defined by
|
||||||
|
# \b salome.kernel.studyedit.getActiveStudyId() function.
|
||||||
|
# \ingroup structelem
|
||||||
class StructuralElementManager:
|
class StructuralElementManager:
|
||||||
"""
|
"""
|
||||||
This class manages the structural elements in the study. It is used to
|
This class manages the structural elements in the study. It is used to
|
||||||
@ -82,6 +128,42 @@ class StructuralElementManager:
|
|||||||
def __init__(self, studyId = None):
|
def __init__(self, studyId = None):
|
||||||
self._studyEditor = getStudyEditor(studyId)
|
self._studyEditor = getStudyEditor(studyId)
|
||||||
|
|
||||||
|
## Create a structural element from the list of commands \em commandList.
|
||||||
|
# Each command in this list represent a part of the structural element,
|
||||||
|
# that is a specific kind of shape (circular beam, grid, etc.)
|
||||||
|
# associated with one or several geometrical primitives. A command must
|
||||||
|
# be a tuple. The first element is the structural element part class
|
||||||
|
# name or alias name. The second element is a dictionary containing the
|
||||||
|
# parameters describing the part. Valid class names are all the classes
|
||||||
|
# defined in the module salome.geom.structelem.parts and inheriting
|
||||||
|
# parts.StructuralElementPart. There are also several
|
||||||
|
# aliases for backward compatibility. Here is the complete list:
|
||||||
|
# - parts.GeneralBeam
|
||||||
|
# - parts.CircularBeam
|
||||||
|
# - parts.RectangularBeam
|
||||||
|
# - parts.ThickShell
|
||||||
|
# - parts.Grid
|
||||||
|
# - parts.VisuPoutreGenerale() (alias for parts.GeneralBeam)
|
||||||
|
# - parts.VisuPoutreCercle() (alias for parts.CircularBeam)
|
||||||
|
# - parts.VisuPoutreRectangle() (alias for parts.RectangularBeam)
|
||||||
|
# - parts.VisuBarreGenerale() (alias for parts.GeneralBeam)
|
||||||
|
# - parts.VisuBarreRectangle() (alias for parts.RectangularBeam)
|
||||||
|
# - parts.VisuBarreCercle() (alias for parts.CircularBeam)
|
||||||
|
# - parts.VisuCable() (alias for parts.CircularBeam)
|
||||||
|
# - parts.VisuCoque() (alias for parts.ThickShell)
|
||||||
|
# - parts.VisuGrille() (alias for parts.Grid)
|
||||||
|
# - \b Orientation: This identifier is used to specify the orientation
|
||||||
|
# of one or several 1D structural element parts (i.e. beams). The
|
||||||
|
# parameters are described in class orientation.Orientation1D.
|
||||||
|
#
|
||||||
|
# The valid parameters in the dictionary depend on the type of the
|
||||||
|
# structural element part, and are detailed in the documentation of
|
||||||
|
# the corresponding class. The only parameter that is common to all the
|
||||||
|
# classes is "MeshGroups" (that can also be named "Group_Maille"). It
|
||||||
|
# defines the name of the geometrical object(s) in the study that will
|
||||||
|
# be used as primitives to build the structural element part. This
|
||||||
|
# parameter can be either a list of strings or a single string with
|
||||||
|
# comma separated names.
|
||||||
def createElement(self, commandList):
|
def createElement(self, commandList):
|
||||||
"""
|
"""
|
||||||
Create a structural element from the list of commands `commandList`.
|
Create a structural element from the list of commands `commandList`.
|
||||||
@ -192,6 +274,11 @@ class StructuralElementManager:
|
|||||||
logger.debug("StructuralElementManager.createElement: END")
|
logger.debug("StructuralElementManager.createElement: END")
|
||||||
return element
|
return element
|
||||||
|
|
||||||
|
## This method extracts the names of the mesh groups (i.e. the
|
||||||
|
# geometrical objects used to build the structural element part) in the
|
||||||
|
# command in parameter. It returns a tuple containing the mesh groups as
|
||||||
|
# a list of strings and the other parameters of the command as a new
|
||||||
|
# dictionary.
|
||||||
def _extractMeshGroups(self, command):
|
def _extractMeshGroups(self, command):
|
||||||
"""
|
"""
|
||||||
This method extracts the names of the mesh groups (i.e. the
|
This method extracts the names of the mesh groups (i.e. the
|
||||||
@ -227,6 +314,15 @@ class StructuralElementManager:
|
|||||||
return (meshGroupList, newparams)
|
return (meshGroupList, newparams)
|
||||||
|
|
||||||
|
|
||||||
|
## This class represents a structural element, i.e. a set of geometrical
|
||||||
|
# objects built along geometrical primitives. The parameter \em studyId
|
||||||
|
# defines the ID of the study that will contain the structural element. If
|
||||||
|
# it is \b None or not specified, the constructor will use the ID of
|
||||||
|
# the active study as defined by \b salome.kernel.studyedit.getActiveStudyId
|
||||||
|
# function. Structural elements are normally created by the class
|
||||||
|
# StructuralElementManager, so this class should not be
|
||||||
|
# instantiated directly in the general case.
|
||||||
|
# \ingroup structelem
|
||||||
class StructuralElement:
|
class StructuralElement:
|
||||||
"""
|
"""
|
||||||
This class represents a structural element, i.e. a set of geometrical
|
This class represents a structural element, i.e. a set of geometrical
|
||||||
@ -256,6 +352,9 @@ class StructuralElement:
|
|||||||
self._studyEditor.studyId)
|
self._studyEditor.studyId)
|
||||||
self._SObject = None
|
self._SObject = None
|
||||||
|
|
||||||
|
## Find or create the study object corresponding to the structural
|
||||||
|
# element. This object is a Geom Folder named "SE_N" where N is a
|
||||||
|
# numerical ID.
|
||||||
def _getSObject(self):
|
def _getSObject(self):
|
||||||
"""
|
"""
|
||||||
Find or create the study object corresponding to the structural
|
Find or create the study object corresponding to the structural
|
||||||
@ -273,6 +372,9 @@ class StructuralElement:
|
|||||||
self._SObject = geompy.NewFolder("SE_" + str(self._id), mainFolder)
|
self._SObject = geompy.NewFolder("SE_" + str(self._id), mainFolder)
|
||||||
return self._SObject
|
return self._SObject
|
||||||
|
|
||||||
|
## Add a part to the structural element.
|
||||||
|
#
|
||||||
|
# \param newpart (StructuralElementPart) the part to add to the structural element.
|
||||||
def addPart(self, newpart):
|
def addPart(self, newpart):
|
||||||
"""
|
"""
|
||||||
Add a part to the structural element.
|
Add a part to the structural element.
|
||||||
@ -310,6 +412,13 @@ class StructuralElement:
|
|||||||
for shape in newshapes:
|
for shape in newshapes:
|
||||||
self._shapeDict[shape] = newpart
|
self._shapeDict[shape] = newpart
|
||||||
|
|
||||||
|
## Add orientation information to a part in the structural element. This
|
||||||
|
# information will be used to build the corresponding markers.
|
||||||
|
#
|
||||||
|
# \param meshGroup (string) the name of a geometrical primitive. The orientation
|
||||||
|
# information will apply to the structural element part built along this primitive.
|
||||||
|
# \param orientParams (dictionary) parameters defining the orientation of the
|
||||||
|
# structural element part. Those parameters are detailed in class orientation.Orientation1D.
|
||||||
def addOrientation(self, meshGroup, orientParams):
|
def addOrientation(self, meshGroup, orientParams):
|
||||||
"""
|
"""
|
||||||
Add orientation information to a part in the structural element. This
|
Add orientation information to a part in the structural element. This
|
||||||
@ -333,6 +442,8 @@ class StructuralElement:
|
|||||||
logger.warning('Mesh group "%s" not found in structural element, '
|
logger.warning('Mesh group "%s" not found in structural element, '
|
||||||
'cannot set orientation.' % meshGroup)
|
'cannot set orientation.' % meshGroup)
|
||||||
|
|
||||||
|
## Build the geometric shapes and the markers corresponding to the
|
||||||
|
# different parts of the structural element, and add them to the study.
|
||||||
def build(self):
|
def build(self):
|
||||||
"""
|
"""
|
||||||
Build the geometric shapes and the markers corresponding to the
|
Build the geometric shapes and the markers corresponding to the
|
||||||
@ -365,6 +476,7 @@ class StructuralElement:
|
|||||||
geompy.addToStudy(marker, markerSObjName)
|
geompy.addToStudy(marker, markerSObjName)
|
||||||
geompy.PutToFolder(marker, self._getSObject())
|
geompy.PutToFolder(marker, self._getSObject())
|
||||||
|
|
||||||
|
## Display the structural element in the geom view.
|
||||||
def display(self):
|
def display(self):
|
||||||
"""
|
"""
|
||||||
Display the structural element in the geom view.
|
Display the structural element in the geom view.
|
||||||
@ -372,6 +484,7 @@ class StructuralElement:
|
|||||||
StructuralElement.showElement(self._SObject)
|
StructuralElement.showElement(self._SObject)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
|
## Display the structural element corresponding to the study object \b theSObject
|
||||||
def showElement(theSObject):
|
def showElement(theSObject):
|
||||||
"""
|
"""
|
||||||
Display the structural element corresponding to the study object
|
Display the structural element corresponding to the study object
|
||||||
|
@ -18,6 +18,14 @@
|
|||||||
#
|
#
|
||||||
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
#
|
#
|
||||||
|
|
||||||
|
## \defgroup orientation orientation
|
||||||
|
# \{
|
||||||
|
# \details
|
||||||
|
# This module is used to compute the orientation of the different parts in a
|
||||||
|
# structural element and to build the corresponding markers (trihedrons).
|
||||||
|
# \}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
This module is used to compute the orientation of the different parts in a
|
This module is used to compute the orientation of the different parts in a
|
||||||
structural element and to build the corresponding markers (trihedrons).
|
structural element and to build the corresponding markers (trihedrons).
|
||||||
@ -29,7 +37,9 @@ from salome.kernel.logger import Logger
|
|||||||
from salome.kernel import termcolor
|
from salome.kernel import termcolor
|
||||||
logger = Logger("salome.geom.structelem.orientation", color = termcolor.RED)
|
logger = Logger("salome.geom.structelem.orientation", color = termcolor.RED)
|
||||||
|
|
||||||
|
## This class is used to compute the orientation of 1D elements and to build
|
||||||
|
# the corresponding markers.
|
||||||
|
# \ingroup orientation
|
||||||
class Orientation1D:
|
class Orientation1D:
|
||||||
"""
|
"""
|
||||||
This class is used to compute the orientation of 1D elements and to build
|
This class is used to compute the orientation of 1D elements and to build
|
||||||
@ -46,6 +56,14 @@ class Orientation1D:
|
|||||||
del reprdict["geom"]
|
del reprdict["geom"]
|
||||||
return '%s(%s)' % (self.__class__.__name__, reprdict)
|
return '%s(%s)' % (self.__class__.__name__, reprdict)
|
||||||
|
|
||||||
|
## Add orientation parameters. \em params is a dictionary containing one or
|
||||||
|
# several orientation parameters. The valid parameters are:
|
||||||
|
# - "VECT_Y": Triplet defining the local Y axis (the X axis is the
|
||||||
|
# main direction of the 1D element).
|
||||||
|
# - "ANGL_VRIL": Angle of rotation along the X axis to define the local
|
||||||
|
# coordinate system.
|
||||||
|
# The parameters can be specified several times. In this case, only the
|
||||||
|
# last "VECT_Y" or "ANGL_VRIL" is taken into account.
|
||||||
def addParams(self, params):
|
def addParams(self, params):
|
||||||
"""
|
"""
|
||||||
Add orientation parameters. `params` is a dictionary containing one or
|
Add orientation parameters. `params` is a dictionary containing one or
|
||||||
@ -78,7 +96,9 @@ class Orientation1D:
|
|||||||
if len(mydict) > 0:
|
if len(mydict) > 0:
|
||||||
logger.warning("Invalid orientation parameter(s) (ignored): %s" %
|
logger.warning("Invalid orientation parameter(s) (ignored): %s" %
|
||||||
str(mydict))
|
str(mydict))
|
||||||
|
## Get the vectors Y and Z for the default LCS, that use the main
|
||||||
|
# direction of the 1D object as the local X axis and the global Z axis
|
||||||
|
# to determine the local Z axis.
|
||||||
def _getDefaultVecYZ(self, center, vecX):
|
def _getDefaultVecYZ(self, center, vecX):
|
||||||
"""
|
"""
|
||||||
Get the vectors Y and Z for the default LCS, that use the main
|
Get the vectors Y and Z for the default LCS, that use the main
|
||||||
@ -101,6 +121,8 @@ class Orientation1D:
|
|||||||
locZ = self.geom.GetNormal(locPlaneXY)
|
locZ = self.geom.GetNormal(locPlaneXY)
|
||||||
return (locY, locZ)
|
return (locY, locZ)
|
||||||
|
|
||||||
|
## Create a marker with origin \em center and X axis \em vecX.
|
||||||
|
# \em geom is the pseudo-geompy object used to build the geometric shapes.
|
||||||
def buildMarker(self, geom, center, vecX):
|
def buildMarker(self, geom, center, vecX):
|
||||||
"""
|
"""
|
||||||
Create a marker with origin `center` and X axis `vecX`. `geom` is the
|
Create a marker with origin `center` and X axis `vecX`. `geom` is the
|
||||||
@ -110,6 +132,9 @@ class Orientation1D:
|
|||||||
marker = geom.MakeMarkerPntTwoVec(center, vecX, locY)
|
marker = geom.MakeMarkerPntTwoVec(center, vecX, locY)
|
||||||
return marker
|
return marker
|
||||||
|
|
||||||
|
## Get the vectors Y and Z for the LCS with origin \em center and X axis
|
||||||
|
# \em vecX. \em geom is the pseudo-geompy object used to build the
|
||||||
|
# geometric shapes.
|
||||||
def getVecYZ(self, geom, center, vecX):
|
def getVecYZ(self, geom, center, vecX):
|
||||||
"""
|
"""
|
||||||
Get the vectors Y and Z for the LCS with origin `center` and X axis
|
Get the vectors Y and Z for the LCS with origin `center` and X axis
|
||||||
@ -148,7 +173,11 @@ class Orientation1D:
|
|||||||
|
|
||||||
return (locY, locZ)
|
return (locY, locZ)
|
||||||
|
|
||||||
|
## This class is used to compute the orientation of 2D elements and to build
|
||||||
|
# the corresponding markers. Angles \em alpha and \em beta are used to determine
|
||||||
|
# the local coordinate system for the 2D element. If \em vect is not
|
||||||
|
# \b None, it is used instead of \em alpha and \em beta.
|
||||||
|
# \ingroup orientation
|
||||||
class Orientation2D:
|
class Orientation2D:
|
||||||
"""
|
"""
|
||||||
This class is used to compute the orientation of 2D elements and to build
|
This class is used to compute the orientation of 2D elements and to build
|
||||||
@ -168,6 +197,10 @@ class Orientation2D:
|
|||||||
del reprdict["geom"]
|
del reprdict["geom"]
|
||||||
return '%s(%s)' % (self.__class__.__name__, reprdict)
|
return '%s(%s)' % (self.__class__.__name__, reprdict)
|
||||||
|
|
||||||
|
## Create the default marker, that use the normal vector of the 2D object
|
||||||
|
# as the local Z axis and the global X axis to determine the local X
|
||||||
|
# axis. \em warnings can be used to enable or disable the logging of
|
||||||
|
# warning messages.
|
||||||
def _buildDefaultMarker(self, center, normal, warnings = True):
|
def _buildDefaultMarker(self, center, normal, warnings = True):
|
||||||
"""
|
"""
|
||||||
Create the default marker, that use the normal vector of the 2D object
|
Create the default marker, that use the normal vector of the 2D object
|
||||||
@ -189,6 +222,8 @@ class Orientation2D:
|
|||||||
marker = self._buildMarkerRefVecX(center, normal, globalVecX)
|
marker = self._buildMarkerRefVecX(center, normal, globalVecX)
|
||||||
return marker
|
return marker
|
||||||
|
|
||||||
|
## Create a marker using \em normal as Z axis and \em refVecX
|
||||||
|
# to determine the X axis.
|
||||||
def _buildMarkerRefVecX(self, center, normal, refVecX):
|
def _buildMarkerRefVecX(self, center, normal, refVecX):
|
||||||
"""
|
"""
|
||||||
Create a marker using `normal` as Z axis and `refVecX` to determine
|
Create a marker using `normal` as Z axis and `refVecX` to determine
|
||||||
@ -204,6 +239,11 @@ class Orientation2D:
|
|||||||
marker = self.geom.MakeMarkerPntTwoVec(center, locX, locY)
|
marker = self.geom.MakeMarkerPntTwoVec(center, locX, locY)
|
||||||
return marker
|
return marker
|
||||||
|
|
||||||
|
## Create a marker with origin \em center and \em normal as Z axis.
|
||||||
|
# The other axes are computed using the parameters alpha and beta of the
|
||||||
|
# Orientation2D instance. \em geom is the pseudo-geompy object used to
|
||||||
|
# build the geometric shapes. \em warnings can be used to enable or
|
||||||
|
# disable the logging of warning messages.
|
||||||
def buildMarker(self, geom, center, normal, warnings = True):
|
def buildMarker(self, geom, center, normal, warnings = True):
|
||||||
"""
|
"""
|
||||||
Create a marker with origin `center` and `normal` as Z axis. The other
|
Create a marker with origin `center` and `normal` as Z axis. The other
|
||||||
|
@ -18,6 +18,16 @@
|
|||||||
#
|
#
|
||||||
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
#
|
#
|
||||||
|
|
||||||
|
## \defgroup parts parts
|
||||||
|
# \{
|
||||||
|
# \details
|
||||||
|
# This module defines the different structural element parts. It is used to
|
||||||
|
# build the geometric shapes of the structural elements. It should not be used
|
||||||
|
# directly in the general case. Structural elements should be created by the
|
||||||
|
# \ref structelem.StructuralElementManager "salome.geom.structelem.StructuralElementManager".
|
||||||
|
# \}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
This module defines the different structural element parts. It is used to
|
This module defines the different structural element parts. It is used to
|
||||||
build the geometric shapes of the structural elements. It should not be used
|
build the geometric shapes of the structural elements. It should not be used
|
||||||
@ -56,7 +66,9 @@ LIGHT_RED = SALOMEDS.Color(1.0, 0.5, 0.5)
|
|||||||
PURPLE = SALOMEDS.Color(170.0/255.0, 85.0/255.0, 1.0)
|
PURPLE = SALOMEDS.Color(170.0/255.0, 85.0/255.0, 1.0)
|
||||||
ORANGE = SALOMEDS.Color(1.0, 170.0/255.0, 0.0)
|
ORANGE = SALOMEDS.Color(1.0, 170.0/255.0, 0.0)
|
||||||
|
|
||||||
|
## This exception is raised when an invalid parameter is used to build a
|
||||||
|
# structural element part.
|
||||||
|
# \ingroup parts
|
||||||
class InvalidParameterError(Exception):
|
class InvalidParameterError(Exception):
|
||||||
"""
|
"""
|
||||||
This exception is raised when an invalid parameter is used to build a
|
This exception is raised when an invalid parameter is used to build a
|
||||||
@ -74,7 +86,10 @@ class InvalidParameterError(Exception):
|
|||||||
self.expression, self.value,
|
self.expression, self.value,
|
||||||
self.groupName)
|
self.groupName)
|
||||||
|
|
||||||
|
## This class enables the use of sub-shapes in sets or as dictionary keys.
|
||||||
|
# It implements __eq__ and __hash__ methods so that sub-shapes with the same
|
||||||
|
# CORBA object \em mainShape and the same \em id are considered equal.
|
||||||
|
# \ingroup parts
|
||||||
class SubShapeID:
|
class SubShapeID:
|
||||||
"""
|
"""
|
||||||
This class enables the use of sub-shapes in sets or as dictionary keys.
|
This class enables the use of sub-shapes in sets or as dictionary keys.
|
||||||
@ -86,6 +101,8 @@ class SubShapeID:
|
|||||||
self._mainShape = mainShape
|
self._mainShape = mainShape
|
||||||
self._id = id
|
self._id = id
|
||||||
|
|
||||||
|
## Return the sub-shape (GEOM object). \em geom is a pseudo-geompy object
|
||||||
|
# used to find the geometrical object.
|
||||||
def getObj(self, geom):
|
def getObj(self, geom):
|
||||||
"""
|
"""
|
||||||
Return the sub-shape (GEOM object). `geom` is a pseudo-geompy object
|
Return the sub-shape (GEOM object). `geom` is a pseudo-geompy object
|
||||||
@ -100,7 +117,16 @@ class SubShapeID:
|
|||||||
def __hash__(self):
|
def __hash__(self):
|
||||||
return self._mainShape._hash(2147483647) ^ self._id
|
return self._mainShape._hash(2147483647) ^ self._id
|
||||||
|
|
||||||
|
## This class is the base class for all structural element parts. It should
|
||||||
|
# not be instantiated directly (consider it as an "abstract" class).
|
||||||
|
# \param studyId (integer) the ID of the study in which the part is created.
|
||||||
|
# \param groupName (string) the name of the underlying geometrical primitive
|
||||||
|
# in the study.
|
||||||
|
# \param groupGeomObj (GEOM object) the underlying geometrical primitive.
|
||||||
|
# \param parameters (dictionary) parameters defining the structural element (see
|
||||||
|
# subclasses for details).
|
||||||
|
# \param name (string) name to use for the created object in the study.
|
||||||
|
# \ingroup parts
|
||||||
class StructuralElementPart:
|
class StructuralElementPart:
|
||||||
"""
|
"""
|
||||||
This class is the base class for all structural element parts. It should
|
This class is the base class for all structural element parts. It should
|
||||||
@ -148,6 +174,9 @@ class StructuralElementPart:
|
|||||||
if self.color is None:
|
if self.color is None:
|
||||||
self.color = self._groupGeomObj.GetColor()
|
self.color = self._groupGeomObj.GetColor()
|
||||||
|
|
||||||
|
## This method finds the value of a parameter in the parameters
|
||||||
|
# dictionary. The argument is a list because some parameters can have
|
||||||
|
# several different names.
|
||||||
def _getParameter(self, nameList, default = None):
|
def _getParameter(self, nameList, default = None):
|
||||||
"""
|
"""
|
||||||
This method finds the value of a parameter in the parameters
|
This method finds the value of a parameter in the parameters
|
||||||
@ -162,6 +191,7 @@ class StructuralElementPart:
|
|||||||
return self._parameters[name]
|
return self._parameters[name]
|
||||||
return default
|
return default
|
||||||
|
|
||||||
|
## This method finds the user name for a parameter.
|
||||||
def _getParamUserName(self, paramName):
|
def _getParamUserName(self, paramName):
|
||||||
"""
|
"""
|
||||||
This method finds the user name for a parameter.
|
This method finds the user name for a parameter.
|
||||||
@ -183,6 +213,9 @@ class StructuralElementPart:
|
|||||||
return '%s("%s", %s)' % (self.__class__.__name__, self.groupName,
|
return '%s("%s", %s)' % (self.__class__.__name__, self.groupName,
|
||||||
reprdict)
|
reprdict)
|
||||||
|
|
||||||
|
## Add orientation information to the structural element part. See class
|
||||||
|
# \ref Orientation1D "salome.geom.structelem.orientation.Orientation1D"
|
||||||
|
# for the description of the parameters.
|
||||||
def addOrientation(self, orientParams):
|
def addOrientation(self, orientParams):
|
||||||
"""
|
"""
|
||||||
Add orientation information to the structural element part. See class
|
Add orientation information to the structural element part. See class
|
||||||
@ -191,6 +224,8 @@ class StructuralElementPart:
|
|||||||
"""
|
"""
|
||||||
self._orientation.addParams(orientParams)
|
self._orientation.addParams(orientParams)
|
||||||
|
|
||||||
|
## This method checks that some parameters or some expressions involving
|
||||||
|
# those parameters are greater than a minimum value.
|
||||||
def _checkSize(self, value, mindim, expression):
|
def _checkSize(self, value, mindim, expression):
|
||||||
"""
|
"""
|
||||||
This method checks that some parameters or some expressions involving
|
This method checks that some parameters or some expressions involving
|
||||||
@ -200,6 +235,8 @@ class StructuralElementPart:
|
|||||||
raise InvalidParameterError(self.groupName, expression,
|
raise InvalidParameterError(self.groupName, expression,
|
||||||
mindim, value)
|
mindim, value)
|
||||||
|
|
||||||
|
## Build the geometric shapes and the markers corresponding to the
|
||||||
|
# structural element part in the study \em studyId.
|
||||||
def build(self):
|
def build(self):
|
||||||
"""
|
"""
|
||||||
Build the geometric shapes and the markers corresponding to the
|
Build the geometric shapes and the markers corresponding to the
|
||||||
@ -212,6 +249,8 @@ class StructuralElementPart:
|
|||||||
marker.SetColor(self.color)
|
marker.SetColor(self.color)
|
||||||
return (shape, markers)
|
return (shape, markers)
|
||||||
|
|
||||||
|
## This abstract method must be implemented in subclasses and should
|
||||||
|
# create the geometrical shape(s) of the structural element part.
|
||||||
def _buildPart(self):
|
def _buildPart(self):
|
||||||
"""
|
"""
|
||||||
This abstract method must be implemented in subclasses and should
|
This abstract method must be implemented in subclasses and should
|
||||||
@ -222,6 +261,9 @@ class StructuralElementPart:
|
|||||||
"StructuralElementPart subclasses)." %
|
"StructuralElementPart subclasses)." %
|
||||||
self.__class__.__name__)
|
self.__class__.__name__)
|
||||||
|
|
||||||
|
## This abstract method must be implemented in subclasses and should
|
||||||
|
# create the markers defining the orientation of the structural element
|
||||||
|
# part.
|
||||||
def _buildMarkers(self):
|
def _buildMarkers(self):
|
||||||
"""
|
"""
|
||||||
This abstract method must be implemented in subclasses and should
|
This abstract method must be implemented in subclasses and should
|
||||||
@ -233,6 +275,7 @@ class StructuralElementPart:
|
|||||||
"StructuralElementPart subclasses)." %
|
"StructuralElementPart subclasses)." %
|
||||||
self.__class__.__name__)
|
self.__class__.__name__)
|
||||||
|
|
||||||
|
## Find and return the base sub-shapes in the structural element part.
|
||||||
def _getSubShapes(self, minDim = MIN_LENGTH_FOR_EXTRUSION):
|
def _getSubShapes(self, minDim = MIN_LENGTH_FOR_EXTRUSION):
|
||||||
"""
|
"""
|
||||||
Find and return the base sub-shapes in the structural element part.
|
Find and return the base sub-shapes in the structural element part.
|
||||||
@ -252,7 +295,10 @@ class StructuralElementPart:
|
|||||||
subShapes.append(subShape)
|
subShapes.append(subShape)
|
||||||
return subShapes
|
return subShapes
|
||||||
|
|
||||||
|
## This class is an "abstract" class for all 1D structural element parts. It
|
||||||
|
# should not be instantiated directly. See class StructuralElementPart
|
||||||
|
# for the description of the parameters.
|
||||||
|
# \ingroup parts
|
||||||
class Beam(StructuralElementPart):
|
class Beam(StructuralElementPart):
|
||||||
"""
|
"""
|
||||||
This class is an "abstract" class for all 1D structural element parts. It
|
This class is an "abstract" class for all 1D structural element parts. It
|
||||||
@ -268,6 +314,9 @@ class Beam(StructuralElementPart):
|
|||||||
parameters, name, color)
|
parameters, name, color)
|
||||||
self._orientation = orientation.Orientation1D()
|
self._orientation = orientation.Orientation1D()
|
||||||
|
|
||||||
|
## This method checks if a 1D object is "reversed", i.e. if its
|
||||||
|
# orientation is different than the orientation of the underlying OCC
|
||||||
|
# object.
|
||||||
def _isReversed(self, path):
|
def _isReversed(self, path):
|
||||||
"""
|
"""
|
||||||
This method checks if a 1D object is "reversed", i.e. if its
|
This method checks if a 1D object is "reversed", i.e. if its
|
||||||
@ -280,6 +329,9 @@ class Beam(StructuralElementPart):
|
|||||||
dist = self.geom.MinDistance(p1, p2)
|
dist = self.geom.MinDistance(p1, p2)
|
||||||
return dist > length / 2
|
return dist > length / 2
|
||||||
|
|
||||||
|
## Get a vertex and the corresponding tangent on a wire by parameter.
|
||||||
|
# This method takes into account the "real" orientation of the wire
|
||||||
|
# (i.e. the orientation of the underlying OCC object).
|
||||||
def _getVertexAndTangentOnOrientedWire(self, path, param):
|
def _getVertexAndTangentOnOrientedWire(self, path, param):
|
||||||
"""
|
"""
|
||||||
Get a vertex and the corresponding tangent on a wire by parameter.
|
Get a vertex and the corresponding tangent on a wire by parameter.
|
||||||
@ -298,6 +350,8 @@ class Beam(StructuralElementPart):
|
|||||||
tangent = self.geom.MakeTangentOnCurve(path, param)
|
tangent = self.geom.MakeTangentOnCurve(path, param)
|
||||||
return (vertex, tangent)
|
return (vertex, tangent)
|
||||||
|
|
||||||
|
## Create a solid by the extrusion of section \em wire1 to section \em wire2
|
||||||
|
# along \em path.
|
||||||
def _makeSolidPipeFromWires(self, wire1, wire2, point1, point2, path):
|
def _makeSolidPipeFromWires(self, wire1, wire2, point1, point2, path):
|
||||||
"""
|
"""
|
||||||
Create a solid by the extrusion of section `wire1` to section `wire2`
|
Create a solid by the extrusion of section `wire1` to section `wire2`
|
||||||
@ -312,6 +366,7 @@ class Beam(StructuralElementPart):
|
|||||||
solid = self.geom.MakeSolid([closedShell])
|
solid = self.geom.MakeSolid([closedShell])
|
||||||
return solid
|
return solid
|
||||||
|
|
||||||
|
## Build the structural element part.
|
||||||
def _buildPart(self):
|
def _buildPart(self):
|
||||||
"""
|
"""
|
||||||
Build the structural element part.
|
Build the structural element part.
|
||||||
@ -351,6 +406,7 @@ class Beam(StructuralElementPart):
|
|||||||
else:
|
else:
|
||||||
return self.geom.MakeCompound(listPipes)
|
return self.geom.MakeCompound(listPipes)
|
||||||
|
|
||||||
|
## Build the markers defining the orientation of the structural element part.
|
||||||
def _buildMarkers(self):
|
def _buildMarkers(self):
|
||||||
"""
|
"""
|
||||||
Build the markers defining the orientation of the structural element
|
Build the markers defining the orientation of the structural element
|
||||||
@ -367,6 +423,18 @@ class Beam(StructuralElementPart):
|
|||||||
return listMarkers
|
return listMarkers
|
||||||
|
|
||||||
|
|
||||||
|
## This class defines a beam with a circular section. It can be full or
|
||||||
|
# hollow, and its radius and thickness can vary from one end of the beam to
|
||||||
|
# the other. The valid parameters for circular beams are:
|
||||||
|
# - "R1" or "R": radius at the first end of the beam.
|
||||||
|
# - "R2" or "R": radius at the other end of the beam.
|
||||||
|
# - "EP1" or "EP" (optional): thickness at the first end of the beam.
|
||||||
|
# If not specified or equal to 0, the beam is considered full.
|
||||||
|
# - "EP2" or "EP" (optional): thickness at the other end of the beam.
|
||||||
|
# If not specified or equal to 0, the beam is considered full.
|
||||||
|
#
|
||||||
|
# See class StructuralElementPart for the description of the other parameters.
|
||||||
|
# \ingroup parts
|
||||||
class CircularBeam(Beam):
|
class CircularBeam(Beam):
|
||||||
"""
|
"""
|
||||||
This class defines a beam with a circular section. It can be full or
|
This class defines a beam with a circular section. It can be full or
|
||||||
@ -428,6 +496,7 @@ class CircularBeam(Beam):
|
|||||||
"%s - %s" % (self._getParamUserName("R2"),
|
"%s - %s" % (self._getParamUserName("R2"),
|
||||||
self._getParamUserName("EP2")))
|
self._getParamUserName("EP2")))
|
||||||
|
|
||||||
|
## Create the circular sections used to build the pipe.
|
||||||
def _makeSectionWires(self, fPoint, fNormal, lPoint, lNormal):
|
def _makeSectionWires(self, fPoint, fNormal, lPoint, lNormal):
|
||||||
"""
|
"""
|
||||||
Create the circular sections used to build the pipe.
|
Create the circular sections used to build the pipe.
|
||||||
@ -446,6 +515,28 @@ class CircularBeam(Beam):
|
|||||||
return (outerCircle1, innerCircle1, outerCircle2, innerCircle2)
|
return (outerCircle1, innerCircle1, outerCircle2, innerCircle2)
|
||||||
|
|
||||||
|
|
||||||
|
## This class defines a beam with a rectangular section. It can be full or
|
||||||
|
# hollow, and its dimensions can vary from one end of the beam to the other.
|
||||||
|
# The valid parameters for rectangular beams are:
|
||||||
|
# - "HY1", "HY", "H1" or "H": width at the first end of the beam.
|
||||||
|
# - "HZ1", "HZ", "H1" or "H": height at the first end of the beam.
|
||||||
|
# - "HY2", "HY", "H2" or "H": width at the other end of the beam.
|
||||||
|
# - "HZ2", "HZ", "H2" or "H": height at the other end of the beam.
|
||||||
|
# - "EPY1", "EPY", "EP1" or "EP" (optional): thickness in the width
|
||||||
|
# direction at the first end of the beam. If not specified or equal to 0,
|
||||||
|
# the beam is considered full.
|
||||||
|
# - "EPZ1", "EPZ", "EP1" or "EP" (optional): thickness in the height
|
||||||
|
# direction at the first end of the beam. If not specified or equal to 0,
|
||||||
|
# the beam is considered full.
|
||||||
|
# - "EPY2", "EPY", "EP2" or "EP" (optional): thickness in the width
|
||||||
|
# direction at the other end of the beam. If not specified or equal to 0,
|
||||||
|
# the beam is considered full.
|
||||||
|
# - "EPZ2", "EPZ", "EP2" or "EP" (optional): thickness in the height
|
||||||
|
# direction at the other end of the beam. If not specified or equal to 0,
|
||||||
|
# the beam is considered full.
|
||||||
|
#
|
||||||
|
# See class StructuralElementPart for the description of the other parameters.
|
||||||
|
# \ingroup parts
|
||||||
class RectangularBeam(Beam):
|
class RectangularBeam(Beam):
|
||||||
"""
|
"""
|
||||||
This class defines a beam with a rectangular section. It can be full or
|
This class defines a beam with a rectangular section. It can be full or
|
||||||
@ -539,6 +630,7 @@ class RectangularBeam(Beam):
|
|||||||
"%s - 2 * %s" % (self._getParamUserName("HZ2"),
|
"%s - 2 * %s" % (self._getParamUserName("HZ2"),
|
||||||
self._getParamUserName("EPZ2")))
|
self._getParamUserName("EPZ2")))
|
||||||
|
|
||||||
|
## Create a rectangle in the specified plane.
|
||||||
def _makeRectangle(self, HY, HZ, lcs):
|
def _makeRectangle(self, HY, HZ, lcs):
|
||||||
"""
|
"""
|
||||||
Create a rectangle in the specified plane.
|
Create a rectangle in the specified plane.
|
||||||
@ -553,6 +645,7 @@ class RectangularBeam(Beam):
|
|||||||
sketch = self.geom.MakeSketcherOnPlane(sketchStr, lcs)
|
sketch = self.geom.MakeSketcherOnPlane(sketchStr, lcs)
|
||||||
return sketch
|
return sketch
|
||||||
|
|
||||||
|
## Create one side of the rectangular sections used to build the pipe.
|
||||||
def _makeSectionRectangles(self, point, vecX, HY, HZ, EPY, EPZ):
|
def _makeSectionRectangles(self, point, vecX, HY, HZ, EPY, EPZ):
|
||||||
"""
|
"""
|
||||||
Create one side of the rectangular sections used to build the pipe.
|
Create one side of the rectangular sections used to build the pipe.
|
||||||
@ -568,6 +661,7 @@ class RectangularBeam(Beam):
|
|||||||
innerRect = None
|
innerRect = None
|
||||||
return (outerRect, innerRect)
|
return (outerRect, innerRect)
|
||||||
|
|
||||||
|
## Create the rectangular sections used to build the pipe.
|
||||||
def _makeSectionWires(self, fPoint, fNormal, lPoint, lNormal):
|
def _makeSectionWires(self, fPoint, fNormal, lPoint, lNormal):
|
||||||
"""
|
"""
|
||||||
Create the rectangular sections used to build the pipe.
|
Create the rectangular sections used to build the pipe.
|
||||||
@ -581,6 +675,10 @@ class RectangularBeam(Beam):
|
|||||||
return (outerRect1, innerRect1, outerRect2, innerRect2)
|
return (outerRect1, innerRect1, outerRect2, innerRect2)
|
||||||
|
|
||||||
|
|
||||||
|
## This method finds the value of a parameter in the parameters
|
||||||
|
# dictionary. The argument is a list because some parameters can have
|
||||||
|
# several different names.
|
||||||
|
# \ingroup parts
|
||||||
def getParameterInDict(nameList, parametersDict, default = None):
|
def getParameterInDict(nameList, parametersDict, default = None):
|
||||||
"""
|
"""
|
||||||
This method finds the value of a parameter in the parameters
|
This method finds the value of a parameter in the parameters
|
||||||
@ -592,7 +690,15 @@ def getParameterInDict(nameList, parametersDict, default = None):
|
|||||||
return parametersDict[name]
|
return parametersDict[name]
|
||||||
return default
|
return default
|
||||||
|
|
||||||
|
## This class defines a beam with a generic section. It is represented as a
|
||||||
|
# full rectangular beam with the following parameters:
|
||||||
|
# - HY1 = sqrt(12 * IZ1 / A1)
|
||||||
|
# - HZ1 = sqrt(12 * IY1 / A1)
|
||||||
|
# - HY2 = sqrt(12 * IZ2 / A2)
|
||||||
|
# - HZ2 = sqrt(12 * IY2 / A2)
|
||||||
|
#
|
||||||
|
# See StructuralElementPart for the description of the other parameters.
|
||||||
|
# \ingroup parts
|
||||||
class GeneralBeam(RectangularBeam):
|
class GeneralBeam(RectangularBeam):
|
||||||
"""
|
"""
|
||||||
This class defines a beam with a generic section. It is represented as a
|
This class defines a beam with a generic section. It is represented as a
|
||||||
@ -629,7 +735,10 @@ class GeneralBeam(RectangularBeam):
|
|||||||
RectangularBeam.__init__(self, studyId, groupName, groupGeomObj, parameters,
|
RectangularBeam.__init__(self, studyId, groupName, groupGeomObj, parameters,
|
||||||
name, color)
|
name, color)
|
||||||
|
|
||||||
|
## This class is an "abstract" class for all 2D structural element parts. It
|
||||||
|
# should not be instantiated directly.
|
||||||
|
# See class StructuralElementPart for the description of the parameters.
|
||||||
|
# \ingroup parts
|
||||||
class StructuralElementPart2D(StructuralElementPart):
|
class StructuralElementPart2D(StructuralElementPart):
|
||||||
"""
|
"""
|
||||||
This class is an "abstract" class for all 2D structural element parts. It
|
This class is an "abstract" class for all 2D structural element parts. It
|
||||||
@ -649,6 +758,7 @@ class StructuralElementPart2D(StructuralElementPart):
|
|||||||
self._getParameter(["Vecteur"]))
|
self._getParameter(["Vecteur"]))
|
||||||
self.offset = self._getParameter(["Excentre"], 0.0)
|
self.offset = self._getParameter(["Excentre"], 0.0)
|
||||||
|
|
||||||
|
## Create a copy of a face at a given offset.
|
||||||
def _makeFaceOffset(self, face, offset, epsilon = 1e-6):
|
def _makeFaceOffset(self, face, offset, epsilon = 1e-6):
|
||||||
"""
|
"""
|
||||||
Create a copy of a face at a given offset.
|
Create a copy of a face at a given offset.
|
||||||
@ -663,6 +773,8 @@ class StructuralElementPart2D(StructuralElementPart):
|
|||||||
self.geom.ShapeType["FACE"])
|
self.geom.ShapeType["FACE"])
|
||||||
return faces[0]
|
return faces[0]
|
||||||
|
|
||||||
|
## Build the markers for the structural element part with a given offset
|
||||||
|
# from the base face.
|
||||||
def _buildMarkersWithOffset(self, offset):
|
def _buildMarkersWithOffset(self, offset):
|
||||||
"""
|
"""
|
||||||
Build the markers for the structural element part with a given offset
|
Build the markers for the structural element part with a given offset
|
||||||
@ -691,7 +803,19 @@ class StructuralElementPart2D(StructuralElementPart):
|
|||||||
|
|
||||||
return listMarkers
|
return listMarkers
|
||||||
|
|
||||||
|
## This class defines a shell with a given thickness. It can be shifted from
|
||||||
|
# the base face. The valid parameters for thick shells are:
|
||||||
|
# - "Epais": thickness of the shell.
|
||||||
|
# - "Excentre": offset of the shell from the base face.
|
||||||
|
# - "angleAlpha": angle used to build the markers (see class
|
||||||
|
# \ref orientation.Orientation2D "salome.geom.structelem.orientation.Orientation2D")
|
||||||
|
# - "angleBeta": angle used to build the markers (see class
|
||||||
|
# \ref orientation.Orientation2D "salome.geom.structelem.orientation.Orientation2D")
|
||||||
|
# - "Vecteur": vector used instead of the angles to build the markers (see
|
||||||
|
# \ref orientation.Orientation2D "salome.geom.structelem.orientation.Orientation2D")
|
||||||
|
#
|
||||||
|
# See class StructuralElementPart for the description of the other parameters.
|
||||||
|
# \ingroup parts
|
||||||
class ThickShell(StructuralElementPart2D):
|
class ThickShell(StructuralElementPart2D):
|
||||||
"""
|
"""
|
||||||
This class defines a shell with a given thickness. It can be shifted from
|
This class defines a shell with a given thickness. It can be shifted from
|
||||||
@ -719,6 +843,7 @@ class ThickShell(StructuralElementPart2D):
|
|||||||
self.thickness = self._getParameter(["Epais"])
|
self.thickness = self._getParameter(["Epais"])
|
||||||
logger.debug(repr(self))
|
logger.debug(repr(self))
|
||||||
|
|
||||||
|
## Create the geometrical shapes corresponding to the thick shell.
|
||||||
def _buildPart(self):
|
def _buildPart(self):
|
||||||
"""
|
"""
|
||||||
Create the geometrical shapes corresponding to the thick shell.
|
Create the geometrical shapes corresponding to the thick shell.
|
||||||
@ -740,6 +865,8 @@ class ThickShell(StructuralElementPart2D):
|
|||||||
else:
|
else:
|
||||||
return self.geom.MakeCompound(listSolids)
|
return self.geom.MakeCompound(listSolids)
|
||||||
|
|
||||||
|
## Create the geometrical shapes corresponding to the thick shell for a
|
||||||
|
# given face.
|
||||||
def _buildThickShellForFace(self, face):
|
def _buildThickShellForFace(self, face):
|
||||||
"""
|
"""
|
||||||
Create the geometrical shapes corresponding to the thick shell for a
|
Create the geometrical shapes corresponding to the thick shell for a
|
||||||
@ -775,6 +902,7 @@ class ThickShell(StructuralElementPart2D):
|
|||||||
resultSolid = self.geom.MakeSolid([resultShell])
|
resultSolid = self.geom.MakeSolid([resultShell])
|
||||||
return resultSolid
|
return resultSolid
|
||||||
|
|
||||||
|
## Remove the side edge in a cylinder.
|
||||||
def _removeCylinderExtraEdge(self, wires):
|
def _removeCylinderExtraEdge(self, wires):
|
||||||
"""
|
"""
|
||||||
Remove the side edge in a cylinder.
|
Remove the side edge in a cylinder.
|
||||||
@ -787,6 +915,7 @@ class ThickShell(StructuralElementPart2D):
|
|||||||
result.append(edge)
|
result.append(edge)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
## Build the markers defining the orientation of the thick shell.
|
||||||
def _buildMarkers(self):
|
def _buildMarkers(self):
|
||||||
"""
|
"""
|
||||||
Build the markers defining the orientation of the thick shell.
|
Build the markers defining the orientation of the thick shell.
|
||||||
@ -794,7 +923,31 @@ class ThickShell(StructuralElementPart2D):
|
|||||||
return self._buildMarkersWithOffset(self.offset +
|
return self._buildMarkersWithOffset(self.offset +
|
||||||
self.thickness / 2.0)
|
self.thickness / 2.0)
|
||||||
|
|
||||||
|
## This class defines a grid. A grid is represented by a 2D face patterned
|
||||||
|
# with small lines in the main direction of the grid frame. The valid
|
||||||
|
# parameters for grids are:
|
||||||
|
# - "Excentre": offset of the grid from the base face.
|
||||||
|
# - "angleAlpha": angle used to build the markers (see class
|
||||||
|
# \ref orientation.Orientation2D "salome.geom.structelem.orientation.Orientation2D")
|
||||||
|
# - "angleBeta": angle used to build the markers (see class
|
||||||
|
# \ref orientation.Orientation2D "salome.geom.structelem.orientation.Orientation2D")
|
||||||
|
# - "Vecteur": vector used instead of the angles to build the markers (see
|
||||||
|
# \ref orientation.Orientation2D "salome.geom.structelem.orientation.Orientation2D")
|
||||||
|
# - "origAxeX": X coordinate of the origin of the axis used to determine the
|
||||||
|
# orientation of the frame in the case of a cylindrical grid.
|
||||||
|
# - "origAxeY": Y coordinate of the origin of the axis used to determine the
|
||||||
|
# orientation of the frame in the case of a cylindrical grid.
|
||||||
|
# - "origAxeZ": Z coordinate of the origin of the axis used to determine the
|
||||||
|
# orientation of the frame in the case of a cylindrical grid.
|
||||||
|
# - "axeX": X coordinate of the axis used to determine the orientation of
|
||||||
|
# the frame in the case of a cylindrical grid.
|
||||||
|
# - "axeY": Y coordinate of the axis used to determine the orientation of
|
||||||
|
# the frame in the case of a cylindrical grid.
|
||||||
|
# - "axeZ": Z coordinate of the axis used to determine the orientation of
|
||||||
|
# the frame in the case of a cylindrical grid.
|
||||||
|
#
|
||||||
|
# See class StructuralElementPart for the description of the other parameters.
|
||||||
|
# \ingroup parts
|
||||||
class Grid(StructuralElementPart2D):
|
class Grid(StructuralElementPart2D):
|
||||||
"""
|
"""
|
||||||
This class defines a grid. A grid is represented by a 2D face patterned
|
This class defines a grid. A grid is represented by a 2D face patterned
|
||||||
@ -839,6 +992,7 @@ class Grid(StructuralElementPart2D):
|
|||||||
self.vz = self._getParameter(["axeZ"])
|
self.vz = self._getParameter(["axeZ"])
|
||||||
logger.debug(repr(self))
|
logger.debug(repr(self))
|
||||||
|
|
||||||
|
## Create the geometrical shapes representing the grid.
|
||||||
def _buildPart(self):
|
def _buildPart(self):
|
||||||
"""
|
"""
|
||||||
Create the geometrical shapes representing the grid.
|
Create the geometrical shapes representing the grid.
|
||||||
@ -867,6 +1021,8 @@ class Grid(StructuralElementPart2D):
|
|||||||
else:
|
else:
|
||||||
return self.geom.MakeCompound(listGridShapes)
|
return self.geom.MakeCompound(listGridShapes)
|
||||||
|
|
||||||
|
## Create the geometrical shapes representing the grid for a given
|
||||||
|
# non-cylindrical face.
|
||||||
def _buildGridForNormalFace(self, face):
|
def _buildGridForNormalFace(self, face):
|
||||||
"""
|
"""
|
||||||
Create the geometrical shapes representing the grid for a given
|
Create the geometrical shapes representing the grid for a given
|
||||||
@ -902,6 +1058,8 @@ class Grid(StructuralElementPart2D):
|
|||||||
grid = self.geom.MakeCompound(gridList)
|
grid = self.geom.MakeCompound(gridList)
|
||||||
return grid
|
return grid
|
||||||
|
|
||||||
|
## Create the geometrical shapes representing the grid for a given
|
||||||
|
# cylindrical face.
|
||||||
def _buildGridForCylinderFace(self, face):
|
def _buildGridForCylinderFace(self, face):
|
||||||
"""
|
"""
|
||||||
Create the geometrical shapes representing the grid for a given
|
Create the geometrical shapes representing the grid for a given
|
||||||
@ -941,13 +1099,15 @@ class Grid(StructuralElementPart2D):
|
|||||||
grid = self.geom.MakeCompound(gridList)
|
grid = self.geom.MakeCompound(gridList)
|
||||||
return grid
|
return grid
|
||||||
|
|
||||||
|
## Create the markers defining the orientation of the grid.
|
||||||
def _buildMarkers(self):
|
def _buildMarkers(self):
|
||||||
"""
|
"""
|
||||||
Create the markers defining the orientation of the grid.
|
Create the markers defining the orientation of the grid.
|
||||||
"""
|
"""
|
||||||
return self._buildMarkersWithOffset(self.offset)
|
return self._buildMarkersWithOffset(self.offset)
|
||||||
|
|
||||||
|
## Alias for class GeneralBeam.
|
||||||
|
# \ingroup parts
|
||||||
def VisuPoutreGenerale(studyId, groupName, groupGeomObj, parameters,
|
def VisuPoutreGenerale(studyId, groupName, groupGeomObj, parameters,
|
||||||
name = "POUTRE"):
|
name = "POUTRE"):
|
||||||
"""
|
"""
|
||||||
@ -955,6 +1115,8 @@ def VisuPoutreGenerale(studyId, groupName, groupGeomObj, parameters,
|
|||||||
"""
|
"""
|
||||||
return GeneralBeam(studyId, groupName, groupGeomObj, parameters, name)
|
return GeneralBeam(studyId, groupName, groupGeomObj, parameters, name)
|
||||||
|
|
||||||
|
## Alias for class CircularBeam.
|
||||||
|
# \ingroup parts
|
||||||
def VisuPoutreCercle(studyId, groupName, groupGeomObj, parameters,
|
def VisuPoutreCercle(studyId, groupName, groupGeomObj, parameters,
|
||||||
name = "POUTRE"):
|
name = "POUTRE"):
|
||||||
"""
|
"""
|
||||||
@ -962,6 +1124,8 @@ def VisuPoutreCercle(studyId, groupName, groupGeomObj, parameters,
|
|||||||
"""
|
"""
|
||||||
return CircularBeam(studyId, groupName, groupGeomObj, parameters, name)
|
return CircularBeam(studyId, groupName, groupGeomObj, parameters, name)
|
||||||
|
|
||||||
|
## Alias for class RectangularBeam.
|
||||||
|
# \ingroup parts
|
||||||
def VisuPoutreRectangle(studyId, groupName, groupGeomObj, parameters,
|
def VisuPoutreRectangle(studyId, groupName, groupGeomObj, parameters,
|
||||||
name = "POUTRE"):
|
name = "POUTRE"):
|
||||||
"""
|
"""
|
||||||
@ -969,6 +1133,8 @@ def VisuPoutreRectangle(studyId, groupName, groupGeomObj, parameters,
|
|||||||
"""
|
"""
|
||||||
return RectangularBeam(studyId, groupName, groupGeomObj, parameters, name)
|
return RectangularBeam(studyId, groupName, groupGeomObj, parameters, name)
|
||||||
|
|
||||||
|
## Alias for class GeneralBeam.
|
||||||
|
# \ingroup parts
|
||||||
def VisuBarreGenerale(studyId, groupName, groupGeomObj, parameters,
|
def VisuBarreGenerale(studyId, groupName, groupGeomObj, parameters,
|
||||||
name = "BARRE"):
|
name = "BARRE"):
|
||||||
"""
|
"""
|
||||||
@ -977,6 +1143,8 @@ def VisuBarreGenerale(studyId, groupName, groupGeomObj, parameters,
|
|||||||
return GeneralBeam(studyId, groupName, groupGeomObj, parameters, name,
|
return GeneralBeam(studyId, groupName, groupGeomObj, parameters, name,
|
||||||
color = ORANGE)
|
color = ORANGE)
|
||||||
|
|
||||||
|
## Alias for class RectangularBeam.
|
||||||
|
# \ingroup parts
|
||||||
def VisuBarreRectangle(studyId, groupName, groupGeomObj, parameters,
|
def VisuBarreRectangle(studyId, groupName, groupGeomObj, parameters,
|
||||||
name = "BARRE"):
|
name = "BARRE"):
|
||||||
"""
|
"""
|
||||||
@ -985,6 +1153,8 @@ def VisuBarreRectangle(studyId, groupName, groupGeomObj, parameters,
|
|||||||
return RectangularBeam(studyId, groupName, groupGeomObj, parameters, name,
|
return RectangularBeam(studyId, groupName, groupGeomObj, parameters, name,
|
||||||
color = ORANGE)
|
color = ORANGE)
|
||||||
|
|
||||||
|
## Alias for class CircularBeam.
|
||||||
|
# \ingroup parts
|
||||||
def VisuBarreCercle(studyId, groupName, groupGeomObj, parameters,
|
def VisuBarreCercle(studyId, groupName, groupGeomObj, parameters,
|
||||||
name = "BARRE"):
|
name = "BARRE"):
|
||||||
"""
|
"""
|
||||||
@ -993,6 +1163,8 @@ def VisuBarreCercle(studyId, groupName, groupGeomObj, parameters,
|
|||||||
return CircularBeam(studyId, groupName, groupGeomObj, parameters, name,
|
return CircularBeam(studyId, groupName, groupGeomObj, parameters, name,
|
||||||
color = ORANGE)
|
color = ORANGE)
|
||||||
|
|
||||||
|
## Alias for class CircularBeam.
|
||||||
|
# \ingroup parts
|
||||||
def VisuCable(studyId, groupName, groupGeomObj, parameters, name = "CABLE"):
|
def VisuCable(studyId, groupName, groupGeomObj, parameters, name = "CABLE"):
|
||||||
"""
|
"""
|
||||||
Alias for class :class:`CircularBeam`.
|
Alias for class :class:`CircularBeam`.
|
||||||
@ -1000,12 +1172,16 @@ def VisuCable(studyId, groupName, groupGeomObj, parameters, name = "CABLE"):
|
|||||||
return CircularBeam(studyId, groupName, groupGeomObj, parameters, name,
|
return CircularBeam(studyId, groupName, groupGeomObj, parameters, name,
|
||||||
color = PURPLE)
|
color = PURPLE)
|
||||||
|
|
||||||
|
## Alias for class ThickShell.
|
||||||
|
# \ingroup parts
|
||||||
def VisuCoque(studyId, groupName, groupGeomObj, parameters, name = "COQUE"):
|
def VisuCoque(studyId, groupName, groupGeomObj, parameters, name = "COQUE"):
|
||||||
"""
|
"""
|
||||||
Alias for class :class:`ThickShell`.
|
Alias for class :class:`ThickShell`.
|
||||||
"""
|
"""
|
||||||
return ThickShell(studyId, groupName, groupGeomObj, parameters, name)
|
return ThickShell(studyId, groupName, groupGeomObj, parameters, name)
|
||||||
|
|
||||||
|
## Alias for class Grid.
|
||||||
|
# \ingroup parts
|
||||||
def VisuGrille(studyId, groupName, groupGeomObj, parameters, name = "GRILLE"):
|
def VisuGrille(studyId, groupName, groupGeomObj, parameters, name = "GRILLE"):
|
||||||
"""
|
"""
|
||||||
Alias for class :class:`Grid`.
|
Alias for class :class:`Grid`.
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
##
|
##
|
||||||
## @defgroup l1_publish_data Publishing results in SALOME study
|
## @defgroup geomBuilder geomBuilder Python module
|
||||||
## @{
|
## @{
|
||||||
##
|
##
|
||||||
## @details
|
## @details
|
||||||
@ -184,8 +184,12 @@
|
|||||||
## it only affects on the representation of the data tree.
|
## it only affects on the representation of the data tree.
|
||||||
## - It is impossible to publish geometry object using any folder as father.
|
## - It is impossible to publish geometry object using any folder as father.
|
||||||
##
|
##
|
||||||
|
## \defgroup l1_publish_data
|
||||||
|
## \defgroup l1_geomBuilder_auxiliary
|
||||||
|
## \defgroup l1_geomBuilder_purpose
|
||||||
## @}
|
## @}
|
||||||
|
|
||||||
|
## @defgroup l1_publish_data Publishing results in SALOME study
|
||||||
|
|
||||||
## @defgroup l1_geomBuilder_auxiliary Auxiliary data structures and methods
|
## @defgroup l1_geomBuilder_auxiliary Auxiliary data structures and methods
|
||||||
|
|
||||||
@ -504,7 +508,7 @@ class info:
|
|||||||
CLOSED = 1
|
CLOSED = 1
|
||||||
UNCLOSED = 2
|
UNCLOSED = 2
|
||||||
|
|
||||||
##! Private class used to bind calls of plugin operations to geomBuilder
|
## Private class used to bind calls of plugin operations to geomBuilder
|
||||||
class PluginOperation:
|
class PluginOperation:
|
||||||
def __init__(self, operation, function):
|
def __init__(self, operation, function):
|
||||||
self.operation = operation
|
self.operation = operation
|
||||||
|
@ -21,6 +21,38 @@
|
|||||||
# Author : Julia DOROVSKIKH, Open CASCADE S.A.S.
|
# Author : Julia DOROVSKIKH, Open CASCADE S.A.S.
|
||||||
# Module : GEOM_SWIG
|
# Module : GEOM_SWIG
|
||||||
|
|
||||||
|
## @defgroup sketcher sketcher - Wrapper to help the creation of simple sketches
|
||||||
|
# @{
|
||||||
|
# @details
|
||||||
|
# This module provides the user with a simple python API
|
||||||
|
# to realize various sketches from the GEOM text user interface.
|
||||||
|
# @n Example:
|
||||||
|
# @code
|
||||||
|
# import GEOM
|
||||||
|
# from salome.geom import geomBuilder
|
||||||
|
# geompy = geomBuilder.New(salome.myStudy)
|
||||||
|
#
|
||||||
|
# # create a wire for sketcher
|
||||||
|
# geomObj_1 = geompy.MakeMarker(0, 0, 0, 1, 0, 0, 0, 1, 0)
|
||||||
|
#
|
||||||
|
# # Create the sketch
|
||||||
|
# sk = geompy.Sketcher2D()
|
||||||
|
# sk.addPoint(0.000000, 0.000000)
|
||||||
|
# sk.addSegmentAbsolute(50.000000, 50.000000)
|
||||||
|
# sk.addSegmentPerpY(0.000000)
|
||||||
|
# sk.addArcAbsolute(0.000000, 0.000000)
|
||||||
|
# sk.close()
|
||||||
|
# Sketch_1 = sk.wire(geomObj_1)
|
||||||
|
#
|
||||||
|
# # add objects in the study
|
||||||
|
# geompy.addToStudy( Sketch_1, 'Sketch_1' )
|
||||||
|
#
|
||||||
|
# # update object browser
|
||||||
|
# salome.sg.updateObjBrowser(1)
|
||||||
|
# @endcode
|
||||||
|
# @n Additionnal examples can be found as unit tests in the source code.
|
||||||
|
# @}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
\namespace geompy
|
\namespace geompy
|
||||||
\brief 2D and 3D Sketcher interfaces
|
\brief 2D and 3D Sketcher interfaces
|
||||||
@ -37,6 +69,7 @@ def printVar (var):
|
|||||||
# Use geompy.Sketcher3D() method to obtain an instance of this class.
|
# Use geompy.Sketcher3D() method to obtain an instance of this class.
|
||||||
#
|
#
|
||||||
# @ref tui_3dsketcher_page "Example"
|
# @ref tui_3dsketcher_page "Example"
|
||||||
|
# @ingroup sketcher
|
||||||
class Sketcher3D:
|
class Sketcher3D:
|
||||||
"""
|
"""
|
||||||
3D sketcher interface.
|
3D sketcher interface.
|
||||||
@ -284,9 +317,9 @@ class Sketcher3D:
|
|||||||
self.geompyD._autoPublish(wire, theName, "wire")
|
self.geompyD._autoPublish(wire, theName, "wire")
|
||||||
return wire
|
return wire
|
||||||
|
|
||||||
# An interface to build a 2D Sketcher step-by-step.
|
## An interface to build a 2D Sketcher step-by-step.
|
||||||
# Use geompy.Sketcher2D() method to obtain an instance of this class.
|
# Use geompy.Sketcher2D() method to obtain an instance of this class.
|
||||||
|
# @ingroup sketcher
|
||||||
class Sketcher2D:
|
class Sketcher2D:
|
||||||
"""
|
"""
|
||||||
2D sketcher interface.
|
2D sketcher interface.
|
||||||
|
Loading…
Reference in New Issue
Block a user