This commit is contained in:
vsr 2005-03-17 14:02:35 +00:00
parent 74382af355
commit 27e469cd20
3 changed files with 32 additions and 9 deletions

View File

@ -50,6 +50,9 @@
#include <TopoDS_Edge.hxx>
#include <TopoDS_Face.hxx>
#include <TopoDS_Iterator.hxx>
#include <AIS_ListOfInteractive.hxx>
#include <AIS_ListIteratorOfListOfInteractive.hxx>
#include <V3d_Viewer.hxx>
#include "SALOME_Event.hxx"
@ -162,7 +165,6 @@ void GEOM_Swig::createAndDisplayGO(const char* Entry)
Handle(GEOM_AISShape) aSh = new GEOM_AISShape(myShape,const_cast<char*>(myName));
aSh->setName(const_cast<char*>(myName));
aSh->setIO(myIO);
ic->Display(aSh);
ic->AddOrRemoveCurrentObject(aSh,true);
}
@ -370,7 +372,26 @@ void GEOM_Swig::setColor(const char* theEntry, int red, int green, int blue)
myRenderInter->Update();
}else if(OCCViewer_ViewFrame* aViewFrame = GetFrame<OCCViewer_ViewFrame>(myStudy)){
OCCViewer_Viewer3d* v3d = aViewFrame->getViewer();
v3d->SetColor(myIO,myParam);
Handle(AIS_InteractiveContext) ic = aViewFrame->getViewer()->getAISContext();
AIS_ListOfInteractive List;
ic->DisplayedObjects(List);
AIS_ListIteratorOfListOfInteractive ite(List);
for ( ; ite.More(); ite.Next() ) {
Handle(SALOME_InteractiveObject) anObj =
Handle(SALOME_InteractiveObject)::DownCast( ite.Value()->GetOwner() );
if ( !anObj.IsNull() && anObj->hasEntry() && anObj->isSame( myIO ) ) {
Quantity_Color CSFColor = Quantity_Color ( myParam.red() / 255.,
myParam.green() / 255.,
myParam.blue() / 255.,
Quantity_TOC_RGB );
ite.Value()->SetColor( CSFColor );
if ( ite.Value()->IsKind( STANDARD_TYPE(GEOM_AISShape) ) )
Handle(GEOM_AISShape)::DownCast( ite.Value() )->SetShadingColor( CSFColor );
ite.Value()->Redisplay( Standard_True );
v3d->getViewer3d()->Update();
break;
}
}
}
}
};

View File

@ -116,7 +116,6 @@ static void indicesToOwners( const TColStd_IndexedMapOfInteger& aIndexMap,
GEOM_AISShape::GEOM_AISShape(const TopoDS_Shape& shape,
const Standard_CString aName): SALOME_AISShape(shape)
{
myIO = NULL;
myName = new char [strlen(aName)+1];
strcpy( myName, aName);
@ -124,15 +123,18 @@ GEOM_AISShape::GEOM_AISShape(const TopoDS_Shape& shape,
}
void GEOM_AISShape::setIO(const Handle(SALOME_InteractiveObject)& io){
myIO = io;
SetOwner( io );
}
Handle(SALOME_InteractiveObject) GEOM_AISShape::getIO(){
return myIO;
Handle(SALOME_InteractiveObject) IO;
if ( !GetOwner().IsNull() )
IO = Handle(SALOME_InteractiveObject)::DownCast( GetOwner() );
return IO;
}
Standard_Boolean GEOM_AISShape::hasIO(){
return !myIO.IsNull();
return !getIO().IsNull();
}
void GEOM_AISShape::setName(const Standard_CString aName)
@ -140,8 +142,9 @@ void GEOM_AISShape::setName(const Standard_CString aName)
myName = new char [strlen(aName)+1];
strcpy( myName, aName);
if ( hasIO() )
myIO->setName(aName);
Handle(SALOME_InteractiveObject) IO = getIO();
if ( !IO.IsNull() )
IO->setName(aName);
}
Standard_CString GEOM_AISShape::getName(){

View File

@ -121,7 +121,6 @@ private:
// Fields PRIVATE
//
Handle_SALOME_InteractiveObject myIO;
Standard_CString myName;
Quantity_Color myShadingColor;
};