-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathutil.go
67 lines (60 loc) · 1.46 KB
/
util.go
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
58
59
60
61
62
63
64
65
66
67
package kar
import (
"image"
"image/color"
"log"
"math"
"os"
"github.com/hajimehoshi/ebiten/v2/vector"
)
func MapRange(v, a, b, c, d float64) float64 {
return (v-a)/(b-a)*(d-c) + c
}
// Linspace returns evenly spaced numbers over a specified closed interval.
func Linspace(start, end float64, n int) []float64 {
nums := make([]float64, n)
step := (end - start) / float64(n-1)
nums[0] = start
for i := 1; i < n; i++ {
nums[i] = start + float64(i)*step
}
nums[n-1] = end
return nums
}
// Sinspace returns n points between start and end based on a sinusoidal function with a given amplitude
//
// start := 0.0 // Start of range
// end := 2 * math.Pi // End of range (one full sine wave)
// amplitude := 2.0 // Amplitude of the sine wave
// n := 10 // Number of points
func Sinspace(start, end, amplitude float64, n int) []float64 {
tValues := Linspace(start, end, n)
for i, t := range tValues {
tValues[i] = amplitude * math.Sin(t)
}
return tValues
}
func ReadPNG(filePath string) image.Image {
f, err := os.Open(filePath)
if err != nil {
log.Fatal(err)
}
defer f.Close()
image, _, err := image.Decode(f)
if err != nil {
log.Fatal(err)
}
return image
}
func DrawAABB(aabb *AABB) {
x, y := cameraRes.ApplyCameraTransformToPoint(aabb.Pos.X, aabb.Pos.Y)
vector.DrawFilledRect(
Screen,
float32(x-aabb.Half.X),
float32(y-aabb.Half.Y),
float32(aabb.Half.X*2),
float32(aabb.Half.Y*2),
color.RGBA{128, 0, 0, 10},
false,
)
}