From 4273df8b2505a3e7d201113ac63dd29335eccfe1 Mon Sep 17 00:00:00 2001 From: Sine Striker <trueful@163.com> Date: 周二, 21 5月 2024 18:00:24 +0800 Subject: [PATCH] minor tweaks --- examples/mainwindow/mainwindow.cpp | 48 ++++++++++++++++++++++-------------------------- 1 files changed, 22 insertions(+), 26 deletions(-) diff --git a/examples/mainwindow/mainwindow.cpp b/examples/mainwindow/mainwindow.cpp index 8d6372a..696b907 100644 --- a/examples/mainwindow/mainwindow.cpp +++ b/examples/mainwindow/mainwindow.cpp @@ -19,6 +19,8 @@ # include <QtWidgets/QActionGroup> #endif +// #include <QtWebEngineWidgets/QWebEngineView> + #include <QWKWidgets/widgetwindowagent.h> #include <widgetframe/windowbar.h> @@ -42,17 +44,25 @@ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) { installWindowAgent(); +#if 1 auto clockWidget = new ClockWidget(); clockWidget->setObjectName(QStringLiteral("clock-widget")); clockWidget->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding); setCentralWidget(clockWidget); +#else + auto webView = new QWebEngineView(); + webView->load(QUrl("https://www.baidu.com")); + setCentralWidget(webView); +#endif loadStyleSheet(Dark); setWindowTitle(tr("Example MainWindow")); resize(800, 600); - windowAgent->centralize(); + setFixedHeight(600); + + // windowAgent->centralize(); } static inline void emulateLeaveEvent(QWidget *widget) { @@ -97,15 +107,19 @@ switch (event->type()) { case QEvent::WindowActivate: { auto menu = menuWidget(); - menu->setProperty("bar-active", true); - style()->polish(menu); + if (menu) { + menu->setProperty("bar-active", true); + style()->polish(menu); + } break; } case QEvent::WindowDeactivate: { auto menu = menuWidget(); - menu->setProperty("bar-active", false); - style()->polish(menu); + if (menu) { + menu->setProperty("bar-active", false); + style()->polish(menu); + } break; } @@ -117,9 +131,9 @@ void MainWindow::closeEvent(QCloseEvent *event) { - if (!(qApp->keyboardModifiers() & Qt::ControlModifier)) { - QTimer::singleShot(1000, this, &QWidget::show); - } + // if (!(qApp->keyboardModifiers() & Qt::ControlModifier)) { + // QTimer::singleShot(1000, this, &QWidget::show); + // } event->accept(); } @@ -313,24 +327,6 @@ setMenuWidget(windowBar); - // 3. Adds simulated mouse events to the title bar buttons -#ifdef Q_OS_WINDOWS - // Emulate Window system menu button behaviors - connect(iconButton, &QAbstractButton::clicked, windowAgent, [this, iconButton] { - iconButton->setProperty("double-click-close", false); - - // Pick a suitable time threshold - QTimer::singleShot(75, windowAgent, [this, iconButton]() { - if (iconButton->property("double-click-close").toBool()) - return; - windowAgent->showSystemMenu(iconButton->mapToGlobal(QPoint{0, iconButton->height()})); - }); - }); - connect(iconButton, &QWK::WindowButton::doubleClicked, this, [iconButton, this]() { - iconButton->setProperty("double-click-close", true); - close(); - }); -#endif #ifndef Q_OS_MAC connect(windowBar, &QWK::WindowBar::minimizeRequested, this, &QWidget::showMinimized); -- Gitblit v1.9.1