We are now ready to have the falling piece respond to timer
events by dropping one row each time the timer fires.
To start, we can have our timerFired function call moveFallingPiece(canvas,+1,0), just as we do in response to a down-arrow
key press.
This is not a bad start, but when it gets to the bottom, it just sits there (until we hit a
non-arrow key to artificially reset the falling piece).
Once
again, when the fallingPiece gets to the bottom, it simply stops
falling and sits there -- it does not get placed on the
board. To remedy this, we first need to know that it
happened! That requires a small change to some code we have
written. We will change moveFallingPiece so that now it
returns True if the move occurred, and False
otherwise for any reason (the piece moved off the board, or the piece
collided with something on the board). This requires only a small
change to our code.
Once we have done this, our timerFired method can test the return value
from moveFallingPiece to determine if the move failed. In that
case, we will use top-down design and call a function (that we are
about to write) to place the falling piece on the board, followed by a
call to newFallingPiece, to start a new piece falling from the top.
Writing placeFallingPiece:
This
function is quite similar to drawFallingPiece, only rather than draw
the cells, we load the corresponding positions on the board with the
fallingColor. In this way, the piece is placed on the board.
David Kosbie |