17#include "moc_qgsloadrasterattributetabledialog.cpp"
26 , mRasterLayer( rasterLayer )
30 connect( mButtonBox, &QDialogButtonBox::accepted,
this, &QDialog::accept );
31 connect( mButtonBox, &QDialogButtonBox::rejected,
this, &QDialog::reject );
37 mRasterBand->setLayer( mRasterLayer );
39 mDbfPathWidget->setFilter( QStringLiteral(
"VAT DBF Files (*.vat.dbf)" ) );
48 return mDbfPathWidget->filePath();
53 return mRasterBand->currentBand();
63 return mOpenRat->isChecked();
70 mOpenRat->setChecked(
false );
72 mOpenRat->setVisible( visible );
77 bool success {
false };
85 std::unique_ptr<QgsRasterAttributeTable> rat = std::make_unique<QgsRasterAttributeTable>();
88 success = rat->readFromFile(
filePath(), &errorMessage );
92 notify( tr(
"Error Loading Raster Attribute Table " ), tr(
"The raster attribute table could not be loaded.\n%1" ).arg( errorMessage ),
Qgis::MessageLevel::Critical );
96 if ( !rat->isValid( &errorMessage ) )
98 switch ( QMessageBox::warning(
nullptr, tr(
"Invalid Raster Attribute Table" ), tr(
"The raster attribute table is not valid:\n%1\nLoad anyway?" ), QMessageBox::Yes | QMessageBox::No | QMessageBox::Cancel ) )
100 case QMessageBox::Cancel:
102 case QMessageBox::Yes:
105 case QMessageBox::No:
114 switch ( QMessageBox::warning(
nullptr, tr(
"Confirm Attribute Table Replacement" ), tr(
"Raster band %1 already has an associated attribute table loaded from '%2'. Are you sure you want to replace the existing raster attribute table?" ).arg( QString::number(
rasterBand() ), mRasterLayer->
attributeTable(
rasterBand() )->
filePath() ), QMessageBox::Yes | QMessageBox::No | QMessageBox::Cancel ) )
116 case QMessageBox::Cancel:
118 case QMessageBox::Yes:
121 case QMessageBox::No:
131 notify( tr(
"Raster Attribute Table Loaded" ), tr(
"The new raster attribute table was successfully loaded." ),
Qgis::MessageLevel::Success );
139void QgsLoadRasterAttributeTableDialog::notify(
const QString &title,
const QString &message,
Qgis::MessageLevel level )
153 QMessageBox::information(
nullptr, title, message );
158 QMessageBox::warning(
nullptr, title, message );
163 QMessageBox::critical(
nullptr, title, message );
170void QgsLoadRasterAttributeTableDialog::updateButtons()
172 const bool isValidPath { !mDbfPathWidget->filePath().isEmpty() && QFile::exists( mDbfPathWidget->filePath() ) };
173 mButtonBox->button( QDialogButtonBox::StandardButton::Ok )->setEnabled( isValidPath );
MessageLevel
Level for messages This will be used both for message log and message bar in application.
@ Warning
Warning message.
@ Critical
Critical/error message.
@ Info
Information message.
@ Success
Used for reporting a successful operation.
static void enableAutoGeometryRestore(QWidget *widget, const QString &key=QString())
Register the widget to allow its position to be automatically saved and restored when open and closed...
bool openWhenDone() const
Returns true if the option to open the newly created attribute table is checked.
int rasterBand()
Returns the raster band associated to the raster attribute table.
QgsLoadRasterAttributeTableDialog(QgsRasterLayer *rasterLayer, QWidget *parent=nullptr)
Creates a new QgsCreateRasterAttributeTableDialog.
QString filePath() const
Returns the file path to VAT.DBF.
void setMessageBar(QgsMessageBar *bar)
Sets the message bar associated with the widget.
void setOpenWhenDoneVisible(bool visible)
Sets the visibility of the "Open newly created raster attribute table" option to visible,...
A bar for displaying non-blocking messages to the user.
void pushMessage(const QString &text, Qgis::MessageLevel level=Qgis::MessageLevel::Info, int duration=-1)
A convenience method for pushing a message with the specified text to the bar.
void setAttributeTable(int bandNumber, QgsRasterAttributeTable *attributeTable)
Set the attribute table to attributeTable for the specified bandNumber, if the attributeTable is null...
Represents a raster layer.
QgsRasterAttributeTable * attributeTable(int bandNumber) const
Returns the (possibly NULL) raster attribute table for the given band bandNumber.
QgsRasterDataProvider * dataProvider() override
Returns the source data provider.