mirror of
https://github.com/hyprwm/Hyprland
synced 2024-11-22 15:45:59 +01:00
groupbars: conserve VRAM by staticizing textures
This commit is contained in:
parent
7bcc01efb7
commit
d1ec314a03
2 changed files with 19 additions and 14 deletions
|
@ -3,6 +3,11 @@
|
|||
#include <ranges>
|
||||
#include <pango/pangocairo.h>
|
||||
|
||||
// shared things to conserve VRAM
|
||||
static std::deque<std::unique_ptr<CTitleTex>> m_dpTitleTextures;
|
||||
static CTexture m_tGradientActive;
|
||||
static CTexture m_tGradientInactive;
|
||||
|
||||
CHyprGroupBarDecoration::CHyprGroupBarDecoration(CWindow* pWindow) {
|
||||
m_pWindow = pWindow;
|
||||
}
|
||||
|
@ -166,8 +171,11 @@ void CHyprGroupBarDecoration::clearUnusedTextures() {
|
|||
for (auto& tex : m_dpTitleTextures | std::views::reverse) {
|
||||
bool found = false;
|
||||
|
||||
for (auto& w : m_dwGroupMembers) {
|
||||
if (tex->szContent == w->m_szTitle && tex->pWindowOwner == w) {
|
||||
for (auto& w : g_pCompositor->m_vWindows) {
|
||||
if (!w->m_sGroupData.pNextWindow)
|
||||
continue;
|
||||
|
||||
if (tex->szContent == w->m_szTitle && tex->pWindowOwner == w.get()) {
|
||||
found = true;
|
||||
break;
|
||||
}
|
||||
|
|
|
@ -33,21 +33,18 @@ class CHyprGroupBarDecoration : public IHyprWindowDecoration {
|
|||
virtual SWindowDecorationExtents getWindowDecorationReservedArea();
|
||||
|
||||
private:
|
||||
SWindowDecorationExtents m_seExtents;
|
||||
SWindowDecorationExtents m_seExtents;
|
||||
|
||||
CWindow* m_pWindow = nullptr;
|
||||
CWindow* m_pWindow = nullptr;
|
||||
|
||||
Vector2D m_vLastWindowPos;
|
||||
Vector2D m_vLastWindowSize;
|
||||
Vector2D m_vLastWindowPos;
|
||||
Vector2D m_vLastWindowSize;
|
||||
|
||||
std::deque<CWindow*> m_dwGroupMembers;
|
||||
std::deque<std::unique_ptr<CTitleTex>> m_dpTitleTextures;
|
||||
std::deque<CWindow*> m_dwGroupMembers;
|
||||
|
||||
CTitleTex* textureFromTitle(const std::string&);
|
||||
void clearUnusedTextures();
|
||||
void invalidateTextures();
|
||||
CTitleTex* textureFromTitle(const std::string&);
|
||||
void clearUnusedTextures();
|
||||
void invalidateTextures();
|
||||
|
||||
void refreshGradients();
|
||||
CTexture m_tGradientActive;
|
||||
CTexture m_tGradientInactive;
|
||||
void refreshGradients();
|
||||
};
|
Loading…
Reference in a new issue