1 // Copyright (C) 2014-2015 EDF-R&D
2 // This library is free software; you can redistribute it and/or
3 // modify it under the terms of the GNU Lesser General Public
4 // License as published by the Free Software Foundation; either
5 // version 2.1 of the License, or (at your option) any later version.
7 // This library is distributed in the hope that it will be useful,
8 // but WITHOUT ANY WARRANTY; without even the implied warranty of
9 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
10 // Lesser General Public License for more details.
12 // You should have received a copy of the GNU Lesser General Public
13 // License along with this library; if not, write to the Free Software
14 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 #include "HYDROGUI_ImportLandCoverMapDlg.h"
24 #include <QListWidget>
25 #include <QVBoxLayout>
26 #include <QToolButton>
28 #include <SUIT_ResourceMgr.h>
29 #include <SUIT_Session.h>
30 #include <SUIT_FileDlg.h>
31 #include <HYDROGUI_Module.h>
32 #include <SUIT_MessageBox.h>
33 #include <LightApp_Application.h>
34 #include <QTableWidget>
35 #include <QHeaderView>
37 #include <QStackedWidget>
38 #include <SUIT_MessageBox.h>
39 #include <SUIT_Desktop.h>
40 #include <QSignalMapper>
42 HYDROGUI_ImportLandCoverMapDlg::HYDROGUI_ImportLandCoverMapDlg( HYDROGUI_Module* theModule, const QString& theTitle )
43 : HYDROGUI_Wizard( theModule, theTitle )
45 addPage( createPage1() );
46 addPage( createPage2() );
47 addPage( createPage3() );
48 myFirstPageState = false;
52 QWizardPage* HYDROGUI_ImportLandCoverMapDlg::createPage1() {
53 QWizardPage* aPage = new QWizardPage( mainFrame() );
54 QFrame* aFrame = new QFrame( aPage );
56 SUIT_ResourceMgr* aResMgr = SUIT_Session::session()->resourceMgr();
58 myFileNameGroup = new QGroupBox( tr( "IMPORT_LANDCOVERMAP_FROM_FILE" ) );
60 QLabel* aFileNameLabel = new QLabel( tr( "FILE_NAME" ), myFileNameGroup );
62 myFileName = new QLineEdit( myFileNameGroup );
63 myFileName->setReadOnly( true );
65 QToolButton* aBrowseBtn = new QToolButton( myFileNameGroup );
66 aBrowseBtn->setIcon( aResMgr->loadPixmap( "HYDRO", tr( "BROWSE_ICO" ) ) );
68 QBoxLayout* aFileNameLayout = new QHBoxLayout( myFileNameGroup );
69 aFileNameLayout->setMargin( 5 );
70 aFileNameLayout->setSpacing( 5 );
71 aFileNameLayout->addWidget( aFileNameLabel );
72 aFileNameLayout->addWidget( myFileName );
73 aFileNameLayout->addWidget( aBrowseBtn );
75 myObjectNameGroup = new QGroupBox( tr( "LANDCOVERMAP_NAME" ) );
77 QLabel* aLandcoverNameLabel = new QLabel( tr( "NAME" ), myObjectNameGroup );
78 myObjectName = new QLineEdit( myObjectNameGroup );
80 QBoxLayout* aLandcoverNameLayout = new QHBoxLayout( myObjectNameGroup );
81 aLandcoverNameLayout->setMargin( 5 );
82 aLandcoverNameLayout->setSpacing( 5 );
83 aLandcoverNameLayout->addWidget( aLandcoverNameLabel );
84 aLandcoverNameLayout->addWidget( myObjectName );
86 QGroupBox* aPolygonsGroup = new QGroupBox( tr( "FOUNDED_POLYGONS" ) );
87 myPolygonsListWidget = new QListWidget( aPolygonsGroup );
88 myPolygonsListWidget->setSelectionMode( QListWidget::ExtendedSelection );
89 myPolygonsListWidget->setEditTriggers( QListWidget::NoEditTriggers );
90 myPolygonsListWidget->setViewMode( QListWidget::ListMode );
91 myPolygonsListWidget->setSortingEnabled( false );
93 QBoxLayout* aPolygonsLayout = new QVBoxLayout;
94 aPolygonsLayout->addWidget( myPolygonsListWidget );
95 aPolygonsGroup->setLayout( aPolygonsLayout );
97 QVBoxLayout* aPageLayout = new QVBoxLayout;
98 myAttrCheckBox = new QCheckBox( tr("USE_DBF_AS_ST") );
99 myAttrCheckBox->setChecked(true);
102 aPageLayout->setMargin( 5 );
103 aPageLayout->setSpacing( 5 );
104 aPageLayout->addWidget( myFileNameGroup );
105 aPageLayout->addWidget( myAttrCheckBox );
106 aPageLayout->addWidget( myObjectNameGroup );
107 aPageLayout->addWidget( aPolygonsGroup );
108 aPage->setLayout( aPageLayout );
111 connect( myPolygonsListWidget, SIGNAL( itemSelectionChanged() ), this, SLOT( onItemSelectionChanged() ) );
112 connect( aBrowseBtn, SIGNAL( clicked() ), this, SLOT( onBrowse() ) );
113 connect( myAttrCheckBox, SIGNAL(clicked(bool)), this, SLOT(onAttrCBChecked(bool)));
118 QWizardPage* HYDROGUI_ImportLandCoverMapDlg::createPage2() {
119 QWizardPage* aPage = new QWizardPage( mainFrame() );
120 QFrame* aFrame = new QFrame( aPage );
122 myAvAttrLabel = new QLabel();
123 myAvAttrLabel->setText(tr("AV_ATTRS"));
125 myDBFAttrListWidget = new QListWidget( );
126 myDBFAttrListWidget->setSelectionMode( QListWidget::SingleSelection );
127 myDBFAttrListWidget->setEditTriggers( QListWidget::NoEditTriggers );
128 myDBFAttrListWidget->setViewMode( QListWidget::ListMode );
129 myDBFAttrListWidget->setSortingEnabled( false );
132 QVBoxLayout* aPageLayout = new QVBoxLayout;
133 aPageLayout->setMargin( 5 );
134 aPageLayout->setSpacing( 5 );
135 aPageLayout->addWidget( myAvAttrLabel );
136 aPageLayout->addWidget( myDBFAttrListWidget );
137 aPage->setLayout( aPageLayout );
142 QWizardPage* HYDROGUI_ImportLandCoverMapDlg::createPage3() {
144 QWizardPage* aPage = new QWizardPage( mainFrame() );
145 QFrame* aFrame = new QFrame( aPage );
146 myCorrLabel = new QLabel();
147 myCorrLabel->setText(tr ("CORR"));
149 myCorrTableWidget = new QTableWidget();
152 QVBoxLayout* aPageLayout = new QVBoxLayout;
153 aPageLayout->setMargin( 5 );
154 aPageLayout->setSpacing( 5 );
155 aPageLayout->addWidget( myCorrLabel );
156 aPageLayout->addWidget( myCorrTableWidget );
157 aPage->setLayout( aPageLayout );
162 HYDROGUI_ImportLandCoverMapDlg::~HYDROGUI_ImportLandCoverMapDlg()
164 myPolygonsListWidget->clear();
165 myDBFAttrListWidget->clear();
168 void HYDROGUI_ImportLandCoverMapDlg::reset()
170 myPolygonsListWidget->clear();
171 myDBFAttrListWidget->clear();
174 void HYDROGUI_ImportLandCoverMapDlg::setPolygonNames( const QStringList& theNames )
176 myPolygonsListWidget->clear();
177 myPolygonsListWidget->addItems( theNames );
180 void HYDROGUI_ImportLandCoverMapDlg::setAttributeNames( const QStringList& theAttrNames )
182 myDBFAttrListWidget->clear();
183 myDBFAttrListWidget->addItems( theAttrNames );
186 void HYDROGUI_ImportLandCoverMapDlg::setSelectedPolygonNames( const QStringList& theNames )
188 myPolygonsListWidget->clearSelection();
190 foreach( const QString aName, theNames ) {
191 QList<QListWidgetItem*> anItems = myPolygonsListWidget->findItems( aName, Qt::MatchExactly );
192 if ( anItems.count() == 1 ) {
193 anItems.first()->setSelected( true );
198 void HYDROGUI_ImportLandCoverMapDlg::onItemSelectionChanged()
200 emit selectionChanged( getSelectedPolygonNames() );
203 QStringList HYDROGUI_ImportLandCoverMapDlg::getSelectedPolygonNames() const
205 QStringList aSelectedNames;
207 QList<QListWidgetItem*> aSelectedItems = myPolygonsListWidget->selectedItems();
208 foreach( const QListWidgetItem* anItem, aSelectedItems )
209 aSelectedNames << anItem->text();
211 return aSelectedNames;
214 void HYDROGUI_ImportLandCoverMapDlg::onBrowse()
216 QString aFilter( tr( "LANDCOVERMAP_FILTER" ) );
217 QString aFileName = SUIT_FileDlg::getFileName( this, "", aFilter, tr( "IMPORT_LANDCOVERMAP_FROM_FILE" ), true );
219 if( !aFileName.isEmpty() )
221 setFileName( aFileName );
222 emit FileSelected( aFileName );
226 void HYDROGUI_ImportLandCoverMapDlg::setObjectName( const QString& theName )
228 myObjectName->setText( theName );
229 myObjectNameGroup->setEnabled( !theName.isEmpty() || !myFileName->text().isEmpty() );
232 QString HYDROGUI_ImportLandCoverMapDlg::getObjectName() const
234 return myObjectName->text();
237 void HYDROGUI_ImportLandCoverMapDlg::setFileName( const QString& theFileName )
239 myFileName->setText( theFileName );
241 if ( !myObjectNameGroup->isEnabled() )
242 myObjectNameGroup->setEnabled( !theFileName.isEmpty() );
245 QString HYDROGUI_ImportLandCoverMapDlg::getFileName() const
247 return myFileName->text();
251 void HYDROGUI_ImportLandCoverMapDlg::FillCorrespondenceTable(const QStringList& theFirstColumn,
252 const QStringList& theSecondColumn,
253 const QVector<int> theDefCBIndices,
254 const QVector<QColor> theColors)
256 int aFCSize = theFirstColumn.size(); // == theDefCBIndices.size() !
257 int aSCSize = theSecondColumn.size();
259 myStrColors = theColors;
261 myCorrTableWidget->setRowCount(aFCSize);
262 myCorrTableWidget->setColumnCount(3);
263 QTableWidgetItem* aHeader_1 = new QTableWidgetItem(QString(tr("TABLE_H1")), QTableWidgetItem::Type);
264 QTableWidgetItem* aHeader_2 = new QTableWidgetItem(QString(tr("TABLE_H2")), QTableWidgetItem::Type);
265 QTableWidgetItem* aHeader_3 = new QTableWidgetItem(QString(tr("TABLE_H3")), QTableWidgetItem::Type);
266 myCorrTableWidget->setHorizontalHeaderItem(0, aHeader_1);
267 myCorrTableWidget->setHorizontalHeaderItem(1, aHeader_2);
268 myCorrTableWidget->setHorizontalHeaderItem(2, aHeader_3);
269 myCorrTableWidget->horizontalHeader()->setResizeMode(QHeaderView::ResizeMode::ResizeToContents);
271 for (int i = 0; i < aFCSize; i++)
273 QTableWidgetItem* aTWI = new QTableWidgetItem();
274 aTWI->setText(theFirstColumn.at(i));
275 aTWI->setFlags(Qt::ItemIsUserCheckable);
276 myCorrTableWidget->setItem(i, 0, aTWI);
279 QSignalMapper* signalMap = new QSignalMapper();
280 for (int i = 0; i < aFCSize; i++)
282 QComboBox* aCB = new QComboBox();
283 connect(aCB, SIGNAL(currentIndexChanged(int)), signalMap, SLOT(map()));
284 signalMap->setMapping(aCB, i);
285 aCB->addItems(theSecondColumn);
286 aCB->setCurrentIndex(theDefCBIndices[i]);
287 myCorrTableWidget->setCellWidget(i, 1, aCB);
289 connect(signalMap, SIGNAL(mapped(int)), this, SLOT(onComboBoxColorChanged(int)));
292 for (int i = 0; i < aFCSize; i++)
294 myCorrTableWidget->setItem(i, 2, new QTableWidgetItem);
295 myCorrTableWidget->item(i, 2)->setBackground(myStrColors[theDefCBIndices[i]]);
300 QString HYDROGUI_ImportLandCoverMapDlg::getSelectedFieldName() const
302 return myDBFAttrListWidget->selectedItems().first()->text();
305 void HYDROGUI_ImportLandCoverMapDlg::setFirstPageState(bool theState)
307 myFirstPageState = theState;
310 bool HYDROGUI_ImportLandCoverMapDlg::acceptCurrent() const
312 //Check the state of the current page
313 int aCurrPage = wizard()->currentIndex();
318 if (!myFirstPageState)
320 SUIT_MessageBox::warning( module()->getApp()->desktop(), tr( "LCM_IMPORT_WARNING" ), tr("FILE_ISNT_CHOSEN"));
323 if (myPolygonsListWidget->selectedItems().empty())
325 SUIT_MessageBox::warning( module()->getApp()->desktop(), tr( "LCM_IMPORT_WARNING" ), tr("POLYGONS_ISNT_SELECTED"));
328 if (getAttrCheckBoxState() && !getDbfState())
330 SUIT_MessageBox::critical( module()->getApp()->desktop(), tr( "DBF_LOAD_ERROR" ), tr("DBF_LOAD_ERR_MESS"));
337 if (myDBFAttrListWidget->selectedItems().empty())
339 SUIT_MessageBox::warning( module()->getApp()->desktop(), tr( "LCM_IMPORT_WARNING" ), "Attribute isn't selected");
350 void HYDROGUI_ImportLandCoverMapDlg::getValAttr2StricklerTypeCorr(QStringList& theAttrValues, QStringList& theST)
352 int aRowCount = myCorrTableWidget->rowCount();
353 for (int i = 0; i < aRowCount; i++)
355 QTableWidgetItem* aTWI = myCorrTableWidget->item(i, 0);
356 theAttrValues.push_back(aTWI->text());
359 for (int i = 0; i < aRowCount; i++)
361 QWidget* aW = myCorrTableWidget->cellWidget(i, 1);
362 QComboBox* aCB = dynamic_cast<QComboBox*> (aW);
363 theST.push_back(aCB->currentText());
368 QVector<int> HYDROGUI_ImportLandCoverMapDlg::getSelectedPolygonIndices() const
370 QVector<int> aSelectedIndices;
372 QModelIndexList aSelectedItems = myPolygonsListWidget->selectionModel()->selectedIndexes();
373 foreach( QModelIndex index, aSelectedItems ) {
374 aSelectedIndices << index.row();
377 return aSelectedIndices;
380 void HYDROGUI_ImportLandCoverMapDlg::onAttrCBChecked( bool theState )
383 SetButtonsState ( false );
385 SetButtonsState ( true );
388 bool HYDROGUI_ImportLandCoverMapDlg::getAttrCheckBoxState() const
390 return myAttrCheckBox->isChecked();
393 void HYDROGUI_ImportLandCoverMapDlg::onComboBoxColorChanged(int theInd)
395 QComboBox* CB = qobject_cast<QComboBox*> (myCorrTableWidget->cellWidget(theInd, 1));
396 int aCurIndOfCB = CB->currentIndex();
397 myCorrTableWidget->item(theInd, 2)->setBackground(myStrColors[aCurIndOfCB]);
400 void HYDROGUI_ImportLandCoverMapDlg::setDbfState(bool theState)
402 myDbfState = theState;
405 bool HYDROGUI_ImportLandCoverMapDlg::getDbfState() const