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:
Noah 2019-04-14 15:25:03 -07:00
parent ed1759e73e
commit 6af64edf68

View File

@ -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 {