1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-08 00:39:30 +02:00

optimizations

This commit is contained in:
MewMew 2020-04-17 15:38:16 +02:00
parent 80524a7a7c
commit 69c8f2b9c7
3 changed files with 63 additions and 50 deletions

View File

@ -231,38 +231,8 @@ function Public.add_chunk(event)
end
end
function Public.ticking_work()
local terrain_gen = global.terrain_gen
local tick = game.tick
if tick < 60 then return end
if tick % 4 == 0 then
for k, chunk in pairs(terrain_gen.chunk_copy) do
if copy_chunk(chunk) then
reveal_chunk(chunk)
table_remove(terrain_gen.chunk_copy, k)
terrain_gen.size_of_chunk_copy = terrain_gen.size_of_chunk_copy - 1
terrain_gen.counter = terrain_gen.counter + 1
end
break
end
end
if tick % 4 == 2 then
for k, chunk in pairs(terrain_gen.chunk_mirror) do
if mirror_chunk(chunk) then
reveal_chunk(chunk)
table_remove(terrain_gen.chunk_mirror, k)
terrain_gen.size_of_chunk_mirror = terrain_gen.size_of_chunk_mirror - 1
terrain_gen.counter = terrain_gen.counter + 1
end
break
end
end
if terrain_gen.counter % 512 == 511 then
local function clear_source_surface(terrain_gen)
if terrain_gen.counter % 1024 == 1023 then
terrain_gen.counter = terrain_gen.counter + 1
local surface = game.surfaces.bb_source
local c = 0
@ -274,4 +244,43 @@ function Public.ticking_work()
end
end
local function north_work()
local terrain_gen = global.terrain_gen
for k, chunk in pairs(terrain_gen.chunk_copy) do
if copy_chunk(chunk) then
reveal_chunk(chunk)
table_remove(terrain_gen.chunk_copy, k)
terrain_gen.size_of_chunk_copy = terrain_gen.size_of_chunk_copy - 1
terrain_gen.counter = terrain_gen.counter + 1
end
break
end
clear_source_surface(terrain_gen)
end
local function south_work()
local terrain_gen = global.terrain_gen
for k, chunk in pairs(terrain_gen.chunk_mirror) do
if mirror_chunk(chunk) then
reveal_chunk(chunk)
table_remove(terrain_gen.chunk_mirror, k)
terrain_gen.size_of_chunk_mirror = terrain_gen.size_of_chunk_mirror - 1
terrain_gen.counter = terrain_gen.counter + 1
end
break
end
clear_source_surface(terrain_gen)
end
local works = {
[1] = north_work,
[3] = south_work,
}
function Public.ticking_work()
local work = works[game.tick % 4]
if not work then return end
work()
end
return Public

View File

@ -8,6 +8,7 @@ local math_random = math.random
local math_abs = math.abs
local math_sqrt = math.sqrt
local GetNoise = require "utils.get_noise"
local simplex_noise = require 'utils.simplex_noise'.d2
local spawn_circle_size = 39
local ores = {"copper-ore", "iron-ore", "stone", "coal"}
@ -338,17 +339,18 @@ local bitera_area_distance = bb_config.bitera_area_distance * -1
local biter_area_angle = 0.45
local function is_biter_area(position)
if position.y - 96 > bitera_area_distance - (math_abs(position.x) * biter_area_angle) then return false end
if position.y + 96 < bitera_area_distance - (math_abs(position.x) * biter_area_angle) then return true end
if position.y + (get_noise(3, position) * 64) > bitera_area_distance - (math_abs(position.x) * biter_area_angle) then return false end
local a = bitera_area_distance - (math_abs(position.x) * biter_area_angle)
if position.y - 70 > a then return false end
if position.y + 70 < a then return true end
if position.y + (get_noise(3, position) * 64) > a then return false end
return true
end
local function draw_biter_area(surface, left_top_x, left_top_y)
if left_top_y > bb_config.bitera_area_distance * -1 + 32 then return end
if not is_biter_area({x = left_top_x, y = left_top_y - 96}) then return end
local seed = game.surfaces[1].map_gen_settings.seed
local out_of_map = {}
local tiles = {}
local i = 1
@ -357,10 +359,9 @@ local function draw_biter_area(surface, left_top_x, left_top_y)
for y = 0, 31, 1 do
local position = {x = left_top_x + x, y = left_top_y + y}
if is_biter_area(position) then
local noise_index = math_floor(math_abs(get_noise(3, position)) * 7) + 1
if noise_index > 7 then noise_index = 7 end
local index = math_floor(GetNoise("bb_biterland", position, seed) * 48) % 7 + 1
out_of_map[i] = {name = "out-of-map", position = position}
tiles[i] = {name = "dirt-" .. noise_index, position = position}
tiles[i] = {name = "dirt-" .. index, position = position}
i = i + 1
end
end
@ -403,24 +404,25 @@ local function draw_biter_area(surface, left_top_x, left_top_y)
end
local function mixed_ore(surface, left_top_x, left_top_y)
local seed = game.surfaces[1].map_gen_settings.seed
local noise = GetNoise("bb_ore", {x = left_top_x + 16, y = left_top_y + 16}, seed)
--Draw noise text values to determine which chunks are valid for mixed ore.
--rendering.draw_text{text = get_noise(1, {x = left_top_x + 16, y = left_top_y + 16}), surface = surface, target = {x = left_top_x + 16, y = left_top_y + 16}, color = {255, 255, 255}, time_to_live = 3600, scale = 2, font = "default-game"}
--rendering.draw_text{text = noise, surface = game.surfaces.biter_battles, target = {x = left_top_x + 16, y = left_top_y + 16}, color = {255, 255, 255}, scale = 2, font = "default-game"}
--Skip chunks that are too far off the ore noise value.
if get_noise(1, {x = left_top_x + 16, y = left_top_y + 16}) < 0.52 then return end
if noise < 0.45 then return end
--Draw the mixed ore patches.
for x = 0, 31, 1 do
for y = 0, 31, 1 do
local pos = {x = left_top_x + x, y = left_top_y + y}
if surface.can_place_entity({name = "iron-ore", position = pos}) then
local noise = get_noise(1, pos)
if noise > 0.82 then
local amount = math_random(1250, 1500) + math_sqrt(pos.x ^ 2 + pos.y ^ 2) * 1.1
local m = (noise - 0.75) * 16
amount = amount * m
local i = math_floor(math_abs(noise * 35)) % 4 + 1
if i == 0 then i = 4 end
local noise = GetNoise("bb_ore", pos, seed)
if noise > 0.75 then
local amount = math_random(1250, 1500) + math_sqrt(pos.x ^ 2 + pos.y ^ 2) * 2
local i = math_floor(noise * 50) % 4 + 1
surface.create_entity({name = ores[i], position = pos, amount = amount})
end
end

View File

@ -2,6 +2,8 @@ local simplex_noise = require "utils.simplex_noise".d2
--add or use noise templates from here
local noises = {
["bb_biterland"] = {{modifier = 0.001, weight = 1}, {modifier = 0.01, weight = 0.35}, {modifier = 0.1, weight = 0.015}},
["bb_ore"] = {{modifier = 0.0042, weight = 1}, {modifier = 0.031, weight = 0.08}, {modifier = 0.1, weight = 0.025}},
["cave_ponds"] = {{modifier = 0.01, weight = 1}, {modifier = 0.1, weight = 0.06}},
["cave_rivers"] = {{modifier = 0.005, weight = 1}, {modifier = 0.01, weight = 0.25}, {modifier = 0.05, weight = 0.01}},
["cave_rivers_2"] = {{modifier = 0.003, weight = 1}, {modifier = 0.01, weight = 0.21}, {modifier = 0.05, weight = 0.01}},