#include <HYDROData_Image.h>
#include <HYDROData_ImmersibleZone.h>
#include <HYDROData_Iterator.h>
-#include <HYDROData_Polyline.h>
+#include <HYDROData_Polyline3D.h>
+#include <HYDROData_PolylineXY.h>
+#include <HYDROData_Profile.h>
#include <HYDROData_VisualState.h>
#include <HYDROData_Region.h>
#include <HYDROData_Zone.h>
+#include <HYDROData_Obstacle.h>
+#include <HYDROData_Channel.h>
+#include <HYDROData_Digue.h>
+#include <HYDROData_River.h>
+#include <HYDROData_Stream.h>
#include <CAM_Application.h>
#include <CAM_DataObject.h>
if( aDocument.IsNull() )
return;
- LightApp_DataObject* anImageRootObj = createObject( aRootObj, partitionName( KIND_IMAGE ) );
+ // Create root objects:
- HYDROData_Iterator anIterator( aDocument, KIND_IMAGE );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_Image) anImageObj =
- Handle(HYDROData_Image)::DownCast( anIterator.Current() );
- if( !anImageObj.IsNull() )
- createObject( anImageRootObj, anImageObj );
- }
+ // IMAGES
+ LightApp_DataObject* anImageRootObj = createObject( aRootObj, tr( partitionName( KIND_IMAGE ).toAscii() ) );
- LightApp_DataObject* aBathymetryRootObj = createObject( aRootObj, partitionName( KIND_BATHYMETRY ) );
+ // BATHYMETRY
+ LightApp_DataObject* aBathymetryRootObj = createObject( aRootObj, tr( partitionName( KIND_BATHYMETRY ).toAscii() ) );
- anIterator = HYDROData_Iterator( aDocument, KIND_BATHYMETRY );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_Bathymetry) aBathymetryObj =
- Handle(HYDROData_Bathymetry)::DownCast( anIterator.Current() );
- if( !aBathymetryObj.IsNull() )
- createObject( aBathymetryRootObj, aBathymetryObj );
- }
+ // ARTIFICIAL OBJECTS
+ LightApp_DataObject* anArtificialObjectsRootObj = createObject( aRootObj, tr( partitionName( KIND_ARTIFICIAL_OBJECT ).toAscii() ) );
- LightApp_DataObject* aPolylineRootObj = createObject( aRootObj, partitionName( KIND_POLYLINE ) );
+ // NATURAL OBJECTS
+ LightApp_DataObject* aNaturalObjectsRootObj = createObject( aRootObj, tr( partitionName( KIND_NATURAL_OBJECT ).toAscii() ) );
- anIterator = HYDROData_Iterator( aDocument, KIND_POLYLINE );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_Polyline) aPolylineObj =
- Handle(HYDROData_Polyline)::DownCast( anIterator.Current() );
- if( !aPolylineObj.IsNull() )
- createObject( aPolylineRootObj, aPolylineObj );
- }
+ // OBSTACLES
+ LightApp_DataObject* anObstaclesRootObj = createObject( aRootObj, tr( partitionName( KIND_OBSTACLE ).toAscii() ) );
- LightApp_DataObject* aZonesRootObj = createObject( aRootObj, partitionName( KIND_IMMERSIBLE_ZONE ) );
+ // CALCULATION CASES
+ LightApp_DataObject* aCalculRootObj = createObject( aRootObj, tr( partitionName( KIND_CALCULATION ).toAscii() ) );
- anIterator = HYDROData_Iterator( aDocument, KIND_IMMERSIBLE_ZONE );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_ImmersibleZone) aZoneObj =
- Handle(HYDROData_ImmersibleZone)::DownCast( anIterator.Current() );
- if( !aZoneObj.IsNull() )
- createObject( aZonesRootObj, aZoneObj );
- }
+ // POLYLINES
+ LightApp_DataObject* aPolylineRootObj = createObject( aRootObj, tr( partitionName( KIND_POLYLINEXY ).toAscii() ) );
- LightApp_DataObject* aCalculRootObj = createObject( aRootObj, partitionName( KIND_CALCULATION ) );
+ // POLYLINES
+ LightApp_DataObject* aPolyline3DRootObj = createObject( aRootObj, tr( partitionName( KIND_POLYLINE ).toAscii() ) );
- anIterator = HYDROData_Iterator( aDocument, KIND_CALCULATION );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_CalculationCase) aCalculObj =
- Handle(HYDROData_CalculationCase)::DownCast( anIterator.Current() );
- if( !aCalculObj.IsNull() )
- createObject( aCalculRootObj, aCalculObj );
- }
+ // PROFILES
+ LightApp_DataObject* aProfileRootObj = createObject( aRootObj, tr( partitionName( KIND_PROFILE ).toAscii() ) );
- LightApp_DataObject* aVisualStateRootObj = createObject( aRootObj, partitionName( KIND_VISUAL_STATE ) );
+ // VISUAL STATES
+ LightApp_DataObject* aVisualStateRootObj = createObject( aRootObj, tr( partitionName( KIND_VISUAL_STATE ).toAscii() ) );
- anIterator = HYDROData_Iterator( aDocument, KIND_VISUAL_STATE );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_VisualState) aVisualStateObj =
- Handle(HYDROData_VisualState)::DownCast( anIterator.Current() );
- if( !aVisualStateObj.IsNull() )
- createObject( aVisualStateRootObj, aVisualStateObj );
+ HYDROData_Iterator anIterator( aDocument, KIND_UNKNOWN );
+ for( ; anIterator.More(); anIterator.Next() ) {
+ Handle(HYDROData_Entity) anObj = anIterator.Current();
+
+ if ( !anObj.IsNull() )
+ {
+ switch ( anObj->GetKind() ) {
+ case KIND_IMAGE:
+ {
+ Handle(HYDROData_Image) anImageObj =
+ Handle(HYDROData_Image)::DownCast( anObj );
+ if( !anImageObj.IsNull() ) {
+ createObject( anImageRootObj, anImageObj );
+ }
+
+ break;
+ }
+ case KIND_BATHYMETRY:
+ {
+ Handle(HYDROData_Bathymetry) aBathymetryObj =
+ Handle(HYDROData_Bathymetry)::DownCast( anObj );
+ if( !aBathymetryObj.IsNull() ) {
+ createObject( aBathymetryRootObj, aBathymetryObj );
+ }
+
+ break;
+ }
+ case KIND_CHANNEL:
+ {
+ Handle(HYDROData_Channel) aChannelObj =
+ Handle(HYDROData_Channel)::DownCast( anObj );
+ if( !aChannelObj.IsNull() ) {
+ createObject( anArtificialObjectsRootObj, aChannelObj );
+ }
+
+ break;
+ }
+ case KIND_DIGUE:
+ {
+ Handle(HYDROData_Digue) aDigueObj =
+ Handle(HYDROData_Digue)::DownCast( anObj );
+ if( !aDigueObj.IsNull() ) {
+ createObject( anArtificialObjectsRootObj, aDigueObj );
+ }
+
+ break;
+ }
+ case KIND_IMMERSIBLE_ZONE:
+ {
+ Handle(HYDROData_ImmersibleZone) anImmersibleZoneObj =
+ Handle(HYDROData_ImmersibleZone)::DownCast( anObj );
+ if( !anImmersibleZoneObj.IsNull() ) {
+ createObject( aNaturalObjectsRootObj, anImmersibleZoneObj );
+ }
+
+ break;
+ }
+ case KIND_RIVER:
+ {
+ Handle(HYDROData_River) aRiverObj =
+ Handle(HYDROData_River)::DownCast( anObj );
+ if( !aRiverObj.IsNull() ) {
+ createObject( aNaturalObjectsRootObj, aRiverObj );
+ }
+
+ break;
+ }
+ case KIND_STREAM:
+ {
+ Handle(HYDROData_Stream) aStreamObj =
+ Handle(HYDROData_Stream)::DownCast( anObj );
+ if( !aStreamObj.IsNull() ) {
+ createObject( aNaturalObjectsRootObj, aStreamObj );
+ }
+
+ break;
+ }
+ case KIND_OBSTACLE:
+ {
+ Handle(HYDROData_Obstacle) anObstacleObj =
+ Handle(HYDROData_Obstacle)::DownCast( anObj );
+ if( !anObstacleObj.IsNull() ) {
+ createObject( anObstaclesRootObj, anObstacleObj );
+ }
+
+ break;
+ }
+ case KIND_CALCULATION:
+ {
+ Handle(HYDROData_CalculationCase) aCalculObj =
+ Handle(HYDROData_CalculationCase)::DownCast( anObj );
+ if( !aCalculObj.IsNull() ) {
+ createObject( aCalculRootObj, aCalculObj );
+ }
+
+ break;
+ }
+ case KIND_POLYLINEXY:
+ {
+ Handle(HYDROData_PolylineXY) aPolylineObj =
+ Handle(HYDROData_PolylineXY)::DownCast( anObj );
+ if( !aPolylineObj.IsNull() ) {
+ createObject( aPolylineRootObj, aPolylineObj );
+ }
+
+ break;
+ }
+ case KIND_POLYLINE:
+ {
+ Handle(HYDROData_Polyline3D) aPolylineObj =
+ Handle(HYDROData_Polyline3D)::DownCast( anObj );
+ if( !aPolylineObj.IsNull() ) {
+ createObject( aPolyline3DRootObj, aPolylineObj );
+ }
+
+ break;
+ }
+ case KIND_PROFILE:
+ {
+ Handle(HYDROData_Profile) aProfileObj =
+ Handle(HYDROData_Profile)::DownCast( anObj );
+ if( !aProfileObj.IsNull() ) {
+ createObject( aProfileRootObj, aProfileObj );
+ }
+
+ break;
+ }
+ case KIND_VISUAL_STATE:
+ {
+ Handle(HYDROData_VisualState) aVisualStateObj =
+ Handle(HYDROData_VisualState)::DownCast( anObj );
+ if( !aVisualStateObj.IsNull() ) {
+ createObject( aVisualStateRootObj, aVisualStateObj );
+ }
+
+ break;
+ }
+ }
+ }
}
if( SUIT_DataBrowser* anObjectBrowser = anApp->objectBrowser() )
ObjectKind aKind = anObject->GetKind();
if( aKind == KIND_IMAGE ||
aKind == KIND_POLYLINE ||
+ aKind == KIND_PROFILE ||
aKind == KIND_CALCULATION )
return true;
{
switch( theObjectKind )
{
- case KIND_IMAGE: return "IMAGES";
- case KIND_POLYLINE: return "POLYLINES";
- case KIND_VISUAL_STATE: return "VISUAL_STATES";
- case KIND_BATHYMETRY: return "BATHYMETRIES";
- case KIND_CALCULATION: return "CALCULATION_CASES";
- case KIND_IMMERSIBLE_ZONE: return "IMMERSIBLE_ZONES";
+ case KIND_IMAGE: return "IMAGES";
+ case KIND_POLYLINE: return "POLYLINES_3D";
+ case KIND_POLYLINEXY: return "POLYLINES";
+ case KIND_PROFILE: return "PROFILES";
+ case KIND_VISUAL_STATE: return "VISUAL_STATES";
+ case KIND_BATHYMETRY: return "BATHYMETRIES";
+ case KIND_CALCULATION: return "CALCULATION_CASES";
+ case KIND_OBSTACLE: return "OBSTACLES";
+ case KIND_ARTIFICIAL_OBJECT: return "ARTIFICIAL_OBJECTS";
+ case KIND_NATURAL_OBJECT: return "NATURAL_OBJECTS";
default: break;
}
return QString();
LightApp_DataObject* aPolylineSect =
createObject( aGuiObj, tr( "ZONE_POLYLINE" ), aGuiObj->entry() );
- Handle(HYDROData_Polyline) aPolyline = aZoneObj->GetPolyline();
+ Handle(HYDROData_PolylineXY) aPolyline = aZoneObj->GetPolyline();
if ( !aPolyline.IsNull() && !aPolyline->IsRemoved() )
createObject( aPolylineSect, aPolyline, aGuiObj->entry(), false );
createZone( aGuiObj, aRegionZone, "", true );
}
}
+ else if ( anObjectKind == KIND_PROFILE )
+ {
+ Handle(HYDROData_Profile) aProfileObj =
+ Handle(HYDROData_Profile)::DownCast( aDataObj );
+
+ aGuiObj->setIsValid( aProfileObj->IsValid() );
+ }
+}
+
+void HYDROGUI_DataModel::buildCaseTree( SUIT_DataObject* theParent, Handle(HYDROData_CalculationCase) theCase )
+{
+ if ( !theCase.IsNull() )
+ {
+ new HYDROGUI_DropTargetObject( theParent, tr( "NEW_REGION" ), "" );
+
+ HYDROData_SequenceOfObjects aCaseRegions = theCase->GetRegions();
+ HYDROData_SequenceOfObjects::Iterator anIter( aCaseRegions );
+ for ( ; anIter.More(); anIter.Next() )
+ {
+ Handle(HYDROData_Region) aCaseRegion =
+ Handle(HYDROData_Region)::DownCast( anIter.Value() );
+ if( !aCaseRegion.IsNull() && !aCaseRegion->IsRemoved() )
+ createRegion( theParent, aCaseRegion, "", true );
+ }
+ }
}
void HYDROGUI_DataModel::removeChild( SUIT_DataObject* theParent,
}
return NULL; // not found
}
+
+bool HYDROGUI_DataModel::createNewRegion( Handle(HYDROData_CalculationCase) theCase,
+ const QList<HYDROGUI_Zone*>& theZonesList )
+{
+ bool isOk = !theCase.IsNull();
+ if ( isOk )
+ {
+ Handle(HYDROData_Region) aRegion;
+ Handle(HYDROData_Zone) aZone;
+ for (int i = 0; i < theZonesList.length(); i++ )
+ {
+ aZone = Handle(HYDROData_Zone)::DownCast( theZonesList.at(i)->modelObject() );
+ if ( !aZone.IsNull() )
+ {
+ if ( aRegion.IsNull() )
+ {
+ aRegion = theCase->AddNewRegion( aZone );
+ isOk = !aRegion.IsNull();
+ }
+ else
+ {
+ if ( !( aRegion->AddZone( aZone ) ) )
+ {
+ isOk = false;
+ }
+ }
+ }
+ }
+ }
+ return isOk;
+}
+
+bool HYDROGUI_DataModel::rename( Handle(HYDROData_Entity) theEntity, const QString& theName )
+{
+ if ( theName.isEmpty() )
+ return false;
+
+ try
+ {
+ getDocument()->StartOperation();
+ theEntity->SetName( theName );
+ getDocument()->CommitOperation( HYDROGUI_Tool::ToExtString( tr("RENAME_TO").arg( theName ) ) );
+ module()->application()->activeStudy()->Modified();
+ }
+ catch ( Standard_Failure )
+ {
+ getDocument()->AbortOperation();
+ return false;
+ }
+ return true;
+}
+