mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2025-01-20 03:29:47 +02:00
Update tank_conquest.lua
Spots are now represented by tags on the map. Raw materials and biter were activated. A button to get to the lobby has been added. Spots that have been taken over are now owned by your own force. Overwriting the floor tiles has been fixed.
This commit is contained in:
parent
563458e7ee
commit
917eadb4d3
@ -3,11 +3,11 @@
|
||||
|
||||
local blueprint_poi_base_json = require 'maps.tank_conquest.blueprint_poi_base_json'
|
||||
|
||||
local blueprint_poi_flag_one_json = require 'maps.tank_conquest.blueprint_poi_flag_one_json'
|
||||
local blueprint_poi_spot_one_json = require 'maps.tank_conquest.blueprint_poi_spot_one_json'
|
||||
|
||||
local blueprint_poi_flag_two_json = require 'maps.tank_conquest.blueprint_poi_flag_two_json'
|
||||
local blueprint_poi_spot_two_json = require 'maps.tank_conquest.blueprint_poi_spot_two_json'
|
||||
|
||||
local blueprint_poi_flag_three_json = require 'maps.tank_conquest.blueprint_poi_flag_three_json'
|
||||
local blueprint_poi_spot_three_json = require 'maps.tank_conquest.blueprint_poi_spot_three_json'
|
||||
|
||||
local blueprint_poi_fire_json = require 'maps.tank_conquest.blueprint_poi_fire_json'
|
||||
|
||||
@ -17,9 +17,9 @@
|
||||
|
||||
global.table_of_properties.required_number_of_players = 2
|
||||
|
||||
global.table_of_properties.countdown_in_seconds = 2701
|
||||
global.table_of_properties.countdown_in_seconds = 28800
|
||||
|
||||
global.table_of_properties.wait_in_seconds = 10
|
||||
global.table_of_properties.wait_in_seconds = 5
|
||||
|
||||
global.table_of_properties.size_of_the_battlefield = 2000
|
||||
|
||||
@ -35,7 +35,7 @@
|
||||
|
||||
global.table_of_scores = {}
|
||||
|
||||
global.table_of_flags = {}
|
||||
global.table_of_spots = {}
|
||||
|
||||
global.table_of_squads = {}
|
||||
|
||||
@ -197,8 +197,6 @@
|
||||
|
||||
local map_gen_settings = {}
|
||||
|
||||
-- map_gen_settings.default_enable_all_autoplace_controls = false
|
||||
|
||||
map_gen_settings.width = global.table_of_properties.size_of_the_battlefield
|
||||
|
||||
map_gen_settings.height = global.table_of_properties.size_of_the_battlefield
|
||||
@ -211,10 +209,12 @@
|
||||
|
||||
map_gen_settings.cliff_settings = { name = 'cliff', cliff_elevation_0 = 0, cliff_elevation_interval = 0 }
|
||||
|
||||
map_gen_settings.autoplace_controls = { [ 'trees' ] = { frequency = 'normal', size = 'normal', richness = 'normal' }, [ 'coal' ] = { frequency = 'none', size = 'none', richness = 'none' }, [ 'stone' ] = { frequency = 'none', size = 'none', richness = 'none' }, [ 'copper-ore' ] = { frequency = 'none', size = 'none', richness = 'none' }, [ 'uranium-ore' ] = { frequency = 'none', size = 'none', richness = 'none' }, [ 'iron-ore' ] = { frequency = 'none', size = 'none', richness = 'none' }, [ 'crude-oil' ] = { frequency = 'none', size = 'none', richness = 'none' }, [ 'enemy-base' ] = { frequency = 'none', size = 'none', richness = 'none' } }
|
||||
map_gen_settings.autoplace_controls = { [ 'trees' ] = { frequency = 'normal', size = 'normal', richness = 'normal' }, [ 'coal' ] = { frequency = 'very-high', size = 'very-low', richness = 'normal' }, [ 'stone' ] = { frequency = 'very-high', size = 'very-low', richness = 'normal' }, [ 'copper-ore' ] = { frequency = 'very-high', size = 'very-low', richness = 'normal' }, [ 'uranium-ore' ] = { frequency = 'very-high', size = 'very-low', richness = 'normal' }, [ 'iron-ore' ] = { frequency = 'very-high', size = 'very-low', richness = 'normal' }, [ 'crude-oil' ] = { frequency = 'very-high', size = 'very-low', richness = 'normal' }, [ 'enemy-base' ] = { frequency = 'normal', size = 'normal', richness = 'normal' } }
|
||||
|
||||
-- map_gen_settings.autoplace_settings = { entity = { treat_missing_as_default = false, settings = { frequency = 'none', size = 'none', richness = 'none' } }, decorative = { treat_missing_as_default = true, settings = { frequency = 'none', size = 'none', richness = 'none' } } }
|
||||
|
||||
-- map_gen_settings.default_enable_all_autoplace_controls = false
|
||||
|
||||
if game.surfaces[ 'tank_conquest' ] == nil then
|
||||
|
||||
game.create_surface( 'tank_conquest', map_gen_settings )
|
||||
@ -235,41 +235,11 @@
|
||||
|
||||
if player.gui.top[ 'draw_gui_button' ] then player.gui.top[ 'draw_gui_button' ].destroy() end
|
||||
|
||||
local element_frame = player.gui.top.add{ type = 'frame', name = 'draw_gui_button', direction = 'vertical' }
|
||||
player.gui.top.add{ type = 'sprite-button', name = 'draw_gui_button', sprite = 'item/tank', tooltip = 'MENU' }
|
||||
|
||||
element_frame.style.minimal_width = 100
|
||||
-- player.gui.top.add{ type = 'sprite-button', name = 'draw_gui_button', sprite = 'item/heavy-armor', tooltip = 'SCORE' }
|
||||
|
||||
element_frame.style.padding = 0
|
||||
|
||||
element_frame.style.margin = 0
|
||||
|
||||
element_frame.style.vertical_align = 'center'
|
||||
|
||||
element_frame.style.horizontal_align = 'center'
|
||||
|
||||
local element_table = element_frame.add{ type = 'table', column_count = 1 }
|
||||
|
||||
local element_button = element_table.add{ type = 'sprite-button', name = 'event_on_click_menu', caption = 'MENU' }
|
||||
|
||||
-- local element_button = element_table.add{ type = 'sprite-button', name = 'event_on_click_score', caption = 'SCORE' }
|
||||
|
||||
-- local element_button = element_table.add{ type = 'sprite-button', name = 'event_on_click_squad', caption = 'SQUAD' }
|
||||
|
||||
for _, element_item in pairs( element_table.children ) do
|
||||
|
||||
element_item.style.minimal_width = 80
|
||||
|
||||
element_item.style.minimal_height = 30
|
||||
|
||||
element_item.style.padding = 0
|
||||
|
||||
element_item.style.margin = 0
|
||||
|
||||
element_item.style.font = 'heading-1'
|
||||
|
||||
element_item.style.font_color = table_of_colors.white
|
||||
|
||||
end
|
||||
-- player.gui.top.add{ type = 'sprite-button', name = 'draw_gui_button', sprite = 'item/personal-roboport-equipment', tooltip = 'SQUAD' }
|
||||
|
||||
end
|
||||
|
||||
@ -279,7 +249,7 @@
|
||||
|
||||
if player.surface.name == 'nauvis' then return end
|
||||
|
||||
if #global.table_of_flags == 0 then return end
|
||||
if #global.table_of_spots == 0 then return end
|
||||
|
||||
local element_frame = player.gui.top.add{ type = 'frame', name = 'draw_gui_status', direction = 'horizontal' }
|
||||
|
||||
@ -297,7 +267,7 @@
|
||||
|
||||
local element_progressbar = element_frame.add{ type = 'progressbar', value = 100 }
|
||||
|
||||
element_progressbar.style.width = 150
|
||||
element_progressbar.style.width = 125
|
||||
|
||||
element_progressbar.style.right_padding = 20
|
||||
|
||||
@ -335,7 +305,7 @@
|
||||
|
||||
local element_progressbar = element_frame.add{ type = 'progressbar', value = 100 }
|
||||
|
||||
element_progressbar.style.width = 150
|
||||
element_progressbar.style.width = 125
|
||||
|
||||
element_progressbar.style.left_padding = 20
|
||||
|
||||
@ -347,15 +317,15 @@
|
||||
|
||||
end
|
||||
|
||||
function draw_gui_flags( player )
|
||||
function draw_gui_spots( player )
|
||||
|
||||
if player.gui.top[ 'draw_gui_flags' ] then player.gui.top[ 'draw_gui_flags' ].destroy() end
|
||||
if player.gui.top[ 'draw_gui_spots' ] then player.gui.top[ 'draw_gui_spots' ].destroy() end
|
||||
|
||||
if player.surface.name == 'nauvis' then return end
|
||||
|
||||
if #global.table_of_flags == 0 then return end
|
||||
if #global.table_of_spots == 0 then return end
|
||||
|
||||
local element_frame = player.gui.top.add{ type = 'frame', name = 'draw_gui_flags', direction = 'horizontal' }
|
||||
local element_frame = player.gui.top.add{ type = 'frame', name = 'draw_gui_spots', direction = 'horizontal' }
|
||||
|
||||
element_frame.style.minimal_width = 38
|
||||
|
||||
@ -369,9 +339,9 @@
|
||||
|
||||
element_frame.style.horizontal_align = 'center'
|
||||
|
||||
for _, flag in pairs( global.table_of_flags ) do
|
||||
for _, spot in pairs( global.table_of_spots ) do
|
||||
|
||||
local element_label = element_frame.add{ type = 'label', caption = flag.properties.name }
|
||||
local element_label = element_frame.add{ type = 'label', caption = spot.properties.name }
|
||||
|
||||
element_label.style.width = 38
|
||||
|
||||
@ -393,9 +363,9 @@
|
||||
|
||||
color = table_of_colors.neutral
|
||||
|
||||
if flag.properties.force.name == global.table_of_properties[ player.force.name ].name and flag.properties.value == 100 then color = table_of_colors.team end
|
||||
if spot.properties.force.name == global.table_of_properties[ player.force.name ].name and spot.properties.value == 100 then color = table_of_colors.team end
|
||||
|
||||
if flag.properties.force.name == global.table_of_properties[ player.force.name ].enemy and flag.properties.value == 100 then color = table_of_colors.enemy end
|
||||
if spot.properties.force.name == global.table_of_properties[ player.force.name ].enemy and spot.properties.value == 100 then color = table_of_colors.enemy end
|
||||
|
||||
end
|
||||
|
||||
@ -415,7 +385,7 @@
|
||||
|
||||
element_frame.style.margin = 0
|
||||
|
||||
local element_table = element_frame.add{ type = 'table', column_count = 6 }
|
||||
local element_table = element_frame.add{ type = 'table', column_count = 2 }
|
||||
|
||||
element_table.style.padding = 0
|
||||
|
||||
@ -599,9 +569,9 @@
|
||||
|
||||
player.insert( { name = 'raw-fish', count = 3 } )
|
||||
|
||||
local table_of_tanks = player.surface.find_entities_filtered( { name = 'tank', force = player.force.name } )
|
||||
local table_of_entities = player.surface.find_entities_filtered( { name = 'tank', force = player.force.name } )
|
||||
|
||||
if #table_of_tanks < #player.force.connected_players then
|
||||
if #table_of_entities < #player.force.connected_players then
|
||||
|
||||
local position = player.surface.find_non_colliding_position( 'tank', player.position, 64, 4 )
|
||||
|
||||
@ -635,114 +605,118 @@
|
||||
|
||||
surface.set_tiles( table_of_items.blueprint.tiles, true )
|
||||
|
||||
for _, entity in pairs( table_of_items.blueprint.entities ) do
|
||||
for _, object in pairs( table_of_items.blueprint.entities ) do
|
||||
|
||||
entity.force = game.forces[ force_name ]
|
||||
object.force = game.forces[ force_name ]
|
||||
|
||||
entity.position = { x = entity.position.x + base_position.x, y = entity.position.y + base_position.y + 10 }
|
||||
object.position = { x = object.position.x + base_position.x, y = object.position.y + base_position.y + 10 }
|
||||
|
||||
local property = surface.create_entity( entity )
|
||||
local entity = surface.create_entity( object )
|
||||
|
||||
if not property then return end
|
||||
if not entity then return end
|
||||
|
||||
if entity.name == 'infinity-chest' or entity.name == 'substation' or entity.name == 'big-electric-pole' or entity.name == 'medium-electric-pole' or entity.name == 'inserter' or entity.name == 'accumulator' or entity.name == 'solar-panel' or entity.name == 'gun-turret' then
|
||||
if object.name == 'infinity-chest' or object.name == 'substation' or object.name == 'big-electric-pole' or object.name == 'medium-electric-pole' or object.name == 'inserter' or object.name == 'accumulator' or object.name == 'solar-panel' or object.name == 'gun-turret' then
|
||||
|
||||
property.destructible = false
|
||||
entity.destructible = false
|
||||
|
||||
property.minable = false
|
||||
entity.minable = false
|
||||
|
||||
property.rotatable = false
|
||||
entity.rotatable = false
|
||||
|
||||
property.operable = false
|
||||
entity.operable = false
|
||||
|
||||
end
|
||||
|
||||
if entity.name == 'wooden-chest' then
|
||||
if object.name == 'wooden-chest' then
|
||||
|
||||
property.destructible = false
|
||||
entity.destructible = false
|
||||
|
||||
property.minable = false
|
||||
entity.minable = false
|
||||
|
||||
property.rotatable = false
|
||||
entity.rotatable = false
|
||||
|
||||
end
|
||||
|
||||
if entity.name == 'stone-wall' or entity.name == 'gate' or entity.name == 'land-mine' then property.minable = false end
|
||||
if object.name == 'stone-wall' or object.name == 'gate' or object.name == 'land-mine' then entity.minable = false end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
function create_a_flag( flag_name, flag_position, flag_blueprint )
|
||||
function create_a_spot( spot_name, spot_position, spot_blueprint )
|
||||
|
||||
local surface = game.surfaces[ 'tank_conquest' ]
|
||||
|
||||
local flag = { name = flag_name, position = flag_position, force = { name = 'neutral' }, value = 0, color = table_of_colors.white }
|
||||
local spot = { name = spot_name, position = spot_position, force = { name = 'neutral' }, value = 0, color = table_of_colors.white }
|
||||
|
||||
local table_of_positions = {}
|
||||
|
||||
for x = 1, 18 do for y = 1, 18 do table.insert( table_of_positions, { x = math.floor( flag.position.x + x - 9 ), y = math.floor( flag.position.y + y - 9 ) } ) end end
|
||||
for x = 1, 18 do for y = 1, 18 do table.insert( table_of_positions, { x = math.floor( spot.position.x + x - 9 ), y = math.floor( spot.position.y + y - 9 ) } ) end end
|
||||
|
||||
local table_of_players = {}
|
||||
|
||||
local draw_flag_border = rendering.draw_rectangle{ surface = surface, target = flag.position, color = flag.color, left_top = { flag.position.x - 9, flag.position.y - 9 }, right_bottom = { flag.position.x + 9, flag.position.y + 9 }, width = 5, filled = false, draw_on_ground = true }
|
||||
local draw_spot_border = rendering.draw_rectangle{ surface = surface, target = spot.position, color = spot.color, left_top = { spot.position.x - 9, spot.position.y - 9 }, right_bottom = { spot.position.x + 9, spot.position.y + 9 }, width = 5, filled = false, draw_on_ground = true }
|
||||
|
||||
local draw_flag_force = rendering.draw_text{ text = flag.force.name, surface = surface, target = { flag.position.x, flag.position.y + 0.5 }, color = flag.color, scale = 5, alignment = 'center' }
|
||||
local draw_spot_force = rendering.draw_text{ text = spot.force.name, surface = surface, target = { spot.position.x, spot.position.y + 0.5 }, color = spot.color, scale = 5, alignment = 'center' }
|
||||
|
||||
local draw_flag_value = rendering.draw_text{ text = flag.value, surface = surface, target = { flag.position.x, flag.position.y - 4 }, color = flag.color, scale = 5, alignment = 'center' }
|
||||
local draw_spot_value = rendering.draw_text{ text = spot.value, surface = surface, target = { spot.position.x, spot.position.y - 4 }, color = spot.color, scale = 5, alignment = 'center' }
|
||||
|
||||
local draw_flag_name = rendering.draw_text{ text = flag.name, surface = surface, target = { flag.position.x, flag.position.y - 2 }, color = flag.color, scale = 5, alignment = 'center' }
|
||||
local draw_spot_name = rendering.draw_text{ text = spot.name, surface = surface, target = { spot.position.x, spot.position.y - 2 }, color = spot.color, scale = 5, alignment = 'center' }
|
||||
|
||||
local table_of_drawings = { name = draw_flag_name, value = draw_flag_value, force = draw_flag_force, border = draw_flag_border }
|
||||
local table_of_drawings = { name = draw_spot_name, value = draw_spot_value, force = draw_spot_force, border = draw_spot_border }
|
||||
|
||||
local table_of_properties = { name = flag.name, value = flag.value, force = flag.force, color = flag.color }
|
||||
local table_of_properties = { name = spot.name, position = spot.position, value = spot.value, force = spot.force, color = spot.color }
|
||||
|
||||
table.insert( global.table_of_flags, { properties = table_of_properties, drawings = table_of_drawings, players = table_of_players, positions = table_of_positions } )
|
||||
local table_of_entities = {}
|
||||
|
||||
local table_of_items = game.json_to_table( flag_blueprint )
|
||||
local table_of_items = game.json_to_table( spot_blueprint )
|
||||
|
||||
for _, tile in pairs( table_of_items.blueprint.tiles ) do tile.position = { x = tile.position.x + flag.position.x - 1, y = tile.position.y + flag.position.y - 1 } end
|
||||
for _, tile in pairs( table_of_items.blueprint.tiles ) do tile.position = { x = tile.position.x + spot.position.x - 1, y = tile.position.y + spot.position.y - 1 } end
|
||||
|
||||
surface.set_tiles( table_of_items.blueprint.tiles, true )
|
||||
|
||||
for _, entity in pairs( table_of_items.blueprint.entities ) do
|
||||
for _, object in pairs( table_of_items.blueprint.entities ) do
|
||||
|
||||
entity.force = 'enemy'
|
||||
object.force = 'enemy'
|
||||
|
||||
entity.position = { x = entity.position.x + flag.position.x - 1, y = entity.position.y + flag.position.y - 1 }
|
||||
object.position = { x = object.position.x + spot.position.x - 1, y = object.position.y + spot.position.y - 1 }
|
||||
|
||||
local property = surface.create_entity( entity )
|
||||
local entity = surface.create_entity( object )
|
||||
|
||||
if not property then return end
|
||||
if not entity then return end
|
||||
|
||||
if entity.name == 'infinity-chest' or entity.name == 'substation' or entity.name == 'inserter' or entity.name == 'accumulator' or entity.name == 'solar-panel' then
|
||||
if object.name == 'infinity-chest' or object.name == 'substation' or object.name == 'inserter' or object.name == 'accumulator' or object.name == 'solar-panel' then
|
||||
|
||||
property.destructible = false
|
||||
entity.destructible = false
|
||||
|
||||
property.minable = false
|
||||
entity.minable = false
|
||||
|
||||
property.rotatable = false
|
||||
entity.rotatable = false
|
||||
|
||||
property.operable = false
|
||||
entity.operable = false
|
||||
|
||||
end
|
||||
|
||||
if entity.name == 'wooden-chest' then
|
||||
if object.name == 'wooden-chest' then
|
||||
|
||||
property.force = 'neutral'
|
||||
entity.force = 'neutral'
|
||||
|
||||
property.destructible = false
|
||||
entity.destructible = false
|
||||
|
||||
property.minable = false
|
||||
entity.minable = false
|
||||
|
||||
property.rotatable = false
|
||||
entity.rotatable = false
|
||||
|
||||
end
|
||||
|
||||
if entity.name == 'stone-wall' or entity.name == 'gate' or entity.name == 'land-mine' then property.minable = false end
|
||||
if object.name == 'stone-wall' or object.name == 'gate' or object.name == 'land-mine' then entity.minable = false end
|
||||
|
||||
table.insert( table_of_entities, entity )
|
||||
|
||||
end
|
||||
|
||||
table.insert( global.table_of_spots, { properties = table_of_properties, drawings = table_of_drawings, players = table_of_players, positions = table_of_positions, entities = table_of_entities } )
|
||||
|
||||
end
|
||||
|
||||
function create_a_point_of_interest( poi_blueprint, poi_position )
|
||||
@ -755,41 +729,41 @@
|
||||
|
||||
surface.set_tiles( table_of_items.blueprint.tiles, true )
|
||||
|
||||
for _, entity in pairs( table_of_items.blueprint.entities ) do
|
||||
for _, object in pairs( table_of_items.blueprint.entities ) do
|
||||
|
||||
entity.force = 'enemy'
|
||||
object.force = 'enemy'
|
||||
|
||||
entity.position = { x = entity.position.x + poi_position.x, y = entity.position.y + poi_position.y }
|
||||
object.position = { x = object.position.x + poi_position.x, y = object.position.y + poi_position.y }
|
||||
|
||||
local property = surface.create_entity( entity )
|
||||
local entity = surface.create_entity( object )
|
||||
|
||||
if not property then return end
|
||||
if not entity then return end
|
||||
|
||||
if entity.name == 'infinity-chest' or entity.name == 'substation' or entity.name == 'inserter' or entity.name == 'accumulator' or entity.name == 'solar-panel' then
|
||||
if object.name == 'infinity-chest' or object.name == 'substation' or object.name == 'inserter' or object.name == 'accumulator' or object.name == 'solar-panel' then
|
||||
|
||||
property.destructible = false
|
||||
entity.destructible = false
|
||||
|
||||
property.minable = false
|
||||
entity.minable = false
|
||||
|
||||
property.rotatable = false
|
||||
entity.rotatable = false
|
||||
|
||||
property.operable = false
|
||||
entity.operable = false
|
||||
|
||||
end
|
||||
|
||||
if entity.name == 'wooden-chest' then
|
||||
if object.name == 'wooden-chest' then
|
||||
|
||||
property.force = 'neutral'
|
||||
entity.force = 'neutral'
|
||||
|
||||
property.destructible = false
|
||||
entity.destructible = false
|
||||
|
||||
property.minable = false
|
||||
entity.minable = false
|
||||
|
||||
property.rotatable = false
|
||||
entity.rotatable = false
|
||||
|
||||
end
|
||||
|
||||
if entity.name == 'stone-wall' or entity.name == 'gate' or entity.name == 'land-mine' then property.minable = false end
|
||||
if object.name == 'stone-wall' or object.name == 'gate' or object.name == 'land-mine' then entity.minable = false end
|
||||
|
||||
end
|
||||
|
||||
@ -897,6 +871,8 @@
|
||||
|
||||
if not player.character then return end
|
||||
|
||||
if global.table_of_properties.game_stage ~= 'ongoing_game' then return end
|
||||
|
||||
if #game.forces.force_player_one.connected_players == #game.forces.force_player_two.connected_players then
|
||||
|
||||
local table_of_forces = { 'force_player_one', 'force_player_two' }
|
||||
@ -921,6 +897,14 @@
|
||||
|
||||
game.permissions.get_group( 'Default' ).add_player( player.name )
|
||||
|
||||
game.print( player.name .. ' joined ' .. global.table_of_properties[ player.force.name ].icon )
|
||||
|
||||
rendering.draw_text{ text = global.table_of_properties[ player.force.name ].icon, target = player.character, target_offset = { 0, - 3.7 }, surface = player.surface, color = table_of_colors.white, scale = 2, alignment = 'center' }
|
||||
|
||||
create_a_tank( player )
|
||||
|
||||
for _, spot in pairs( global.table_of_spots ) do player.force.chart( game.surfaces[ 'tank_conquest' ], { { x = spot.properties.position.x - 10, y = spot.properties.position.y - 10 }, { x = spot.properties.position.x + 10, y = spot.properties.position.y + 10 } } ) end
|
||||
|
||||
end
|
||||
|
||||
function event_on_click_lobby( player )
|
||||
@ -969,33 +953,49 @@
|
||||
|
||||
if global.table_of_properties.game_stage == 'ongoing_game' then
|
||||
|
||||
for _, flag in pairs( global.table_of_flags ) do
|
||||
for _, spot in pairs( global.table_of_spots ) do
|
||||
|
||||
if flag.properties.value == 100 then
|
||||
if spot.properties.value == 100 then
|
||||
|
||||
local enemy = global.table_of_properties[ flag.properties.force.name ].enemy
|
||||
local enemy = global.table_of_properties[ spot.properties.force.name ].enemy
|
||||
|
||||
if global.table_of_properties[ enemy ].available_tickets >= 0 then global.table_of_properties[ enemy ].available_tickets = global.table_of_properties[ enemy ].available_tickets - global.table_of_properties.acceleration_value end
|
||||
|
||||
end
|
||||
|
||||
for _, player in pairs( flag.players ) do
|
||||
for _, player in pairs( spot.players ) do
|
||||
|
||||
if flag.properties.force.name == 'neutral' and flag.properties.value == 0 then flag.properties.force.name = player.force.name end
|
||||
if spot.properties.force.name == 'neutral' and spot.properties.value == 0 then
|
||||
|
||||
if flag.properties.force.name == 'neutral' or flag.properties.force.name == player.force.name and flag.properties.value < 100 then flag.properties.value = flag.properties.value + 1 * global.table_of_properties.conquest_speed end
|
||||
spot.properties.force.name = player.force.name
|
||||
|
||||
if flag.properties.force.name ~= player.force.name and flag.properties.value > 0 then flag.properties.value = flag.properties.value - 1 * global.table_of_properties.conquest_speed end
|
||||
for _, entity in pairs( spot.entities ) do
|
||||
|
||||
if flag.properties.value == 0 then flag.properties.force.name = 'neutral' end
|
||||
if entity.valid then
|
||||
|
||||
local force_label = flag.properties.force.name
|
||||
entity.force = player.force.name
|
||||
|
||||
if entity.name == 'stone-wall' or entity.name == 'gate' or entity.name == 'land-mine' then entity.minable = true end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
if spot.properties.force.name == 'neutral' or spot.properties.force.name == player.force.name and spot.properties.value < 100 then spot.properties.value = spot.properties.value + 1 * global.table_of_properties.conquest_speed end
|
||||
|
||||
if spot.properties.force.name ~= player.force.name and spot.properties.value > 0 then spot.properties.value = spot.properties.value - 1 * global.table_of_properties.conquest_speed end
|
||||
|
||||
if spot.properties.value == 0 then spot.properties.force.name = 'neutral' end
|
||||
|
||||
local force_label = spot.properties.force.name
|
||||
|
||||
if force_label ~= 'neutral' then force_label = global.table_of_properties[ force_label ].icon end
|
||||
|
||||
rendering.set_text( flag.drawings.force, force_label )
|
||||
rendering.set_text( spot.drawings.force, force_label )
|
||||
|
||||
rendering.set_text( flag.drawings.value, flag.properties.value )
|
||||
rendering.set_text( spot.drawings.value, spot.properties.value )
|
||||
|
||||
end
|
||||
|
||||
@ -1019,13 +1019,13 @@
|
||||
|
||||
end
|
||||
|
||||
global.table_of_flags = {}
|
||||
global.table_of_spots = {}
|
||||
|
||||
global.table_of_properties[ 'force_player_one' ].available_tickets = global.table_of_properties.amount_of_tickets
|
||||
|
||||
global.table_of_properties[ 'force_player_two' ].available_tickets = global.table_of_properties.amount_of_tickets
|
||||
|
||||
global.table_of_properties.countdown_in_seconds = 2701
|
||||
global.table_of_properties.countdown_in_seconds = 28800
|
||||
|
||||
global.table_of_properties.wait_in_seconds = 30
|
||||
|
||||
@ -1035,11 +1035,11 @@
|
||||
|
||||
for _, player in pairs( game.connected_players ) do
|
||||
|
||||
-- if player.gui.top[ 'draw_gui_button' ] then player.gui.top[ 'draw_gui_button' ].destroy() end
|
||||
if player.gui.top[ 'draw_gui_button' ] then player.gui.top[ 'draw_gui_button' ].destroy() end
|
||||
|
||||
if player.gui.top[ 'draw_gui_status' ] then player.gui.top[ 'draw_gui_status' ].destroy() end
|
||||
|
||||
if player.gui.top[ 'draw_gui_flags' ] then player.gui.top[ 'draw_gui_flags' ].destroy() end
|
||||
if player.gui.top[ 'draw_gui_spots' ] then player.gui.top[ 'draw_gui_spots' ].destroy() end
|
||||
|
||||
-- if player.gui.left[ 'draw_gui_squad' ] then player.gui.left[ 'draw_gui_squad' ].destroy() end
|
||||
|
||||
@ -1057,7 +1057,7 @@
|
||||
|
||||
draw_gui_status( player )
|
||||
|
||||
draw_gui_flags( player )
|
||||
draw_gui_spots( player )
|
||||
|
||||
end
|
||||
|
||||
@ -1065,17 +1065,23 @@
|
||||
|
||||
if global.table_of_properties.game_stage == 'regenerate_facilities' then
|
||||
|
||||
replace_tiles_of_water()
|
||||
local position = game.forces[ 'force_player_one' ].get_spawn_position( game.surfaces[ 'tank_conquest' ] )
|
||||
|
||||
create_a_base( 'force_player_one', game.forces[ 'force_player_one' ].get_spawn_position( game.surfaces[ 'tank_conquest' ] ) )
|
||||
create_a_base( 'force_player_one', position )
|
||||
|
||||
create_a_base( 'force_player_two', game.forces[ 'force_player_two' ].get_spawn_position( game.surfaces[ 'tank_conquest' ] ) )
|
||||
local position = game.forces[ 'force_player_two' ].get_spawn_position( game.surfaces[ 'tank_conquest' ] )
|
||||
|
||||
create_a_point_of_interest( blueprint_poi_laser_json, { x = 0, y = -350 } )
|
||||
create_a_base( 'force_player_two', position )
|
||||
|
||||
create_a_point_of_interest( blueprint_poi_fire_json, { x = 0, y = 450 } )
|
||||
local position = { x = 0, y = -350 }
|
||||
|
||||
local table_of_blueprints = { blueprint_poi_flag_one_json, blueprint_poi_flag_two_json, blueprint_poi_flag_three_json }
|
||||
create_a_point_of_interest( blueprint_poi_laser_json, position )
|
||||
|
||||
local position = { x = 0, y = 450 }
|
||||
|
||||
create_a_point_of_interest( blueprint_poi_fire_json, position )
|
||||
|
||||
local table_of_blueprints = { blueprint_poi_spot_one_json, blueprint_poi_spot_two_json, blueprint_poi_spot_three_json }
|
||||
|
||||
local table_of_names = { 'A', 'B', 'C', 'D', 'E', 'F', 'G' }
|
||||
|
||||
@ -1085,26 +1091,20 @@
|
||||
|
||||
local table_of_positions = draw_a_polygon( position, radius, angle, sides )
|
||||
|
||||
for index = 1, length_of_names do create_a_flag( table_of_names[ index ], table_of_positions[ index ], table_of_blueprints[ math.random( 1, #table_of_blueprints ) ] ) end
|
||||
for index = 1, length_of_names do create_a_spot( table_of_names[ index ], table_of_positions[ index ], table_of_blueprints[ math.random( 1, #table_of_blueprints ) ] ) end
|
||||
|
||||
for _, player in pairs( game.connected_players ) do
|
||||
|
||||
-- if player.gui.left[ 'draw_gui_squad' ] then player.gui.left[ 'draw_gui_squad' ].destroy() end
|
||||
|
||||
-- if player.gui.center[ 'draw_gui_menu' ] then player.gui.center[ 'draw_gui_menu' ].destroy() end
|
||||
|
||||
-- if player.gui.center[ 'draw_gui_score' ] then player.gui.center[ 'draw_gui_score' ].destroy() end
|
||||
|
||||
-- draw_gui_button( player )
|
||||
if player.gui.center[ 'draw_gui_menu' ] then player.gui.center[ 'draw_gui_menu' ].destroy() end
|
||||
|
||||
draw_gui_button( player )
|
||||
|
||||
event_on_click_join( player )
|
||||
|
||||
game.print( player.name .. ' joined ' .. global.table_of_properties[ player.force.name ].icon )
|
||||
|
||||
rendering.draw_text{ text = global.table_of_properties[ player.force.name ].icon, target = player.character, target_offset = { 0, - 3.5 }, surface = player.surface, color = table_of_colors.white, scale = 1.5, alignment = 'center' }
|
||||
|
||||
create_a_tank( player )
|
||||
|
||||
end
|
||||
|
||||
global.table_of_properties.game_stage = 'ongoing_game'
|
||||
@ -1113,13 +1113,13 @@
|
||||
|
||||
if global.table_of_properties.game_stage == 'preparing_spawn_positions' then
|
||||
|
||||
local position_one = { x = -500, y = 50 }
|
||||
local position = { x = -500, y = 50 }
|
||||
|
||||
local position_two = { x = 500, y = 50 }
|
||||
game.forces[ 'force_player_one' ].set_spawn_position( position, game.surfaces[ 'tank_conquest' ] )
|
||||
|
||||
game.forces[ 'force_player_one' ].set_spawn_position( position_one, game.surfaces[ 'tank_conquest' ] )
|
||||
local position = { x = 500, y = 50 }
|
||||
|
||||
game.forces[ 'force_player_two' ].set_spawn_position( position_two, game.surfaces[ 'tank_conquest' ] )
|
||||
game.forces[ 'force_player_two' ].set_spawn_position( position, game.surfaces[ 'tank_conquest' ] )
|
||||
|
||||
global.table_of_scores = {}
|
||||
|
||||
@ -1145,9 +1145,9 @@
|
||||
|
||||
initialize_surface()
|
||||
|
||||
game.connected_players[ 1 ].teleport( { 0, 0 }, game.surfaces[ 'tank_conquest' ] )
|
||||
game.surfaces[ 'tank_conquest' ].force_generate_chunk_requests()
|
||||
|
||||
game.connected_players[ 1 ].force.chart_all( game.surfaces[ 'tank_conquest' ] )
|
||||
game.surfaces[ 'tank_conquest' ].request_to_generate_chunks( { 0, 0 }, 15 )
|
||||
|
||||
game.print( 'A new battlefield was created.' )
|
||||
|
||||
@ -1159,7 +1159,7 @@
|
||||
|
||||
if #game.connected_players >= global.table_of_properties.required_number_of_players and global.table_of_properties.wait_in_seconds > 0 then
|
||||
|
||||
if global.table_of_properties.wait_in_seconds % 5 == 0 then game.print( 'The round starts in ' .. global.table_of_properties.wait_in_seconds .. ' seconds.' ) end
|
||||
if global.table_of_properties.wait_in_seconds % 10 == 0 then game.print( 'The round starts in ' .. global.table_of_properties.wait_in_seconds .. ' seconds.' ) end
|
||||
|
||||
global.table_of_properties.wait_in_seconds = global.table_of_properties.wait_in_seconds - 1
|
||||
|
||||
@ -1171,6 +1171,30 @@
|
||||
|
||||
end
|
||||
|
||||
if game.tick % 1800 == 0 then
|
||||
|
||||
if game.surfaces[ 'tank_conquest' ] ~= nil and #game.connected_players and #global.table_of_spots then
|
||||
|
||||
for _, player in pairs( game.connected_players ) do
|
||||
|
||||
for _, spot in pairs( global.table_of_spots ) do
|
||||
|
||||
if player.force.is_chunk_charted( game.surfaces[ 'tank_conquest' ], { x = math.floor( spot.properties.position.x / 32 ), y = math.floor( spot.properties.position.y / 32 ) } ) then
|
||||
|
||||
local chart_tags = player.force.find_chart_tags( game.surfaces[ 'tank_conquest' ], { { spot.properties.position.x - 1,spot.properties.position.y - 1 }, { spot.properties.position.x + 1, spot.properties.position.y + 1 } } )
|
||||
|
||||
if #chart_tags == 0 then player.force.add_chart_tag( game.surfaces[ 'tank_conquest' ], { icon = { type = 'virtual', name = 'signal-' .. spot.properties.name }, position = spot.properties.position } ) end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
if game.tick == 60 then
|
||||
|
||||
generate_circle_spawn( game.surfaces[ 'nauvis' ], 28, { x = 0, y = 0 } )
|
||||
@ -1207,7 +1231,7 @@
|
||||
|
||||
if player.surface.name == 'nauvis' then return end
|
||||
|
||||
rendering.draw_text{ text = global.table_of_properties[ player.force.name ].icon, target = player.character, target_offset = { 0, - 3.5 }, surface = player.surface, color = table_of_colors.white, scale = 1.5, alignment = 'center' }
|
||||
rendering.draw_text{ text = global.table_of_properties[ player.force.name ].icon, target = player.character, target_offset = { 0, - 3.7 }, surface = player.surface, color = table_of_colors.white, scale = 2, alignment = 'center' }
|
||||
|
||||
create_a_tank( player )
|
||||
|
||||
@ -1243,7 +1267,7 @@
|
||||
|
||||
if force ~= nil and force.available_tickets > 0 then force.available_tickets = force.available_tickets - 1 end
|
||||
|
||||
for _, flag in pairs( global.table_of_flags ) do if flag.players[ event.player_index ] ~= nil then flag.players[ event.player_index ] = nil end end
|
||||
for _, spot in pairs( global.table_of_spots ) do if spot.players[ event.player_index ] ~= nil then spot.players[ event.player_index ] = nil end end
|
||||
|
||||
end
|
||||
|
||||
@ -1255,17 +1279,17 @@
|
||||
|
||||
local player = game.players[ event.player_index ]
|
||||
|
||||
for flag_index, flag_item in pairs( global.table_of_flags ) do
|
||||
for spot_index, spot_item in pairs( global.table_of_spots ) do
|
||||
|
||||
if global.table_of_flags[ flag_index ].players[ event.player_index ] ~= nil then global.table_of_flags[ flag_index ].players[ event.player_index ] = nil end
|
||||
if global.table_of_spots[ spot_index ].players[ event.player_index ] ~= nil then global.table_of_spots[ spot_index ].players[ event.player_index ] = nil end
|
||||
|
||||
for _, position in pairs( flag_item.positions ) do
|
||||
for _, position in pairs( spot_item.positions ) do
|
||||
|
||||
if math.floor( player.position.x ) == position.x and math.floor( player.position.y ) == position.y or math.ceil( player.position.x ) == position.x and math.ceil( player.position.y ) == position.y then
|
||||
|
||||
if global.table_of_flags[ flag_index ].players[ event.player_index ] == nil then
|
||||
if global.table_of_spots[ spot_index ].players[ event.player_index ] == nil then
|
||||
|
||||
global.table_of_flags[ flag_index ].players[ event.player_index ] = player
|
||||
global.table_of_spots[ spot_index ].players[ event.player_index ] = player
|
||||
|
||||
break
|
||||
|
||||
@ -1275,7 +1299,7 @@
|
||||
|
||||
end
|
||||
|
||||
if global.table_of_flags[ flag_index ].players[ event.player_index ] ~= nil then break end
|
||||
if global.table_of_spots[ spot_index ].players[ event.player_index ] ~= nil then break end
|
||||
|
||||
end
|
||||
|
||||
@ -1287,9 +1311,11 @@
|
||||
|
||||
if not event.element then return end
|
||||
|
||||
if not event.element.valid then return end
|
||||
|
||||
local player = game.players[ event.player_index ]
|
||||
|
||||
if event.element.name == 'event_on_click_menu' then
|
||||
if event.element.name == 'draw_gui_button' then
|
||||
|
||||
if player.gui.center[ 'draw_gui_menu' ] then player.gui.center[ 'draw_gui_menu' ].destroy() else draw_gui_menu( player ) end
|
||||
|
||||
@ -1345,19 +1371,15 @@
|
||||
|
||||
game.permissions.get_group( 'permission_spectator' ).add_player( player.name )
|
||||
|
||||
player.print( 'Info: Each force has a number of tickets. Per conquered point, 0.1 tickets are deducted per second. If a player loses his life, 1 ticket is deducted from his own force.' )
|
||||
player.print( 'Info: Each force has a number of tickets. Per conquered spot, 0.1 tickets are deducted per second. If a player loses his life, 1 ticket is deducted from his own force.' )
|
||||
|
||||
end
|
||||
|
||||
if global.table_of_properties.game_stage == 'ongoing_game' then
|
||||
if global.table_of_properties.game_stage ~= 'lobby' then
|
||||
|
||||
event_on_click_join( player )
|
||||
draw_gui_button( player )
|
||||
|
||||
game.print( player.name .. ' joined ' .. global.table_of_properties[ player.force.name ].icon )
|
||||
|
||||
rendering.draw_text{ text = global.table_of_properties[ player.force.name ].icon, target = player.character, target_offset = { 0, - 3.5 }, surface = player.surface, color = table_of_colors.white, scale = 1.5, alignment = 'center' }
|
||||
|
||||
create_a_tank( player )
|
||||
draw_gui_menu( player )
|
||||
|
||||
end
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user