使用PNG作为背景图并进行碰撞检测

时间:2015-03-22 14:05:04

标签: c# xna background-image collision-detection alpha

我必须制作类似pacman的游戏,我尝试了很多次,但我无法让它发挥作用。这是我做的:

Map

这是地图。我不希望发生碰撞的地方是透明的。

Pac

这是pacman精灵。当然也是透明的。

这是我的地图代码:

mapTexture = Content.Load<Texture2D("11074582_10203478069210715_531544477_n");
mapPosition = new Vector2(0, 0);
mapRectangle = new Rectangle((int)mapLeftPosition.X, (int)mapLeftPosition.Y, 800, 500);

spriteBatch.Draw(mapTexture, mapPosition, mapRectangle, Color.White); 

我的Pacman代码:

pacmanSprite = Content.Load<Texture2D>("pacman");
pacmanPosition = new Vector2((width / 2), height / 2);
pacmanOrigin = new Vector2(pacmanAnimatedRectangle.Width / 2, pacmanAnimatedRectangle.Height / 2);
pacmanAnimatedRectangle = new Rectangle(currentFrame.X * frameSize.X, currentFrame.Y * frameSize.Y, frameSize.X, frameSize.Y);
spriteBatch.Draw(pacmanSprite, pacmanPosition, pacmanAnimatedRectangle, Color.White, rotation, pacmanOrigin, 1f, SpriteEffects.None, 0);

我用来检查是否存在碰撞的代码:

private bool IntersectsPixel()

     {
         Color[] colorData1 = new Color[pacmanSprite.Width * pacmanSprite.Height]; //Get every pixel of the sprite

         Color[] colorData2 = new Color[mapTexture.Width * mapTexture.Height];

         pacmanSprite.GetData<Color>(colorData1);

         mapTexture.GetData<Color>(colorData2);



         int top = Math.Max(pacmanAnimatedRectangle.Top, mapRectangle.Top);   //Get the square of both sprites

         int bottom = Math.Min(pacmanAnimatedRectangle.Bottom, mapRectangle.Bottom);

         int left = Math.Max(pacmanAnimatedRectangle.Left, mapRectangle.Left);

         int right = Math.Min(pacmanAnimatedRectangle.Right, mapRectangle.Right);

         for (int y = top; y < bottom; y++)

         {

             for (int x = left; x < right; x++)

             {

                 Color A = colorData1[(y - pacmanAnimatedRectangle.Top) * (pacmanAnimatedRectangle.Width) + (x - pacmanAnimatedRectangle.Left)];

                 Color B = colorData2[(y - mapRectangle.Top) * (mapRectangle.Width) + (x - mapRectangle.Left)];


                 if (A.A != 0 && B.A != 0) //if collision spot is not transparent return true
                 {
                     return true;                    
                 }
             }

            }   

             return false;

所以我认为它应该有效,但不是!这一切都搞砸了:

img

这里它在碰撞检测中返回false,就像它应该的那样。 但是,一旦我上去一点点:

img

它已经返回true(检测到碰撞)。为什么??怎么可能,我做错了什么? 谢谢!

1 个答案:

答案 0 :(得分:0)

问题是我的代码检查了矩形中的左上角,我正在通过矩形的中心,这弄乱了整个代码。不管怎样,谢谢你!