mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2025-01-04 00:15:45 +02:00
new tool > lazy_chunk_loader
This commit is contained in:
parent
3a2ece5b0c
commit
a3d0537971
@ -2,6 +2,7 @@
|
||||
|
||||
local simplex_noise = require 'utils.simplex_noise'
|
||||
local event = require 'utils.event'
|
||||
require "maps.tools.lazy_chunk_loader"
|
||||
|
||||
local function get_noise(name, pos)
|
||||
local seed = game.surfaces[1].map_gen_settings.seed
|
||||
@ -47,7 +48,7 @@ local function get_noise(name, pos)
|
||||
end
|
||||
end
|
||||
|
||||
local function generate_chunk_tiles(chunk_piece)
|
||||
function generate_chunk_tiles(chunk_piece)
|
||||
local area = chunk_piece.area
|
||||
local surface = chunk_piece.surface
|
||||
local tiles = {}
|
||||
@ -76,7 +77,7 @@ local function generate_chunk_tiles(chunk_piece)
|
||||
surface.set_tiles(tiles,true)
|
||||
end
|
||||
|
||||
local function generate_chunk_entities(chunk_piece)
|
||||
function generate_chunk_entities(chunk_piece)
|
||||
local area = chunk_piece.area
|
||||
local surface = chunk_piece.surface
|
||||
local enemy_building_positions = {}
|
||||
@ -96,16 +97,10 @@ local function generate_chunk_entities(chunk_piece)
|
||||
local pos_y = area.left_top.y + y
|
||||
local pos = {x = pos_x, y = pos_y}
|
||||
tile_distance_to_center = pos_x^2 + pos_y^2
|
||||
if surface.can_place_entity({name="biter-spawner", position=p}) then surface.create_entity {name="biter-spawner", position=p} end
|
||||
if surface.can_place_entity({name="tree-04", position=pos}) then surface.create_entity {name="tree-04", position=pos} end
|
||||
--local noise_3 = get_noise(3, pos)
|
||||
if tile_to_insert == false then
|
||||
table.insert(tiles, {name = "sand-3", position = {pos_x,pos_y}})
|
||||
else
|
||||
table.insert(tiles, {name = tile_to_insert, position = {pos_x,pos_y}})
|
||||
end
|
||||
end
|
||||
end
|
||||
surface.set_tiles(tiles,true)
|
||||
end
|
||||
|
||||
|
||||
@ -122,22 +117,7 @@ function dump(o)
|
||||
end
|
||||
end
|
||||
|
||||
--cut chunks into 8x8 pieces and fill them into global.chunk_pieces
|
||||
local function on_chunk_generated(event)
|
||||
if not global.chunk_pieces then global.chunk_pieces = {} end
|
||||
if not global.chunk_pieces_tile_index then global.chunk_pieces_tile_index = 1 end
|
||||
if not global.chunk_pieces_entity_index then global.chunk_pieces_entity_index = 1 end
|
||||
local a
|
||||
for pos_y = 0, 24, 8 do
|
||||
for pos_x = 0, 24, 8 do
|
||||
a = {
|
||||
left_top = {x = event.area.left_top.x + pos_x, y = event.area.left_top.y + pos_y},
|
||||
right_bottom = {x = event.area.left_top.x + pos_x + 8, y = event.area.left_top.y + pos_y + 8}
|
||||
}
|
||||
table.insert(global.chunk_pieces, {area = a, surface = event.surface})
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
local function on_player_joined_game(event)
|
||||
local player = game.players[event.player_index]
|
||||
@ -178,18 +158,6 @@ local function on_marked_for_deconstruction(event)
|
||||
end
|
||||
end
|
||||
|
||||
local function on_tick()
|
||||
if global.chunk_pieces[global.chunk_pieces_tile_index] then
|
||||
generate_chunk_tiles(global.chunk_pieces[global.chunk_pieces_tile_index])
|
||||
global.chunk_pieces_tile_index = global.chunk_pieces_tile_index + 1
|
||||
else
|
||||
if global.chunk_pieces[global.chunk_entity_tile_index] then
|
||||
generate_chunk_entities(global.chunk_pieces[global.chunk_pieces_tile_index])
|
||||
global.chunk_entity_tile_index = global.chunk_entity_tile_index + 1
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
function cheat_mode()
|
||||
local cheat_mode_enabed = true
|
||||
if cheat_mode_enabed == true then
|
||||
@ -211,6 +179,4 @@ function cheat_mode()
|
||||
end
|
||||
|
||||
event.add(defines.events.on_marked_for_deconstruction, on_marked_for_deconstruction)
|
||||
event.add(defines.events.on_chunk_generated, on_chunk_generated)
|
||||
event.add(defines.events.on_tick, on_tick)
|
||||
event.add(defines.events.on_player_joined_game, on_player_joined_game)
|
59
maps/tools/lazy_chunk_loader.lua
Normal file
59
maps/tools/lazy_chunk_loader.lua
Normal file
@ -0,0 +1,59 @@
|
||||
--this tool should provide you with smoother gameplay in heavily modified custom maps--
|
||||
--tiles will be generated first, entities will be placed, when there are no more tiles left to process--
|
||||
--by mewmew
|
||||
|
||||
local event = require 'utils.event'
|
||||
|
||||
--cut chunks into 8x8 pieces and fill them into global.chunk_pieces
|
||||
local function on_chunk_generated(event)
|
||||
if not global.chunk_pieces then global.chunk_pieces = {} end
|
||||
if not global.chunk_pieces_tile_index then global.chunk_pieces_tile_index = 1 end
|
||||
if not global.chunk_pieces_entity_index then global.chunk_pieces_entity_index = 1 end
|
||||
local a
|
||||
for pos_y = 0, 24, 8 do
|
||||
for pos_x = 0, 24, 8 do
|
||||
a = {
|
||||
left_top = {x = event.area.left_top.x + pos_x, y = event.area.left_top.y + pos_y},
|
||||
right_bottom = {x = event.area.left_top.x + pos_x + 8, y = event.area.left_top.y + pos_y + 8}
|
||||
}
|
||||
table.insert(global.chunk_pieces, {area = a, surface = event.surface})
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
--process the pieces lazy, calling generate_chunk_tiles() and generate_chunk_entities()
|
||||
local function on_tick()
|
||||
if not generate_chunk_tiles then game.print("no function > generate_chunk_tiles") return end
|
||||
if not generate_chunk_entities then game.print("no function > generate_chunk_entities") return end
|
||||
|
||||
if global.chunk_pieces[global.chunk_pieces_tile_index] then
|
||||
if global.chunk_pieces_tile_index < 4096 then --4096 for a fast spawn generation
|
||||
for x = 1, 16, 1 do
|
||||
if global.chunk_pieces[global.chunk_pieces_tile_index] then
|
||||
generate_chunk_tiles(global.chunk_pieces[global.chunk_pieces_tile_index])
|
||||
global.chunk_pieces_tile_index = global.chunk_pieces_tile_index + 1
|
||||
end
|
||||
end
|
||||
else
|
||||
generate_chunk_tiles(global.chunk_pieces[global.chunk_pieces_tile_index])
|
||||
global.chunk_pieces_tile_index = global.chunk_pieces_tile_index + 1
|
||||
end
|
||||
else
|
||||
if global.chunk_pieces[global.chunk_pieces_entity_index] then
|
||||
if global.chunk_pieces_entity_index < 4096 then --4096 for a fast spawn generation
|
||||
for x = 1, 16, 1 do
|
||||
if global.chunk_pieces[global.chunk_pieces_entity_index] then
|
||||
generate_chunk_entities(global.chunk_pieces[global.chunk_pieces_entity_index])
|
||||
global.chunk_pieces_entity_index = global.chunk_pieces_entity_index + 1
|
||||
end
|
||||
end
|
||||
else
|
||||
generate_chunk_entities(global.chunk_pieces[global.chunk_pieces_entity_index])
|
||||
global.chunk_pieces_entity_index = global.chunk_pieces_entity_index + 1
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
event.add(defines.events.on_tick, on_tick)
|
||||
event.add(defines.events.on_chunk_generated, on_chunk_generated)
|
Loading…
Reference in New Issue
Block a user