6.实现方块的还原和匹配
(1)如果交换后没有实现三个及以上的元素,那么交换的元素自动还原
cpp
void restore() {
//发生移动后,而且这个单向移动已经结束
if (isSwap && !isMoving)
{
//如果没有匹配到三个以上相同的元素,还原
int count = 0;
for (int i = 1; i <= ROW; i++) {
for (int j = 1; j <= COL; j++) {
count += map[i][j].match;
}
}
if (count==0)
{
exchange(posX1, posY1, posX2, posY2);
}
isSwap = false;
}
}
(2)消除检测,检查所有可以消除的方块
cpp
void cheek() {
for (int i = 1; i <= ROW; i++) {
for (int j = 1; j <= COL; j++) {
if (map[i][j].type == map[i + 1][j].type && map[i][j].type == map[i - 1][j].type) {
for (int k = -1; k <= 1; k++)
map[i + k][j].match++;
}
if (map[i][j].type == map[i][j-1].type && map[i][j].type == map[i][j+1].type) {
for (int k = -1; k <= 1; k++)
map[i][j+k].match++;
}
}
}
}