2018-09-08 18:29:27 +02:00
|
|
|
-- this
|
|
|
|
local Mask = {}
|
|
|
|
|
2018-09-11 17:39:09 +02:00
|
|
|
|
2018-09-11 20:09:06 +02:00
|
|
|
local blurFilters = {}
|
|
|
|
blurFilters[5] = {
|
2018-09-11 17:39:09 +02:00
|
|
|
{0.003765, 0.015019, 0.023792, 0.015019, 0.003765},
|
|
|
|
{0.015019, 0.059912, 0.094907, 0.059912, 0.015019},
|
|
|
|
{0.023792, 0.094907, 0.150342, 0.094907, 0.023792},
|
|
|
|
{0.015019, 0.059912, 0.094907, 0.059912, 0.015019},
|
|
|
|
{0.003765, 0.015019, 0.023792, 0.015019, 0.003765}
|
|
|
|
}
|
|
|
|
local n = 5;
|
|
|
|
|
|
|
|
|
|
|
|
--[[--
|
2018-09-11 20:09:06 +02:00
|
|
|
Applies a blur filter.
|
2018-09-11 17:39:09 +02:00
|
|
|
|
2018-09-11 22:15:02 +02:00
|
|
|
@param x_start number center point
|
|
|
|
@param y_start number center point
|
|
|
|
@param factor number relative strength of the entity to withstand the pressure
|
2018-09-11 17:39:09 +02:00
|
|
|
factor < 0 if entity is placed
|
2018-09-11 22:15:02 +02:00
|
|
|
factor > 0 if entity is removed
|
2018-09-11 17:39:09 +02:00
|
|
|
@param callback function to execute on each tile within the mask callback(x, y, value)
|
|
|
|
]]
|
2018-09-11 20:09:06 +02:00
|
|
|
function Mask.blur(x_start, y_start, factor, callback)
|
|
|
|
local filter = blurFilters[n]
|
2018-09-11 17:39:09 +02:00
|
|
|
local offset = - math.floor(n / 2) - 1 --move matrix over x_start|y_start and adjust for 1 index
|
|
|
|
for x = 1, n do
|
|
|
|
for y = 1, n do
|
|
|
|
cell = filter[x][y]
|
|
|
|
value = factor * cell
|
|
|
|
callback(x_start + x + offset, y_start + y + offset, value)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-09-08 18:29:27 +02:00
|
|
|
--[[--
|
|
|
|
Masks in the shape of a circle.
|
|
|
|
|
|
|
|
@param x_start number, center point
|
|
|
|
@param y_start number, center point
|
|
|
|
@param diameter number size of the circle
|
|
|
|
@param callback function to execute on each tile within the circle callback(x, y, tile_distance_to_center, diameter)
|
|
|
|
]]
|
|
|
|
function Mask.circle(x_start, y_start, diameter, callback)
|
|
|
|
for x = (diameter * -1), diameter, 1 do
|
|
|
|
for y = (diameter * -1), diameter, 1 do
|
|
|
|
local tile_distance_to_center = math.floor(math.sqrt(x^2 + y^2))
|
|
|
|
|
|
|
|
if (tile_distance_to_center < diameter) then
|
|
|
|
callback(x + x_start, y + y_start, tile_distance_to_center, diameter)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
return Mask
|