Page 1 of 1

Collision

Posted: Mon Nov 26, 2012 9:20 pm
by SuperMeijin
Hello again
I have a problem.
This is my collision code for my bullet and enemy

Code: Select all

local remEnemy = {}
	local remShot = {}
	for i,v in ipairs(player.shots) do
        v.x = v.x + 5
		if v.x > 800 then
		    table.insert(remShot, i)
		end
        for ii,vv in ipairs(enemies) do
	        if CheckCollision(v.x,v.y,2,5,vv.x,vv.y,vv.width,vv.height) then
			    table.insert(remEnemy, ii)
				table.insert(remShot, i)
		    end
	    end
	end
    for i,v in ipairs(remEnemy) do
	    table.remove(enemies, v)
	end
	for i,v in ipairs(remShot) do
	    table.remove(player.shots, v)
    end
I tried replicating this for my player vs enemy collision but it does not work what part is wrong

Code: Select all

local remPlayer = {}
	for i,v in ipairs(player) do
        for ii,vv in ipairs(enemies) do
	        if CheckCollision(v.x,v.y,2,5,vv.x,vv.y,vv.width,vv.height) then
			    table.insert(remPlayer, i)
		    end
	    end
	end
    for i,v in ipairs(remPlayer) do
	    table.remove(player, v)
    end
Here is my enemy and player tables

Code: Select all

	enemies = {} -- enemy mutiple spawn
    for i=0,0 do
        enemy = {}
        enemy.width = 72
		enemy.height = 102
		enemy.x = math.random(0,728)
        enemy.y = math.random(0,428)
    table.insert(enemies, enemy)
    end

Code: Select all

    player = {}
        player.width = 72
		player.height = 102
		player.x = 365
        player.y = 260

Re: Collision

Posted: Mon Nov 26, 2012 9:35 pm
by Robin
Notice your enemies table is a sequence of enemy object, while player is the player object itself.

I would suggest doing this:

Code: Select all

-- have in love.load:
playerDead = false

-- then, in your update function:
    for ii,vv in ipairs(enemies) do
       if CheckCollision(player.x,player.y,2,5,vv.x,vv.y,vv.width,vv.height) then
           playerDead = true
       end
    end
Your enemy/shot collision code also has a problem: it removes the wrong ones if there's more than one collision at the same time. (I can explain why if you can't figure it out yourself). Here's a solution:

Code: Select all

    table.sort(enemies)
    for i = #remEnemy, 1, -1 do
       table.remove(enemies, remEnemy[i])
   end
    for i = #remShot, 1, -1 do
       table.remove(enemies, remShot[i])
   end
Also, please fix your indentation. It makes your code look sloppy and makes your code confusing to read.

Re: Collision

Posted: Mon Nov 26, 2012 9:43 pm
by SuperMeijin
Thanks for explanation very useful. As for the indentation it seems to have gone wrong when I copied it over from notepad++.

Re: Collision

Posted: Mon Nov 26, 2012 10:14 pm
by Robin
SuperMeijin wrote:As for the indentation it seems to have gone wrong when I copied it over from notepad++.
That probably means there were tabs mixed with spaces in there, which can result in pretty confusing things when copy/pasting or viewing it on another computer or with another editor (tabs are converted to different number of spaces). There is an option to make whitespace visible, you can use that to see if that's really what's going on.