mirror of
https://invent.kde.org/network/falkon.git
synced 2024-11-11 01:22:10 +01:00
Fixed conflict between blur background and Adobe PDF plugins on Windows.
This commit is contained in:
parent
47c9faa97d
commit
2861f4dae4
2
src/lib/3rdparty/qtwin.cpp
vendored
2
src/lib/3rdparty/qtwin.cpp
vendored
|
@ -204,7 +204,7 @@ bool QtWin::extendFrameIntoClientArea(QWidget* widget, int left, int top, int ri
|
|||
if (resolveLibs()) {
|
||||
QLibrary dwmLib(QString::fromAscii("dwmapi"));
|
||||
HRESULT hr = S_OK;
|
||||
MARGINS m = {left, top, right, bottom};
|
||||
MARGINS m = {left, right, top, bottom};
|
||||
hr = pDwmExtendFrameIntoClientArea(widget->winId(), &m);
|
||||
if (SUCCEEDED(hr)) {
|
||||
result = true;
|
||||
|
|
|
@ -260,6 +260,7 @@ void QupZilla::setupUi()
|
|||
m_navigationBar = new NavigationBar(this);
|
||||
m_navigationBar->setSplitterSizes(locationBarWidth, websearchBarWidth);
|
||||
m_bookmarksToolbar = new BookmarksToolbar(this);
|
||||
|
||||
m_mainSplitter->addWidget(m_tabWidget);
|
||||
m_mainLayout->addWidget(m_navigationBar);
|
||||
m_mainLayout->addWidget(m_bookmarksToolbar);
|
||||
|
@ -595,6 +596,7 @@ void QupZilla::loadSettings()
|
|||
|
||||
#ifdef Q_WS_WIN
|
||||
if (m_usingTransparentBackground && !makeTransparent) {
|
||||
QtWin::extendFrameIntoClientArea(this, 0, 0, 0, 0);
|
||||
QtWin::enableBlurBehindWindow(this, false);
|
||||
m_usingTransparentBackground = false;
|
||||
}
|
||||
|
@ -615,12 +617,21 @@ void QupZilla::loadSettings()
|
|||
ensurePolished(); // workaround Oxygen filling the background
|
||||
setAttribute(Qt::WA_StyledBackground, false);
|
||||
#endif
|
||||
|
||||
#ifdef Q_WS_WIN
|
||||
if (QtWin::isCompositionEnabled()) {
|
||||
QtWin::extendFrameIntoClientArea(this);
|
||||
setContentsMargins(0, 0, 0, 0);
|
||||
|
||||
m_usingTransparentBackground = true;
|
||||
|
||||
applyBlurToMainWindow();
|
||||
//install event filter
|
||||
menuBar()->installEventFilter(this);
|
||||
m_navigationBar->installEventFilter(this);
|
||||
m_bookmarksToolbar->installEventFilter(this);
|
||||
statusBar()->installEventFilter(this);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void QupZilla::goNext()
|
||||
|
@ -1226,6 +1237,13 @@ SideBar* QupZilla::addSideBar()
|
|||
|
||||
m_mainSplitter->setSizes(QList<int>() << m_sideBarWidth << m_webViewWidth);
|
||||
|
||||
#ifdef Q_WS_WIN
|
||||
if (QtWin::isCompositionEnabled()) {
|
||||
applyBlurToMainWindow();
|
||||
m_sideBar.data()->installEventFilter(this);
|
||||
}
|
||||
#endif
|
||||
|
||||
return m_sideBar.data();
|
||||
}
|
||||
|
||||
|
@ -1290,6 +1308,13 @@ void QupZilla::showWebInspector(bool toggle)
|
|||
m_webInspectorDock = new WebInspectorDockWidget(this);
|
||||
connect(m_tabWidget, SIGNAL(currentChanged(int)), m_webInspectorDock.data(), SLOT(tabChanged()));
|
||||
addDockWidget(Qt::BottomDockWidgetArea, m_webInspectorDock.data());
|
||||
|
||||
#ifdef Q_WS_WIN
|
||||
if (QtWin::isCompositionEnabled()) {
|
||||
applyBlurToMainWindow();
|
||||
m_webInspectorDock.data()->installEventFilter(this);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void QupZilla::showBookmarkImport()
|
||||
|
@ -1389,6 +1414,13 @@ void QupZilla::searchOnPage()
|
|||
SearchToolBar* search = new SearchToolBar(this);
|
||||
m_mainLayout->insertWidget(3, search);
|
||||
search->focusSearchLine();
|
||||
|
||||
#ifdef Q_WS_WIN
|
||||
if (QtWin::isCompositionEnabled()) {
|
||||
applyBlurToMainWindow();
|
||||
search->installEventFilter(this);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void QupZilla::openFile()
|
||||
|
@ -1449,6 +1481,7 @@ void QupZilla::fullScreen(bool make)
|
|||
m_tabWidget->getTabBar()->hide();
|
||||
#ifdef Q_WS_WIN
|
||||
if (m_usingTransparentBackground) {
|
||||
QtWin::extendFrameIntoClientArea(this, 0, 0, 0 ,0);
|
||||
QtWin::enableBlurBehindWindow(this, false);
|
||||
}
|
||||
#endif
|
||||
|
@ -1463,7 +1496,7 @@ void QupZilla::fullScreen(bool make)
|
|||
m_tabWidget->showTabBar();
|
||||
#ifdef Q_WS_WIN
|
||||
if (m_usingTransparentBackground) {
|
||||
QtWin::enableBlurBehindWindow(this);
|
||||
applyBlurToMainWindow(true);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
@ -1794,6 +1827,108 @@ bool QupZilla::quitApp()
|
|||
return true;
|
||||
}
|
||||
|
||||
#ifdef Q_WS_WIN
|
||||
bool QupZilla::winEvent(MSG *message, long *result)
|
||||
{
|
||||
if (message && message->message == WM_DWMCOMPOSITIONCHANGED) {
|
||||
Settings settings;
|
||||
settings.beginGroup("Browser-View-Settings");
|
||||
m_usingTransparentBackground = settings.value("useTransparentBackground", false).toBool();
|
||||
settings.endGroup();
|
||||
if (m_usingTransparentBackground && QtWin::isCompositionEnabled()) {
|
||||
setUpdatesEnabled(false);
|
||||
|
||||
QtWin::extendFrameIntoClientArea(this, 0, 0, 0, 0);
|
||||
QTimer::singleShot(0, this, SLOT(applyBlurToMainWindow()));
|
||||
|
||||
//install event filter
|
||||
menuBar()->installEventFilter(this);
|
||||
m_navigationBar->installEventFilter(this);
|
||||
m_bookmarksToolbar->installEventFilter(this);
|
||||
statusBar()->installEventFilter(this);
|
||||
|
||||
if (m_sideBar) {
|
||||
m_sideBar.data()->installEventFilter(this);
|
||||
}
|
||||
|
||||
if (m_mainLayout->count() == 4) {
|
||||
SearchToolBar* search = qobject_cast<SearchToolBar*>(m_mainLayout->itemAt(3)->widget());
|
||||
if (search) {
|
||||
search->installEventFilter(this);
|
||||
}
|
||||
}
|
||||
|
||||
if (m_webInspectorDock) {
|
||||
m_webInspectorDock.data()->installEventFilter(this);
|
||||
}
|
||||
|
||||
if (isVisible())
|
||||
{
|
||||
hide();
|
||||
show();
|
||||
}
|
||||
setUpdatesEnabled(true);
|
||||
}
|
||||
}
|
||||
return QMainWindow::winEvent(message, result);
|
||||
}
|
||||
|
||||
void QupZilla::applyBlurToMainWindow(bool force)
|
||||
{
|
||||
if (!force && (m_actionShowFullScreen->isChecked() || !m_usingTransparentBackground)) return;
|
||||
int topMargin = 0;
|
||||
int bottomMargin = 1;
|
||||
int rightMargin = 1;
|
||||
int leftMargin = 1;
|
||||
|
||||
if (m_sideBar) {
|
||||
if (isRightToLeft())
|
||||
rightMargin += m_sideBar.data()->width() + m_mainSplitter->handleWidth();
|
||||
else
|
||||
leftMargin += m_sideBar.data()->width() + m_mainSplitter->handleWidth();
|
||||
}
|
||||
|
||||
topMargin += menuBar()->isVisible() ? menuBar()->height() : 0;
|
||||
topMargin += m_navigationBar->isVisible() ? m_navigationBar->height() : 0;
|
||||
topMargin += m_bookmarksToolbar->isVisible() ? m_bookmarksToolbar->height() : 0;
|
||||
topMargin += m_tabWidget->getTabBar()->height();
|
||||
|
||||
if (m_mainLayout->count() == 4) {
|
||||
SearchToolBar* search = qobject_cast<SearchToolBar*>(m_mainLayout->itemAt(3)->widget());
|
||||
if (search) {
|
||||
bottomMargin += search->height();
|
||||
}
|
||||
}
|
||||
|
||||
bottomMargin += statusBar()->isVisible() ? statusBar()->height() : 0;
|
||||
|
||||
if (m_webInspectorDock) {
|
||||
bottomMargin += m_webInspectorDock.data()->isVisible()
|
||||
? m_webInspectorDock.data()->height()
|
||||
+ m_webInspectorDock.data()->style()->pixelMetric( QStyle::PM_DockWidgetSeparatorExtent)
|
||||
: 0;
|
||||
}
|
||||
|
||||
QtWin::extendFrameIntoClientArea(this, leftMargin, topMargin, rightMargin, bottomMargin);
|
||||
}
|
||||
|
||||
bool QupZilla::eventFilter(QObject *object, QEvent *event)
|
||||
{
|
||||
switch (event->type()) {
|
||||
case QEvent::DeferredDelete:
|
||||
case QEvent::Show:
|
||||
case QEvent::Hide:
|
||||
case QEvent::Resize:
|
||||
applyBlurToMainWindow();
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return QMainWindow::eventFilter(object, event);
|
||||
}
|
||||
#endif
|
||||
|
||||
QupZilla::~QupZilla()
|
||||
{
|
||||
}
|
||||
|
|
|
@ -187,6 +187,9 @@ private slots:
|
|||
|
||||
void closeWindow();
|
||||
bool quitApp();
|
||||
#ifdef Q_WS_WIN
|
||||
void applyBlurToMainWindow(bool force = false);
|
||||
#endif
|
||||
|
||||
private:
|
||||
void resizeEvent(QResizeEvent* event);
|
||||
|
@ -198,6 +201,10 @@ private:
|
|||
void setupMenu();
|
||||
|
||||
void disconnectObjects();
|
||||
#ifdef Q_WS_WIN
|
||||
bool winEvent(MSG* message, long* result);
|
||||
bool eventFilter(QObject *object, QEvent *event);
|
||||
#endif
|
||||
|
||||
bool m_historyMenuChanged;
|
||||
bool m_bookmarksMenuChanged;
|
||||
|
|
Loading…
Reference in New Issue
Block a user