Play Mode: Fix Level Collision w/ Scrolling
Fixes: * Move the call to CollidesWithGrid() inside the Canvas instead of outside in the PlayScene.movePlayer() so it can apply to all Actors in motion. * PlayScene.movePlayer() in turn just sets the player's Velocity so the Canvas.Loop() can move the actor itself. * When keeping the player inside the level boundaries: previously it was assuming the player Position was relative to the window, and was checking the WorldIndexAt and getting wrong results. * Canvas scrolling (loopFollowActor): check that the actor is getting close to the screen edge using the Viewport into the world, NOT the screen-relative coordinates of the Canvas bounding boxes.
This commit is contained in:
parent
ed1759e73e
commit
6af64edf68
5
label.go
5
label.go
|
@ -68,11 +68,14 @@ func (w *Label) Compute(e render.Engine) {
|
||||||
// Max rect to encompass all lines of text.
|
// Max rect to encompass all lines of text.
|
||||||
var maxRect = render.Rect{}
|
var maxRect = render.Rect{}
|
||||||
for _, line := range lines {
|
for _, line := range lines {
|
||||||
|
if line == "" {
|
||||||
|
line = "<empty>"
|
||||||
|
}
|
||||||
|
|
||||||
text.Text = line // only this line at this time.
|
text.Text = line // only this line at this time.
|
||||||
rect, err := e.ComputeTextRect(text)
|
rect, err := e.ComputeTextRect(text)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(fmt.Sprintf("%s: failed to compute text rect: %s", w, err)) // TODO return an error
|
panic(fmt.Sprintf("%s: failed to compute text rect: %s", w, err)) // TODO return an error
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if rect.W > maxRect.W {
|
if rect.W > maxRect.W {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user