Summary: | Incorrect Yakuake height handling on dualhead | ||
---|---|---|---|
Product: | [Applications] yakuake | Reporter: | Martin Kyral <sine.nomine> |
Component: | general | Assignee: | Eike Hein <hein> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | alvaro.aguilera, bettman.marek, chri, cyberang3l, eric.donkersloot, fungs, gotletter, job, michal.bryxi, nicksanders11, perezmeyer, rumanzo, tietze.heiko, trick, viranch.mehta, zachleigh |
Priority: | NOR | ||
Version: | 2.9.9 | ||
Target Milestone: | --- | ||
Platform: | Fedora RPMs | ||
OS: | Linux | ||
Latest Commit: | http://commits.kde.org/yakuake/5e31ccfdbc3a46e6bffd79fc6bcafc3a2bde0ed3 | Version Fixed In: | |
Sentry Crash Report: | |||
Attachments: |
Screenshot of the behavior
Yakuake on KDE 4.9.95 patch tha fixes this problem in two different dual head setups. "Improved" patch Using KWindowInfo::isOnCurrentDesktop() patch generated with git show > Yakuake.patch |
Description
Martin Kyral
2012-11-15 15:53:11 UTC
Created attachment 75284 [details]
Screenshot of the behavior
yakuake window is too tall, the tabs and controls are hidden underneath the panel.
Haven't looked into it yet, but FWIW, thanks for a high-quality bug report. *** Bug 310324 has been marked as a duplicate of this bug. *** I've just updated to KDE 4.9.95 (along with Fedora 17 -> Fedora 18 update) and the behavior changed. Now, Yakuake height is almost always set according to the primary / smaller display height with the respect of the plasma panel height. In my case it means that on the primary display (notebook built-in 1366x768) the behavior is always correct. However on the secondary, the yakuake window is too small (see screenshot, yakuake height is set to 100%), with the only exception - if the yakuake window width is changed while yakuake window is visible (on the secondary / larger display), it changes its height to the correct one (ie. full display height with the panel taken into account, nothing hidden beneath). After hiding and showing (press F12 twice) yakuake shows again too small. Created attachment 76165 [details]
Yakuake on KDE 4.9.95
shown on secondary display 1920x1080 (with primary 1366x768)
The problem is somewhere in MainWindow::getDesktopGeometry(), in the 'if (KApplication::desktop()->numScreens() > 1)' branch. Unfortunatelly ATM, I don't understand the code enough to point better or provide patch. screenGeometry before the branch for 'numScreens() > 1' is correct (not counting the bottom panel height) -> ie. fullscreen works. In my case in KWindowSystem::workArea(offScreenWindows, currentDesktop).intersect(screenGeometry) the data is: workArea(..): height: 736, width: 3286 screenGeometry: height: 1080, width: 1920 The intersection then has the following dimensions height: 736, width: 1920 I can confirm this bug on ArchLinux latest packages too. I can also confirm this bug, using the following packages: yakuake 2.9.9-1 kdebase-workspace 4.10.1-1 I can also confirm with Kubuntu 13.04 kdebase-workspace 4.10.2 yakuake 2.9.9 I should have said downgrading yakuake to 2.9.8 fixes the problem *** Bug 318704 has been marked as a duplicate of this bug. *** *** Bug 318862 has been marked as a duplicate of this bug. *** *** Bug 322867 has been marked as a duplicate of this bug. *** *** Bug 308866 has been marked as a duplicate of this bug. *** Created attachment 89675 [details]
patch tha fixes this problem in two different dual head setups.
After some testing, I see that the line:
int currentDesktop = KWindowSystem::windowInfo(winId(), NET::WMDesktop).desktop();
returns -1 the first time Yakuake is toggled (or when the settings are updated) and for all of the subsequent toggles, 0 is returned.
Moreover, if you split the above line in a few lines like this:
KWindowInfo windowInfo = KWindowSystem::windowInfo(winId(), NET::WMDesktop);
int currentDesktop = 1000;
if(windowInfo.valid())
currentDesktop = windowInfo..desktop();
else
qDebug() << "NOT VALID :(";
You will see that the windowInfo.valid() always returns FALSE!
So it looks like this line is useless.
After adding some qDebug() messages in the while loop, I saw that the function KWindowInfo.desktop(), always returned -1 for window IDs running in the currentDesktop, and the number of the desktop for the rest of the desktops.
So it looks like the currentDesktop variable is not needed at all and it can "safely" be replaced with -1.
The attached patch fixes the problem for me in two different laptops running in two different dual head configurations.
Thanks for looking into it! Unfortunately that's not really an acceptable fix, we'll rather have to address the timing issue that causes the window info to be invalid in the first place. We could probably do that by just using KWindowSystem::currentDesktop(), taking the state of Yakuake's window mapping out of the equation - I probably wrote it this way in case Yakuake would ever not be on the actually-current desktop by the time this code runs, but off-hand I can't actually think of a scenario where this would be either true, or matter. As for KWindowInfo.desktop() always returning -1, we should probably port it to KWindowInfo::isOnDesktop(currentDesktop), then we can avoid hardcoding any sort of number in our code. Would you like to check that those two things work for you? Created attachment 89687 [details]
"Improved" patch
Hi Eike,
Your concerns sound reasonable :)
How about this one?
We get the currentDesktop from KWindowSystem::currentDesktop() and we deal with the struts from windows located in the current desktop if (windowInfo.valid() && windowInfo.isOnDesktop(currentDesktop))
I just saw that there is a function "KWindowInfo::isOnCurrentDesktop()" http://api.kde.org/4.14-api/kdelibs-apidocs/kdeui/html/classKWindowInfo.html#ac5d51bdc5ebbe8c8eae00e422c134127 If we use this one, then we do not need the currentDesktop variable at all. KWindowSystem::workArea() by default (without a passed parameter) returns the workArea of the current desktop. --- yakuake-2.9.9-a/app/mainwindow.cpp 2014-11-22 22:49:39.297582382 +0100 +++ yakuake-2.9.9-b/app/mainwindow.cpp 2014-11-22 23:33:09.566934201 +0100 @@ -1265,8 +1265,6 @@ QRect MainWindow::getDesktopGeometry() if (action->isChecked()) return screenGeometry; - int currentDesktop = KWindowSystem::windowInfo(winId(), NET::WMDesktop).desktop(); - if (KApplication::desktop()->numScreens() > 1) { const QList<WId> allWindows = KWindowSystem::windows(); @@ -1282,7 +1280,9 @@ QRect MainWindow::getDesktopGeometry() { KWindowInfo windowInfo = KWindowSystem::windowInfo(windowId, NET::WMDesktop, NET::WM2ExtendedStrut); - if (windowInfo.valid() && windowInfo.desktop() == currentDesktop) + // If windowInfo is valid and the window is located at the same (current) + // desktop with the yakuake window... + if (windowInfo.valid() && windowInfo.isOnCurrentDesktop()) { NETExtendedStrut strut = windowInfo.extendedStrut(); @@ -1312,10 +1312,10 @@ QRect MainWindow::getDesktopGeometry() } } - return KWindowSystem::workArea(offScreenWindows, currentDesktop).intersect(screenGeometry); + return KWindowSystem::workArea(offScreenWindows).intersect(screenGeometry); } - return KWindowSystem::workArea(currentDesktop); + return KWindowSystem::workArea(); } void MainWindow::whatsThis() Created attachment 89688 [details]
Using KWindowInfo::isOnCurrentDesktop()
Looks good - do you have a KDE dev account to commit? (In reply to Eike Hein from comment #21) > Looks good - do you have a KDE dev account to commit? Nope, but you can do it! No problem :) Do you want to provide the patch in git format (make a local commit, git show > file) so your author metadata is preserved? Created attachment 89689 [details]
patch generated with git show > Yakuake.patch
I didn't know that I could supply a patch like this with git.
Hope it fine.
Thanks :)
Git commit 5e31ccfdbc3a46e6bffd79fc6bcafc3a2bde0ed3 by Eike Hein, on behalf of Vangelis Tasoulas. Committed on 22/11/2014 at 23:16. Pushed by hein into branch 'master'. Fixes incorrect Yakuake height handling on dualhead setups. M +5 -5 app/mainwindow.cpp http://commits.kde.org/yakuake/5e31ccfdbc3a46e6bffd79fc6bcafc3a2bde0ed3 I backported it to 2.9.9 and seems to work :-D Thanks a lot! I'm running 2.9.9 on OpenSUSE (KDE 4.14.9) and still the screen hight changes correctly when first set but the next time it is toggled it resizes according to the hight of the fist screen. This is a laptop dual-screen setup with nvidia display driver. Are you sure the patch is applied to 2.9.9? It's still an issue. Same config as described above, and yakuake pops up at the wrong position. >plasmashell -v plasmashell 5.4.3 >qtdiag-qt5 Qt 5.5.1 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 5.2.0) on "xcb" OS: Arch Linux [linux version 4.2.5-1-ARCH] Can confirm its still a problem on plasma 5. Using Kubuntu 15.10. When the height is set, it adjusts properly, but the next time it opens, the height change does not take affect. Arch linux plasmashell 5.5.4 Qt 5.5.1 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 5.3.0) on "xcb" Yakuake: 2.9.9 Problem still exist. Still there on Kubuntu 16.04.1 64bit $ qtdiag Qt 5.5.1 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 5.3.1 20160413) on "xcb" OS: Ubuntu 16.04.1 LTS [linux version 4.4.0-38-generic] yakuake 2.9.9-3 plasma-desktop 4:5.5.5-0ubuntu1 plasma-workspace 4:5.5.5.2-0ubuntu1 $ plasmashell -v plasmashell 5.5.5 Nevermind, which screen is set as primary in System Settings, it always falls back to the smaller one. |