// #define DEB_GROUPS 1
#ifdef DEB_GROUPS
-#include <HYDROData_EdgesGroup.h>
+#include <HYDROData_ShapesGroup.h>
#endif
static HYDROData_SequenceOfObjects myCopyingObjects;
return false;
ObjectKind aKind = anObject->GetKind();
- if( aKind == KIND_IMAGE ||
- aKind == KIND_POLYLINE ||
- aKind == KIND_PROFILE ||
- aKind == KIND_CALCULATION )
+ if( aKind > KIND_UNKNOWN && aKind <= KIND_LAST &&
+ aKind != KIND_DUMMY_3D && aKind != KIND_ZONE &&
+ aKind != KIND_SHAPES_GROUP && aKind != KIND_SPLITTED_GROUP )
return true;
return false;
return new HYDROGUI_NamedObject( theParent, theName, theParentEntry );
}
+void HYDROGUI_DataModel::buildObjectPartition( SUIT_DataObject* theObject,
+ const HYDROData_SequenceOfObjects& theObjects,
+ const QString& thePartName,
+ const bool theIsCreateEmpty )
+{
+ if ( theObjects.IsEmpty() && !theIsCreateEmpty )
+ return;
+
+ HYDROGUI_DataObject* aGuiObj = dynamic_cast<HYDROGUI_DataObject*>( theObject );
+ if ( !aGuiObj )
+ return;
+
+ LightApp_DataObject* aPartSect =
+ createObject( aGuiObj, thePartName, aGuiObj->entry() );
+
+ HYDROData_SequenceOfObjects::Iterator anIter( theObjects );
+ for ( ; anIter.More(); anIter.Next() )
+ {
+ Handle(HYDROData_Entity) anObj = anIter.Value();
+ if( !anObj.IsNull() && !anObj->IsRemoved() )
+ createObject( aPartSect, anObj, aGuiObj->entry(), false );
+ }
+}
+
void HYDROGUI_DataModel::buildObjectTree( SUIT_DataObject* theParent,
SUIT_DataObject* theObject,
const QString& theParentEntry,
createObject( aGuiObj, anObject3D, aGuiObj->entry(), false );
#ifdef DEB_GROUPS
- LightApp_DataObject* aGroupsSect =
- createObject( aGuiObj, tr( "OBJECT_GROUPS" ), aGuiObj->entry() );
-
HYDROData_SequenceOfObjects anObjGroups = aGeomObj->GetGroups();
- HYDROData_SequenceOfObjects::Iterator anIter( anObjGroups );
- for ( ; anIter.More(); anIter.Next() )
- {
- Handle(HYDROData_EdgesGroup) anObjGroup =
- Handle(HYDROData_EdgesGroup)::DownCast( anIter.Value() );
- if( !anObjGroup.IsNull() && !anObjGroup->IsRemoved() )
- createObject( aGroupsSect, anObjGroup, aGuiObj->entry(), false );
- }
+ buildObjectPartition( aGuiObj, anObjGroups, tr( "OBJECT_GROUPS" ), false );
#endif
}
LightApp_DataObject* aBathSect =
createObject( aGuiObj, tr( "ZONE_BATHYMETRY" ), aGuiObj->entry() );
- Handle(HYDROData_Bathymetry) aBathymetry = aZoneObj->GetBathymetry();
- if ( !aBathymetry.IsNull() && !aBathymetry->IsRemoved() )
- createObject( aBathSect, aBathymetry, aGuiObj->entry(), false );
+ Handle(HYDROData_IAltitudeObject) anAltitudeObj = aZoneObj->GetAltitudeObject();
+ if ( !anAltitudeObj.IsNull() && !anAltitudeObj->IsRemoved() )
+ createObject( aBathSect, anAltitudeObj, aGuiObj->entry(), false );
}
else if ( anObjectKind == KIND_POLYLINE )
{
LightApp_DataObject* aBathSect =
createObject( aGuiObj, tr( "POLYLINE3D_BATHYMETRY" ), aGuiObj->entry() );
- Handle(HYDROData_Bathymetry) aBathymetry = aPolyline3D->GetBathymetry();
- if ( !aBathymetry.IsNull() && !aBathymetry->IsRemoved() )
- createObject( aBathSect, aBathymetry, aGuiObj->entry(), false );
+ Handle(HYDROData_IAltitudeObject) anAltitudeObj = aPolyline3D->GetAltitudeObject();
+ if ( !anAltitudeObj.IsNull() && !anAltitudeObj->IsRemoved() )
+ createObject( aBathSect, anAltitudeObj, aGuiObj->entry(), false );
}
else if ( anObjectKind == KIND_CALCULATION )
{
Handle(HYDROData_CalculationCase) aCaseObj =
Handle(HYDROData_CalculationCase)::DownCast( aDataObj );
+ LightApp_DataObject* aCaseAOSect =
+ createObject( aGuiObj, tr( partitionName( KIND_ARTIFICIAL_OBJECT ).toAscii() ),
+ aGuiObj->entry() );
+ LightApp_DataObject* aCaseNOSect =
+ createObject( aGuiObj, tr( partitionName( KIND_NATURAL_OBJECT ).toAscii() ),
+ aGuiObj->entry() );
+
+ HYDROData_SequenceOfObjects aSeq = aCaseObj->GetGeometryObjects();
+ HYDROData_SequenceOfObjects::Iterator aGOIter( aSeq );
+ Handle(HYDROData_Entity) anEntity;
+ Handle(HYDROData_ArtificialObject) anAObject;
+ Handle(HYDROData_NaturalObject) aNObject;
+ for ( ; aGOIter.More(); aGOIter.Next() )
+ {
+ anEntity = aGOIter.Value();
+ if ( anEntity.IsNull() )
+ continue;
+ anAObject = Handle(HYDROData_ArtificialObject)::DownCast( anEntity );
+ if ( !anAObject.IsNull() )
+ createObject( aCaseAOSect, anAObject, aGuiObj->entry(), false );
+ else
+ {
+ aNObject = Handle(HYDROData_NaturalObject)::DownCast( anEntity );
+ if ( !aNObject.IsNull() )
+ createObject( aCaseNOSect, aNObject, aGuiObj->entry(), false );
+ }
+ }
LightApp_DataObject* aCaseRegionsSect =
createObject( aGuiObj, tr( "CASE_REGIONS" ), aGuiObj->entry() );
if( !aCaseRegion.IsNull() && !aCaseRegion->IsRemoved() )
createRegion( aCaseRegionsSect, aCaseRegion, "", true, theIsInOperation );
}
+
+#ifdef DEB_GROUPS
+ HYDROData_SequenceOfObjects aCalcGroups = aCaseObj->GetSplittedGroups();
+ buildObjectPartition( aGuiObj, aCalcGroups, tr( "OBJECT_GROUPS" ), false );
+
+ HYDROData_SequenceOfObjects aCalcSplitGroups = aCaseObj->GetSplittedGroups();
+ buildObjectPartition( aGuiObj, aCalcSplitGroups, tr( "CASE_SPLITTED_GROUPS" ), false );
+#endif
+
}
else if ( anObjectKind == KIND_REGION )
{
aGuiObj->setIsValid( aProfileObj->IsValid() );
}
+ else if ( anObjectKind == KIND_CHANNEL || anObjectKind == KIND_DIGUE )
+ {
+ Handle(HYDROData_Channel) aChannelObj =
+ Handle(HYDROData_Channel)::DownCast( aDataObj );
+
+ LightApp_DataObject* aGuideLineSect =
+ createObject( aGuiObj, tr( "CHANNEL_GUIDE_LINE" ), aGuiObj->entry() );
+ Handle(HYDROData_Polyline3D) aGuideLine = aChannelObj->GetGuideLine();
+ if ( !aGuideLine.IsNull() && !aGuideLine->IsRemoved() ) {
+ createObject( aGuideLineSect, aGuideLine, aGuiObj->entry(), false );
+ }
+
+ LightApp_DataObject* aProfileSect =
+ createObject( aGuiObj, tr( "CHANNEL_PROFILE" ), aGuiObj->entry() );
+ Handle(HYDROData_Profile) aProfile = aChannelObj->GetProfile();
+ if ( !aProfile.IsNull() && !aProfile->IsRemoved() ) {
+ createObject( aProfileSect, aProfile, aGuiObj->entry(), false );
+ }
+ }
+ else if ( anObjectKind == KIND_STREAM )
+ {
+ Handle(HYDROData_Stream) aStreamObj =
+ Handle(HYDROData_Stream)::DownCast( aDataObj );
+
+ LightApp_DataObject* aHydraulicAxisSect =
+ createObject( aGuiObj, tr( "STREAM_HYDRAULIC_AXIS" ), aGuiObj->entry() );
+ Handle(HYDROData_PolylineXY) aHydraulicAxis = aStreamObj->GetHydraulicAxis();
+ if ( !aHydraulicAxis.IsNull() && !aHydraulicAxis->IsRemoved() ) {
+ createObject( aHydraulicAxisSect, aHydraulicAxis, aGuiObj->entry(), false );
+ }
+
+ HYDROData_SequenceOfObjects aProfiles = aStreamObj->GetProfiles();
+ buildObjectPartition( aGuiObj, aProfiles, tr( "STREAM_PROFILES" ), true );
+ }
}
void HYDROGUI_DataModel::buildCaseTree( SUIT_DataObject* theParent, Handle(HYDROData_CalculationCase) theCase )