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" 34 #include "ui_ComposeBandsWizardPageForm.h" 37 #include <QMessageBox> 41 te::qt::widgets::ComposeBandsWizardPage::ComposeBandsWizardPage(
QWidget* parent)
43 m_ui(new
Ui::ComposeBandsWizardPageForm)
48 m_ui->m_addToolButton->setIcon(QIcon::fromTheme(
"list-add"));
49 m_ui->m_removeToolButton->setIcon(QIcon::fromTheme(
"list-remove"));
52 fillInterpolatorTypes();
55 connect(m_ui->m_addToolButton, SIGNAL(clicked()),
this, SLOT(onAddToolButtonClicked()));
56 connect(m_ui->m_removeToolButton, SIGNAL(clicked()),
this, SLOT(onRemoveToolButtonClicked()));
59 this->setTitle(tr(
"Compose / Decompose Bands"));
60 this->setSubTitle(tr(
"Select the operation (Compose / Decompose) and set their specific parameters."));
74 m_ui->m_composeTableWidget->setRowCount(0);
75 m_ui->m_decomposeTableWidget->setRowCount(0);
77 std::list<te::map::AbstractLayerPtr>::iterator it;
85 std::unique_ptr<te::da::DataSet>
ds = l->getData();
91 std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
95 int newrow =
m_ui->m_composeTableWidget->rowCount();
96 m_ui->m_composeTableWidget->insertRow(newrow);
99 QComboBox* layerCmbBox =
new QComboBox(
this);
103 std::list<te::map::AbstractLayerPtr>::iterator itLayer;
112 layerCmbBox->addItem(lItem->getTitle().c_str(), QVariant::fromValue(lItem));
122 layerCmbBox->setCurrentIndex(curItem);
124 m_ui->m_composeTableWidget->setCellWidget(newrow, 1, layerCmbBox);
126 m_cmbMap.insert(std::map<QComboBox*, int>::value_type(layerCmbBox, newrow));
129 QComboBox* cmbBox =
new QComboBox(
this);
131 for(
unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
133 cmbBox->addItem(QString::number(i+1));
136 m_ui->m_composeTableWidget->setCellWidget(newrow, 0, cmbBox);
147 std::unique_ptr<te::da::DataSet>
ds = l->getData();
149 m_ui->m_rasterLineEdit->setText(l->getTitle().c_str());
155 std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
159 for(
unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
161 int newrow =
m_ui->m_decomposeTableWidget->rowCount();
162 m_ui->m_decomposeTableWidget->insertRow(newrow);
165 QString bName(tr(
"Band "));
166 bName.append(QString::number(i+1));
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);
180 if(
m_ui->m_tabWidget->currentIndex() == 0)
188 if(
m_ui->m_tabWidget->currentIndex() == 1)
196 int rowCount =
m_ui->m_composeTableWidget->rowCount();
198 for(
int i = 0; i < rowCount; ++i)
200 QComboBox* layerCmb = (QComboBox*)
m_ui->m_composeTableWidget->cellWidget(i, 1);
202 int curIdx = layerCmb->currentIndex();
203 QVariant varLayer = layerCmb->itemData(curIdx, Qt::UserRole);
213 rasters.push_back(inputRst.release());
216 QComboBox* bandCmb = (QComboBox*)
m_ui->m_composeTableWidget->cellWidget(i, 0);
218 bands.push_back((
unsigned int)bandCmb->currentText().toInt() - 1);
222 int idx =
m_ui->m_interpolatorComboBox->currentIndex();
238 for(
int r = 0; r <
m_ui->m_decomposeTableWidget->rowCount(); ++r)
240 if(
m_ui->m_decomposeTableWidget->item(r, 0)->checkState() == Qt::Checked)
242 bands.push_back((
unsigned int)r);
249 return m_ui->m_normalizeCheckBox->isChecked();
254 int newrow =
m_ui->m_composeTableWidget->rowCount();
255 m_ui->m_composeTableWidget->insertRow(newrow);
258 QComboBox* layerCmbBox =
new QComboBox(
this);
262 std::list<te::map::AbstractLayerPtr>::iterator itLayer;
268 layerCmbBox->addItem(lItem->getTitle().c_str(), QVariant::fromValue(lItem));
271 m_ui->m_composeTableWidget->setCellWidget(newrow, 1, layerCmbBox);
273 m_cmbMap.insert(std::map<QComboBox*, int>::value_type(layerCmbBox, newrow));
277 QComboBox* cmbBox =
new QComboBox(
this);
279 m_ui->m_composeTableWidget->setCellWidget(newrow, 0, cmbBox);
285 std::unique_ptr<te::da::DataSet>
ds = lFirst->getData();
291 std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
295 for(
unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
297 cmbBox->addItem(QString::number(i+1));
306 int currow =
m_ui->m_composeTableWidget->currentRow();
307 m_ui->m_composeTableWidget->removeRow(currow);
312 QComboBox* cmb =
dynamic_cast<QComboBox*
>(sender());
314 QVariant varLayer = cmb->itemData(index, Qt::UserRole);
319 QComboBox* bandCmb = (QComboBox*)
m_ui->m_composeTableWidget->cellWidget(row, 0);
324 std::unique_ptr<te::da::DataSet>
ds = layer->getData();
330 std::unique_ptr<te::rst::Raster> inputRst = ds->getRaster(rpos);
334 for(
unsigned int i = 0; i < inputRst->getNumberOfBands(); ++i)
336 bandCmb->addItem(QString::number(i+1));
344 m_ui->m_interpolatorComboBox->clear();
Near neighborhood interpolation method.
static te::dt::Date ds(2010, 01, 01)
void onAddToolButtonClicked()
InterpolationMethod
Allowed interpolation methods.
InterpolationMethod Method
Allowed interpolation methods.
std::list< te::map::AbstractLayerPtr > m_layerList
void setList(std::list< te::map::AbstractLayerPtr > &layerList)
An abstract class for raster data strucutures.
Q_DECLARE_METATYPE(te::map::AbstractLayerPtr) te
std::map< QComboBox *, int > m_cmbMap
void onLayerCmbActivated(int index)
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.
void onRemoveToolButtonClicked()
This file defines a class for a Compose / Decompose Bands Wizard page.
TEDATAACCESSEXPORT std::size_t GetFirstPropertyPos(const te::da::DataSet *dataset, int datatype)
boost::intrusive_ptr< AbstractLayer > AbstractLayerPtr
void fillInterpolatorTypes()
~ComposeBandsWizardPage()