mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 13:18:13 +00:00
LibGUI: Use wrapped text rect for paint invalidation
This fixes an issue where after anything past first line would not get invalidated after unhovering an icon.
This commit is contained in:
parent
4db286e63f
commit
d940f7ba4f
2 changed files with 14 additions and 1 deletions
|
@ -41,6 +41,7 @@ public:
|
|||
virtual ModelIndex index_at_event_position(const Gfx::IntPoint&) const override;
|
||||
virtual Gfx::IntRect content_rect(const ModelIndex&) const override;
|
||||
virtual Gfx::IntRect editing_rect(ModelIndex const&) const override;
|
||||
virtual Gfx::IntRect paint_invalidation_rect(ModelIndex const&) const override;
|
||||
|
||||
virtual void select_all() override;
|
||||
|
||||
|
@ -61,6 +62,7 @@ private:
|
|||
|
||||
struct ItemData {
|
||||
Gfx::IntRect text_rect;
|
||||
Optional<Gfx::IntRect> text_rect_wrapped;
|
||||
Gfx::IntRect icon_rect;
|
||||
int icon_offset_y;
|
||||
int text_offset_y;
|
||||
|
@ -90,8 +92,10 @@ private:
|
|||
return icon_rect.contains(point) || text_rect.contains(point);
|
||||
}
|
||||
|
||||
Gfx::IntRect rect() const
|
||||
Gfx::IntRect rect(bool wrapped = false) const
|
||||
{
|
||||
if (wrapped && text_rect_wrapped.has_value())
|
||||
return text_rect_wrapped->united(icon_rect);
|
||||
return text_rect.united(icon_rect);
|
||||
}
|
||||
};
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue