ComposeBandsWizardPage.cpp
Go to the documentation of this file.
1 /* Copyright (C) 2008 National Institute For Space Research (INPE) - Brazil.
2 
3  This file is part of the TerraLib - a Framework for building GIS enabled applications.
4 
5  TerraLib is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published by
7  the Free Software Foundation, either version 3 of the License,
8  or (at your option) any later version.
9 
10  TerraLib is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with TerraLib. See COPYING. If not, write to
17  TerraLib Team at <terralib-team@terralib.org>.
18  */
19 
20 /*!
21  \file terralib/qt/widgets/rp/ComposeBandsWizardPage.cpp
22 
23  \brief This file defines a class for a Compose / Decompose Bands Wizard page.
24 */
25 
26 // TerraLib
27 #include "../../../common/StringUtils.h"
28 #include "../../../dataaccess/dataset/DataSet.h"
29 #include "../../../dataaccess/utils/Utils.h"
30 #include "../../../raster/Raster.h"
31 #include "../../../maptools/Utils.h"
32 #include "../../../rp/Functions.h"
33 #include "ComposeBandsWizardPage.h"
34 #include "ui_ComposeBandsWizardPageForm.h"
35 
36 // Qt
37 #include <QMessageBox>
38 
40 
41 te::qt::widgets::ComposeBandsWizardPage::ComposeBandsWizardPage(QWidget* parent)
42  : QWizardPage(parent),
43  m_ui(new Ui::ComposeBandsWizardPageForm)
44 {
45  //setup controls
46  m_ui->setupUi(this);
47 
48  m_ui->m_addToolButton->setIcon(QIcon::fromTheme("list-add"));
49  m_ui->m_removeToolButton->setIcon(QIcon::fromTheme("list-remove"));
50 
51  //set interpolator types
52  fillInterpolatorTypes();
53 
54  //connects
55  connect(m_ui->m_addToolButton, SIGNAL(clicked()), this, SLOT(onAddToolButtonClicked()));
56  connect(m_ui->m_removeToolButton, SIGNAL(clicked()), this, SLOT(onRemoveToolButtonClicked()));
57 
58  //configure page
59  this->setTitle(tr("Compose / Decompose Bands"));
60  this->setSubTitle(tr("Select the operation (Compose / Decompose) and set their specific parameters."));
61 }
62 
64 
66 {
67  return true;
68 }
69 
70 void te::qt::widgets::ComposeBandsWizardPage::setList(std::list<te::map::AbstractLayerPtr>& layerList)
71 {
72  m_layerList = layerList;
73 
74  m_ui->m_composeTableWidget->setRowCount(0);
75  m_ui->m_decomposeTableWidget->setRowCount(0);
76 
77  std::list<te::map::AbstractLayerPtr>::iterator it;
78 
79  //set compose table info
80  for(it = m_layerList.begin(); it!= m_layerList.end(); ++it)
81  {
83 
84  //get input raster
85  std::unique_ptr<te::da::DataSet> ds = l->getData();
86 
87  if(ds.get())
88  {
89  std::size_t rpos = te::da::GetFirstPropertyPos(ds.get(), te::dt::RASTER_TYPE);
90 
91  std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
92 
93  if(inputRst.get())
94  {
95  int newrow = m_ui->m_composeTableWidget->rowCount();
96  m_ui->m_composeTableWidget->insertRow(newrow);
97 
98  //layer combo
99  QComboBox* layerCmbBox = new QComboBox(this);
100 
101  connect(layerCmbBox, SIGNAL(activated(int)), this, SLOT(onLayerCmbActivated(int)));
102 
103  std::list<te::map::AbstractLayerPtr>::iterator itLayer;
104 
105  int curItem = -1;
106  int item = 0;
107 
108  for(itLayer = m_layerList.begin(); itLayer!= m_layerList.end(); ++itLayer)
109  {
110  te::map::AbstractLayerPtr lItem = *itLayer;
111 
112  layerCmbBox->addItem(lItem->getTitle().c_str(), QVariant::fromValue(lItem));
113 
114  if(lItem == l)
115  {
116  curItem = item;
117  }
118 
119  ++item;
120  }
121 
122  layerCmbBox->setCurrentIndex(curItem);
123 
124  m_ui->m_composeTableWidget->setCellWidget(newrow, 1, layerCmbBox);
125 
126  m_cmbMap.insert(std::map<QComboBox*, int>::value_type(layerCmbBox, newrow));
127 
128  //band
129  QComboBox* cmbBox = new QComboBox(this);
130 
131  for(unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
132  {
133  cmbBox->addItem(QString::number(i+1));
134  }
135 
136  m_ui->m_composeTableWidget->setCellWidget(newrow, 0, cmbBox);
137  }
138  }
139  }
140 
141  //set decompose table info
142  if(!m_layerList.empty())
143  {
145 
146  //get input raster
147  std::unique_ptr<te::da::DataSet> ds = l->getData();
148 
149  m_ui->m_rasterLineEdit->setText(l->getTitle().c_str());
150 
151  if(ds.get())
152  {
153  std::size_t rpos = te::da::GetFirstPropertyPos(ds.get(), te::dt::RASTER_TYPE);
154 
155  std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
156 
157  if(inputRst.get())
158  {
159  for(unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
160  {
161  int newrow = m_ui->m_decomposeTableWidget->rowCount();
162  m_ui->m_decomposeTableWidget->insertRow(newrow);
163 
164  //band item
165  QString bName(tr("Band "));
166  bName.append(QString::number(i+1));
167 
168  QTableWidgetItem* itemBand = new QTableWidgetItem(bName);
169  itemBand->setFlags(Qt::ItemIsEnabled | Qt::ItemIsUserCheckable);
170  itemBand->setCheckState(Qt::Checked);
171  m_ui->m_decomposeTableWidget->setItem(newrow, 0, itemBand);
172  }
173  }
174  }
175  }
176 }
177 
179 {
180  if(m_ui->m_tabWidget->currentIndex() == 0)
181  return true;
182 
183  return false;
184 }
185 
187 {
188  if(m_ui->m_tabWidget->currentIndex() == 1)
189  return true;
190 
191  return false;
192 }
193 
194 void te::qt::widgets::ComposeBandsWizardPage::getComposeParameters(std::vector<const te::rst::Raster*>& rasters, std::vector<unsigned int>& bands, te::rst::Interpolator::Method& interpMethod)
195 {
196  int rowCount = m_ui->m_composeTableWidget->rowCount();
197 
198  for(int i = 0; i < rowCount; ++i)
199  {
200  QComboBox* layerCmb = (QComboBox*)m_ui->m_composeTableWidget->cellWidget(i, 1);
201 
202  int curIdx = layerCmb->currentIndex();
203  QVariant varLayer = layerCmb->itemData(curIdx, Qt::UserRole);
204  te::map::AbstractLayerPtr layer = varLayer.value<te::map::AbstractLayerPtr>();
205 
206  //get input raster
207 
208  std::unique_ptr<te::rst::Raster> inputRst(te::map::GetRaster(layer.get()));
209 
210  if(!inputRst.get())
211  throw;
212 
213  rasters.push_back(inputRst.release());
214 
215 
216  QComboBox* bandCmb = (QComboBox*)m_ui->m_composeTableWidget->cellWidget(i, 0);
217 
218  bands.push_back((unsigned int)bandCmb->currentText().toInt() - 1);
219  }
220 
221  //interpolator method
222  int idx = m_ui->m_interpolatorComboBox->currentIndex();
223  interpMethod = (te::rst::Interpolator::Method)m_ui->m_interpolatorComboBox->itemData(idx).toInt();
224 }
225 
227 {
229 
230  //get input raster
231 
232  raster = te::map::GetRaster(l.get());
233 
234  if(!raster)
235  throw;
236 
237  //get bands
238  for(int r = 0; r < m_ui->m_decomposeTableWidget->rowCount(); ++r)
239  {
240  if(m_ui->m_decomposeTableWidget->item(r, 0)->checkState() == Qt::Checked)
241  {
242  bands.push_back((unsigned int)r);
243  }
244  }
245 }
246 
248 {
249  return m_ui->m_normalizeCheckBox->isChecked();
250 }
251 
253 {
254  int newrow = m_ui->m_composeTableWidget->rowCount();
255  m_ui->m_composeTableWidget->insertRow(newrow);
256 
257  //layer combo
258  QComboBox* layerCmbBox = new QComboBox(this);
259 
260  connect(layerCmbBox, SIGNAL(activated(int)), this, SLOT(onLayerCmbActivated(int)));
261 
262  std::list<te::map::AbstractLayerPtr>::iterator itLayer;
263 
264  for(itLayer = m_layerList.begin(); itLayer!= m_layerList.end(); ++itLayer)
265  {
266  te::map::AbstractLayerPtr lItem = *itLayer;
267 
268  layerCmbBox->addItem(lItem->getTitle().c_str(), QVariant::fromValue(lItem));
269  }
270 
271  m_ui->m_composeTableWidget->setCellWidget(newrow, 1, layerCmbBox);
272 
273  m_cmbMap.insert(std::map<QComboBox*, int>::value_type(layerCmbBox, newrow));
274 
275 
276  //band
277  QComboBox* cmbBox = new QComboBox(this);
278 
279  m_ui->m_composeTableWidget->setCellWidget(newrow, 0, cmbBox);
280 
281  te::map::AbstractLayerPtr lFirst = *m_layerList.begin();
282 
283  if(lFirst.get())
284  {
285  std::unique_ptr<te::da::DataSet> ds = lFirst->getData();
286 
287  if(ds.get())
288  {
289  std::size_t rpos = te::da::GetFirstPropertyPos(ds.get(), te::dt::RASTER_TYPE);
290 
291  std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
292 
293  if(inputRst.get())
294  {
295  for(unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
296  {
297  cmbBox->addItem(QString::number(i+1));
298  }
299  }
300  }
301  }
302 }
303 
305 {
306  int currow = m_ui->m_composeTableWidget->currentRow();
307  m_ui->m_composeTableWidget->removeRow(currow);
308 }
309 
311 {
312  QComboBox* cmb = dynamic_cast<QComboBox*>(sender());
313 
314  QVariant varLayer = cmb->itemData(index, Qt::UserRole);
315  te::map::AbstractLayerPtr layer = varLayer.value<te::map::AbstractLayerPtr>();
316 
317  int row = m_cmbMap[cmb];
318 
319  QComboBox* bandCmb = (QComboBox*)m_ui->m_composeTableWidget->cellWidget(row, 0);
320 
321  bandCmb->clear();
322 
323  //get input raster
324  std::unique_ptr<te::da::DataSet> ds = layer->getData();
325 
326  if(ds.get())
327  {
328  std::size_t rpos = te::da::GetFirstPropertyPos(ds.get(), te::dt::RASTER_TYPE);
329 
330  std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
331 
332  if(inputRst.get())
333  {
334  for(unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
335  {
336  bandCmb->addItem(QString::number(i+1));
337  }
338  }
339  }
340 }
341 
343 {
344  m_ui->m_interpolatorComboBox->clear();
345 
346  m_ui->m_interpolatorComboBox->addItem(tr("Nearest Neighbor"), te::rst::NearestNeighbor);
347  m_ui->m_interpolatorComboBox->addItem(tr("Bilinear"), te::rst::Bilinear);
348  m_ui->m_interpolatorComboBox->addItem(tr("Bicubic"), te::rst::Bicubic);
349 }
Near neighborhood interpolation method.
static te::dt::Date ds(2010, 01, 01)
InterpolationMethod
Allowed interpolation methods.
InterpolationMethod Method
Allowed interpolation methods.
Definition: Interpolator.h:62
std::list< te::map::AbstractLayerPtr > m_layerList
void setList(std::list< te::map::AbstractLayerPtr > &layerList)
An abstract class for raster data strucutures.
URI C++ Library.
Definition: Attributes.h:37
list bands
Definition: compose.py:2
Q_DECLARE_METATYPE(te::map::AbstractLayerPtr) te
void getComposeParameters(std::vector< const te::rst::Raster * > &rasters, std::vector< unsigned int > &bands, te::rst::Interpolator::Method &interpMethod)
std::unique_ptr< Ui::ComposeBandsWizardPageForm > m_ui
Bicubic interpolation method.
TEMAPEXPORT te::rst::Raster * GetRaster(AbstractLayer *layer)
It gets the raster referenced by the given data set layer.
void getDecomposeParameters(te::rst::Raster *&raster, std::vector< unsigned int > &bands)
Bilinear interpolation method.
This file defines a class for a Compose / Decompose Bands Wizard page.
TEDATAACCESSEXPORT std::size_t GetFirstPropertyPos(const te::da::DataSet *dataset, int datatype)
list rasters
Definition: compose.py:3
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr