game against red team seems ok spacecampaign
authorPeriklis Ntanasis <pntanasis@gmail.com>
Sat, 17 Aug 2013 04:10:39 +0300
branchspacecampaign
changeset 9540 92329918463f
parent 9538 51596e01c5df
child 9542 d1ea2d1540f2
game against red team seems ok
share/hedgewars/Data/Missions/Campaign/A_Space_Adventure/fruit02.lua
--- a/share/hedgewars/Data/Missions/Campaign/A_Space_Adventure/fruit02.lua	Sat Aug 17 01:51:20 2013 +0300
+++ b/share/hedgewars/Data/Missions/Campaign/A_Space_Adventure/fruit02.lua	Sat Aug 17 04:10:39 2013 +0300
@@ -105,7 +105,7 @@
 	-- Fruit Assasins
 	AddTeam(teamC.name, teamC.color, "Bone", "Island", "HillBilly", "cm_birdy")
 	for i=1,table.getn(redHedgehogs) do
-		redHedgehogs[i].gear =  AddHog(redHedgehogs[i].name, 0, 100, "war_desertgrenadier1")
+		redHedgehogs[i].gear =  AddHog(redHedgehogs[i].name, 1, 100, "war_desertgrenadier1")
 		AnimSetGearPosition(redHedgehogs[i].gear, 2010 + 50*i, 630)
 	end
 
@@ -116,8 +116,8 @@
 function onGameStart()
 	AnimWait(hero.gear, 3000)
 	FollowGear(hero.gear)
-	
-	if GetCampaignVar(Fruit01JoinedBattle) and GetCampaignVar(Fruit01JoinedBattle) == "true" then
+	WriteLnToConsole("***"..GetCampaignVar("Fruit01JoinedBattle"))
+	if GetCampaignVar("Fruit01JoinedBattle") and GetCampaignVar("Fruit01JoinedBattle") == "true" then
 		tookPartInBattle = true
 	end
 	
@@ -136,6 +136,7 @@
 	-- Assasins weapons
 	AddAmmo(redHedgehogs[1].gear, amBazooka, 6)
 	AddAmmo(redHedgehogs[1].gear, amGrenade, 6)
+	AddAmmo(redHedgehogs[1].bot, amDEagle, 6)
 	for i=1,table.getn(redHedgehogs) do
 		HideHog(redHedgehogs[i].gear)
 	end
@@ -206,10 +207,16 @@
 			TurnTimeLeft = 0
 			return
 		end
+		for i=1,table.getn(redHedgehogs) do
+			if CurrentHedgehog == redHedgehogs[i].gear and previousHog ~= hero.gear then
+				TurnTimeLeft = 0
+				return
+			end
+		end
 		WriteLnToConsole("IN BATTLE")
 		TurnTimeLeft = 20000
 		wind()
-	elseif not inBattle then
+	elseif not inBattle and CurrentHedgehog == hero.gear then
 	WriteLnToConsole("4")
 		TurnTimeLeft = -1
 		wind()
@@ -282,6 +289,17 @@
 	return false
 end
 
+function onRedTeamDeath(gear)
+	local redDead = true
+	for i=1,table.getn(redHedgehogs) do
+		if GetHealth(redHedgehogs[i].gear) then
+			redDead = false
+			break
+		end
+	end
+	return redDead
+end
+
 -------------- ACTIONS ------------------
 
 function heroDeath(gear)
@@ -306,19 +324,22 @@
 	WriteLnToConsole("surface first round")
 	previousHog = -1
 	if tookPartInBattle then
-	
+		if GetHealth(green1.gear) then
+			HideHog(green1.gear)
+		end
+		AddEvent(onRedTeamDeath, {green1.gear}, redTeamDeath, {green1.gear}, 0)
 	else
-		if GetHealth(green2.gear) then
-			HideHog(green2.gear)
-		end
-		if GetHealth(green3.gear) then
-			HideHog(green3.gear)
-		end
 		DeleteGear(green1.human)
 		RestoreHog(green1.bot)
 		green1.gear = green1.bot
 		AddEvent(onGaptainLimeDeath, {green1.gear}, captainLimeDeath, {green1.gear}, 0)
 	end
+	if GetHealth(green2.gear) then
+		HideHog(green2.gear)
+	end
+	if GetHealth(green3.gear) then
+		HideHog(green3.gear)
+	end
 	WriteLnToConsole("surface in battle")
 	inBattle = true
 end
@@ -327,6 +348,12 @@
 	-- hero win in scenario of escape in 1st part
 	EndGame()
 end
+
+function redTeamDeath(gear)
+	-- hero win in battle scenario
+	EndGame()
+end
+
 -------------- ANIMATIONS ------------------
 
 function Skipanim(anim)