2 #include "HYDROData_Object.h"
4 #include "HYDROData_Bathymetry.h"
6 #include <TNaming_Builder.hxx>
7 #include <TNaming_NamedShape.hxx>
9 #include <TopoDS_Shape.hxx>
13 IMPLEMENT_STANDARD_HANDLE(HYDROData_Object,HYDROData_Entity)
14 IMPLEMENT_STANDARD_RTTIEXT(HYDROData_Object,HYDROData_Entity)
16 HYDROData_Object::HYDROData_Object()
21 HYDROData_Object::~HYDROData_Object()
25 HYDROData_SequenceOfObjects HYDROData_Object::GetAllReferenceObjects() const
27 HYDROData_SequenceOfObjects aResSeq = HYDROData_Entity::GetAllReferenceObjects();
29 Handle(HYDROData_Bathymetry) aRefBathymetry = GetBathymetry();
30 if ( !aRefBathymetry.IsNull() )
31 aResSeq.Append( aRefBathymetry );
36 void HYDROData_Object::SetTopShape( const TopoDS_Shape& theShape )
38 TNaming_Builder aBuilder( myLab.FindChild( DataTag_TopShape ) );
39 aBuilder.Generated( theShape );
42 void HYDROData_Object::SetShape3D( const TopoDS_Shape& theShape )
44 TNaming_Builder aBuilder( myLab.FindChild( DataTag_Shape3D ) );
45 aBuilder.Generated( theShape );
48 void HYDROData_Object::Update()
50 HYDROData_Entity::Update();
55 void HYDROData_Object::SetBathymetry( const Handle(HYDROData_Bathymetry)& theBathymetry )
57 SetReferenceObject( theBathymetry, DataTag_Bathymetry );
61 Handle(HYDROData_Bathymetry) HYDROData_Object::GetBathymetry() const
63 return Handle(HYDROData_Bathymetry)::DownCast(
64 GetReferenceObject( DataTag_Bathymetry ) );
67 void HYDROData_Object::RemoveBathymetry()
69 ClearReferenceObjects( DataTag_Bathymetry );
73 TopoDS_Shape HYDROData_Object::getTopShape() const
75 TDF_Label aLabel = myLab.FindChild( DataTag_TopShape, false );
76 if ( !aLabel.IsNull() )
78 Handle(TNaming_NamedShape) aNamedShape;
79 if( aLabel.FindAttribute( TNaming_NamedShape::GetID(), aNamedShape ) )
80 return aNamedShape->Get();
83 return TopoDS_Shape();
86 void HYDROData_Object::removeTopShape()
88 TDF_Label aLabel = myLab.FindChild( DataTag_TopShape, false );
89 if ( !aLabel.IsNull() )
90 aLabel.ForgetAllAttributes();
93 TopoDS_Shape HYDROData_Object::getShape3D() const
95 TDF_Label aLabel = myLab.FindChild( DataTag_Shape3D, false );
96 if ( !aLabel.IsNull() )
98 Handle(TNaming_NamedShape) aNamedShape;
99 if( aLabel.FindAttribute( TNaming_NamedShape::GetID(), aNamedShape ) )
100 return aNamedShape->Get();
103 return TopoDS_Shape();
106 void HYDROData_Object::removeShape3D()
108 TDF_Label aLabel = myLab.FindChild( DataTag_Shape3D, false );
109 if ( !aLabel.IsNull() )
110 aLabel.ForgetAllAttributes();
113 void HYDROData_Object::SetFillingColor( const QColor& theColor )
115 SetColor( theColor, DataTag_FillingColor );
118 QColor HYDROData_Object::GetFillingColor() const
120 return GetColor( DefaultFillingColor(), DataTag_FillingColor );
123 void HYDROData_Object::SetBorderColor( const QColor& theColor )
125 SetColor( theColor, DataTag_BorderColor );
128 QColor HYDROData_Object::GetBorderColor() const
130 return GetColor( DefaultBorderColor(), DataTag_BorderColor );
133 QColor HYDROData_Object::DefaultFillingColor()
135 return QColor( Qt::yellow );
138 QColor HYDROData_Object::DefaultBorderColor()
140 return QColor( Qt::transparent );