mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 20:18:59 +01:00
example/vector: Add the logo
There is a known issue in the logo rendering.
This commit is contained in:
parent
f1a788801c
commit
6edb586f52
@ -98,6 +98,34 @@ func drawEbitenText(screen *ebiten.Image) {
|
|||||||
path.Fill(screen, color.White)
|
path.Fill(screen, color.White)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func drawEbitenLogo(screen *ebiten.Image, x, y int) {
|
||||||
|
const unit = 16
|
||||||
|
|
||||||
|
var path vector.Path
|
||||||
|
xf, yf := float32(x), float32(y)
|
||||||
|
|
||||||
|
path.MoveTo(xf, yf+4*unit)
|
||||||
|
path.LineTo(xf, yf+6*unit)
|
||||||
|
path.LineTo(xf+2*unit, yf+6*unit)
|
||||||
|
path.LineTo(xf+2*unit, yf+5*unit)
|
||||||
|
path.LineTo(xf+3*unit, yf+5*unit)
|
||||||
|
path.LineTo(xf+3*unit, yf+4*unit)
|
||||||
|
path.LineTo(xf+4*unit, yf+4*unit)
|
||||||
|
path.LineTo(xf+4*unit, yf+2*unit)
|
||||||
|
path.LineTo(xf+6*unit, yf+2*unit)
|
||||||
|
path.LineTo(xf+6*unit, yf+1*unit)
|
||||||
|
path.LineTo(xf+5*unit, yf+1*unit)
|
||||||
|
path.LineTo(xf+5*unit, yf)
|
||||||
|
path.LineTo(xf+4*unit, yf)
|
||||||
|
path.LineTo(xf+4*unit, yf+2*unit)
|
||||||
|
path.LineTo(xf+2*unit, yf+2*unit)
|
||||||
|
path.LineTo(xf+2*unit, yf+3*unit)
|
||||||
|
path.LineTo(xf+unit, yf+3*unit)
|
||||||
|
path.LineTo(xf+unit, yf+4*unit)
|
||||||
|
|
||||||
|
path.Fill(screen, color.RGBA{0xdb, 0x56, 0x20, 0xff})
|
||||||
|
}
|
||||||
|
|
||||||
var counter = 0
|
var counter = 0
|
||||||
|
|
||||||
func update(screen *ebiten.Image) error {
|
func update(screen *ebiten.Image) error {
|
||||||
@ -107,6 +135,7 @@ func update(screen *ebiten.Image) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
drawEbitenText(screen)
|
drawEbitenText(screen)
|
||||||
|
drawEbitenLogo(screen, 20, 80)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,34 +45,9 @@ func Triangulate(pts []Point) []uint16 {
|
|||||||
var currentIndices []uint16
|
var currentIndices []uint16
|
||||||
|
|
||||||
// Remove duplicated points
|
// Remove duplicated points
|
||||||
dup:
|
|
||||||
for i := range pts {
|
for i := range pts {
|
||||||
for j := 0; j < i; j++ {
|
|
||||||
if pts[i] == pts[j] {
|
|
||||||
continue dup
|
|
||||||
}
|
|
||||||
}
|
|
||||||
currentIndices = append(currentIndices, uint16(i))
|
currentIndices = append(currentIndices, uint16(i))
|
||||||
}
|
}
|
||||||
if len(currentIndices) < 3 {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Determine the direction of the polygon from the upper-left point.
|
|
||||||
var upperLeft int
|
|
||||||
for ci, i := range currentIndices {
|
|
||||||
if pts[upperLeft].X < pts[i].X {
|
|
||||||
upperLeft = int(ci)
|
|
||||||
}
|
|
||||||
if pts[upperLeft].X == pts[i].X && pts[upperLeft].Y < pts[i].Y {
|
|
||||||
upperLeft = int(ci)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
i0, i1, i2 := adjacentIndices(currentIndices, upperLeft)
|
|
||||||
pt0 := pts[i0]
|
|
||||||
pt1 := pts[i1]
|
|
||||||
pt2 := pts[i2]
|
|
||||||
clockwise := triangleCross(pt0, pt1, pt2) < 0
|
|
||||||
|
|
||||||
var indices []uint16
|
var indices []uint16
|
||||||
|
|
||||||
@ -81,25 +56,43 @@ dup:
|
|||||||
for len(currentIndices) >= 3 {
|
for len(currentIndices) >= 3 {
|
||||||
// Calculate cross-products and remove unneeded vertices.
|
// Calculate cross-products and remove unneeded vertices.
|
||||||
cs := make([]float32, len(currentIndices))
|
cs := make([]float32, len(currentIndices))
|
||||||
idx := -1
|
idxToRemove := -1
|
||||||
|
|
||||||
|
// Determine the direction of the polygon from the upper-left point.
|
||||||
|
var upperLeft int
|
||||||
for i := range currentIndices {
|
for i := range currentIndices {
|
||||||
|
next := (i + 1) % len(currentIndices)
|
||||||
|
if pts[currentIndices[i]] == pts[currentIndices[next]] {
|
||||||
|
idxToRemove = next
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
i0, i1, i2 := adjacentIndices(currentIndices, i)
|
i0, i1, i2 := adjacentIndices(currentIndices, i)
|
||||||
pt0 := pts[i0]
|
pt0 := pts[i0]
|
||||||
pt1 := pts[i1]
|
pt1 := pts[i1]
|
||||||
pt2 := pts[i2]
|
pt2 := pts[i2]
|
||||||
c := triangleCross(pt0, pt1, pt2)
|
c := triangleCross(pt0, pt1, pt2)
|
||||||
if c == 0 {
|
if c == 0 {
|
||||||
idx = i
|
idxToRemove = i
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
cs[i] = c
|
cs[i] = c
|
||||||
|
|
||||||
|
if pts[currentIndices[upperLeft]].X > pts[currentIndices[i]].X {
|
||||||
|
upperLeft = i
|
||||||
|
} else if pts[currentIndices[upperLeft]].X == pts[currentIndices[i]].X &&
|
||||||
|
pts[currentIndices[upperLeft]].Y > pts[currentIndices[i]].Y {
|
||||||
|
upperLeft = i
|
||||||
}
|
}
|
||||||
if idx != -1 {
|
}
|
||||||
currentIndices = append(currentIndices[:idx], currentIndices[idx+1:]...)
|
if idxToRemove != -1 {
|
||||||
|
currentIndices = append(currentIndices[:idxToRemove], currentIndices[idxToRemove+1:]...)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
idx = -1
|
clockwise := cs[upperLeft] < 0
|
||||||
|
|
||||||
|
idx := -1
|
||||||
index:
|
index:
|
||||||
for i := range currentIndices {
|
for i := range currentIndices {
|
||||||
i0, i1, i2 := adjacentIndices(currentIndices, i)
|
i0, i1, i2 := adjacentIndices(currentIndices, i)
|
||||||
@ -119,6 +112,10 @@ dup:
|
|||||||
if l := len(currentIndices); j == (i+l-1)%l || j == i || j == (i+1)%l {
|
if l := len(currentIndices); j == (i+l-1)%l || j == i || j == (i+1)%l {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
jj := currentIndices[j]
|
||||||
|
if pts[i0] == pts[jj] || pts[i1] == pts[jj] || pts[i2] == pts[jj] {
|
||||||
|
continue
|
||||||
|
}
|
||||||
if InTriangle(pts[currentIndices[j]], pt0, pt1, pt2) {
|
if InTriangle(pts[currentIndices[j]], pt0, pt1, pt2) {
|
||||||
// If the triangle includes another point, the triangle is not an ear.
|
// If the triangle includes another point, the triangle is not an ear.
|
||||||
continue index
|
continue index
|
||||||
|
@ -215,6 +215,61 @@ func TestTriangulate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
Out: []uint16{8, 0, 1, 1, 2, 4, 1, 4, 5, 8, 1, 5, 8, 5, 7},
|
Out: []uint16{8, 0, 1, 1, 2, 4, 1, 4, 5, 8, 1, 5, 8, 5, 7},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
In: []Point{
|
||||||
|
{0, 0},
|
||||||
|
{0, 1},
|
||||||
|
{1, 1},
|
||||||
|
{1, 0},
|
||||||
|
{2, 0},
|
||||||
|
},
|
||||||
|
Out: []uint16{3, 0, 1, 3, 1, 2},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
In: []Point{
|
||||||
|
{2, 0},
|
||||||
|
{0, 0},
|
||||||
|
{1, 0},
|
||||||
|
{1, 1},
|
||||||
|
{2, 1},
|
||||||
|
},
|
||||||
|
Out: []uint16{4, 0, 2, 4, 2, 3},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
In: []Point{
|
||||||
|
{2, 0},
|
||||||
|
{2, 1},
|
||||||
|
{1, 1},
|
||||||
|
{1, 0},
|
||||||
|
{0, 0},
|
||||||
|
},
|
||||||
|
Out: []uint16{3, 0, 1, 3, 1, 2},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
// Butterfly
|
||||||
|
In: []Point{
|
||||||
|
{0, 0},
|
||||||
|
{0, 2},
|
||||||
|
{1, 1},
|
||||||
|
{2, 2},
|
||||||
|
{2, 0},
|
||||||
|
{1, 1},
|
||||||
|
},
|
||||||
|
Out: []uint16{5, 0, 1, 5, 3, 4},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
In: []Point{
|
||||||
|
{0, 6},
|
||||||
|
{0, 9},
|
||||||
|
{6, 6},
|
||||||
|
{6, 3},
|
||||||
|
{9, 3},
|
||||||
|
{8, 0},
|
||||||
|
{6, 0},
|
||||||
|
{6, 3},
|
||||||
|
},
|
||||||
|
Out: []uint16{7, 0, 1, 7, 1, 2, 7, 4, 5, 7, 5, 6},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
for _, tc := range tests {
|
for _, tc := range tests {
|
||||||
got := Triangulate(tc.In)
|
got := Triangulate(tc.In)
|
||||||
|
Loading…
Reference in New Issue
Block a user