diff options
Diffstat (limited to 'mario')
-rwxr-xr-x | mario/gamestate.lua | 10 | ||||
-rw-r--r-- | mario/portal.lua | 10 | ||||
-rw-r--r-- | mario/turtle.lua | 14 |
3 files changed, 29 insertions, 5 deletions
diff --git a/mario/gamestate.lua b/mario/gamestate.lua index a2bfb89..7f6ec61 100755 --- a/mario/gamestate.lua +++ b/mario/gamestate.lua @@ -47,6 +47,14 @@ function mario.game_start(pos, player, gamedef) mario.games[id] = gamestate mario.players[id] = player + -- store previous priviledges, disable fly whilöe the game is running + gamestate.player_privs = minetest.get_player_privs(player_name) + local new_privs = table.copy(gamestate.player_privs) + new_privs.fly = nil + new_privs.noclip = nil + new_privs.fast = nil + minetest.set_player_privs(player_name, new_privs) + minetest.log("action","New mario game started at " .. id .. " by " .. gamestate.player_name) -- place schematic @@ -71,6 +79,8 @@ function mario.game_end(id) mario.remove_hud(player, gamestate.player_name) player:moveto(vector.add(gamestate.pos,{x=0.5,y=0.5,z=-1.5})) end + -- Restore player priviledges + minetest.set_player_privs(gamestate.player_name, gamestate.player_privs) -- Save score if gamestate.scorename then local ranking = myhighscore.save_score(gamestate.scorename, { diff --git a/mario/portal.lua b/mario/portal.lua index 1ff31ee..6bee29b 100644 --- a/mario/portal.lua +++ b/mario/portal.lua @@ -9,8 +9,8 @@ minetest.register_node("mario:portal", { walkable = false, is_ground_content = false, groups = {cracky = 2,not_in_creative_inventory=1}, - on_player_collision = function(pos, player, gameid) - player:setpos({x=pos.x,y=pos.y+12,z=pos.z}) + on_turtle_collision = function(pos, obj, gameid) + obj:setpos({x=pos.x,y=pos.y+12,z=pos.z}) end }) minetest.register_node("mario:portal_left", { @@ -25,6 +25,9 @@ minetest.register_node("mario:portal_left", { groups = {cracky = 2,not_in_creative_inventory=0}, on_player_collision = function(pos, player, gameid) player:setpos(vector.add(pos,{x=31, y=0, z=0})) + end, + on_turtle_collision = function(pos, obj, gameid) + obj:setpos(vector.add(pos,{x=31, y=0, z=0})) end }) minetest.register_node("mario:portal_right", { @@ -39,5 +42,8 @@ minetest.register_node("mario:portal_right", { groups = {cracky = 2,not_in_creative_inventory=0}, on_player_collision = function(pos, player, gameid) player:setpos(vector.add(pos,{x=-31, y=0, z=0})) + end, + on_turtle_collision = function(pos, obj, gameid) + obj:setpos(vector.add(pos,{x=31, y=0, z=0})) end }) diff --git a/mario/turtle.lua b/mario/turtle.lua index 546123f..262997e 100644 --- a/mario/turtle.lua +++ b/mario/turtle.lua @@ -80,9 +80,17 @@ for i in ipairs(turtles) do local velocity = self.object:getvelocity() - -- if our velocity is close to zero, turn around (we are in collision) + -- if our velocity is close to zero, we are in collision if math.abs(velocity.x) < 0.25 then - self.direction.x = -self.direction.x + -- Check if there's a portal or some other node + local pos = self.object:getpos() + pos.y = pos.y + 0.5 + local node = minetest.get_node(pos) + if minetest.registered_nodes[node.name].on_turtle_collision then + minetest.registered_nodes[node.name].on_turtle_collision(pos, self.object, self.gameid) + else + self.direction.x = -self.direction.x + end if(self.direction.x == 0) then self.direction.x = 1 end @@ -121,7 +129,7 @@ for i in ipairs(turtles) do end --end mario.update_hud(self.gameid, player) - + else |