2017-06-13 05:16:43 +02:00
|
|
|
local buildUtils = {}
|
|
|
|
|
|
|
|
-- imports
|
|
|
|
|
|
|
|
local constants = require("Constants")
|
|
|
|
local mathUtils = require("MathUtils")
|
|
|
|
|
|
|
|
local baseRegisterUtils = require("BaseRegisterUtils")
|
|
|
|
|
2017-07-02 07:40:25 +02:00
|
|
|
local mapUtils = require("MapUtils")
|
|
|
|
|
2017-06-13 05:16:43 +02:00
|
|
|
-- constants
|
|
|
|
|
|
|
|
local MAGIC_MAXIMUM_BASE_NUMBER = constants.MAGIC_MAXIMUM_BASE_NUMBER
|
|
|
|
|
|
|
|
local AI_NEST_COST = constants.AI_NEST_COST
|
|
|
|
local AI_WORM_COST = constants.AI_WORM_COST
|
|
|
|
|
2017-07-02 07:40:25 +02:00
|
|
|
local NEST_COUNT = constants.NEST_COUNT
|
|
|
|
|
2017-06-13 05:16:43 +02:00
|
|
|
local DOUBLE_CHUNK_SIZE = constants.DOUBLE_CHUNK_SIZE
|
|
|
|
|
2017-07-02 07:40:25 +02:00
|
|
|
-- imported functions
|
|
|
|
|
2017-06-13 05:16:43 +02:00
|
|
|
local registerEnemyBaseStructure = baseRegisterUtils.registerEnemyBaseStructure
|
|
|
|
local gaussianRandomRange = mathUtils.gaussianRandomRange
|
|
|
|
|
2017-07-01 06:36:23 +02:00
|
|
|
local mRandom = math.random
|
|
|
|
|
2017-07-02 07:40:25 +02:00
|
|
|
local getChunkByPosition = mapUtils.getChunkByPosition
|
|
|
|
|
2017-06-13 05:16:43 +02:00
|
|
|
-- module code
|
|
|
|
|
2017-07-02 07:40:25 +02:00
|
|
|
function buildUtils.buildNest(regionMap, base, surface, targetPosition, name)
|
|
|
|
local position = surface.find_non_colliding_position(name, targetPosition, DOUBLE_CHUNK_SIZE, 2)
|
|
|
|
local chunk = getChunkByPosition(regionMap, position.x, position.y)
|
|
|
|
local nest = nil
|
|
|
|
if position and chunk and (chunk[NEST_COUNT] < 3) then
|
|
|
|
local biterSpawner = {name=name, position=position}
|
|
|
|
nest = surface.create_entity(biterSpawner)
|
|
|
|
registerEnemyBaseStructure(regionMap, nest, base)
|
|
|
|
end
|
|
|
|
return nest
|
|
|
|
end
|
|
|
|
|
2017-06-13 05:16:43 +02:00
|
|
|
function buildUtils.buildHive(regionMap, base, surface)
|
|
|
|
local valid = false
|
2017-07-02 07:40:25 +02:00
|
|
|
local hive = buildUtils.buildNest(regionMap, base, surface, base, "biter-spawner-hive")
|
|
|
|
if hive then
|
2017-06-13 05:16:43 +02:00
|
|
|
if (#base.hives == 0) then
|
|
|
|
base.x = hive.position.x
|
|
|
|
base.y = hive.position.y
|
|
|
|
end
|
|
|
|
base.hives[#base.hives+1] = hive
|
|
|
|
valid = true
|
|
|
|
end
|
|
|
|
return valid
|
|
|
|
end
|
|
|
|
|
2017-07-01 06:36:23 +02:00
|
|
|
function buildUtils.buildOutpost(regionMap, natives, base, surface, tendril)
|
2017-06-13 05:16:43 +02:00
|
|
|
local foundHive = false
|
|
|
|
for _,_ in pairs(base.hives) do
|
|
|
|
foundHive = true
|
|
|
|
break
|
|
|
|
end
|
|
|
|
if not foundHive or (base.upgradePoints < 10) then
|
|
|
|
return
|
|
|
|
end
|
2017-07-01 06:36:23 +02:00
|
|
|
|
|
|
|
if not tendril.unit.valid then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
local position = tendril.unit.position
|
2017-06-13 05:16:43 +02:00
|
|
|
local generator = natives.randomGenerator
|
2017-07-01 06:36:23 +02:00
|
|
|
generator.re_seed(mRandom(MAGIC_MAXIMUM_BASE_NUMBER))
|
2017-06-13 05:16:43 +02:00
|
|
|
|
|
|
|
for level=0,(base.level * 0.5) do
|
|
|
|
local slices = (level * 3)
|
|
|
|
slices = gaussianRandomRange(slices, slices * 0.1, slices * 0.6, slices * 1.4, generator)
|
|
|
|
local slice = (2 * math.pi) / slices
|
|
|
|
local pos = 0
|
|
|
|
local thing
|
|
|
|
local cost
|
|
|
|
local radiusAdjustment
|
|
|
|
if (generator() < 0.3) then
|
|
|
|
thing = "small-worm-turret"
|
|
|
|
cost = AI_WORM_COST
|
|
|
|
radiusAdjustment = -4
|
|
|
|
else
|
|
|
|
thing = "biter-spawner"
|
|
|
|
cost = AI_NEST_COST
|
|
|
|
radiusAdjustment = 0
|
|
|
|
end
|
|
|
|
for _ = 1, slices do
|
|
|
|
if (base.upgradePoints < 10) then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
local radius = 10 * level
|
|
|
|
local distortion = gaussianRandomRange(radius, 10, radius - 7.5 + radiusAdjustment, radius + 7.5 + radiusAdjustment, generator)
|
|
|
|
local nestPosition = {x = position.x + (distortion * math.cos(pos)),
|
|
|
|
y = position.y + (distortion * math.sin(pos))}
|
|
|
|
local biterSpawner = {name=thing, position=nestPosition}
|
|
|
|
if surface.can_place_entity(biterSpawner) then
|
|
|
|
registerEnemyBaseStructure(regionMap, surface.create_entity(biterSpawner), base)
|
|
|
|
base.upgradePoints = base.upgradePoints - cost
|
|
|
|
end
|
|
|
|
pos = pos + slice
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
function buildUtils.buildOrder(regionMap, natives, base, surface)
|
|
|
|
local foundHive = false
|
|
|
|
for _,_ in pairs(base.hives) do
|
|
|
|
foundHive = true
|
|
|
|
break
|
|
|
|
end
|
|
|
|
if not foundHive or (base.upgradePoints < 10) then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
local generator = natives.randomGenerator
|
|
|
|
generator.re_seed(base.pattern)
|
|
|
|
|
|
|
|
for level=0,base.level do
|
|
|
|
local slices = (level * 3)
|
|
|
|
slices = gaussianRandomRange(slices, slices * 0.1, slices * 0.6, slices * 1.4, generator)
|
|
|
|
local slice = (2 * math.pi) / slices
|
|
|
|
local pos = 0
|
|
|
|
local thing
|
|
|
|
local cost
|
|
|
|
local radiusAdjustment
|
|
|
|
if (generator() < 0.3) then
|
|
|
|
thing = "small-worm-turret"
|
|
|
|
cost = AI_WORM_COST
|
|
|
|
radiusAdjustment = -4
|
|
|
|
else
|
|
|
|
thing = "biter-spawner"
|
|
|
|
cost = AI_NEST_COST
|
|
|
|
radiusAdjustment = 0
|
|
|
|
end
|
|
|
|
for _ = 1, slices do
|
|
|
|
if (base.upgradePoints < 10) then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
local radius = 10 * level
|
|
|
|
local distortion = gaussianRandomRange(radius, 10, radius - 7.5 + radiusAdjustment, radius + 7.5 + radiusAdjustment, generator)
|
|
|
|
local nestPosition = {x = base.x + (distortion * math.cos(pos)),
|
|
|
|
y = base.y + (distortion * math.sin(pos))}
|
|
|
|
local biterSpawner = {name=thing, position=nestPosition}
|
|
|
|
if surface.can_place_entity(biterSpawner) then
|
|
|
|
registerEnemyBaseStructure(regionMap, surface.create_entity(biterSpawner), base)
|
|
|
|
base.upgradePoints = base.upgradePoints - cost
|
|
|
|
end
|
|
|
|
pos = pos + slice
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
return buildUtils
|