#include "HYDROGUI_DataObject.h"
#include "HYDROGUI_Module.h"
#include "HYDROGUI_Tool.h"
+#include "HYDROGUI_Zone.h"
+#include "HYDROGUI_Region.h"
#include <HYDROData_Bathymetry.h>
-#include <HYDROData_Calculation.h>
+#include <HYDROData_CalculationCase.h>
#include <HYDROData_Document.h>
#include <HYDROData_Image.h>
+#include <HYDROData_ImmersibleZone.h>
#include <HYDROData_Iterator.h>
-#include <HYDROData_Polyline.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 <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* aCalculRootObj = createObject( aRootObj, partitionName( KIND_CALCULATION ) );
+ // NATURAL OBJECTS
+ LightApp_DataObject* aNaturalObjectsRootObj = createObject( aRootObj, tr( partitionName( KIND_NATURAL_OBJECT ).toAscii() ) );
- anIterator = HYDROData_Iterator( aDocument, KIND_CALCULATION );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_Calculation) aCalculObj =
- Handle(HYDROData_Calculation)::DownCast( anIterator.Current() );
- if( !aCalculObj.IsNull() )
- createObject( aCalculRootObj, aCalculObj );
- }
+ // OBSTACLES
+ LightApp_DataObject* anObstaclesRootObj = createObject( aRootObj, tr( partitionName( KIND_OBSTACLE ).toAscii() ) );
- LightApp_DataObject* aPolylineRootObj = createObject( aRootObj, partitionName( KIND_POLYLINE ) );
+ // CALCULATION CASES
+ LightApp_DataObject* aCalculRootObj = createObject( aRootObj, tr( partitionName( KIND_CALCULATION ).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 );
- }
+ // POLYLINES
+ LightApp_DataObject* aPolylineRootObj = createObject( aRootObj, tr( partitionName( KIND_POLYLINEXY ).toAscii() ) );
- LightApp_DataObject* aZonesRootObj = createObject( aRootObj, partitionName( KIND_ZONE ) );
+ // PROFILES
+ LightApp_DataObject* aProfileRootObj = createObject( aRootObj, tr( partitionName( KIND_PROFILE ).toAscii() ) );
- anIterator = HYDROData_Iterator( aDocument, KIND_ZONE );
- for( ; anIterator.More(); anIterator.Next() )
- {
- Handle(HYDROData_Zone) aZoneObj =
- Handle(HYDROData_Zone)::DownCast( anIterator.Current() );
- if( !aZoneObj.IsNull() )
- createObject( aZonesRootObj, aZoneObj );
- }
+ // VISUAL STATES
+ LightApp_DataObject* aVisualStateRootObj = createObject( aRootObj, tr( partitionName( KIND_VISUAL_STATE ).toAscii() ) );
- LightApp_DataObject* aVisualStateRootObj = createObject( aRootObj, partitionName( KIND_VISUAL_STATE ) );
+ HYDROData_Iterator anIterator( aDocument, KIND_UNKNOWN );
+ for( ; anIterator.More(); anIterator.Next() ) {
+ Handle(HYDROData_Entity) anObj = anIterator.Current();
- 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 );
+ 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_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_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() )
}
}
-HYDROGUI_DataObject* HYDROGUI_DataModel::getDataObject( const Handle(HYDROData_Object)& theModelObject )
+HYDROGUI_DataObject* HYDROGUI_DataModel::getDataObject( const Handle(HYDROData_Entity)& theModelObject )
{
return NULL; // to do if necessary
}
update( aModule->getStudyId() );
}
-Handle(HYDROData_Object) HYDROGUI_DataModel::objectByEntry( const QString& theEntry,
+Handle(HYDROData_Entity) HYDROGUI_DataModel::objectByEntry( const QString& theEntry,
const ObjectKind theObjectKind )
{
QString anEntry = theEntry;
HYDROData_Iterator anIterator( aDocument, theObjectKind );
for( ; anIterator.More(); anIterator.Next() )
{
- Handle(HYDROData_Object) anObject = anIterator.Current();
+ Handle(HYDROData_Entity) anObject = anIterator.Current();
if( !anObject.IsNull() )
{
QString anEntryRef = HYDROGUI_DataObject::dataObjectEntry( anObject );
if( aSeq.Length() != 1 )
return false;
- Handle(HYDROData_Object) anObject = aSeq.First();
+ Handle(HYDROData_Entity) anObject = aSeq.First();
if( anObject.IsNull() )
return false;
ObjectKind aKind = anObject->GetKind();
if( aKind == KIND_IMAGE ||
aKind == KIND_POLYLINE ||
+ aKind == KIND_PROFILE ||
aKind == KIND_CALCULATION )
return true;
{
for( int anIndex = 1, aLength = myCopyingObjects.Length(); anIndex <= aLength; anIndex++ )
{
- Handle(HYDROData_Object) anObject = myCopyingObjects.Value( anIndex );
+ Handle(HYDROData_Entity) anObject = myCopyingObjects.Value( anIndex );
if( !anObject.IsNull() && !anObject->IsRemoved() )
return true;
}
bool anIsChanged = false;
for( int anIndex = 1, aLength = myCopyingObjects.Length(); anIndex <= aLength; anIndex++ )
{
- Handle(HYDROData_Object) anObject = myCopyingObjects.Value( anIndex );
+ Handle(HYDROData_Entity) anObject = myCopyingObjects.Value( anIndex );
if( !anObject.IsNull() && !anObject->IsRemoved() )
{
ObjectKind aKind = anObject->GetKind();
- Handle(HYDROData_Object) aClone = getDocument()->CreateObject( aKind );
+ Handle(HYDROData_Entity) aClone = getDocument()->CreateObject( aKind );
if( !aClone.IsNull() )
{
anObject->CopyTo( aClone );
{
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_ZONE: return "ZONES";
+ case KIND_IMAGE: return "IMAGES";
+ 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* HYDROGUI_DataModel::createObject( SUIT_DataObject* theParent,
- Handle(HYDROData_Object) theModelObject,
- const QString& theParentEntry )
+ Handle(HYDROData_Entity) theModelObject,
+ const QString& theParentEntry,
+ const bool theIsBuildTree )
{
- HYDROGUI_DataObject* aResObj =
- new HYDROGUI_DataObject( theParent, theModelObject, theParentEntry );
- buildObjectTree( theParent, aResObj, theParentEntry );
+ HYDROGUI_DataObject* aResObj = new HYDROGUI_DataObject( theParent, theModelObject, theParentEntry );
+
+ if ( theIsBuildTree )
+ {
+ buildObjectTree( theParent, aResObj, theParentEntry );
+ }
+
return aResObj;
}
+LightApp_DataObject* HYDROGUI_DataModel::buildObject( SUIT_DataObject* theParent,
+ HYDROGUI_DataObject* theObject,
+ const QString& theParentEntry,
+ const bool theIsBuildTree )
+{
+ if ( theIsBuildTree )
+ {
+ buildObjectTree( theParent, theObject, theParentEntry );
+ }
+ return theObject;
+}
+
+LightApp_DataObject* HYDROGUI_DataModel::createZone( SUIT_DataObject* theParent,
+ Handle(HYDROData_Zone) theModelObject,
+ const QString& theParentEntry,
+ const bool theIsBuildTree )
+{
+ return buildObject( theParent, new HYDROGUI_Zone( theParent, theModelObject, theParentEntry ), theParentEntry, theIsBuildTree );
+}
+
+LightApp_DataObject* HYDROGUI_DataModel::createRegion( SUIT_DataObject* theParent,
+ Handle(HYDROData_Region) theModelObject,
+ const QString& theParentEntry,
+ const bool theIsBuildTree )
+{
+ return buildObject( theParent, new HYDROGUI_Region( theParent, theModelObject, theParentEntry ), theParentEntry, theIsBuildTree );
+}
+
LightApp_DataObject* HYDROGUI_DataModel::createObject( SUIT_DataObject* theParent,
const QString& theName,
- const QString& theParentEntry )
+ const QString& theParentEntry )
{
return new HYDROGUI_NamedObject( theParent, theName, theParentEntry );
}
if ( !aGuiObj )
return;
- Handle(HYDROData_Object) aDataObj = aGuiObj->modelObject();
+ Handle(HYDROData_Entity) aDataObj = aGuiObj->modelObject();
if ( aDataObj.IsNull() )
return;
Handle(HYDROData_Image)::DownCast( aDataObj );
for ( int anIndex = 0, aNbRef = anImageObj->NbReferences(); anIndex < aNbRef; anIndex++ )
{
- Handle(HYDROData_Object) aRefObj = anImageObj->Reference( anIndex );
+ Handle(HYDROData_Entity) aRefObj = anImageObj->Reference( anIndex );
if ( !aRefObj.IsNull() && !aRefObj->IsRemoved() )
- createObject( aGuiObj, aRefObj, aGuiObj->entry() );
+ createObject( aGuiObj, aRefObj, aGuiObj->entry(), false );
}
}
- else if ( anObjectKind == KIND_ZONE )
+ else if ( anObjectKind == KIND_IMMERSIBLE_ZONE )
{
- Handle(HYDROData_Zone) aZoneObj =
- Handle(HYDROData_Zone)::DownCast( aDataObj );
+ Handle(HYDROData_ImmersibleZone) aZoneObj =
+ Handle(HYDROData_ImmersibleZone)::DownCast( aDataObj );
- LightApp_DataObject* aPolylineSect = createObject( aGuiObj, tr( "ZONE_POLYLINE" ), aGuiObj->entry() );
+ 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() );
+ createObject( aPolylineSect, aPolyline, aGuiObj->entry(), false );
+
+ 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 );
+ }
+ else if ( anObjectKind == KIND_CALCULATION )
+ {
+ Handle(HYDROData_CalculationCase) aCaseObj =
+ Handle(HYDROData_CalculationCase)::DownCast( aDataObj );
+
+ LightApp_DataObject* aCaseRegionsSect =
+ createObject( aGuiObj, tr( "CASE_REGIONS" ), aGuiObj->entry() );
+
+ HYDROData_SequenceOfObjects aCaseRegions = aCaseObj->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( aCaseRegionsSect, aCaseRegion, "", true );
+ }
+ }
+ else if ( anObjectKind == KIND_REGION )
+ {
+ Handle(HYDROData_Region) aRegionObj =
+ Handle(HYDROData_Region)::DownCast( aDataObj );
+
+ HYDROData_SequenceOfObjects aRegionZones = aRegionObj->GetZones();
+ HYDROData_SequenceOfObjects::Iterator anIter( aRegionZones );
+ for ( ; anIter.More(); anIter.Next() )
+ {
+ Handle(HYDROData_Zone) aRegionZone =
+ Handle(HYDROData_Zone)::DownCast( anIter.Value() );
+ if( !aRegionZone.IsNull() && !aRegionZone->IsRemoved() )
+ createZone( aGuiObj, aRegionZone, "", true );
+ }
+ }
+}
- LightApp_DataObject* aBathsSect = createObject( aGuiObj, tr( "ZONE_BATHYMETRIES" ), aGuiObj->entry() );
+void HYDROGUI_DataModel::buildCaseTree( SUIT_DataObject* theParent, Handle(HYDROData_CalculationCase) theCase )
+{
+ if ( !theCase.IsNull() )
+ {
+ new HYDROGUI_DropTargetObject( theParent, tr( "NEW_REGION" ), "" );
- HYDROData_SequenceOfObjects aZoneBaths = aZoneObj->GetBathymetries();
- HYDROData_SequenceOfObjects::Iterator aBathsIter( aZoneBaths );
- for ( ; aBathsIter.More(); aBathsIter.Next() )
+ HYDROData_SequenceOfObjects aCaseRegions = theCase->GetRegions();
+ HYDROData_SequenceOfObjects::Iterator anIter( aCaseRegions );
+ for ( ; anIter.More(); anIter.Next() )
{
- Handle(HYDROData_Bathymetry) aRefBath =
- Handle(HYDROData_Bathymetry)::DownCast( aBathsIter.Value() );
- if( !aRefBath.IsNull() && !aRefBath->IsRemoved() )
- createObject( aBathsSect, aRefBath, aGuiObj->entry() );
+ Handle(HYDROData_Region) aCaseRegion =
+ Handle(HYDROData_Region)::DownCast( anIter.Value() );
+ if( !aCaseRegion.IsNull() && !aCaseRegion->IsRemoved() )
+ createRegion( theParent, aCaseRegion, "", true );
}
}
}
}
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;
+}