mirror of
https://github.com/tanema/light_world.lua.git
synced 2025-01-07 15:24:21 +00:00
122 lines
3.1 KiB
Lua
122 lines
3.1 KiB
Lua
normal_map = {}
|
|
|
|
function normal_map.fromHeightMap(heightMap, strength)
|
|
local imgData = heightMap:getData()
|
|
local imgData2 = love.image.newImageData(heightMap:getWidth(), heightMap:getHeight())
|
|
local red, green, blue, alpha
|
|
local x, y
|
|
local matrix = {}
|
|
matrix[1] = {}
|
|
matrix[2] = {}
|
|
matrix[3] = {}
|
|
strength = strength or 1.0
|
|
|
|
for i = 0, heightMap:getHeight() - 1 do
|
|
for k = 0, heightMap:getWidth() - 1 do
|
|
for l = 1, 3 do
|
|
for m = 1, 3 do
|
|
if k + (l - 1) < 1 then
|
|
x = heightMap:getWidth() - 1
|
|
elseif k + (l - 1) > heightMap:getWidth() - 1 then
|
|
x = 1
|
|
else
|
|
x = k + l - 1
|
|
end
|
|
|
|
if i + (m - 1) < 1 then
|
|
y = heightMap:getHeight() - 1
|
|
elseif i + (m - 1) > heightMap:getHeight() - 1 then
|
|
y = 1
|
|
else
|
|
y = i + m - 1
|
|
end
|
|
|
|
local red, green, blue, alpha = imgData:getPixel(x, y)
|
|
matrix[l][m] = red
|
|
end
|
|
end
|
|
|
|
red = (255 + ((matrix[1][2] - matrix[2][2]) + (matrix[2][2] - matrix[3][2])) * strength) / 2.0
|
|
green = (255 + ((matrix[2][2] - matrix[1][1]) + (matrix[2][3] - matrix[2][2])) * strength) / 2.0
|
|
blue = 192
|
|
|
|
imgData2:setPixel(k, i, red, green, blue)
|
|
end
|
|
end
|
|
|
|
return love.graphics.newImage(imgData2)
|
|
end
|
|
|
|
function normal_map.generateFlat(img, mode)
|
|
local imgData = img:getData()
|
|
local imgNormalData = love.image.newImageData(img:getWidth(), img:getHeight())
|
|
local color
|
|
|
|
if mode == "top" then
|
|
color = {127, 127, 255}
|
|
elseif mode == "front" then
|
|
color = {127, 0, 127}
|
|
elseif mode == "back" then
|
|
color = {127, 255, 127}
|
|
elseif mode == "left" then
|
|
color = {31, 0, 223}
|
|
elseif mode == "right" then
|
|
color = {223, 0, 127}
|
|
end
|
|
|
|
for i = 0, img:getHeight() - 1 do
|
|
for k = 0, img:getWidth() - 1 do
|
|
local r, g, b, a = imgData:getPixel(k, i)
|
|
imgNormalData:setPixel(k, i, color[1], color[2], color[3], a)
|
|
end
|
|
end
|
|
|
|
return love.graphics.newImage(imgNormalData)
|
|
end
|
|
|
|
function normal_map.generateGradient(img, horizontalGradient, verticalGradient)
|
|
horizontalGradient = horizontalGradient or "gradient"
|
|
verticalGradient = verticalGradient or horizontalGradient
|
|
|
|
local imgData = img:getData()
|
|
local imgWidth, imgHeight = img:getWidth(), img:getHeight()
|
|
local imgNormalData = love.image.newImageData(imgWidth, imgHeight)
|
|
local dx = 255.0 / imgWidth
|
|
local dy = 255.0 / imgHeight
|
|
local nx
|
|
local ny
|
|
local nz
|
|
|
|
for i = 0, imgWidth - 1 do
|
|
for k = 0, imgHeight - 1 do
|
|
local r, g, b, a = imgData:getPixel(i, k)
|
|
if a > 0 then
|
|
if horizontalGradient == "gradient" then
|
|
nx = i * dx
|
|
elseif horizontalGradient == "inverse" then
|
|
nx = 255 - i * dx
|
|
else
|
|
nx = 127
|
|
end
|
|
|
|
if verticalGradient == "gradient" then
|
|
ny = 127 - k * dy * 0.5
|
|
nz = 255 - k * dy * 0.5
|
|
elseif verticalGradient == "inverse" then
|
|
ny = 127 + k * dy * 0.5
|
|
nz = 127 - k * dy * 0.25
|
|
else
|
|
ny = 255
|
|
nz = 127
|
|
end
|
|
|
|
imgNormalData:setPixel(i, k, nx, ny, nz, 255)
|
|
end
|
|
end
|
|
end
|
|
|
|
return love.graphics.newImage(imgNormalData)
|
|
end
|
|
|
|
return normal_map
|