Bug 481379 - Sometimes Panel continuously floats and defloats when window is in the wrong spot (or the right spot?!)
Summary: Sometimes Panel continuously floats and defloats when window is in the wrong ...
Status: RESOLVED FIXED
Alias: None
Product: plasmashell
Classification: Plasma
Component: Panel (show other bugs)
Version: 5.93.0
Platform: Arch Linux Linux
: NOR normal
Target Milestone: 1.0
Assignee: Plasma Bugs List
URL:
Keywords: qt6
Depends on:
Blocks:
 
Reported: 2024-02-15 20:30 UTC by Bernhard
Modified: 2024-02-16 22:03 UTC (History)
3 users (show)

See Also:
Latest Commit:
Version Fixed In: 6.0
Sentry Crash Report:


Attachments
panel doing its thing (2.70 MB, video/webm)
2024-02-15 20:30 UTC, Bernhard
Details

Note You need to log in before you can comment on or make changes to this bug.
Description Bernhard 2024-02-15 20:30:30 UTC
Created attachment 165839 [details]
panel doing its thing

SUMMARY
When a window is positioned on the first pixel where where the panel unfloats, it will try to float again, continuously.

STEPS TO REPRODUCE
1. Have a floating panel
2. Move a window into the position where the panel starts to unfloat

OBSERVED RESULT
See attached video

EXPECTED RESULT
Panel should decide on one position

SOFTWARE/OS VERSIONS
Operating System: Arch Linux 
KDE Plasma Version: 5.93.0
KDE Frameworks Version: 5.249.0
Qt Version: 6.7.0
Kernel Version: 6.6.16-1-lts (64-bit)
Graphics Platform: Wayland

ADDITIONAL INFORMATION
In case it is important, here my scree configuration:

$ kscreen-doctor -o | grep -e Geometry -e Scale -e Modes
	Modes:  [...] 2:3840x2160@120* [...]
	Geometry: 1280,0 3840x2160
	Scale: 1
	Modes:  0:2560x1440@60*!  [...]
	Geometry: 0,0 1280x2276
	Scale: 1.125
Comment 1 fanzhuyifan 2024-02-16 00:35:07 UTC
Can reproduce.

It's our new dancing panel feature! A game you could play when you are bored : )

P.s. Just kidding
Comment 2 fanzhuyifan 2024-02-16 00:35:50 UTC
I think fractional scaling might be a key factor here.
Comment 3 Nate Graham 2024-02-16 00:43:15 UTC
Haha wow! FWIW I can't reproduce it with a right screen edge panel myself at 225% scale.
Comment 4 fanzhuyifan 2024-02-16 00:51:21 UTC
Oh this has nothing to do with fractional geometry -- this is because we change the geometry of the panel upon float/defloat, and the defloating zone is always calculated with respect to the actual geometry of the panel -- when the panel moves left, the defloating zone also moves left, thus making the panel float again...
Comment 5 Bug Janitor Service 2024-02-16 01:41:21 UTC
A possibly relevant merge request was started @ https://invent.kde.org/plasma/plasma-workspace/-/merge_requests/3907
Comment 6 Bug Janitor Service 2024-02-16 01:41:43 UTC
A possibly relevant merge request was started @ https://invent.kde.org/plasma/plasma-desktop/-/merge_requests/2040
Comment 7 fanzhuyifan 2024-02-16 20:58:00 UTC
Git commit ab9de16b11a714684ae689d04c43520ff04194bb by Yifan Zhu.
Committed on 16/02/2024 at 20:42.
Pushed by fanzhuyifan into branch 'master'.

shell/panelview: calculate dodge geometry independent of floatingness

The dodge/defloat geometry should be the same no matter the panel is
floating or not. In addition, constrain it to the geometry of the
current screen, so that content from other screens have no impact.

Previously, the compensation for floatingness was done in Panel.qml,
which made the code more complicated, and had rounding errors that
caused the panel to continuously cycle between float and defloat.
FIXED-IN: 6.0

M  +18   -4    shell/panelview.cpp
M  +6    -0    shell/panelview.h

https://invent.kde.org/plasma/plasma-workspace/-/commit/ab9de16b11a714684ae689d04c43520ff04194bb
Comment 8 Bug Janitor Service 2024-02-16 21:03:48 UTC
A possibly relevant merge request was started @ https://invent.kde.org/plasma/plasma-workspace/-/merge_requests/3913
Comment 9 fanzhuyifan 2024-02-16 21:11:57 UTC
Git commit 9309df10945cf092a5a855b8d34c6b024060b77b by Yifan Zhu.
Committed on 16/02/2024 at 21:04.
Pushed by fanzhuyifan into branch 'master'.

Panel: use new API to calculate regionGeometry

Previously the compensation for floatingness was done in qml, which had
rounding errors that caused the panel to continuously float/defloat. Use
new api that calculates regionGeometry independent of floatingness. This
also simplifies the code.
FIXED-IN: 6.0

M  +2    -4    desktoppackage/contents/views/Panel.qml

https://invent.kde.org/plasma/plasma-desktop/-/commit/9309df10945cf092a5a855b8d34c6b024060b77b
Comment 10 fanzhuyifan 2024-02-16 21:18:31 UTC
Git commit 711ebf79e784fb1440a037dfec73b0b706d41556 by Yifan Zhu.
Committed on 16/02/2024 at 21:03.
Pushed by fanzhuyifan into branch 'Plasma/6.0'.

shell/panelview: calculate dodge geometry independent of floatingness

The dodge/defloat geometry should be the same no matter the panel is
floating or not. In addition, constrain it to the geometry of the
current screen, so that content from other screens have no impact.

Previously, the compensation for floatingness was done in Panel.qml,
which made the code more complicated, and had rounding errors that
caused the panel to continuously cycle between float and defloat.
FIXED-IN: 6.0


(cherry picked from commit ab9de16b11a714684ae689d04c43520ff04194bb)

M  +18   -4    shell/panelview.cpp
M  +6    -0    shell/panelview.h

https://invent.kde.org/plasma/plasma-workspace/-/commit/711ebf79e784fb1440a037dfec73b0b706d41556
Comment 11 fanzhuyifan 2024-02-16 22:03:38 UTC
Git commit e3a270ef18ecc85624e2c835d2e49f6b1cca382b by Yifan Zhu.
Committed on 16/02/2024 at 21:37.
Pushed by fanzhuyifan into branch 'Plasma/6.0'.

Panel: use new API to calculate regionGeometry

Previously the compensation for floatingness was done in qml, which had
rounding errors that caused the panel to continuously float/defloat. Use
new api that calculates regionGeometry independent of floatingness. This
also simplifies the code.
FIXED-IN: 6.0


(cherry picked from commit 9309df10945cf092a5a855b8d34c6b024060b77b)

M  +2    -4    desktoppackage/contents/views/Panel.qml

https://invent.kde.org/plasma/plasma-desktop/-/commit/e3a270ef18ecc85624e2c835d2e49f6b1cca382b