From 1e6973180403e513c6c9469ec92751f083f5ff3c Mon Sep 17 00:00:00 2001 From: Danilo Cesar Lemes de Paula Date: Thu, 22 Aug 2013 16:20:47 -0300 Subject: use QWebView to show the user manual Looks like the QTextBrowser can't render the manual correctly. Also, QWebView provides a better way to find contents on a webpage, which is an important feature for an user manual (to be implemented). Signed-off-by: Danilo Cesar Lemes de Paula --- Configure.mk | 2 +- qt-ui/mainwindow.cpp | 8 ++++---- qt-ui/mainwindow.h | 4 ++-- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/Configure.mk b/Configure.mk index a532d4138..4039db454 100644 --- a/Configure.mk +++ b/Configure.mk @@ -106,7 +106,7 @@ ifeq ($(strip $(QMAKE)),) $(error Could not find qmake or qmake-qt4 in $$PATH for the Qt4 version they failed) endif - QT_MODULES = QtGui QtSvg QtNetwork + QT_MODULES = QtGui QtSvg QtNetwork QtWebKit QT_CORE = QtCore MOC = $(shell $(PKGCONFIG) --variable=moc_location QtCore) UIC = $(shell $(PKGCONFIG) --variable=uic_location QtGui) diff --git a/qt-ui/mainwindow.cpp b/qt-ui/mainwindow.cpp index a78b84565..75f18000c 100644 --- a/qt-ui/mainwindow.cpp +++ b/qt-ui/mainwindow.cpp @@ -15,7 +15,7 @@ #include #include #include -#include +#include #include #include "divelistview.h" #include "starwidget.h" @@ -411,14 +411,14 @@ void MainWindow::on_actionAboutSubsurface_triggered() void MainWindow::on_actionUserManual_triggered() { if(!helpView){ - helpView = new QTextBrowser(); + helpView = new QWebView(); } QString searchPath = getSubsurfaceDataPath("Documentation"); if (searchPath != "") { QUrl url(searchPath.append("/user-manual.html")); - helpView->setSource(url); + helpView->setUrl(url); } else { - helpView->setText(tr("Cannot find the Subsurface manual")); + helpView->setHtml(tr("Cannot find the Subsurface manual")); } helpView->show(); } diff --git a/qt-ui/mainwindow.h b/qt-ui/mainwindow.h index 2009740fe..0b0b0055d 100644 --- a/qt-ui/mainwindow.h +++ b/qt-ui/mainwindow.h @@ -29,7 +29,7 @@ class DiveListView; class GlobeGPS; class MainTab; class ProfileGraphicsView; -class QTextBrowser; +class QWebView; enum MainWindowTitleFormat { MWTF_DEFAULT, MWTF_FILENAME }; @@ -110,7 +110,7 @@ private: Ui::MainWindow *ui; QAction *actionNextDive; QAction *actionPreviousDive; - QTextBrowser *helpView; + QWebView *helpView; QString filter(); bool askSaveChanges(); void writeSettings(); -- cgit v1.2.3-70-g09d2 From db44045cfea21510415ef53b27895cc0770312a7 Mon Sep 17 00:00:00 2001 From: Danilo Cesar Lemes de Paula Date: Thu, 22 Aug 2013 17:58:39 -0300 Subject: fixing planner's gas dialog Before this commit this dialog had a weird behavior in which when it was shown, the whole screen was still active. In case of a alt+tab, this dialog is sent to behind the application window, but still visible in the task bar. This commit basically changes this behavior to a regular pop-up. Signed-off-by: Danilo Cesar Lemes de Paula --- qt-ui/diveplanner.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index 95b6c211c..39d3b20a8 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -142,9 +142,10 @@ DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent) // Prepare the stuff for the gas-choices. gasChoices = new QStringListModel(QStringList() << tr("AIR") << tr("EAN32") << tr("EAN36")); - gasListView = new QListView(); - gasListView->setWindowFlags(Qt::FramelessWindowHint); + gasListView = new QListView(this); + gasListView->setWindowFlags(Qt::FramelessWindowHint | Qt::Popup); gasListView->setModel(gasChoices); + gasListView->setWindowModality(Qt::WindowModal); gasListView->hide(); connect(gasListView, SIGNAL(activated(QModelIndex)), this, SLOT(selectGas(QModelIndex))); -- cgit v1.2.3-70-g09d2 From ab649e21ba07c9f572d61350b9217609f44f7f04 Mon Sep 17 00:00:00 2001 From: Danilo Cesar Lemes de Paula Date: Sun, 25 Aug 2013 10:01:59 -0300 Subject: fix DownloadDialog behavior The DownloadDialog behavior was broken in a way it allows the user to make changes on the dialog while the download is happening. Also, clicking on "Cancel" breaks/hangs the UI sometimes, as libdivingcomputer doesn't always cancels the download right away. That's a bug that still needs to be fixed. Signed-off-by: Danilo Cesar Lemes de Paula --- qt-ui/downloadfromdivecomputer.cpp | 42 +++++++++++++++++++++++++++++++++++++- qt-ui/downloadfromdivecomputer.h | 9 +++++++- 2 files changed, 49 insertions(+), 2 deletions(-) diff --git a/qt-ui/downloadfromdivecomputer.cpp b/qt-ui/downloadfromdivecomputer.cpp index 65e7a16e2..7514c9482 100644 --- a/qt-ui/downloadfromdivecomputer.cpp +++ b/qt-ui/downloadfromdivecomputer.cpp @@ -65,7 +65,11 @@ DownloadFromDCWidget::DownloadFromDCWidget(QWidget* parent, Qt::WindowFlags f) : void DownloadFromDCWidget::runDialog() { + // Since the DownloadDialog is only + // created once, we need to do put some starting code here ui->progressBar->hide(); + markChildrenAsEnabled(); + exec(); } @@ -138,7 +142,11 @@ void DownloadFromDCWidget::on_cancel_clicked() thread->deleteLater(); thread = 0; } - close(); + + // Confusing, but if the user press cancel during a download + // he probably want to cancel the download, not to close the window. + if (!downloading) + close(); } void DownloadFromDCWidget::on_ok_clicked() @@ -146,6 +154,7 @@ void DownloadFromDCWidget::on_ok_clicked() if (downloading) return; + markChildrenAsDisabled(); ui->progressBar->setValue(0); ui->progressBar->show(); @@ -156,6 +165,7 @@ void DownloadFromDCWidget::on_ok_clicked() data.devname = strdup(ui->device->text().toUtf8().data()); data.vendor = strdup(ui->vendor->currentText().toUtf8().data()); data.product = strdup(ui->product->currentText().toUtf8().data()); + data.descriptor = descriptorLookup[ui->vendor->currentText() + ui->product->currentText()]; data.force_download = ui->forceDownload->isChecked(); data.deviceid = data.diveid = 0; @@ -177,6 +187,36 @@ bool DownloadFromDCWidget::preferDownloaded() return ui->preferDownloaded->isChecked(); } +void DownloadFromDCWidget::reject() +{ + // we don't want the download window being able to close + // while we're still downloading. + if (!downloading) + QDialog::reject(); +} + +void DownloadFromDCWidget::markChildrenAsDisabled() +{ + ui->device->setDisabled(true); + ui->vendor->setDisabled(true); + ui->product->setDisabled(true); + ui->forceDownload->setDisabled(true); + ui->preferDownloaded->setDisabled(true); + ui->ok->setDisabled(true); + ui->search->setDisabled(true); +} + +void DownloadFromDCWidget::markChildrenAsEnabled() +{ + ui->device->setDisabled(false); + ui->vendor->setDisabled(false); + ui->product->setDisabled(false); + ui->forceDownload->setDisabled(false); + ui->preferDownloaded->setDisabled(false); + ui->ok->setDisabled(false); + ui->search->setDisabled(false); +} + DownloadThread::DownloadThread(device_data_t* data): data(data) { } diff --git a/qt-ui/downloadfromdivecomputer.h b/qt-ui/downloadfromdivecomputer.h index 444c03e81..26216c1e0 100644 --- a/qt-ui/downloadfromdivecomputer.h +++ b/qt-ui/downloadfromdivecomputer.h @@ -24,7 +24,7 @@ private: class InterfaceThread : public QThread{ Q_OBJECT public: - InterfaceThread(QObject *parent, device_data_t *data) ; + InterfaceThread(QObject *parent, device_data_t *data); virtual void run(); signals: @@ -39,13 +39,19 @@ class DownloadFromDCWidget : public QDialog{ public: explicit DownloadFromDCWidget(QWidget* parent = 0, Qt::WindowFlags f = 0); static DownloadFromDCWidget *instance(); + void reject(); + public slots: void on_ok_clicked(); void on_cancel_clicked(); void runDialog(); void stoppedDownloading(); void on_vendor_currentIndexChanged(const QString& vendor); + private: + void markChildrenAsDisabled(); + void markChildrenAsEnabled(); + Ui::DownloadFromDiveComputer *ui; InterfaceThread *thread; bool downloading; @@ -58,6 +64,7 @@ private: QStringListModel *vendorModel; QStringListModel *productModel; void fill_computer_list(); + public: bool preferDownloaded(); }; -- cgit v1.2.3-70-g09d2