diff options
| author | Allusive <[email protected]> | 2023-11-08 14:53:27 +1100 |
|---|---|---|
| committer | GitHub <[email protected]> | 2023-11-08 14:53:27 +1100 |
| commit | 9efbdea90442c954ad8f13e26fa62d3289da652e (patch) | |
| tree | ce3d50079374618bdcf1e40692bcf4ec4f36d984 | |
| parent | Testing Issue #23 (diff) | |
| parent | Don't animate hlwm tab switches (working #23 fix) (diff) | |
| download | compfy-1.3.3.tar.xz compfy-1.3.3.zip | |
Merge pull request #26 from xrun1/main1.3.3
Don't animate hlwm tab switches (working #23 fix)
| -rw-r--r-- | src/win.c | 36 |
1 files changed, 16 insertions, 20 deletions
@@ -766,26 +766,22 @@ void win_process_update_flags(session_t *ps, struct managed_win *w) { w->g.height = (uint16_t)round(w->animation_h); } else { - if (ps->o.support_for_wm == WM_SUPPORT_HERB) { - - if (w->pending_g.x < -(w->g.width) && w->pending_g.y < -(w->g.height)) { - log_warn("Animation geometry postion update cancelled"); - } else { - w->animation_dest_center_x = - w->pending_g.x + w->pending_g.width * 0.5; - w->animation_dest_center_y = - w->pending_g.y + w->pending_g.height * 0.5; - w->animation_dest_w = w->pending_g.width; - w->animation_dest_h = w->pending_g.height; - } - } else { - w->animation_dest_center_x = - w->pending_g.x + w->pending_g.width * 0.5; - w->animation_dest_center_y = - w->pending_g.y + w->pending_g.height * 0.5; - w->animation_dest_w = w->pending_g.width; - w->animation_dest_h = w->pending_g.height; - } + w->animation_dest_center_x = + w->pending_g.x + w->pending_g.width * 0.5; + w->animation_dest_center_y = + w->pending_g.y + w->pending_g.height * 0.5; + + bool herb = ps->o.support_for_wm == WM_SUPPORT_HERB; + bool hidingTab = w->pending_g.x < -(w->g.width) && w->pending_g.y < -(w->g.height); + bool unhidingTab = w->g.x < -(w->g.width) && w->g.y < -(w->g.height); + + if (herb && (hidingTab || unhidingTab)) { + w->animation_center_x = w->animation_dest_center_x; + w->animation_center_y = w->animation_dest_center_y; + }; + + w->animation_dest_w = w->pending_g.width; + w->animation_dest_h = w->pending_g.height; } w->g.border_width = w->pending_g.border_width; |