1

我在画布上绘制了多个不同大小和位置的圆圈,但我需要检测它们之间的碰撞。

public void run() {         
            while(Run){
                if(!sHold.getSurface().isValid())
                    continue;

                c[0][cnum].r++;
                canvas = sHold.lockCanvas();
                canvas.drawRGB(02, 02, 150);
                Paint white = new Paint();
                white.setColor(Color.WHITE);
                if(c[0][cnum].x != 0 && c[0][cnum].y != 0)
                    canvas.drawCircle(c[0][cnum].x, c[0][cnum].y, c[0][cnum].r, white);
                if(cnum!=0)
                    for(int i=0; i<cnum; i++)
                        canvas.drawCircle(c[1][i].x, c[1][i].y, c[1][i].r, white);
                sHold.unlockCanvasAndPost(canvas);
                if(((c[0][cnum].x - c[0][cnum].r)<0)||((c[0][cnum].y-c[0][cnum].r)<0)||((c[0][cnum].y+c[0][cnum].r)>height)||((c[0][cnum].x+c[0][cnum].r>width))){
                    c[1][cnum].x = c[0][cnum].x;
                    c[1][cnum].y = c[0][cnum].y;
                    c[1][cnum].r = c[0][cnum].r;
                    broken = true;
                    break;
                }
            }
        }
4

2 回答 2

6

你不应该在渲染阶段这样做。

在处理逻辑时,您应该检查圆圈是否相交,如下所述:

v1 = 圆心 1 v2 = 圆心 2

相交 = v1 - v2 < circle1radius + circle2radius

于 2012-06-12T21:45:33.667 回答
1

这个链接非常有用!

圆-圆碰撞

它非常详细和教学


在该页面的底部还有另一个链接,指向更详细的内容!


我使用了中心之间的距离方法---

通过测量每个中心之间的距离,您可以判断它们是否正在碰撞。距离不应大于 2 半径之和。

这是我所做的:

private boolean checkDrawContains(ShapeDrawable newHole) 
{
    long newCenterX = newHole.getBounds().left + (newHole.getBounds().width()/2); //Get the center of my shapes
    long newCenterY = newHole.getBounds().top + (newHole.getBounds().height()/2);

    for(ShapeDrawable hole: mHoles) // I was storing the circles in an ArrayList
    { 
        long centerX = hole.getBounds().left + (hole.getBounds().width()/2); //Get the center of my shapes
        long centerY = hole.getBounds().top + (hole.getBounds().height()/2);
        long x = centerX - newCenterX;
        long y = centerY - newCenterY;
        long aux = (long) ((Math.pow(Math.abs(x),2)) + (Math.pow(Math.abs(y),2))); //Pythagoras the hard way :P
        long distance = (long) Math.sqrt(aux);
        long sRads = (newHole.getBounds().width()/2) + (hole.getBounds().width()/2);

        if(distance <=  sRads ) {
            return true;  //Is Colliding!
        }
    }
    return false; // Is not Colliding!
}
于 2015-05-31T05:50:40.457 回答