minor acceleration of the predictNextRow function
This commit is contained in:
parent
8e2261eddd
commit
b16b908003
1 changed files with 10 additions and 12 deletions
|
@ -465,22 +465,20 @@ uint16_t* tetris_bucket_predictBottomRow(tetris_bucket_iterator_t *pIt,
|
||||||
pIt->nCurrentRow = pBucket->nHeight - 1;
|
pIt->nCurrentRow = pBucket->nHeight - 1;
|
||||||
pIt->nRowBuffer = 0;
|
pIt->nRowBuffer = 0;
|
||||||
|
|
||||||
// determine sane start and stop values for the piece's row indices
|
|
||||||
pIt->nPieceHighestRow = nRow;
|
|
||||||
pIt->nPieceLowestRow = ((pIt->nPieceHighestRow + 3) < pBucket->nHeight) ?
|
|
||||||
(pIt->nPieceHighestRow + 3) : pBucket->nHeight - 1;
|
|
||||||
|
|
||||||
// prepare piece bitmap for faster detection of complete lines
|
|
||||||
pIt->nPieceMap = tetris_piece_getBitmap(pPiece);
|
pIt->nPieceMap = tetris_piece_getBitmap(pPiece);
|
||||||
if ((nRow + 3) >= pBucket->nHeight)
|
|
||||||
{
|
// determine sane start and stop values for the piece's row indices
|
||||||
pIt->nPieceMap <<= (nRow + 4 - pBucket->nHeight) * 4;
|
pIt->nPieceHighestRow = nRow + tetris_piece_getTopRow(pIt->nPieceMap);
|
||||||
}
|
int8_t nBottomOffset = tetris_piece_getBottomOffset(pIt->nPieceMap);
|
||||||
|
pIt->nPieceLowestRow = (nRow + nBottomOffset) < pBucket->nHeight ?
|
||||||
|
nRow + nBottomOffset : pBucket->nHeight - 1;
|
||||||
|
// accelerate detection of full rows
|
||||||
|
pIt->nPieceMap <<= (nRow + 3 - pIt->nPieceLowestRow) * 4;
|
||||||
pIt->nShift = nColumn - 12;
|
pIt->nShift = nColumn - 12;
|
||||||
|
|
||||||
// don't return any trailing rows which are empty, so we look for a stop row
|
// don't return any trailing rows which are empty, so we look for a stop row
|
||||||
pIt->nStopRow = pBucket->nFirstTaintedRow < nRow ?
|
pIt->nStopRow = pBucket->nFirstTaintedRow < pIt->nPieceHighestRow ?
|
||||||
pBucket->nFirstTaintedRow : nRow;
|
pBucket->nFirstTaintedRow : pIt->nPieceHighestRow;
|
||||||
pIt->nStopRow = pIt->nStopRow < 0 ? 0 : pIt->nStopRow;
|
pIt->nStopRow = pIt->nStopRow < 0 ? 0 : pIt->nStopRow;
|
||||||
|
|
||||||
return tetris_bucket_predictNextRow(pIt);
|
return tetris_bucket_predictNextRow(pIt);
|
||||||
|
|
Loading…
Reference in a new issue