mirror of
https://github.com/subsurface/subsurface.git
synced 2024-11-30 22:20:21 +00:00
76f61468e6
Subsurface-mobile has a long startup time; in order to isolate the problem(s) a timer is added to see where time is "lost". The collected startup times are added to the clipboard together with the other logs, allowing test users to report back. All this is only enabled when compiling with -DENABLE_STARTUP_TIMING Closes #1340 [Dirk Hohndel: collapsed multiple commits and minor white space cleanups, added missing QMutex variable] Signed-off-by: Jan Iversen <jani@apache.org> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
156 lines
5.6 KiB
C++
156 lines
5.6 KiB
C++
// SPDX-License-Identifier: GPL-2.0
|
|
/* qt-gui.cpp */
|
|
/* Qt UI implementation */
|
|
#include "core/display.h"
|
|
#include "core/helpers.h"
|
|
|
|
#include <QApplication>
|
|
#include <QDesktopWidget>
|
|
#include <QNetworkProxy>
|
|
#include <QLibraryInfo>
|
|
|
|
#include "core/qt-gui.h"
|
|
|
|
#include <QQuickWindow>
|
|
#include <QScreen>
|
|
#include <QQmlApplicationEngine>
|
|
#include <QQmlContext>
|
|
#include <QSortFilterProxyModel>
|
|
#include "mobile-widgets/qmlmanager.h"
|
|
#include "qt-models/divelistmodel.h"
|
|
#include "qt-models/gpslistmodel.h"
|
|
#include "mobile-widgets/qmlprofile.h"
|
|
#include "core/downloadfromdcthread.h"
|
|
#include "core/connectionlistmodel.h"
|
|
#include "qt-models/diveimportedmodel.h"
|
|
#include "qt-models/messagehandlermodel.h"
|
|
#include "map-widget/qmlmapwidgethelper.h"
|
|
#include "qt-models/maplocationmodel.h"
|
|
|
|
#include "mobile-widgets/qml/kirigami/src/kirigamiplugin.h"
|
|
|
|
#include "core/ssrf.h"
|
|
|
|
QObject *qqWindowObject = NULL;
|
|
|
|
void set_non_bt_addresses() {
|
|
#if defined(Q_OS_ANDROID)
|
|
connectionListModel.addAddress("FTDI");
|
|
#elif defined(Q_OS_LINUX) // since this is in the else, it does NOT include Android
|
|
connectionListModel.addAddress("/dev/ttyS0");
|
|
connectionListModel.addAddress("/dev/ttyS1");
|
|
connectionListModel.addAddress("/dev/ttyS2");
|
|
connectionListModel.addAddress("/dev/ttyS3");
|
|
// this makes debugging so much easier - use the simulator
|
|
connectionListModel.addAddress("/tmp/ttyS1");
|
|
#endif
|
|
}
|
|
|
|
void init_ui()
|
|
{
|
|
init_qt_late();
|
|
}
|
|
|
|
void run_ui()
|
|
{
|
|
LOG_STP("run_ui starting");
|
|
qmlRegisterType<QMLManager>("org.subsurfacedivelog.mobile", 1, 0, "QMLManager");
|
|
qmlRegisterType<QMLProfile>("org.subsurfacedivelog.mobile", 1, 0, "QMLProfile");
|
|
|
|
qmlRegisterType<DCDeviceData>("org.subsurfacedivelog.mobile", 1, 0, "DCDeviceData");
|
|
qmlRegisterType<DownloadThread>("org.subsurfacedivelog.mobile", 1, 0, "DCDownloadThread");
|
|
qmlRegisterType<DiveImportedModel>("org.subsurfacedivelog.mobile", 1, 0, "DCImportModel");
|
|
|
|
qmlRegisterType<MapWidgetHelper>("org.subsurfacedivelog.mobile", 1, 0, "MapWidgetHelper");
|
|
qmlRegisterType<MapLocationModel>("org.subsurfacedivelog.mobile", 1, 0, "MapLocationModel");
|
|
qmlRegisterType<MapLocation>("org.subsurfacedivelog.mobile", 1, 0, "MapLocation");
|
|
|
|
QQmlApplicationEngine engine;
|
|
LOG_STP("run_ui qml engine started");
|
|
KirigamiPlugin::getInstance().registerTypes();
|
|
#if defined(__APPLE__) && !defined(Q_OS_IOS)
|
|
// when running the QML UI on a Mac the deployment of the QML Components seems
|
|
// to fail and the search path for the components is rather odd - simply the
|
|
// same directory the executable was started from <bundle>/Contents/MacOS/
|
|
// To work around this we need to manually copy the components at install time
|
|
// to Contents/Frameworks/qml and make sure that we add the correct import path
|
|
QStringList importPathList = engine.importPathList();
|
|
Q_FOREACH(QString importPath, importPathList) {
|
|
if (importPath.contains("MacOS"))
|
|
engine.addImportPath(importPath.replace("MacOS", "Frameworks"));
|
|
}
|
|
qDebug() << "QML import path" << engine.importPathList();
|
|
#endif
|
|
engine.addImportPath("qrc://imports");
|
|
DiveListModel diveListModel;
|
|
LOG_STP("run_ui diveListModel started");
|
|
DiveListSortModel *sortModel = new DiveListSortModel(0);
|
|
sortModel->setSourceModel(&diveListModel);
|
|
sortModel->setDynamicSortFilter(true);
|
|
sortModel->setSortRole(DiveListModel::DiveDateRole);
|
|
sortModel->sort(0, Qt::DescendingOrder);
|
|
LOG_STP("run_ui diveListModel sorted");
|
|
GpsListModel gpsListModel;
|
|
QSortFilterProxyModel *gpsSortModel = new QSortFilterProxyModel(0);
|
|
gpsSortModel->setSourceModel(&gpsListModel);
|
|
gpsSortModel->setDynamicSortFilter(true);
|
|
gpsSortModel->setSortRole(GpsListModel::GpsWhenRole);
|
|
gpsSortModel->sort(0, Qt::DescendingOrder);
|
|
QQmlContext *ctxt = engine.rootContext();
|
|
ctxt->setContextProperty("diveModel", sortModel);
|
|
ctxt->setContextProperty("gpsModel", gpsSortModel);
|
|
ctxt->setContextProperty("vendorList", vendorList);
|
|
set_non_bt_addresses();
|
|
LOG_STP("run_ui set_non_bt_adresses");
|
|
|
|
ctxt->setContextProperty("connectionListModel", &connectionListModel);
|
|
ctxt->setContextProperty("logModel", MessageHandlerModel::self());
|
|
|
|
engine.load(QUrl(QStringLiteral("qrc:///qml/main.qml")));
|
|
LOG_STP("run_ui qml loaded");
|
|
qqWindowObject = engine.rootObjects().value(0);
|
|
if (!qqWindowObject) {
|
|
fprintf(stderr, "can't create window object\n");
|
|
exit(1);
|
|
}
|
|
QQuickWindow *qml_window = qobject_cast<QQuickWindow *>(qqWindowObject);
|
|
qml_window->setIcon(QIcon(":subsurface-mobile-icon"));
|
|
qqWindowObject->setProperty("messageText", QVariant("Subsurface-mobile startup"));
|
|
qDebug() << "qqwindow devicePixelRatio" << qml_window->devicePixelRatio() << qml_window->screen()->devicePixelRatio();
|
|
QScreen *screen = qml_window->screen();
|
|
QObject::connect(qml_window, &QQuickWindow::screenChanged, QMLManager::instance(), &QMLManager::screenChanged);
|
|
QMLManager *manager = QMLManager::instance();
|
|
LOG_STP("run_ui qmlmanager instance started");
|
|
// now that the log file is initialized...
|
|
show_computer_list();
|
|
LOG_STP("run_ui show_computer_list");
|
|
|
|
manager->setDevicePixelRatio(qml_window->devicePixelRatio(), qml_window->screen());
|
|
manager->dlSortModel = sortModel;
|
|
manager->screenChanged(screen);
|
|
qDebug() << "qqwindow screen has ldpi/pdpi" << screen->logicalDotsPerInch() << screen->physicalDotsPerInch();
|
|
#if !defined(Q_OS_ANDROID) && !defined(Q_OS_IOS)
|
|
qml_window->setHeight(1200);
|
|
qml_window->setWidth(800);
|
|
#endif
|
|
qml_window->show();
|
|
LOG_STP("run_ui running exec");
|
|
qApp->exec();
|
|
}
|
|
|
|
void exit_ui()
|
|
{
|
|
delete qApp;
|
|
free((void *)existing_filename);
|
|
}
|
|
|
|
double get_screen_dpi()
|
|
{
|
|
QDesktopWidget *mydesk = qApp->desktop();
|
|
return mydesk->physicalDpiX();
|
|
}
|
|
|
|
bool haveFilesOnCommandLine()
|
|
{
|
|
return false;
|
|
}
|