mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-04-02 15:34:30 +05:00
174 lines
6.0 KiB
Python
174 lines
6.0 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
# Copyright (C) 2007-2011 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.
|
|
#
|
|
# 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
|
|
#
|
|
"""
|
|
This module provides tools to facilitate the use of geom engine and geom
|
|
objects in Salome.
|
|
"""
|
|
|
|
import salome
|
|
GEOM = None # GEOM module is loaded only when needed
|
|
|
|
from salome.kernel.logger import Logger
|
|
from salome.kernel import termcolor
|
|
logger = Logger("salome.geom.geomtools", color = termcolor.RED)
|
|
|
|
from salome.kernel.studyedit import getActiveStudyId, getStudyEditor
|
|
from salome.gui import helper
|
|
from salome.kernel.services import IDToObject
|
|
|
|
_geompys = {}
|
|
|
|
def getGeompy(studyId = None):
|
|
"""
|
|
Return an object behaving exactly like geompy module, except that it is
|
|
associated with the study `studyId`. If `studyId` is :const:`None`, return
|
|
a pseudo geompy object for the current study.
|
|
"""
|
|
# We can't use geompy module because it initializes GEOM with
|
|
# salome.myStudy, which may not exist. So we use this trick to create
|
|
# a pseudo geompy module.
|
|
salome.salome_init()
|
|
if studyId is None:
|
|
studyId = getActiveStudyId()
|
|
if not _geompys.has_key(studyId):
|
|
import geompyDC
|
|
_geompys[studyId] = salome.lcc.FindOrLoadComponent("FactoryServer",
|
|
"GEOM")
|
|
_geompys[studyId].ShapeType = geompyDC.ShapeType
|
|
_geompys[studyId].GEOM = geompyDC.GEOM
|
|
_geompys[studyId].kind = geompyDC.kind
|
|
_geompys[studyId].info = geompyDC.info
|
|
_geompys[studyId].PackData = geompyDC.PackData
|
|
_geompys[studyId].ReadTexture = geompyDC.ReadTexture
|
|
study = salome.myStudyManager.GetStudyByID(studyId)
|
|
_geompys[studyId].init_geom(study)
|
|
return _geompys[studyId]
|
|
|
|
|
|
ModeWireFrame = 0
|
|
ModeShading = 1
|
|
DisplayMode=ModeShading
|
|
|
|
class GeomStudyTools:
|
|
"""
|
|
This class provides several methods to manipulate geom objects in Salome
|
|
study. The parameter `studyEditor` defines a
|
|
:class:`~salome.kernel.studyedit.StudyEditor` object used to access the study. If
|
|
:const:`None`, the method returns a :class:`~salome.kernel.studyedit.StudyEditor`
|
|
object on the current study.
|
|
|
|
.. attribute:: editor
|
|
|
|
This instance attribute contains the underlying
|
|
:class:`~salome.kernel.studyedit.StudyEditor` object. It can be used to access
|
|
the study but the attribute itself should not be modified.
|
|
|
|
"""
|
|
|
|
def __init__(self, studyEditor = None):
|
|
global GEOM
|
|
if GEOM is None:
|
|
GEOM = __import__("GEOM")
|
|
if studyEditor is None:
|
|
studyEditor = helper.getStudyEditor()
|
|
self.editor = studyEditor
|
|
|
|
def displayShapeByName(self, shapeName, color = None):
|
|
"""
|
|
Display the geometrical shape whose name in the study is `shapeName`.
|
|
|
|
:type shapeName: string
|
|
:param shapeName: name of the geometrical shape
|
|
|
|
:type color: tuple (triplet)
|
|
:param color: RGB components of the color of the shape
|
|
|
|
:return: True if the shape was found, False otherwise
|
|
"""
|
|
logger.debug("displayShapeByName in PAL: %s with color %s" %
|
|
(shapeName, color))
|
|
listSO = self.editor.study.FindObjectByName(shapeName, "GEOM")
|
|
for sObj in listSO:
|
|
entry = sObj.GetID()
|
|
geomObj = self.editor.getOrLoadObject(sObj)
|
|
if geomObj:
|
|
shape = geomObj._narrow(GEOM.GEOM_Object)
|
|
if shape:
|
|
geomgui = salome.ImportComponentGUI("GEOM")
|
|
geomgui.createAndDisplayGO(entry)
|
|
geomgui.setDisplayMode(entry, DisplayMode)
|
|
if color is not None:
|
|
geomgui.setColor(entry, color[0], color[1], color[2])
|
|
return True
|
|
return False
|
|
|
|
def getGeomObjectSelected(self):
|
|
'''
|
|
Returns the GEOM object currently selected in the objects browser.
|
|
'''
|
|
sobject, entry = helper.getSObjectSelected()
|
|
geomObject = self.getGeomObjectFromEntry(entry)
|
|
return geomObject
|
|
|
|
def getGeomObjectFromEntry(self,entry):
|
|
'''
|
|
Returns the GEOM object associated to the specified entry,
|
|
(the entry is the identifier of an item in the active study)
|
|
'''
|
|
if entry is None:
|
|
return None
|
|
geomObject=IDToObject(entry, self.editor.study)
|
|
return geomObject._narrow(GEOM.GEOM_Object)
|
|
|
|
#
|
|
# ==================================================================
|
|
# Use cases and demo functions
|
|
# ==================================================================
|
|
#
|
|
|
|
# How to test?
|
|
# 1. Run a SALOME application including GEOM, and create a new study
|
|
# 2. In the console, enter:
|
|
# >>> from salome.geom import geomtools
|
|
# >>> geomtools.TEST_createBox()
|
|
# 3. Select the object named "box" in the browser
|
|
# 4. In the console, enter:
|
|
# >>> geomtools.TEST_getGeomObjectSelected()
|
|
|
|
def TEST_createBox():
|
|
geompy = getGeompy()
|
|
box = geompy.MakeBoxDXDYDZ(200, 200, 200)
|
|
geompy.addToStudy( box, 'box' )
|
|
if salome.sg.hasDesktop():
|
|
salome.sg.updateObjBrowser(1)
|
|
|
|
|
|
def TEST_getGeomObjectSelected():
|
|
tool = GeomStudyTools()
|
|
myGeomObject = tool.getGeomObjectSelected()
|
|
print myGeomObject
|
|
|
|
if __name__ == "__main__":
|
|
TEST_getGeomObjectSelected()
|
|
|
|
|
|
|