From 96fa7b562351e7b4c9471ea98cc7e4641d29101c Mon Sep 17 00:00:00 2001 From: Sasha Koshka Date: Mon, 13 May 2024 19:35:03 -0400 Subject: [PATCH] Fix scroll behavior for ContainerBox --- containerbox.go | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/containerbox.go b/containerbox.go index 5a9899d..96c27b4 100644 --- a/containerbox.go +++ b/containerbox.go @@ -274,7 +274,7 @@ func (this *containerBox) doLayout () { // offset the content bounds by the scroll so children can be positioned // accordingly. this.constrainScroll() - this.contentBounds = this.contentBounds.Sub(this.scroll).Sub(innerBounds.Min) + this.contentBounds = this.contentBounds.Add(this.scroll).Sub(innerBounds.Min) // arrange children if this.layout != nil { @@ -294,19 +294,19 @@ func (this *containerBox) constrainScroll () { // X if width <= innerBounds.Dx() { this.scroll.X = 0 - } else if this.scroll.X < 0 { + } else if this.scroll.X > 0 { this.scroll.X = 0 - } else if this.scroll.X > width - innerBounds.Dx() { - this.scroll.X = width - innerBounds.Dx() + } else if this.scroll.X < innerBounds.Dx() - width { + this.scroll.X = innerBounds.Dx() - width } // Y if height <= innerBounds.Dy() { this.scroll.Y = 0 - } else if this.scroll.Y < 0 { + } else if this.scroll.Y > 0 { this.scroll.Y = 0 - } else if this.scroll.Y > height - innerBounds.Dy() { - this.scroll.Y = height - innerBounds.Dy() + } else if this.scroll.Y < innerBounds.Dy() - height { + this.scroll.Y = innerBounds.Dy() - height } }