Salome HOME
getting nb of intersections (non-gui) + add of profiles of stream to tree
[modules/hydro.git] / src / HYDROGUI / HYDROGUI_RiverBottomDlg.cxx
index 0922662bc789cc88c4a7a58a26c0e6eaf9dcba40..55418b2b81ea0702dfa671b428d46a794acd8c89 100644 (file)
@@ -1,12 +1,8 @@
-// Copyright (C) 2007-2013  CEA/DEN, EDF R&D, OPEN CASCADE
-//
-// Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
-// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
-//
+// Copyright (C) 2014-2015  EDF-R&D
 // This library is free software; you can redistribute it and/or
 // modify it under the terms of the GNU Lesser General Public
 // License as published by the Free Software Foundation; either
-// version 2.1 of the License.
+// version 2.1 of the License, or (at your option) any later version.
 //
 // This library is distributed in the hope that it will be useful,
 // but WITHOUT ANY WARRANTY; without even the implied warranty of
 #include "HYDROGUI_Tool.h"
 #include "HYDROGUI_ObjComboBox.h"
 
+#include <HYDROData_Stream.h>
+#include <HYDROData_Polyline3D.h>
+
 #include <QLabel>
 #include <QLayout>
 #include <QComboBox>
 #include <QGroupBox>
 
 HYDROGUI_RiverBottomDlg::HYDROGUI_RiverBottomDlg( HYDROGUI_Module* theModule, const QString& theTitle )
-    : HYDROGUI_InputPanel( theModule, theTitle )
+    : HYDROGUI_InputPanel( theModule, theTitle ),
+    HYDROGUI_ObjComboBoxFilter()
 {
     // Channel name
     QGroupBox* group = new QGroupBox( mainFrame() );
     QBoxLayout* base = new QVBoxLayout( group );
 
-    base->addWidget( myRivers = new HYDROGUI_ObjComboBox( theModule, tr( "RIVER_OBJECT" ), KIND_STREAM, group ) );
+    base->addWidget( myRivers = new HYDROGUI_ObjComboBox( theModule, tr( "STREAM_OBJECT" ), KIND_STREAM, group ) );
+    myRivers->setObjectFilter( this );
 
     addWidget( group );
 
     addStretch();
+
+    connect( myRivers, SIGNAL( objectSelected( const QString& ) ), this, SLOT( onRiverChanged( const QString& ) ) );
+
+    updateState();
 }
 
 HYDROGUI_RiverBottomDlg::~HYDROGUI_RiverBottomDlg()
@@ -55,6 +60,8 @@ void HYDROGUI_RiverBottomDlg::reset()
     myRivers->reset();
 
     blockSignals( isBlocked );
+
+    updateState();
 }
 
 QString HYDROGUI_RiverBottomDlg::getRiverName() const
@@ -64,5 +71,21 @@ QString HYDROGUI_RiverBottomDlg::getRiverName() const
 
 void HYDROGUI_RiverBottomDlg::setRiverName( const QString& theName )
 {
-    myRivers->setSectedObject( theName );
+    myRivers->setSelectedObject( theName );
+}
+
+bool HYDROGUI_RiverBottomDlg::isOk( const Handle(HYDROData_Entity)& theEntity ) const
+{
+    Handle(HYDROData_Stream) aStream = Handle(HYDROData_Stream)::DownCast(theEntity);
+    return !aStream.IsNull() && aStream->GetBottomPolyline().IsNull();
+}
+
+void HYDROGUI_RiverBottomDlg::onRiverChanged( const QString& )
+{
+    updateState();
+}
+
+void HYDROGUI_RiverBottomDlg::updateState()
+{
+    setApplyEnabled( !getRiverName().isEmpty() );
 }