Summary: | Clementine Player's seek bar started to blink since version 4.7.0 | ||
---|---|---|---|
Product: | [Plasma] Oxygen | Reporter: | Lilian A. Moraru <moraru69> |
Component: | style | Assignee: | Unassigned bugs mailing-list <unassigned-bugs> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | andresbajotierra, hugo.pereira.da.costa, kdelibs-bugs, kwin-bugs-null |
Priority: | NOR | ||
Version: | 4.0 | ||
Target Milestone: | --- | ||
Platform: | Ubuntu | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Lilian A. Moraru
2011-09-11 14:53:33 UTC
Can reproduce, with oxygen and bespin. Not plastique. KDE: from trunk (== 4.7.1 more or less) Qt: 4.7.3 Clementine: 0.7.1 Could reproduce with compiz instead of kwin, and without compositing, so this is not kwin related. I believe that it is due to some widget flags that are set by the widget style for this custom overlay tooltip. Will browse through Clementine's code and investigate. Yep, under Plastique works normally. If you get the code using: git clone https://code.google.com/p/clementine-player/ clementine-player the code for this popup is under: clementine-player->src->widgets and there are 2 files: - tracksliderpopup.cpp - tracksliderpopup.h I have impression that it has problems with the blurring. Set kBlurRadius from 20.0 to 0.0. My result: If I move the mouse over the progress bar it doesn't blink but if I hover over the painted Rectangle(which is the Popup) it blinks again. (In reply to comment #3) > I have impression that it has problems with the blurring. > Set kBlurRadius from 20.0 to 0.0. > My result: If I move the mouse over the progress bar it doesn't blink but if I > hover over the painted Rectangle(which is the Popup) it blinks again. Or set it to 1.0 and observe that if you hover the mouse over that 1 pixel additional border it starts to blink again. Looks like if you hover the mouse over the widget(which is the popup) it blinks, it has nothing with blurring. Ok, here is my solution: http://code.google.com/r/lilianftp-solution1forissue1715/source/checkout Do u think it's the way to go? I removed the line going to the track slider so the mouse doesn't hover over the popup widget. But it's yet a KDE 4.7.x bug with Oxygen widget style. "But it's yet a KDE 4.7.x bug with Oxygen widget style." well. The fact that it happens with other styles (bespin) makes the statement above not so clear. Now, indeed, your change does seem like the right way to go (in fact I was originally heading the same way while changing clementine on my side). Do you have a "diff" between your clone and the original git ? My understanding is that the flicker (in oxygen) is created because the widget keeps getting shown/hidden. "Enter event" in the slider generates "show" which generates "leave event" on the slider, which triggers "hide", which triggers "enter event" etc. I'm still investigating (on the oxygen side) why this happens with oxygen and not with plastique. Re-assigning to Oxygen, and keeping the bug open. Will keep you posted. Cheers, Hugo First, adding Thomas in CC, since bespin is also affected. I checked out your "fixed" code, and well, though it works, it would be unfortunate that this is the only solution (namely, not make the popup overlap with the slider). So I would refrain to push that to official clementine for the moment. On my side, in the oxygen code, I've found out which piece of code is responsible for the bad behavior. Unfortunatly its a totally unrelated chunk of code. Namely some XDeleteProperty, which indeed was introduced with kde4.7, is related to the needed code for kwin to install shadows on menus (which is why bespin is also affected) and is not even called for any widget of the slider (its called for some QMenu). So I'm totally confused why this code has such effect, and am still investigating. Thomas, if you have any clue ... Git commit f8d4bfbda31f3bbb43e29341a8f00411dcac4280 by Hugo Pereira Da Costa. Committed on 13/09/2011 at 15:42. Pushed by hpereiradacosta into branch 'master'. Test for widget creation before deleting property at unregistration. CCBUG: 281804 M +1 -1 kstyles/oxygen/oxygenshadowhelper.cpp http://commits.kde.org/kde-workspace/f8d4bfbda31f3bbb43e29341a8f00411dcac4280 ok. In fact I just found the issue, and fixed it (in oxygen). So closing. Thomas: have a look, for bespin. Its straightforward, and really a bug. (one should not access widget->winId() for not 'WA_CREATED' widgets). Git commit efc6da88d6846082e0c61eb3f34e6e344c886158 by Hugo Pereira Da Costa. Committed on 13/09/2011 at 15:42. Pushed by hpereiradacosta into branch 'KDE/4.7'. Test for widget creation before deleting property at unregistration. CCBUG: 281804 M +1 -1 kstyles/oxygen/oxygenshadowhelper.cpp http://commits.kde.org/kde-workspace/efc6da88d6846082e0c61eb3f34e6e344c886158 @Hugo Many thanks for attaching me and the hint but Bespin doesn't ;-) (Ok: "anymore" - just a few versions with rather initial shadow support did.) I cannot reproduce the issue here (raster & native, despite installing gstreamer...) - what bespin revision did you test? (ftr: QWidget::windId() triggers a native widget what that popup seems to be not supposed to be) @thomas: old old. (svn, some time in August). I can confirm that after updating I can't reproduce either. Bespin (but likely too old too) was also mentioned in the original bug report (http://code.google.com/p/clementine-player/issues/detail?id=1715) Ok, thanks once more =) So, the next KDE update(which I guess is 4.7.2) will have this fixed without changing Clementine visual look? At least for Oxygen widget style? @Moraru: yes. So I guess you can close the original clementine's bug, as "resolved upstream" or smthing similar. Sorry for the trouble. (and it is already fixed for latest bespin) Thx a lot. |