2025-08-18 02:39:56 +01:00
|
|
|
structure Rect =
|
2024-11-15 21:14:43 +00:00
|
|
|
struct
|
2025-08-18 02:39:56 +01:00
|
|
|
fun xToNdc (xOffset, xpos, scale, halfWidth) =
|
|
|
|
|
((xpos * scale + xOffset) - halfWidth) / halfWidth
|
|
|
|
|
|
|
|
|
|
fun yToNdc (yOffset, ypos, scale, halfHeight) =
|
|
|
|
|
~(((ypos * scale + yOffset) - halfHeight) / halfHeight)
|
|
|
|
|
|
2025-09-11 01:53:13 +01:00
|
|
|
fun lerp (xOffset: Real32.real, yOffset, z, scale, windowWidth, windowHeight, r, g, b) =
|
2024-11-15 21:14:43 +00:00
|
|
|
let
|
2025-08-18 02:39:56 +01:00
|
|
|
val halfWidth = windowWidth / 2.0
|
|
|
|
|
val halfHeight = windowHeight / 2.0
|
2024-11-15 21:14:43 +00:00
|
|
|
in
|
2025-08-18 02:39:56 +01:00
|
|
|
#[
|
|
|
|
|
xToNdc (xOffset, 0.000000000000000, scale, halfWidth),
|
|
|
|
|
yToNdc (yOffset, 13.000000000000000, scale, halfHeight),
|
2025-09-27 08:14:22 +01:00
|
|
|
z, r, g, b,
|
|
|
|
|
xToNdc (xOffset, 7.000000000000000, scale, halfWidth),
|
2025-08-18 02:39:56 +01:00
|
|
|
yToNdc (yOffset, 13.000000000000000, scale, halfHeight),
|
2025-09-27 08:14:22 +01:00
|
|
|
z, r, g, b,
|
2025-08-18 02:39:56 +01:00
|
|
|
xToNdc (xOffset, 0.000000000000000, scale, halfWidth),
|
|
|
|
|
yToNdc (yOffset, 0.000000000000000, scale, halfHeight),
|
2025-09-27 08:14:22 +01:00
|
|
|
z, r, g, b,
|
2025-08-18 02:39:56 +01:00
|
|
|
xToNdc (xOffset, 0.000000000000000, scale, halfWidth),
|
|
|
|
|
yToNdc (yOffset, 0.000000000000000, scale, halfHeight),
|
2025-09-27 08:14:22 +01:00
|
|
|
z, r, g, b,
|
|
|
|
|
xToNdc (xOffset, 7.000000000000000, scale, halfWidth),
|
2025-08-18 02:39:56 +01:00
|
|
|
yToNdc (yOffset, 13.000000000000000, scale, halfHeight),
|
2025-09-27 08:14:22 +01:00
|
|
|
z, r, g, b,
|
|
|
|
|
xToNdc (xOffset, 7.000000000000000, scale, halfWidth),
|
2025-08-18 02:39:56 +01:00
|
|
|
yToNdc (yOffset, 0.000000000000000, scale, halfHeight),
|
2025-09-27 08:14:22 +01:00
|
|
|
z, r, g, b
|
2025-08-18 02:39:56 +01:00
|
|
|
]
|
|
|
|
|
end
|
2024-11-15 21:14:43 +00:00
|
|
|
end
|