blob: dc7cc911d8163969b966651cb960e8e3186ced0d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
import kotlinx.browser.document
import org.w3c.dom.CanvasRenderingContext2D
import org.w3c.dom.HTMLCanvasElement
class Minimap(private val map: List<List<Int>>) {
private val scale = 30
private val mapWidth = map[0].size
private val mapHeight = map.size
private val canvas = (document.createElement("canvas") as HTMLCanvasElement)
.apply {
width = mapWidth * scale
height = mapHeight * scale
id = "minimap"
style.width = "${width}px"
style.height = "${height}px"
}
private val context = canvas.getContext("2d") as CanvasRenderingContext2D
init {
document.body!!.appendChild(canvas)
}
private fun drawMap() {
for (y in 0 until mapHeight) {
for (x in 0 until mapWidth) {
val wall = map[y][x]
if (wall > 0) {
context.fillStyle = "#000000"
context.fillRect((x * scale).toDouble(), (y * scale).toDouble(), scale.toDouble(), scale.toDouble())
}
}
}
}
fun update(camera: Camera) {
context.clearRect(0.0, 0.0, (mapWidth * scale).toDouble(), (mapHeight * scale).toDouble())
drawMap()
context.fillStyle = "#FF0000"
context.fillRect(camera.xPos * scale, camera.yPos * scale, scale.toDouble(), scale.toDouble())
context.strokeStyle = "#00FF00"
context.lineWidth = 2.0
context.beginPath()
context.moveTo(camera.xPos * scale, camera.yPos * scale)
val cameraCos = kotlin.math.cos(toRadians(camera.rotation)) * 4
val cameraSin = kotlin.math.sin(toRadians(camera.rotation)) * 4
val dirX = camera.xPos + cameraCos
val dirY = camera.yPos + cameraSin
context.lineTo(dirX * scale, dirY * scale)
context.stroke()
}
}
|