如何检查一个坐标是否与另一个坐标相邻?

时间:2021-04-30 17:02:23

标签: java game-development

我正在写一个蛇游戏。我想编写一个方法来检查头部(索引 0)是否与任何其他身体部位相邻。我不确定出了什么问题,但这种方法没有做任何事情。我已经设置好了,如果它返回 true 游戏结束(用于测试目的) 这是我的代码:

public boolean headNextToBody()
{
    boolean xClose = false;
    boolean yClose = false;
    for(int i = 0; i < bodyParts; i++)
    {
        if( x[i] == (x[0] + 1) || x[i] == (x[0] - 1))
        {
            xClose = true;
        }
        if(y[i] == y[0] + 1 || y[i] == y[0] - 1)
        {
            yClose = true;
        }
    }
    return (xClose && yClose);
}

1 个答案:

答案 0 :(得分:1)

首先,不需要在测试中包含头部(位置 0),因为它总是假的。

Dim HeaderColFoundRng As Range
Set HeaderColFoundRng = Range("A1:H1").Find("FindStr", , xlValues, xlPart)

邻接的条件是

for(int i = 1; i < bodyParts; i++)

(y[i] == y[0]) && (x[i] == (x[0] + 1) || x[i] == (x[0] - 1))

如果对于蛇上的任何非头点,如果其中任何一个为真,您可以立即返回 (x[i] == x[0]) && (y[i] == (y[0] + 1) || y[i] == (y[0] - 1)) ,否则返回 true

您可以将单独的测试合并为一个 false 语句:

if

或者,您可以使用一些数学方法来缩短测试时间:

public boolean headNextToBody()
{
    for(int i = 1; i < bodyParts; i++)
    {
        if(((y[i] == y[0]) && (x[i] == (x[0] + 1) || x[i] == (x[0] - 1))) ||
           ((x[i] == x[0]) && (y[i] == (y[0] + 1) || y[i] == (y[0] - 1)))
        {
            return true;
        }
    }
    return false;
}