mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2025-01-16 02:47:48 +02:00
Render beam - minor luacheck fix
This commit is contained in:
parent
ecee194aaa
commit
98e42d550f
@ -42,18 +42,23 @@ local remove = table.remove
|
|||||||
local speed = 0.06
|
local speed = 0.06
|
||||||
|
|
||||||
--- Draws a new render.
|
--- Draws a new render.
|
||||||
---@return table
|
---@return table|nil
|
||||||
function Public:new_render()
|
function Public:new_render()
|
||||||
local surface = game.get_surface(self.surface_id)
|
local surface = game.get_surface(self.surface_id)
|
||||||
|
if not surface or not surface.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
self.render_id = rendering.draw_sprite {target = self.position, sprite = self.sprite, surface = surface}
|
self.render_id = rendering.draw_sprite {target = self.position, sprite = self.sprite, surface = surface}
|
||||||
return self
|
return self
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Sets a new target for a given render.
|
--- Sets a new target for a given render.
|
||||||
---@return table
|
---@return table|nil, table|nil
|
||||||
---@return table
|
|
||||||
function Public:new_target()
|
function Public:new_target()
|
||||||
local surface = game.get_surface(self.surface_id)
|
local surface = game.get_surface(self.surface_id)
|
||||||
|
if not surface or not surface.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
local position
|
local position
|
||||||
local entities = surface.find_entities_filtered {type = this.valid_targets}
|
local entities = surface.find_entities_filtered {type = this.valid_targets}
|
||||||
if entities and #entities > 0 then
|
if entities and #entities > 0 then
|
||||||
@ -92,6 +97,7 @@ function Public:set_render_scalar_size()
|
|||||||
}
|
}
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Gets a random position.
|
--- Gets a random position.
|
||||||
---@return table
|
---@return table
|
||||||
function Public:random_position()
|
function Public:random_position()
|
||||||
@ -128,6 +134,9 @@ function Public:switch_position()
|
|||||||
self.target_position = self:random_position()
|
self.target_position = self:random_position()
|
||||||
else
|
else
|
||||||
local surface = game.get_surface(self.surface_id)
|
local surface = game.get_surface(self.surface_id)
|
||||||
|
if not surface or not surface.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
local chunk = surface.get_random_chunk()
|
local chunk = surface.get_random_chunk()
|
||||||
self.target_position = {x = (chunk.x + math.random()) * 32, y = (chunk.y + math.random()) * 32}
|
self.target_position = {x = (chunk.x + math.random()) * 32, y = (chunk.y + math.random()) * 32}
|
||||||
end
|
end
|
||||||
@ -138,6 +147,10 @@ function Public:notify_new_beam()
|
|||||||
if not self.notify then
|
if not self.notify then
|
||||||
self.notify = true
|
self.notify = true
|
||||||
local surface = game.get_surface(self.surface_id)
|
local surface = game.get_surface(self.surface_id)
|
||||||
|
if not surface or not surface.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
game.print('[Orbital] A new orbital strike has been spotted at: [gps=' .. self.position.x .. ',' .. self.position.y .. ',' .. surface.name .. ']')
|
game.print('[Orbital] A new orbital strike has been spotted at: [gps=' .. self.position.x .. ',' .. self.position.y .. ',' .. surface.name .. ']')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -149,6 +162,10 @@ function Public:render_chart()
|
|||||||
end
|
end
|
||||||
|
|
||||||
local surface = game.get_surface(self.surface_id)
|
local surface = game.get_surface(self.surface_id)
|
||||||
|
if not surface or not surface.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
self.chart =
|
self.chart =
|
||||||
game.forces[self.force].add_chart_tag(
|
game.forces[self.force].add_chart_tag(
|
||||||
surface,
|
surface,
|
||||||
@ -182,9 +199,19 @@ end
|
|||||||
function Public:render_fire_damage()
|
function Public:render_fire_damage()
|
||||||
if random(1, 15) == 1 then
|
if random(1, 15) == 1 then
|
||||||
local surface = game.get_surface(self.surface_id)
|
local surface = game.get_surface(self.surface_id)
|
||||||
|
if not surface or not surface.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
surface.create_entity({name = 'fire-flame', position = {x = self.position.x, y = self.position.y + 5}})
|
surface.create_entity({name = 'fire-flame', position = {x = self.position.x, y = self.position.y + 5}})
|
||||||
if random(1, 5) == 1 then
|
if random(1, 5) == 1 then
|
||||||
surface.create_entity({name = 'medium-scorchmark', position = {x = self.position.x, y = self.position.y + 5}, force = 'neutral'})
|
surface.create_entity(
|
||||||
|
{
|
||||||
|
name = 'medium-scorchmark',
|
||||||
|
position = {x = self.position.x, y = self.position.y + 5},
|
||||||
|
force = 'neutral'
|
||||||
|
}
|
||||||
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -193,8 +220,20 @@ end
|
|||||||
function Public:damage_entities_nearby()
|
function Public:damage_entities_nearby()
|
||||||
if random(1, 3) == 1 then
|
if random(1, 3) == 1 then
|
||||||
local surface = game.get_surface(self.surface_id)
|
local surface = game.get_surface(self.surface_id)
|
||||||
|
if not surface or not surface.valid then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
local damage = random(10, 15)
|
local damage = random(10, 15)
|
||||||
local entities = surface.find_entities_filtered({position = self.position, radius = 20, type = 'simple-entity', invert = true})
|
local entities =
|
||||||
|
surface.find_entities_filtered(
|
||||||
|
{
|
||||||
|
position = self.position,
|
||||||
|
radius = 20,
|
||||||
|
type = 'simple-entity',
|
||||||
|
invert = true
|
||||||
|
}
|
||||||
|
)
|
||||||
for _, entity in pairs(entities) do
|
for _, entity in pairs(entities) do
|
||||||
if entity.valid then
|
if entity.valid then
|
||||||
if entity.health then
|
if entity.health then
|
||||||
|
Loading…
Reference in New Issue
Block a user