0

我很难让我的碰撞检测算法正常工作。我正在从包含 0 和 1 的 .txt 中读取数据(0 是空格,1 不能通过)。我的算法有时会捕捉到有时它没有捕捉到并且最终不起作用。我当前的算法发布在下面,其中 sep 是一个分隔值,以防止我的精神重叠。

private void collisionDetect()
{
    float diffxleft, diffxright, diffytop, diffybottom;
    float diffx, diffy;

    hit = false;
    foreach (Block b in blocks)
    {
        if (hit)
            break;
        if (inside(charPos, sep, b))
        {
            hit = true;
            diffxleft = Math.Abs(charPos.X + sep - b.pos.X);
            diffxright = Math.Abs(charPos.X - sep - (b.pos.X + b.rect.Width));
            diffytop = Math.Abs(charPos.Y + sep - b.pos.Y);
            diffybottom = Math.Abs(charPos.Y - sep - (b.pos.Y + b.rect.Height));
            diffx = Math.Min(diffxleft, diffxright);
            diffy = Math.Min(diffytop, diffybottom);
            if (diffx < diffy)
            {
                charVel.X = 0;
                if (diffxleft < diffxright)
                    charPos.X = b.pos.X - sep;
                else
                    charPos.X = b.pos.X + b.rect.Width + sep;
            }
            else
            {
                charVel.Y = 0;
                if (diffytop < diffybottom)
                    charPos.Y = b.pos.Y - sep;
                else
                    charPos.Y = b.pos.Y + b.rect.Height + sep;
            }
        }
    }

    foreach (Block b in blocks)
    {
        b.disp.X = b.pos.X + 10 - bkgdisplay.X;
        b.disp.Y = 470 - b.pos.Y;
    }
    charPosDisp.X = charPos.X - bkgdisplay.X;
    charPosDisp.Y = 480 - charPos.Y;
}

帮助!

4

1 回答 1

1

我会稍微改变您处理冲突的方式,使其更易于阅读和实施。

对于每个块(或图块)来说,0 或 1 值表示该块是否可碰撞。然后,您可以在块位置和精灵位置之间使用 intersect 方法来查看它们当前是否相交。如果它们确实相交并且图块的布尔值设置为 1,那么我们有一个碰撞,然后您可以处理碰撞,即停止精灵移动,将其反弹回来等。如果值为 0,那么精灵可以移动到当前块位置。

使用以下伪代码很容易实现。

步骤1:读入块的值并在类中设置一个布尔成员变量来判断它是否可碰撞,即从字符串中解析值,如果值为0,则bool = false,否则bool = true。

第 2 步:在块类中创建一个方法来返回可碰撞的成员变量,它会做类似的事情bool is_collidable() const { return collide; }

第三步:使用sprite rect和block rect之间的Rectangle.Intersect 方法。

第四步:查看block和sprite是否有交集后,测试block的成员变量是真还是假。

第 5 步:如果 value 为 true,则我们不能越过瓷砖,否则我们可以。

于 2013-11-08T08:51:50.820 回答