mirror of
https://github.com/PHIDIAS0303/ExpCluster.git
synced 2025-12-29 04:06:39 +09:00
Added Paths
This commit is contained in:
105
old/modules/DONE/WornPaths/control.lua
Normal file
105
old/modules/DONE/WornPaths/control.lua
Normal file
@@ -0,0 +1,105 @@
|
||||
--- Makes paths which wear down and paths where entities are placed.
|
||||
-- @module WornPaths@^4.0.0
|
||||
-- @author Cooldude2606
|
||||
-- @license https://github.com/explosivegaming/scenario/blob/master/LICENSE
|
||||
-- @alias ThisModule
|
||||
|
||||
-- Module Require
|
||||
local Game = require('FactorioStdLib.Game')
|
||||
|
||||
-- Local Variables
|
||||
local entities = require(module_path..'/src/entites')
|
||||
local paths = require(module_path..'/src/paths')
|
||||
for _,value in pairs(paths) do value[1]=-1/value[1] end
|
||||
local placed_paths = require(module_path..'/src/placed')
|
||||
|
||||
local adjacency_boost = 2 -- makes paths more likely to be next to each other; must be greater than 0
|
||||
adjacency_boost = 10/adjacency_boost -- dont change this line
|
||||
|
||||
-- Module Define
|
||||
local module_verbose = false
|
||||
local ThisModule = {}
|
||||
|
||||
-- Global Define
|
||||
local global = {}
|
||||
Global.register(global,function(tbl) global = tbl end)
|
||||
|
||||
-- Function Define
|
||||
local function global_key(surface,pos)
|
||||
return 'S'..surface.name..'X'..math.floor(pos.x)..'Y'..math.floor(pos.y)
|
||||
end
|
||||
|
||||
--- Downgrades a tile in this position
|
||||
-- @usage ThisModule.down_grade(surface,{x=10,y=10})
|
||||
-- @tparam surface surface the surface the tile is on
|
||||
-- @tparam table pos the position of the tile to change
|
||||
function ThisModule.down_grade(surface,pos)
|
||||
local tile = surface.get_tile(pos).name
|
||||
local new_tile = paths[tile][2]
|
||||
if new_tile == 'world-gen' then
|
||||
new_tile = global[global_key(surface,pos)] or 'grass-1'
|
||||
end
|
||||
surface.set_tiles{{name=new_tile,position=pos}}
|
||||
end
|
||||
|
||||
-- Event Handlers Define
|
||||
Event.add({defines.events.on_player_built_tile,defines.events.on_robot_built_tile}, function(event)
|
||||
local surface = event.surface_index and game.surfaces[event.surface_index] or event.robot and event.robot.surface
|
||||
local old_tiles = event.tiles
|
||||
for _,old_tile in pairs(old_tiles) do
|
||||
if not placed_paths[old_tile.old_tile.name] and old_tile.old_tile.name ~= 'water' and old_tile.old_tile.name ~= 'deepwater' then
|
||||
global[global_key(surface,old_tile.position)]=old_tile.old_tile.name -- not a mistake, this makes it have demising returns
|
||||
end
|
||||
end
|
||||
end)
|
||||
|
||||
Event.add(defines.events.on_player_changed_position, function(event)
|
||||
local player = Game.get_player(event)
|
||||
if not player or not player.valid or game.tick < 10 then return end
|
||||
if player.afk_time > 300 then return end
|
||||
local surface = player.surface
|
||||
local pos = player.position
|
||||
local tile_name = surface.get_tile(pos).name
|
||||
if not paths[tile_name] then return end
|
||||
local count = -9 -- this value is important
|
||||
for x = -1,1 do for y = -1,1 do
|
||||
local _pos = {pos.x+x,pos.y+y}
|
||||
if placed_paths[tile_name] and not placed_paths[surface.get_tile(_pos).name]
|
||||
or surface.get_tile(_pos).name == paths[tile_name][2]
|
||||
then count=count+1 end
|
||||
end end
|
||||
local chance = paths[tile_name][1]/(count-adjacency_boost)
|
||||
if math.random() < chance then
|
||||
ThisModule.down_grade(surface,pos)
|
||||
end
|
||||
end)
|
||||
|
||||
Event.add({defines.events.on_built_entity,on_robot_built_entity}, function(event)
|
||||
local entity = event.created_entity
|
||||
local surface = entity.surface
|
||||
if entities[entity.name] then
|
||||
local box = entity.prototype.collision_box
|
||||
for x = box.left_top.x,box.right_bottom.x do for y = box.left_top.y,box.right_bottom.y do
|
||||
local pos = {x=entity.position.x+x,y=entity.position.y+y}
|
||||
local tile = surface.get_tile(pos).name
|
||||
if paths[tile] then ThisModule.down_grade(surface,pos) end
|
||||
end end
|
||||
end
|
||||
end)
|
||||
-- Module Return
|
||||
-- when called it will downgrade a tile
|
||||
return setmetatable(ThisModule,{__call=function(self,...) self.down_grade(...) end})
|
||||
|
||||
--[[
|
||||
/interface
|
||||
local tile_name = surface.get_tile(position).name
|
||||
if not paths[tile_name] then return end
|
||||
local count = -9 -- this value is important
|
||||
for x = -1,1 do for y = -1,1 do
|
||||
local _pos = {position.x+x,position.y+y}
|
||||
if placed_paths[tile_name] and not placed_paths[surface.get_tile(_pos).name]
|
||||
or surface.get_tile(_pos).name == paths[tile_name][2]
|
||||
then count=count+1 end
|
||||
end end
|
||||
return paths[tile_name][1]/(count-adjacency_boost)
|
||||
]]
|
||||
Reference in New Issue
Block a user