mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-02-11 12:53:09 +05:00
0021830: [CEA 652] TUI createAndDisplayGO
This commit is contained in:
parent
03a4ab784b
commit
0ac708f1b0
@ -66,12 +66,14 @@ _libGEOM_Swig_la_CPPFLAGS = \
|
|||||||
-I$(srcdir)/../OBJECT \
|
-I$(srcdir)/../OBJECT \
|
||||||
-I$(srcdir)/../GEOMGUI \
|
-I$(srcdir)/../GEOMGUI \
|
||||||
-I$(srcdir)/../GEOMToolsGUI \
|
-I$(srcdir)/../GEOMToolsGUI \
|
||||||
|
-I$(srcdir)/../Material \
|
||||||
-I$(top_builddir)/idl
|
-I$(top_builddir)/idl
|
||||||
|
|
||||||
_libGEOM_Swig_la_LDFLAGS = -module
|
_libGEOM_Swig_la_LDFLAGS = -module
|
||||||
_libGEOM_Swig_la_LIBADD = \
|
_libGEOM_Swig_la_LIBADD = \
|
||||||
../GEOMGUI/libGEOM.la \
|
../GEOMGUI/libGEOM.la \
|
||||||
../GEOMToolsGUI/libGEOMToolsGUI.la \
|
../GEOMToolsGUI/libGEOMToolsGUI.la \
|
||||||
|
../Material/libMaterial.la \
|
||||||
$(PYTHON_LIBS)
|
$(PYTHON_LIBS)
|
||||||
|
|
||||||
swig_wrap.cpp : $(SWIG_SOURCES)
|
swig_wrap.cpp : $(SWIG_SOURCES)
|
||||||
|
@ -19,313 +19,275 @@
|
|||||||
//
|
//
|
||||||
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
//
|
//
|
||||||
|
|
||||||
// GEOM GEOMGUI : GUI for Geometry component
|
|
||||||
// File : libGEOM_Swig.cxx
|
// File : libGEOM_Swig.cxx
|
||||||
// Author : Nicolas REJNERI, Paul RASCLE
|
// Author : Nicolas REJNERI, Paul RASCLE
|
||||||
//
|
|
||||||
#include "libGEOM_Swig.h"
|
#include "libGEOM_Swig.h"
|
||||||
|
|
||||||
#include "GeometryGUI.h"
|
#include "GeometryGUI.h"
|
||||||
#include "GEOMToolsGUI.h"
|
|
||||||
|
|
||||||
#include "SUIT_Desktop.h"
|
|
||||||
#include "SUIT_Session.h"
|
|
||||||
#include "SalomeApp_Application.h"
|
|
||||||
#include "SalomeApp_Study.h"
|
|
||||||
|
|
||||||
#include "OB_Browser.h"
|
|
||||||
|
|
||||||
#include "OCCViewer_ViewWindow.h"
|
|
||||||
#include "OCCViewer_ViewManager.h"
|
|
||||||
#include "SOCC_ViewModel.h"
|
|
||||||
#include <SOCC_Prs.h>
|
|
||||||
|
|
||||||
#include "SVTK_ViewModel.h"
|
|
||||||
#include "SVTK_ViewWindow.h"
|
|
||||||
#include "SVTK_View.h"
|
|
||||||
#include "SVTK_Renderer.h"
|
|
||||||
#include <SVTK_Prs.h>
|
|
||||||
|
|
||||||
#include "GEOM_Actor.h"
|
|
||||||
#include "GEOM_Client.hxx"
|
|
||||||
#include "GEOM_AISShape.hxx"
|
|
||||||
#include "GEOM_InteractiveObject.hxx"
|
|
||||||
#include "GEOM_Displayer.h"
|
#include "GEOM_Displayer.h"
|
||||||
#include "GEOM_Constants.h"
|
#include "GEOM_Constants.h"
|
||||||
|
#include "Material_Model.h"
|
||||||
|
|
||||||
#include "SALOME_Event.h"
|
#include <SUIT_Desktop.h>
|
||||||
|
#include <SUIT_Session.h>
|
||||||
|
#include <SUIT_ViewManager.h>
|
||||||
|
#include <SUIT_ViewModel.h>
|
||||||
|
#include <SalomeApp_Application.h>
|
||||||
|
#include <SalomeApp_Study.h>
|
||||||
|
#include <OCCViewer_ViewFrame.h>
|
||||||
|
#include <SVTK_ViewWindow.h>
|
||||||
|
|
||||||
// OCCT Includes
|
#include <SALOME_Event.h>
|
||||||
#include <TopAbs.hxx>
|
|
||||||
#include <TopoDS_Shape.hxx>
|
|
||||||
#include <AIS_ListOfInteractive.hxx>
|
|
||||||
#include <AIS_ListIteratorOfListOfInteractive.hxx>
|
|
||||||
#include <AIS_Drawer.hxx>
|
|
||||||
#include <Prs3d_IsoAspect.hxx>
|
|
||||||
#include <BRepTools.hxx>
|
|
||||||
|
|
||||||
// IDL Headers
|
// IDL Headers
|
||||||
#include <SALOMEconfig.h>
|
#include <SALOMEconfig.h>
|
||||||
#include CORBA_SERVER_HEADER(GEOM_Gen)
|
#include CORBA_SERVER_HEADER(GEOM_Gen)
|
||||||
|
|
||||||
#include <vtkRenderer.h>
|
/*!
|
||||||
|
\brief Constructor
|
||||||
static SHAPE_READER(ShapeReader);
|
*/
|
||||||
|
|
||||||
inline OCCViewer_Viewer* GetOCCViewer(SUIT_Application* theApp){
|
|
||||||
SUIT_ViewWindow* window = theApp->desktop()->activeWindow();
|
|
||||||
if(window && window->getViewManager()->getType() == OCCViewer_Viewer::Type()){
|
|
||||||
OCCViewer_ViewWindow* vw = dynamic_cast<OCCViewer_ViewWindow*>( window );
|
|
||||||
if ( vw ) {
|
|
||||||
OCCViewer_ViewManager* vm = dynamic_cast<OCCViewer_ViewManager*>( vw->getViewManager() );
|
|
||||||
if ( vm )
|
|
||||||
return vm->getOCCViewer();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline SVTK_ViewWindow* GetSVTKViewWindow(SUIT_Application* theApp){
|
|
||||||
SUIT_ViewWindow* window = theApp->desktop()->activeWindow();
|
|
||||||
if(window && window->getViewManager()->getType() == SVTK_Viewer::Type())
|
|
||||||
return dynamic_cast<SVTK_ViewWindow*>( window );
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
GEOM_Swig::GEOM_Swig()
|
GEOM_Swig::GEOM_Swig()
|
||||||
{
|
{
|
||||||
// MESSAGE("Constructeur");
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Destructor
|
||||||
|
*/
|
||||||
GEOM_Swig::~GEOM_Swig()
|
GEOM_Swig::~GEOM_Swig()
|
||||||
{
|
{
|
||||||
// MESSAGE("Destructeur");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GEOM_Swig::createAndDisplayGO (const char* Entry, bool theUpdateViewer)
|
/*!
|
||||||
|
\brief Internal initialization
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::init()
|
||||||
|
{
|
||||||
|
class TEvent: public SALOME_Event
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
TEvent()
|
||||||
|
{}
|
||||||
|
virtual void Execute()
|
||||||
|
{
|
||||||
|
// check active study
|
||||||
|
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
||||||
|
if (!app) return;
|
||||||
|
|
||||||
|
SalomeApp_Study* study = dynamic_cast<SalomeApp_Study*>( app->activeStudy() );
|
||||||
|
if ( !study ) return;
|
||||||
|
|
||||||
|
_PTR(Study) studyDS( study->studyDS() );
|
||||||
|
_PTR(StudyBuilder) builder = studyDS->NewBuilder();
|
||||||
|
|
||||||
|
// get/init GEOM engine
|
||||||
|
GEOM::GEOM_Gen_var engine = GeometryGUI::GetGeomGen();
|
||||||
|
if ( CORBA::is_nil( engine ) )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// find GEOM component in the study
|
||||||
|
_PTR(SComponent) component = studyDS->FindComponent( "GEOM" );
|
||||||
|
if ( !component )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// load GEOM data (if it is not done yet)
|
||||||
|
std::string ior;
|
||||||
|
if ( !component->ComponentIOR( ior ) ) {
|
||||||
|
CORBA::String_var engineIOR = SalomeApp_Application::orb()->object_to_string( engine );
|
||||||
|
builder->LoadWith( component, engineIOR.in() );
|
||||||
|
}
|
||||||
|
|
||||||
|
// update Object browser
|
||||||
|
if ( dynamic_cast<SalomeApp_Application*>( app ) )
|
||||||
|
dynamic_cast<SalomeApp_Application*>( app )->updateObjectBrowser( true );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
ProcessVoidEvent( new TEvent() );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Display the presenation in the currently active view
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::createAndDisplayGO( const char* theEntry, bool theUpdateViewer )
|
||||||
{
|
{
|
||||||
class TEvent: public SALOME_Event
|
class TEvent: public SALOME_Event
|
||||||
{
|
{
|
||||||
std::string myEntry;
|
std::string myEntry;
|
||||||
bool myUpdateViewer;
|
bool myUpdateViewer;
|
||||||
public:
|
public:
|
||||||
TEvent(const char* theEntry, bool toUpdateViewer):
|
TEvent( const char* _entry, bool _update ):
|
||||||
myEntry(theEntry),
|
myEntry( _entry ), myUpdateViewer( _update )
|
||||||
myUpdateViewer(toUpdateViewer)
|
|
||||||
{}
|
{}
|
||||||
virtual void Execute()
|
virtual void Execute()
|
||||||
{
|
{
|
||||||
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
||||||
if (!app) return;
|
if ( !app ) return;
|
||||||
|
SalomeApp_Study* study = dynamic_cast<SalomeApp_Study*>( app->activeStudy() );
|
||||||
|
if ( !study ) return;
|
||||||
|
|
||||||
SalomeApp_Study* ActiveStudy = dynamic_cast<SalomeApp_Study*>(app->activeStudy());
|
Handle(SALOME_InteractiveObject) io = new SALOME_InteractiveObject( myEntry.c_str(), "GEOM", "" );
|
||||||
if (!ActiveStudy) return;
|
|
||||||
|
|
||||||
_PTR(Study) aStudy(ActiveStudy->studyDS());
|
GEOM_Displayer( study ).Display( io, myUpdateViewer );
|
||||||
_PTR(StudyBuilder) aStudyBuilder = aStudy->NewBuilder();
|
|
||||||
|
|
||||||
GEOM::GEOM_Gen_var Geom = GeometryGUI::GetGeomGen();
|
|
||||||
if (CORBA::is_nil(Geom)) {
|
|
||||||
GeometryGUI::InitGeomGen();
|
|
||||||
Geom = GeometryGUI::GetGeomGen();
|
|
||||||
}
|
|
||||||
if (CORBA::is_nil(Geom))
|
|
||||||
return;
|
|
||||||
|
|
||||||
std::string aFatherIOR;
|
|
||||||
_PTR(SComponent) father = aStudy->FindComponent("GEOM");
|
|
||||||
if (!father)
|
|
||||||
return;
|
|
||||||
if (!father->ComponentIOR(aFatherIOR)) {
|
|
||||||
CORBA::String_var objStr = SalomeApp_Application::orb()->object_to_string(Geom);
|
|
||||||
aStudyBuilder->LoadWith(father, objStr.in());
|
|
||||||
father->ComponentIOR(aFatherIOR);
|
|
||||||
}
|
|
||||||
|
|
||||||
_PTR(SObject) obj = aStudy->FindObjectID(myEntry);
|
|
||||||
if (!obj)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// Create new actor
|
|
||||||
_PTR(GenericAttribute) anAttr;
|
|
||||||
if (!obj->FindAttribute(anAttr, "AttributeIOR"))
|
|
||||||
return;
|
|
||||||
_PTR(AttributeIOR) anIOR(anAttr);
|
|
||||||
std::string anIORValue = anIOR->Value();
|
|
||||||
|
|
||||||
GEOM::GEOM_Object_var aShape = Geom->GetIORFromString(anIORValue.c_str());
|
|
||||||
TopoDS_Shape Shape = ShapeReader.GetShape(Geom,aShape);
|
|
||||||
if (!Shape.IsNull()) {
|
|
||||||
if (obj->FindAttribute(anAttr, "AttributeName")) {
|
|
||||||
_PTR(AttributeName) aName (anAttr);
|
|
||||||
std::string aNameValue = aName->Value();
|
|
||||||
// open transaction
|
|
||||||
/*SUIT_Operation* op = new SalomeApp_ImportOperation (app);
|
|
||||||
op->start();
|
|
||||||
|
|
||||||
_PTR(SObject) newObj1 = aStudyBuilder->NewObject(father);
|
|
||||||
aStudyBuilder->Addreference(newObj1, obj);
|
|
||||||
// commit transaction
|
|
||||||
op->commit();*/
|
|
||||||
Handle(GEOM_InteractiveObject) anIO =
|
|
||||||
new GEOM_InteractiveObject (const_cast<char*>(anIORValue.c_str()),
|
|
||||||
const_cast<char*>(aFatherIOR.c_str()),
|
|
||||||
"GEOM",
|
|
||||||
const_cast<char*>( obj->GetID().c_str()));
|
|
||||||
|
|
||||||
GEOM_Displayer(ActiveStudy).Display(anIO, myUpdateViewer);
|
|
||||||
/*if (SVTK_ViewWindow* aViewWindow = GetSVTKViewWindow(app)) {
|
|
||||||
SVTK_View* aView = aViewWindow->getView();
|
|
||||||
int aMode = aView->GetDisplayMode();
|
|
||||||
|
|
||||||
vtkActorCollection* theActors =
|
|
||||||
GEOM_AssemblyBuilder::BuildActors(Shape,0,aMode,true);
|
|
||||||
theActors->InitTraversal();
|
|
||||||
while (vtkActor* anActor = theActors->GetNextActor()) {
|
|
||||||
GEOM_Actor* GActor = GEOM_Actor::SafeDownCast(anActor);
|
|
||||||
GActor->setName(const_cast<char*>(aNameValue.c_str()));
|
|
||||||
GActor->setIO(anIO);
|
|
||||||
aView->Display(GActor);
|
|
||||||
}
|
|
||||||
aView->Repaint();
|
|
||||||
} else if (OCCViewer_Viewer* occViewer = GetOCCViewer(app)) {
|
|
||||||
Handle(AIS_InteractiveContext) ic = occViewer->getAISContext();
|
|
||||||
Handle(GEOM_AISShape) aSh =
|
|
||||||
new GEOM_AISShape (Shape,const_cast<char*>(aNameValue.c_str()));
|
|
||||||
aSh->setName(const_cast<char*>(aNameValue.c_str()));
|
|
||||||
aSh->setIO(anIO);
|
|
||||||
ic->Display(aSh);
|
|
||||||
ic->AddOrRemoveCurrentObject(aSh,true);
|
|
||||||
}*/
|
|
||||||
// update object browser
|
|
||||||
SalomeApp_Application* app = NULL; //dynamic_cast<SalomeApp_Application*>(app);
|
|
||||||
if (app) {
|
|
||||||
CAM_Module* module = app->module("Geometry");
|
|
||||||
SalomeApp_Module* appMod = dynamic_cast<SalomeApp_Module*>(module);
|
|
||||||
if (appMod)
|
|
||||||
appMod->updateObjBrowser(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// MESSAGE("createAndDisplayGO");
|
ProcessVoidEvent( new TEvent( theEntry, theUpdateViewer ) );
|
||||||
ProcessVoidEvent(new TEvent (Entry, theUpdateViewer));
|
|
||||||
|
|
||||||
class TEventUpdateBrowser: public SALOME_Event
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
TEventUpdateBrowser() {}
|
|
||||||
virtual void Execute() {
|
|
||||||
SalomeApp_Application* app =
|
|
||||||
dynamic_cast<SalomeApp_Application*>(SUIT_Session::session()->activeApplication());
|
|
||||||
if (app) {
|
|
||||||
CAM_Module* module = app->module("Geometry");
|
|
||||||
SalomeApp_Module* appMod = dynamic_cast<SalomeApp_Module*>(module);
|
|
||||||
if (appMod) appMod->updateObjBrowser(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
if (theUpdateViewer)
|
|
||||||
ProcessVoidEvent(new TEventUpdateBrowser ());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GEOM_Swig::createAndDisplayFitAllGO (const char* Entry)
|
/*!
|
||||||
|
\brief Same as createAndDisplayGO, but also fits the active view to the contents
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::createAndDisplayFitAllGO( const char* theEntry )
|
||||||
{
|
{
|
||||||
|
// display object
|
||||||
|
createAndDisplayGO( theEntry );
|
||||||
|
|
||||||
|
// fit all the view
|
||||||
class TEventFitAll: public SALOME_Event
|
class TEventFitAll: public SALOME_Event
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
TEventFitAll() {}
|
TEventFitAll() {}
|
||||||
virtual void Execute() {
|
virtual void Execute()
|
||||||
|
{
|
||||||
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
||||||
if (!app) return;
|
if ( app ) {
|
||||||
|
SUIT_ViewWindow* window = app->desktop()->activeWindow();
|
||||||
if (SVTK_ViewWindow* aViewWindow = GetSVTKViewWindow(app))
|
if ( dynamic_cast<SVTK_ViewWindow*>( window ) )
|
||||||
{
|
dynamic_cast<SVTK_ViewWindow*>( window )->onFitAll();
|
||||||
SVTK_View* aView = aViewWindow->getView();
|
else if ( dynamic_cast<OCCViewer_ViewFrame*>( window ) )
|
||||||
aView->GetRenderer()->OnFitAll();
|
dynamic_cast<OCCViewer_ViewFrame*>( window )->onViewFitAll();
|
||||||
}
|
|
||||||
else if (OCCViewer_Viewer* occViewer = GetOCCViewer(app))
|
|
||||||
{
|
|
||||||
Handle(V3d_Viewer) aViewer3d = occViewer->getViewer3d();
|
|
||||||
aViewer3d->InitActiveViews();
|
|
||||||
|
|
||||||
if (aViewer3d->MoreActiveViews())
|
|
||||||
aViewer3d->ActiveView()->FitAll();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
createAndDisplayGO(Entry);
|
ProcessVoidEvent( new TEventFitAll() );
|
||||||
ProcessVoidEvent(new TEventFitAll());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Erase presentation in the currently active viewer
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::eraseGO( const char* theEntry, bool theUpdateViewer )
|
||||||
|
{
|
||||||
|
class TEvent: public SALOME_Event
|
||||||
|
{
|
||||||
|
std::string myEntry;
|
||||||
|
bool myUpdateViewer;
|
||||||
|
public:
|
||||||
|
TEvent( const char* _entry, bool _update ):
|
||||||
|
myEntry( _entry ), myUpdateViewer( _update )
|
||||||
|
{}
|
||||||
|
virtual void Execute()
|
||||||
|
{
|
||||||
|
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
||||||
|
if ( !app ) return;
|
||||||
|
SalomeApp_Study* study = dynamic_cast<SalomeApp_Study*>( app->activeStudy() );
|
||||||
|
if ( !study ) return;
|
||||||
|
|
||||||
|
Handle(SALOME_InteractiveObject) io = new SALOME_InteractiveObject( myEntry.c_str(), "GEOM", "" );
|
||||||
|
|
||||||
|
GEOM_Displayer( study ).Erase( io, true, myUpdateViewer );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
ProcessVoidEvent( new TEvent( theEntry, theUpdateViewer ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Update active viewer contents
|
||||||
|
*/
|
||||||
void GEOM_Swig::UpdateViewer()
|
void GEOM_Swig::UpdateViewer()
|
||||||
{
|
{
|
||||||
class TEventUpdateViewer: public SALOME_Event
|
class TEventUpdateViewer: public SALOME_Event
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
TEventUpdateViewer() {}
|
TEventUpdateViewer()
|
||||||
virtual void Execute() {
|
{}
|
||||||
|
virtual void Execute()
|
||||||
|
{
|
||||||
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
||||||
if (!app) return;
|
if ( !app ) return;
|
||||||
SalomeApp_Study* ActiveStudy = dynamic_cast<SalomeApp_Study*>(app->activeStudy());
|
|
||||||
if (!ActiveStudy) return;
|
|
||||||
|
|
||||||
GEOM_Displayer(ActiveStudy).UpdateViewer();
|
SalomeApp_Study* study = dynamic_cast<SalomeApp_Study*>( app->activeStudy() );
|
||||||
|
if ( !study ) return;
|
||||||
|
|
||||||
|
GEOM_Displayer( study ).UpdateViewer();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
ProcessVoidEvent(new TEventUpdateViewer());
|
ProcessVoidEvent(new TEventUpdateViewer());
|
||||||
}
|
}
|
||||||
|
|
||||||
int GEOM_Swig::getIndexTopology(const char* SubIOR, const char* IOR)
|
/*!
|
||||||
|
\brief Get sub-shape index inside main shape
|
||||||
|
\param theSubIOR sub-shape geometry object's IOR
|
||||||
|
\param theMainIOR main shape geometry object's IOR
|
||||||
|
\return sub-shape index (-1 in case of error)
|
||||||
|
*/
|
||||||
|
int GEOM_Swig::getIndexTopology( const char* theSubIOR, const char* theMainIOR )
|
||||||
{
|
{
|
||||||
|
int index = -1;
|
||||||
|
|
||||||
|
// get geom engine
|
||||||
GEOM::GEOM_Gen_var aGeomGen = GeometryGUI::GetGeomGen();
|
GEOM::GEOM_Gen_var aGeomGen = GeometryGUI::GetGeomGen();
|
||||||
if (CORBA::is_nil(aGeomGen))
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
GEOM::GEOM_Object_var aMainShape = aGeomGen->GetIORFromString(IOR);
|
// get main shape's geom object by IOR
|
||||||
GEOM::GEOM_Object_var aSubShape = aGeomGen->GetIORFromString(SubIOR);
|
CORBA::Object_var anObject = SalomeApp_Application::orb()->string_to_object( theMainIOR );
|
||||||
if (CORBA::is_nil(aMainShape) || CORBA::is_nil(aSubShape))
|
GEOM::GEOM_Object_var aMainShape = GEOM::GEOM_Object::_narrow( anObject.in() );
|
||||||
return -1;
|
// get sub-shape's geom object by IOR
|
||||||
|
anObject = SalomeApp_Application::orb()->string_to_object( theSubIOR );
|
||||||
|
GEOM::GEOM_Object_var aSubShape = GEOM::GEOM_Object::_narrow( anObject.in() );
|
||||||
|
|
||||||
|
if ( !CORBA::is_nil( aGeomGen ) && !CORBA::is_nil( aMainShape ) && !CORBA::is_nil( aSubShape ) ) {
|
||||||
|
// get shapes operations interface
|
||||||
GEOM::GEOM_IShapesOperations_var anIShapesOperations =
|
GEOM::GEOM_IShapesOperations_var anIShapesOperations =
|
||||||
aGeomGen->GetIShapesOperations(aMainShape->GetStudyID());
|
aGeomGen->GetIShapesOperations( aMainShape->GetStudyID() );
|
||||||
if (CORBA::is_nil(anIShapesOperations))
|
if ( !CORBA::is_nil( anIShapesOperations ) )
|
||||||
return -1;
|
index = anIShapesOperations->GetTopologyIndex( aMainShape, aSubShape );
|
||||||
|
}
|
||||||
|
|
||||||
return anIShapesOperations->GetTopologyIndex(aMainShape, aSubShape);
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* GEOM_Swig::getShapeTypeString(const char* IOR)
|
/*!
|
||||||
|
\brief Get shape type name
|
||||||
|
\param theIOR geometry object's IOR
|
||||||
|
\return shape type name ("Shape of unknown type" in case of error)
|
||||||
|
*/
|
||||||
|
const char* GEOM_Swig::getShapeTypeString( const char* theIOR )
|
||||||
{
|
{
|
||||||
TCollection_AsciiString aTypeName ("Shape of unknown type");
|
QString aTypeName = "Shape of unknown type";
|
||||||
|
|
||||||
|
// get geom engine
|
||||||
GEOM::GEOM_Gen_var aGeomGen = GeometryGUI::GetGeomGen();
|
GEOM::GEOM_Gen_var aGeomGen = GeometryGUI::GetGeomGen();
|
||||||
if (!CORBA::is_nil(aGeomGen))
|
|
||||||
{
|
// get shape's geom object by IOR
|
||||||
GEOM::GEOM_Object_var aShape = aGeomGen->GetIORFromString(IOR);
|
CORBA::Object_var anObject = SalomeApp_Application::orb()->string_to_object( theIOR );
|
||||||
if (!CORBA::is_nil(aShape))
|
GEOM::GEOM_Object_var aShape = GEOM::GEOM_Object::_narrow( anObject.in() );
|
||||||
{
|
|
||||||
|
if ( !CORBA::is_nil( aGeomGen ) && !CORBA::is_nil( aShape ) ) {
|
||||||
|
// get shapes operations interface
|
||||||
GEOM::GEOM_IShapesOperations_var anIShapesOperations =
|
GEOM::GEOM_IShapesOperations_var anIShapesOperations =
|
||||||
aGeomGen->GetIShapesOperations(aShape->GetStudyID());
|
aGeomGen->GetIShapesOperations( aShape->GetStudyID() );
|
||||||
if (!CORBA::is_nil(anIShapesOperations))
|
if ( !CORBA::is_nil( anIShapesOperations ) )
|
||||||
{
|
aTypeName = anIShapesOperations->GetShapeTypeString( aShape );
|
||||||
aTypeName = anIShapesOperations->GetShapeTypeString(aShape);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return CORBA::string_dup(aTypeName.ToCString());
|
return strdup( qPrintable( aTypeName ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Get shape's icon ID (specified by its type)
|
||||||
|
\param theIOR geometry object's IOR
|
||||||
|
\return icon ID ("None" in case of error)
|
||||||
|
*/
|
||||||
const char* GEOM_Swig::getShapeTypeIcon( const char* theIOR )
|
const char* GEOM_Swig::getShapeTypeIcon( const char* theIOR )
|
||||||
{
|
{
|
||||||
static const char* icons[] = {
|
static const char* icons[] = {
|
||||||
@ -358,17 +320,34 @@ const char* GEOM_Swig::getShapeTypeIcon( const char* theIOR )
|
|||||||
return anIcon;
|
return anIcon;
|
||||||
}
|
}
|
||||||
|
|
||||||
void GEOM_Swig::setDisplayMode(const char* theEntry, int theMode, bool theUpdateViewer)
|
class TSetPropertyEvent: public SALOME_Event
|
||||||
{
|
{
|
||||||
class TEvent: public SALOME_Event {
|
|
||||||
QString myEntry;
|
QString myEntry;
|
||||||
int myMode;
|
QString myProperty;
|
||||||
|
QVariant myValue;
|
||||||
bool myUpdateViewer;
|
bool myUpdateViewer;
|
||||||
public:
|
|
||||||
TEvent(const char* theEntryArg, int theModeArg, bool theUpdated):
|
public:
|
||||||
myEntry(theEntryArg), myMode(theModeArg), myUpdateViewer(theUpdated)
|
TSetPropertyEvent( const QString& _entry,
|
||||||
{}
|
const QString& _property,
|
||||||
virtual void Execute() {
|
const QVariant& _value,
|
||||||
|
bool _update = true );
|
||||||
|
virtual void Execute();
|
||||||
|
};
|
||||||
|
|
||||||
|
TSetPropertyEvent::TSetPropertyEvent( const QString& _entry,
|
||||||
|
const QString& _property,
|
||||||
|
const QVariant& _value,
|
||||||
|
bool _update ):
|
||||||
|
myEntry( _entry ),
|
||||||
|
myProperty( _property ),
|
||||||
|
myValue( _value ),
|
||||||
|
myUpdateViewer( _update )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void TSetPropertyEvent::Execute()
|
||||||
|
{
|
||||||
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
||||||
if ( !app ) return;
|
if ( !app ) return;
|
||||||
|
|
||||||
@ -381,342 +360,133 @@ void GEOM_Swig::setDisplayMode(const char* theEntry, int theMode, bool theUpdate
|
|||||||
if ( !window ) return;
|
if ( !window ) return;
|
||||||
|
|
||||||
int mgrId = dynamic_cast<SUIT_ViewModel*>( window )->getViewManager()->getGlobalId();
|
int mgrId = dynamic_cast<SUIT_ViewModel*>( window )->getViewManager()->getGlobalId();
|
||||||
study->setObjectProperty( mgrId, myEntry, GEOM::propertyName( GEOM::DisplayMode ), myMode );
|
|
||||||
|
study->setObjectProperty( mgrId, myEntry, myProperty, myValue );
|
||||||
|
|
||||||
Handle(SALOME_InteractiveObject) io = new SALOME_InteractiveObject( myEntry.toLatin1().data(), "GEOM" );
|
Handle(SALOME_InteractiveObject) io = new SALOME_InteractiveObject( myEntry.toLatin1().data(), "GEOM" );
|
||||||
if ( window->isVisible( io ) ) {
|
if ( window->isVisible( io ) ) displayer.Redisplay( io, myUpdateViewer );
|
||||||
SALOME_Prs* prs = displayer.buildPresentation( myEntry, window );
|
|
||||||
displayer.Redisplay( io );
|
|
||||||
delete prs;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
ProcessVoidEvent( new TEvent( theEntry, theMode, theUpdateViewer ) );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GEOM_Swig::setVectorsMode(const char* theEntry, bool isOn, bool theUpdateViewer)
|
/*!
|
||||||
|
\brief Set display mode to the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theMode display mode: 0 - wireframe, 1 - shading, 2 - shading+edges, 3-textured
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setDisplayMode( const char* theEntry, int theMode, bool theUpdateViewer )
|
||||||
{
|
{
|
||||||
class TEvent: public SALOME_Event {
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::DisplayMode ),
|
||||||
std::string myEntry;
|
theMode, theUpdateViewer ) );
|
||||||
bool myOn;
|
|
||||||
bool myUpdateViewer;
|
|
||||||
public:
|
|
||||||
TEvent(const char* theEntryArg, bool theOn, bool theUpdated):
|
|
||||||
myEntry(theEntryArg), myOn(theOn), myUpdateViewer(theUpdated)
|
|
||||||
{}
|
|
||||||
virtual void Execute() {
|
|
||||||
SUIT_Application* anApp = SUIT_Session::session()->activeApplication();
|
|
||||||
if (!anApp) return;
|
|
||||||
|
|
||||||
Handle(SALOME_InteractiveObject) anIO =
|
|
||||||
new SALOME_InteractiveObject(myEntry.c_str(), "GEOM", "");
|
|
||||||
|
|
||||||
if (SVTK_ViewWindow* aViewWindow = GetSVTKViewWindow(anApp)) {
|
|
||||||
SVTK_View* aView = aViewWindow->getView();
|
|
||||||
SVTK_Viewer* stvkViewer = dynamic_cast<SVTK_Viewer*>(aViewWindow->getViewManager()->getViewModel());
|
|
||||||
SVTK_Prs* vtkPrs = dynamic_cast<SVTK_Prs*>( stvkViewer->CreatePrs( myEntry.c_str() ) );
|
|
||||||
vtkActorCollection* anActors = vtkPrs->GetObjects();
|
|
||||||
anActors->InitTraversal();
|
|
||||||
while (vtkActor* anAct = anActors->GetNextActor()) {
|
|
||||||
GEOM_Actor* aGeomActor = GEOM_Actor::SafeDownCast(anAct);
|
|
||||||
aGeomActor->SetVectorMode(!aGeomActor->GetVectorMode());
|
|
||||||
}
|
|
||||||
if (myUpdateViewer)
|
|
||||||
aView->Repaint();
|
|
||||||
}
|
|
||||||
else if (OCCViewer_Viewer* occViewer = GetOCCViewer(anApp)) {
|
|
||||||
Handle(AIS_InteractiveContext) ic = occViewer->getAISContext();
|
|
||||||
SOCC_Viewer* soccViewer = dynamic_cast<SOCC_Viewer*>(occViewer);
|
|
||||||
if (soccViewer) {
|
|
||||||
SOCC_Prs* occPrs = dynamic_cast<SOCC_Prs*>( soccViewer->CreatePrs( myEntry.c_str() ) );
|
|
||||||
if ( occPrs && !occPrs->IsNull() ) {
|
|
||||||
AIS_ListOfInteractive shapes; occPrs->GetObjects( shapes );
|
|
||||||
AIS_ListIteratorOfListOfInteractive interIter( shapes );
|
|
||||||
for ( ; interIter.More(); interIter.Next() ) {
|
|
||||||
Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast( interIter.Value() );
|
|
||||||
aSh->SetDisplayVectors(myOn);
|
|
||||||
ic->RecomputePrsOnly(interIter.Value());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
ProcessVoidEvent(new TEvent (theEntry, isOn, theUpdateViewer));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GEOM_Swig::setColor(const char* theEntry, int red, int green, int blue, bool theUpdateViewer)
|
/*!
|
||||||
|
\brief Show / hide edges direction vectors for the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theOn \c true to show edges direction vectors or \c false otherwise
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setVectorsMode( const char* theEntry, bool theOn, bool theUpdateViewer )
|
||||||
{
|
{
|
||||||
class TEvent: public SALOME_Event {
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::EdgesDirection ),
|
||||||
QString myEntry;
|
theOn, theUpdateViewer ) );
|
||||||
int myRed;
|
|
||||||
int myGreen;
|
|
||||||
int myBlue;
|
|
||||||
bool myUpdateViewer;
|
|
||||||
public:
|
|
||||||
TEvent(const char* theEntryArg, int theR, int theG, int theB, bool theUpdated):
|
|
||||||
myEntry(theEntryArg), myRed(theR), myGreen(theG), myBlue(theB), myUpdateViewer(theUpdated)
|
|
||||||
{}
|
|
||||||
virtual void Execute() {
|
|
||||||
SUIT_Application* anApp = SUIT_Session::session()->activeApplication();
|
|
||||||
if (!anApp) return;
|
|
||||||
GEOMToolsGUI::SetColor( myEntry, QColor( myRed, myGreen, myBlue), myUpdateViewer );
|
|
||||||
}
|
|
||||||
};
|
|
||||||
ProcessVoidEvent(new TEvent(theEntry, red, green, blue, theUpdateViewer));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GEOM_Swig::setIsos(const char* Entry, int nbU, int nbV, bool theUpdateViewer )
|
/*!
|
||||||
|
\brief Change color of the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theRed red component of the component (0-255)
|
||||||
|
\param theGreen green component of the component (0-255)
|
||||||
|
\param theBlue blue component of the component (0-255)
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setColor( const char* theEntry, int theRed, int theGreen, int theBlue, bool theUpdateViewer )
|
||||||
{
|
{
|
||||||
class TEvent: public SALOME_Event {
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::Color ),
|
||||||
std::string myEntry;
|
QColor( theRed, theGreen, theBlue ), theUpdateViewer ) );
|
||||||
int myNbU, myNbV;
|
|
||||||
bool myUpdateViewer;
|
|
||||||
public:
|
|
||||||
TEvent(const char* theEntry, int theNbU, int theNbV, bool theUpdated):
|
|
||||||
myEntry(theEntry), myNbU(theNbU), myNbV(theNbV), myUpdateViewer(theUpdated)
|
|
||||||
{}
|
|
||||||
virtual void Execute() {
|
|
||||||
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
|
||||||
if (!app) return;
|
|
||||||
SalomeApp_Study* study = dynamic_cast<SalomeApp_Study*>(app->activeStudy());
|
|
||||||
if (!study) return;
|
|
||||||
|
|
||||||
Handle(SALOME_InteractiveObject) anIO =
|
|
||||||
new SALOME_InteractiveObject(myEntry.c_str(), "GEOM", "");
|
|
||||||
|
|
||||||
if (SVTK_ViewWindow* aViewWindow = GetSVTKViewWindow(app)) {
|
|
||||||
SVTK_Viewer* aView = dynamic_cast<SVTK_Viewer*>(aViewWindow->getViewManager()->getViewModel());
|
|
||||||
SVTK_Prs* vtkPrs = dynamic_cast<SVTK_Prs*>( aView->CreatePrs( myEntry.c_str() ) );
|
|
||||||
if ( vtkPrs ) {
|
|
||||||
vtkActorCollection* anActors = vtkPrs->GetObjects();
|
|
||||||
anActors->InitTraversal();
|
|
||||||
GEOM_Actor* anActor = GEOM_Actor::SafeDownCast( anActors->GetNextActor() );
|
|
||||||
if ( anActor ) {
|
|
||||||
int aIsos[2]={myNbU,myNbV};
|
|
||||||
anActor->SetNbIsos(aIsos);
|
|
||||||
anActor->StoreIsoNumbers();
|
|
||||||
QString anIsos = QString("%1%2%3").arg(myNbU).arg(GEOM::subSectionSeparator()).arg(myNbV);
|
|
||||||
int aMgrId = aView->getViewManager()->getGlobalId();
|
|
||||||
study->setObjectProperty(aMgrId, myEntry.c_str(), GEOM::propertyName( GEOM::NbIsos ), anIsos);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (myUpdateViewer)
|
|
||||||
aView->Repaint();
|
|
||||||
}
|
|
||||||
else if (OCCViewer_Viewer* occViewer = GetOCCViewer(app)) {
|
|
||||||
Handle(AIS_InteractiveContext) ic = occViewer->getAISContext();
|
|
||||||
SOCC_Viewer* soccViewer = dynamic_cast<SOCC_Viewer*>(occViewer);
|
|
||||||
if (soccViewer) {
|
|
||||||
int aMgrId = soccViewer->getViewManager()->getGlobalId();
|
|
||||||
SOCC_Prs* occPrs = dynamic_cast<SOCC_Prs*>( soccViewer->CreatePrs( myEntry.c_str() ) );
|
|
||||||
if ( occPrs && !occPrs->IsNull() ) {
|
|
||||||
AIS_ListOfInteractive shapes; occPrs->GetObjects( shapes );
|
|
||||||
AIS_ListIteratorOfListOfInteractive interIter( shapes );
|
|
||||||
for ( ; interIter.More(); interIter.Next() ) {
|
|
||||||
Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast( interIter.Value() );
|
|
||||||
if ( !aSh.IsNull() ) {
|
|
||||||
Handle(AIS_Drawer) drawer = aSh->Attributes();
|
|
||||||
QVariant v = study->getObjectProperty( aMgrId, myEntry.c_str(), GEOM::propertyName( GEOM::LineWidth ), QVariant() );
|
|
||||||
int width = v.isValid() ? v.toInt() : 1;
|
|
||||||
drawer->SetUIsoAspect( new Prs3d_IsoAspect(Quantity_NOC_GRAY75, Aspect_TOL_SOLID, width, myNbU) );
|
|
||||||
drawer->SetVIsoAspect( new Prs3d_IsoAspect(Quantity_NOC_GRAY75, Aspect_TOL_SOLID, width, myNbV) );
|
|
||||||
aSh->storeIsoNumbers();
|
|
||||||
ic->SetLocalAttributes(aSh, drawer);
|
|
||||||
ic->Redisplay(aSh);
|
|
||||||
QString anIsos = QString("%1%2%3").arg(myNbU).arg(GEOM::subSectionSeparator()).arg(myNbV);
|
|
||||||
study->setObjectProperty(aMgrId, myEntry.c_str(), GEOM::propertyName( GEOM::NbIsos ), anIsos);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
ProcessVoidEvent(new TEvent (Entry, nbU, nbV, theUpdateViewer));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GEOM_Swig::setTransparency(const char* theEntry, float transp, bool theUpdateViewer)
|
/*!
|
||||||
|
\brief Set number of iso-lines to the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theNbU number of iso-lines along U axis (interger value >= 0)
|
||||||
|
\param theNbV number of iso-lines along V axis (interger value >= 0)
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setIsos( const char* theEntry, int theNbU, int theNbV, bool theUpdateViewer )
|
||||||
{
|
{
|
||||||
class TEvent: public SALOME_Event {
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::NbIsos ),
|
||||||
std::string myEntry;
|
QString( "%1%2%3" ).arg( theNbU ).arg( GEOM::subSectionSeparator() ).arg( theNbV ),
|
||||||
float myParam;
|
theUpdateViewer ) );
|
||||||
bool myUpdateViewer;
|
|
||||||
public:
|
|
||||||
TEvent(const char* theEntryArg, float theParam, bool theUpdated):
|
|
||||||
myEntry(theEntryArg), myParam(theParam), myUpdateViewer(theUpdated)
|
|
||||||
{}
|
|
||||||
virtual void Execute() {
|
|
||||||
SUIT_Application* anApp = SUIT_Session::session()->activeApplication();
|
|
||||||
if (!anApp) return;
|
|
||||||
|
|
||||||
Handle(SALOME_InteractiveObject) anIO =
|
|
||||||
new SALOME_InteractiveObject(myEntry.c_str(), "GEOM", "");
|
|
||||||
|
|
||||||
if (SVTK_ViewWindow* aViewWindow = GetSVTKViewWindow(anApp)) {
|
|
||||||
SVTK_View* aView = aViewWindow->getView();
|
|
||||||
aView->SetTransparency(anIO, myParam);
|
|
||||||
if (myUpdateViewer)
|
|
||||||
aView->Repaint();
|
|
||||||
} else if (OCCViewer_Viewer* occViewer = GetOCCViewer(anApp)) {
|
|
||||||
SOCC_Viewer* soccViewer = dynamic_cast<SOCC_Viewer*>(occViewer);
|
|
||||||
if (soccViewer)
|
|
||||||
soccViewer->setTransparency(anIO, myParam, myUpdateViewer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
ProcessVoidEvent(new TEvent (theEntry, transp, theUpdateViewer));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Set transparency of the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theTransparency transparency (floating point value between 0 and 1)
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setTransparency( const char* theEntry, float theTransparency, bool theUpdateViewer )
|
||||||
|
{
|
||||||
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::Transparency ),
|
||||||
|
theTransparency, theUpdateViewer ) );
|
||||||
|
}
|
||||||
|
|
||||||
class TInitGeomGenEvent: public SALOME_Event {
|
/*!
|
||||||
|
\brief Set deflection coefficient of the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theDeflection deflection coefficient (floating point value)
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setDeflection( const char* theEntry, float theDeflection, bool theUpdateViewer )
|
||||||
|
{
|
||||||
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::Deflection ),
|
||||||
|
theDeflection, theUpdateViewer ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Set material to the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theMaterial material name (string)
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setMaterial( const char* theEntry, const char* theMaterial, bool theUpdateViewer )
|
||||||
|
{
|
||||||
|
Material_Model material;
|
||||||
|
material.fromResources( theMaterial );
|
||||||
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::Material ),
|
||||||
|
material.toProperties(), theUpdateViewer ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\brief Set material property to the presentation
|
||||||
|
\param theEntry geometry object's entry
|
||||||
|
\param theMaterial material property string
|
||||||
|
\param theUpdateViewer \c true to update active view's contents
|
||||||
|
*/
|
||||||
|
void GEOM_Swig::setMaterialProperty( const char* theEntry, const char* theMaterial, bool theUpdateViewer )
|
||||||
|
{
|
||||||
|
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::Material ),
|
||||||
|
theMaterial, theUpdateViewer ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
class TInitGeomGenEvent: public SALOME_Event
|
||||||
|
{
|
||||||
public:
|
public:
|
||||||
typedef bool TResult;
|
typedef bool TResult;
|
||||||
TResult myResult;
|
TResult myResult;
|
||||||
TInitGeomGenEvent() : myResult(false) {}
|
TInitGeomGenEvent() : myResult(false)
|
||||||
virtual void Execute() {
|
|
||||||
myResult = GeometryGUI::InitGeomGen();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
bool GEOM_Swig::initGeomGen()
|
|
||||||
{
|
|
||||||
return ProcessEvent(new TInitGeomGenEvent());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void GEOM_Swig::eraseGO (const char* Entry, bool allWindows)
|
|
||||||
{
|
|
||||||
class TEvent: public SALOME_Event
|
|
||||||
{
|
|
||||||
std::string myEntry;
|
|
||||||
bool myFromAllWindows;
|
|
||||||
public:
|
|
||||||
TEvent(const char* theEntry, bool fromAllWindows):
|
|
||||||
myEntry(theEntry), myFromAllWindows(fromAllWindows)
|
|
||||||
{}
|
{}
|
||||||
virtual void Execute()
|
virtual void Execute()
|
||||||
{
|
{
|
||||||
SUIT_Application* app = SUIT_Session::session()->activeApplication();
|
myResult = GeometryGUI::InitGeomGen();
|
||||||
if (!app) return;
|
}
|
||||||
SalomeApp_Study* ActiveStudy = dynamic_cast<SalomeApp_Study*>(app->activeStudy());
|
};
|
||||||
if (!ActiveStudy) return;
|
|
||||||
|
|
||||||
Handle (SALOME_InteractiveObject) aIO = new SALOME_InteractiveObject(myEntry.c_str(), "GEOM", "");
|
/*!
|
||||||
|
\brief Initialize GEOM module's engine
|
||||||
GEOM_Displayer(ActiveStudy).Erase(aIO, true);
|
\return \c true if initialization succeedes or \c false otherwise
|
||||||
/* if (myFromAllWindows) {
|
*/
|
||||||
QPtrList<SUIT_ViewWindow> aWindows = app->desktop()->windows();
|
bool GEOM_Swig::initGeomGen()
|
||||||
SUIT_ViewWindow* aWin = 0;
|
|
||||||
for (aWin = aWindows.first(); aWin; aWin = aWindows.next()) {
|
|
||||||
EraseObject(aWin, aIO);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
SUIT_ViewWindow* aWin = app->desktop()->activeWindow();
|
|
||||||
if (aWin)
|
|
||||||
EraseObject(aWin, aIO);
|
|
||||||
}*/
|
|
||||||
}
|
|
||||||
|
|
||||||
/* private:
|
|
||||||
void EraseObject(SUIT_ViewWindow* theWin, Handle (SALOME_InteractiveObject) theIO)
|
|
||||||
{
|
|
||||||
if (theWin->getViewManager()->getType() == OCCViewer_Viewer::Type()){
|
|
||||||
OCCViewer_ViewWindow* vw = dynamic_cast<OCCViewer_ViewWindow*>( theWin );
|
|
||||||
if ( vw ) {
|
|
||||||
OCCViewer_ViewManager* vm = dynamic_cast<OCCViewer_ViewManager*>( vw->getViewManager() );
|
|
||||||
if ( vm ) {
|
|
||||||
SOCC_Viewer* aViewer = dynamic_cast<SOCC_Viewer*>(vm->getOCCViewer());
|
|
||||||
if (aViewer) {
|
|
||||||
SALOME_Prs* aPrs = aViewer->CreatePrs(myEntry.c_str());
|
|
||||||
if (aPrs) {
|
|
||||||
SALOME_OCCPrs* aOccPrs = dynamic_cast<SALOME_OCCPrs*>(aPrs);
|
|
||||||
if (aOccPrs) {
|
|
||||||
aViewer->Erase(aOccPrs);
|
|
||||||
aViewer->Repaint();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (theWin->getViewManager()->getType() == SVTK_Viewer::Type()){
|
|
||||||
SVTK_ViewWindow* aViewWindow = dynamic_cast<SVTK_ViewWindow*>( theWin );
|
|
||||||
if (aViewWindow) {
|
|
||||||
aViewWindow->Erase(theIO);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
|
|
||||||
};
|
|
||||||
ProcessVoidEvent(new TEvent(Entry, allWindows));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void GEOM_Swig::setDeflection(const char* theEntry, float theDeflect)
|
|
||||||
{
|
{
|
||||||
class TEvent: public SALOME_Event {
|
return ProcessEvent( new TInitGeomGenEvent() );
|
||||||
std::string myEntry;
|
|
||||||
float myParam;
|
|
||||||
public:
|
|
||||||
TEvent(const char* theEntryArg, float theParam):
|
|
||||||
myEntry(theEntryArg), myParam(theParam)
|
|
||||||
{}
|
|
||||||
virtual void Execute() {
|
|
||||||
SUIT_Application* anApp = SUIT_Session::session()->activeApplication();
|
|
||||||
if (!anApp) return;
|
|
||||||
|
|
||||||
Handle(SALOME_InteractiveObject) anIO =
|
|
||||||
new SALOME_InteractiveObject(myEntry.c_str(), "GEOM", "");
|
|
||||||
|
|
||||||
if (SVTK_ViewWindow* aViewWindow = GetSVTKViewWindow(anApp)) {
|
|
||||||
vtkActorCollection* aActors = aViewWindow->getRenderer()->GetActors();
|
|
||||||
aActors->InitTraversal();
|
|
||||||
while (vtkActor* aAct = aActors->GetNextActor()) {
|
|
||||||
if (GEOM_Actor* aGeomActor = dynamic_cast<GEOM_Actor*>(aAct)) {
|
|
||||||
if (aGeomActor->hasIO()) {
|
|
||||||
Handle(SALOME_InteractiveObject) aNextIO = aGeomActor->getIO();
|
|
||||||
if (aNextIO->isSame(anIO)) {
|
|
||||||
aGeomActor->setDeflection(myParam);
|
|
||||||
aViewWindow->Repaint();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// aView->SetTransparency(anIO, myParam);
|
|
||||||
//aView->Repaint();
|
|
||||||
} else if (OCCViewer_Viewer* occViewer = GetOCCViewer(anApp)) {
|
|
||||||
Handle(AIS_InteractiveContext) aContext = occViewer->getAISContext();
|
|
||||||
AIS_ListOfInteractive aAISList;
|
|
||||||
aContext->DisplayedObjects(aAISList);
|
|
||||||
AIS_ListIteratorOfListOfInteractive it(aAISList);
|
|
||||||
for (; it.More(); it.Next()) {
|
|
||||||
Handle(SALOME_InteractiveObject) aObj =
|
|
||||||
Handle(SALOME_InteractiveObject)::DownCast(it.Value()->GetOwner());
|
|
||||||
if ((!aObj.IsNull()) && aObj->hasEntry() && aObj->isSame(anIO)) {
|
|
||||||
Handle(AIS_Shape) aShape = Handle(AIS_Shape)::DownCast(it.Value());
|
|
||||||
if (!aShape.IsNull()) {
|
|
||||||
TopoDS_Shape aSh = aShape->Shape();
|
|
||||||
if (!aSh.IsNull())
|
|
||||||
BRepTools::Clean(aSh);
|
|
||||||
|
|
||||||
aShape->SetOwnDeviationCoefficient( myParam );
|
|
||||||
aShape->SetOwnHLRDeviationAngle( 1.57 );
|
|
||||||
aContext->Redisplay(aShape);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
ProcessVoidEvent(new TEvent (theEntry, theDeflect));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,14 +19,11 @@
|
|||||||
//
|
//
|
||||||
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
//
|
//
|
||||||
|
|
||||||
// GEOM GEOMGUI : GUI for Geometry component
|
|
||||||
// File : libGEOM_Swig.h
|
// File : libGEOM_Swig.h
|
||||||
// Author : Nicolas REJNERI, Paul RASCLE
|
// Author : Nicolas REJNERI, Paul RASCLE
|
||||||
//
|
|
||||||
|
|
||||||
#ifndef GEOMETRYGUI_SWIG_HXX
|
#ifndef LIBGEOM_SWIG_H
|
||||||
#define GEOMETRYGUI_SWIG_HXX
|
#define LIBGEOM_SWIG_H
|
||||||
|
|
||||||
#include "GEOM_GEOMGUI.hxx"
|
#include "GEOM_GEOMGUI.hxx"
|
||||||
|
|
||||||
@ -36,22 +33,29 @@ public:
|
|||||||
GEOM_Swig();
|
GEOM_Swig();
|
||||||
~GEOM_Swig();
|
~GEOM_Swig();
|
||||||
|
|
||||||
void createAndDisplayGO(const char* Entry, bool theUpdateViewer = true);
|
void createAndDisplayGO( const char* theEntry, bool theUpdateViewer = true );
|
||||||
void eraseGO(const char* Entry, bool allWindows);
|
void createAndDisplayFitAllGO( const char* theEntry );
|
||||||
void createAndDisplayFitAllGO(const char* Entry);
|
void eraseGO( const char* theEntry, bool theUpdateViewer = true );
|
||||||
void UpdateViewer();
|
|
||||||
void setDisplayMode(const char* Entry, int mode, bool theUpdateViewer = true);
|
|
||||||
void setVectorsMode(const char* Entry, bool isSet, bool theUpdateViewer = true);
|
|
||||||
void setColor(const char* Entry, int red, int green, int blue, bool theUpdateViewer = true);
|
|
||||||
void setTransparency(const char* Entry, float transp, bool theUpdateViewer = true);
|
|
||||||
void setIsos(const char* Entry, int nbU, int nbV, bool theUpdateViewer =true);
|
|
||||||
void setDeflection(const char* Entry, float deflect);
|
|
||||||
|
|
||||||
int getIndexTopology(const char *SubEntry, const char *Entry);
|
void UpdateViewer();
|
||||||
const char* getShapeTypeString(const char *Entry);
|
|
||||||
const char* getShapeTypeIcon(const char *Ior);
|
void setDisplayMode( const char* theEntry, int theMode, bool theUpdateViewer = true );
|
||||||
|
void setVectorsMode( const char* theEntry, bool theOn, bool theUpdateViewer = true );
|
||||||
|
void setColor( const char* theEntry, int theRed, int theGreen, int theBlue, bool theUpdateViewer = true );
|
||||||
|
void setTransparency( const char* theEntry, float theTransparency, bool theUpdateViewer = true );
|
||||||
|
void setIsos( const char* theEntry, int theNbU, int theNbV, bool theUpdateViewer = true );
|
||||||
|
void setDeflection( const char* theEntry, float theDeflection, bool theUpdateViewer = true );
|
||||||
|
void setMaterial( const char* theEntry, const char* theMaterial, bool theUpdateViewer = true );
|
||||||
|
void setMaterialProperty( const char* theEntry, const char* theMaterial, bool theUpdateViewer = true );
|
||||||
|
|
||||||
|
int getIndexTopology( const char* theSubIOR, const char* theMainIOR );
|
||||||
|
const char* getShapeTypeString( const char* theIOR );
|
||||||
|
const char* getShapeTypeIcon( const char* theIOR );
|
||||||
|
|
||||||
bool initGeomGen();
|
bool initGeomGen();
|
||||||
|
private:
|
||||||
|
|
||||||
|
void init();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // GEOMETRYGUI_SWIG_HXX
|
#endif // LIBGEOM_SWIG_H
|
||||||
|
@ -55,20 +55,24 @@ class GEOM_Swig
|
|||||||
GEOM_Swig();
|
GEOM_Swig();
|
||||||
~GEOM_Swig();
|
~GEOM_Swig();
|
||||||
|
|
||||||
void createAndDisplayGO(const char* Entry, bool isUpdated =true);
|
void createAndDisplayGO( const char* theEntry, bool theUpdateViewer = true );
|
||||||
void eraseGO(const char* Entry, bool allWindows);
|
void createAndDisplayFitAllGO( const char* theEntry );
|
||||||
void createAndDisplayFitAllGO(const char* Entry);
|
void eraseGO( const char* theEntry, bool theUpdateViewer = true );
|
||||||
void UpdateViewer();
|
|
||||||
int getIndexTopology(const char *SubEntry, const char *Entry);
|
|
||||||
const char* getShapeTypeString(const char *Entry);
|
|
||||||
|
|
||||||
void setDisplayMode(const char* Entry, int mode, bool isUpdated =true);
|
void UpdateViewer();
|
||||||
void setVectorsMode(const char* Entry, bool isSet, bool isUpdated =true);
|
|
||||||
void setColor(const char* Entry, int red, int green, int blue, bool isUpdated =true);
|
void setDisplayMode( const char* theEntry, int theMode, bool theUpdateViewer = true );
|
||||||
void setTransparency(const char* Entry, float transp, bool isUpdated =true);
|
void setVectorsMode( const char* theEntry, bool theOn, bool theUpdateViewer = true );
|
||||||
void setIsos(const char* Entry, int nbU, int nbV, bool isUpdated =true);
|
void setColor( const char* theEntry, int theRed, int theGreen, int theBlue, bool theUpdateViewer = true );
|
||||||
void setDeflection(const char* Entry, float deflect);
|
void setTransparency( const char* theEntry, float theTransparency, bool theUpdateViewer = true );
|
||||||
const char* getShapeTypeIcon(const char *Ior);
|
void setIsos( const char* theEntry, int theNbU, int theNbV, bool theUpdateViewer = true );
|
||||||
|
void setDeflection( const char* theEntry, float theDeflection, bool theUpdateViewer = true );
|
||||||
|
void setMaterial( const char* theEntry, const char* theMaterial, bool theUpdateViewer = true );
|
||||||
|
void setMaterialProperty( const char* theEntry, const char* theMaterial, bool theUpdateViewer = true );
|
||||||
|
|
||||||
|
int getIndexTopology( const char* theSubIOR, const char* theMainIOR );
|
||||||
|
const char* getShapeTypeString( const char* theIOR );
|
||||||
|
const char* getShapeTypeIcon( const char* theIOR );
|
||||||
|
|
||||||
bool initGeomGen();
|
bool initGeomGen();
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user