mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-27 03:02:49 +01:00
parent
5c201af311
commit
6f23029e4c
21
geom.go
21
geom.go
@ -162,6 +162,27 @@ func (g *GeoM) Rotate(theta float64) {
|
|||||||
g.ty = ty
|
g.ty = ty
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Skew skews the matrix by (skewX, skewY). The unit is radian.
|
||||||
|
func (g *GeoM) Skew(skewX, skewY float64) {
|
||||||
|
sx64 := math.Tan(skewX)
|
||||||
|
sy64 := math.Tan(skewY)
|
||||||
|
sx, sy := float32(sx64), float32(sy64)
|
||||||
|
|
||||||
|
a := (g.a_1 + 1) + g.c*sx
|
||||||
|
b := g.b + (g.d_1+1)*sx
|
||||||
|
c := (g.a_1+1)*sy + g.c
|
||||||
|
d := g.b*sy + (g.d_1 + 1)
|
||||||
|
tx := g.tx + g.ty*sx
|
||||||
|
ty := g.ty + g.tx*sy
|
||||||
|
|
||||||
|
g.a_1 = a - 1
|
||||||
|
g.b = b
|
||||||
|
g.c = c
|
||||||
|
g.d_1 = d - 1
|
||||||
|
g.tx = tx
|
||||||
|
g.ty = ty
|
||||||
|
}
|
||||||
|
|
||||||
func (g *GeoM) det() float32 {
|
func (g *GeoM) det() float32 {
|
||||||
return (g.a_1+1)*(g.d_1+1) - g.b*g.c
|
return (g.a_1+1)*(g.d_1+1) - g.b*g.c
|
||||||
}
|
}
|
||||||
|
55
geom_test.go
55
geom_test.go
@ -206,6 +206,9 @@ func TestGeoMIsInvert(t *testing.T) {
|
|||||||
cpx2.Rotate(0.234)
|
cpx2.Rotate(0.234)
|
||||||
cpx2.Translate(100, 100)
|
cpx2.Translate(100, 100)
|
||||||
|
|
||||||
|
skew := GeoM{}
|
||||||
|
skew.Skew(1, 1)
|
||||||
|
|
||||||
cases := []struct {
|
cases := []struct {
|
||||||
GeoM GeoM
|
GeoM GeoM
|
||||||
Invertible bool
|
Invertible bool
|
||||||
@ -234,6 +237,10 @@ func TestGeoMIsInvert(t *testing.T) {
|
|||||||
GeoM: cpx2,
|
GeoM: cpx2,
|
||||||
Invertible: true,
|
Invertible: true,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
GeoM: skew,
|
||||||
|
Invertible: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
pts := []struct {
|
pts := []struct {
|
||||||
@ -279,6 +286,54 @@ func TestGeoMIsInvert(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func constructGeom(a, b, c, d, tx, ty float64) GeoM {
|
||||||
|
outp := GeoM{}
|
||||||
|
outp.SetElement(0, 0, a)
|
||||||
|
outp.SetElement(0, 1, b)
|
||||||
|
outp.SetElement(0, 2, tx)
|
||||||
|
outp.SetElement(1, 0, c)
|
||||||
|
outp.SetElement(1, 1, d)
|
||||||
|
outp.SetElement(1, 2, ty)
|
||||||
|
return outp
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestGeomSkew(t *testing.T) {
|
||||||
|
testSkew := func(skewX, skewY float64, input, expected GeoM) {
|
||||||
|
input.Skew(skewX, skewY)
|
||||||
|
for i := 0; i < 2; i++ {
|
||||||
|
for j := 0; j < 3; j++ {
|
||||||
|
got := input.Element(i, j)
|
||||||
|
want := expected.Element(i, j)
|
||||||
|
if want != got {
|
||||||
|
t.Errorf("Geom{}.Skew(%f, %f): got %s, want: %s", skewX, skewY, input.String(), expected.String())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// skewX = 0.25
|
||||||
|
expectedX := constructGeom(1, math.Tan(0.25), math.Tan(0), 1, 0, 0)
|
||||||
|
testSkew(0.25, 0, GeoM{}, expectedX)
|
||||||
|
|
||||||
|
// skewY = 0.25
|
||||||
|
expectedY := constructGeom(1, math.Tan(0), math.Tan(0.5), 1, 0, 0)
|
||||||
|
testSkew(0, 0.5, GeoM{}, expectedY)
|
||||||
|
|
||||||
|
// skewX, skewY = 0.3, 0.8
|
||||||
|
expectedXY := constructGeom(1, math.Tan(0.3), math.Tan(0.8), 1, 0, 0)
|
||||||
|
testSkew(0.3, 0.8, GeoM{}, expectedXY)
|
||||||
|
|
||||||
|
// skewX, skewY = 0.4, -1.8 ; b, c = 2, 3
|
||||||
|
expectedOffDiag := constructGeom(1+3*math.Tan(0.4), 2+math.Tan(0.4), 3+math.Tan(-1.8), 1+2*math.Tan(-1.8), 0, 0)
|
||||||
|
inputOffDiag := constructGeom(1, 2, 3, 1, 0, 0)
|
||||||
|
testSkew(0.4, -1.8, inputOffDiag, expectedOffDiag)
|
||||||
|
|
||||||
|
// skewX, skewY = -1.5, 1.5 ; tx, ty = 5, 6
|
||||||
|
expectedTrn := constructGeom(1, math.Tan(-1.5), math.Tan(1.5), 1, 5+math.Tan(-1.5)*6, 6+5*math.Tan(1.5))
|
||||||
|
inputTrn := constructGeom(1, 0, 0, 1, 5, 6)
|
||||||
|
testSkew(-1.5, 1.5, inputTrn, expectedTrn)
|
||||||
|
}
|
||||||
|
|
||||||
func BenchmarkGeoM(b *testing.B) {
|
func BenchmarkGeoM(b *testing.B) {
|
||||||
var m GeoM
|
var m GeoM
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
|
Loading…
Reference in New Issue
Block a user