ebiten/example/game.go

183 lines
4.3 KiB
Go
Raw Normal View History

2013-12-08 08:19:24 +01:00
package main
2013-07-02 18:27:04 +02:00
import (
2013-07-04 16:57:53 +02:00
"fmt"
2013-10-14 04:34:58 +02:00
"github.com/hajimehoshi/go-ebiten/graphics"
"github.com/hajimehoshi/go-ebiten/graphics/matrix"
"github.com/hajimehoshi/go-ebiten/ui"
2013-12-08 13:03:30 +01:00
"image/color"
"math"
2013-07-02 18:27:04 +02:00
)
2013-12-08 08:19:24 +01:00
var TexturePaths = map[string]string{
"ebiten": "images/ebiten.png",
2013-12-08 08:28:56 +01:00
"text": "images/text.png",
2013-12-08 08:19:24 +01:00
}
2013-12-08 15:03:00 +01:00
type Size struct {
Width int
Height int
}
var RenderTargetSizes = map[string]Size{
"whole": Size{256, 254},
}
2013-12-08 09:02:35 +01:00
type drawInfo struct {
2013-12-08 15:03:00 +01:00
textures map[string]graphics.TextureId
renderTargets map[string]graphics.RenderTargetId
inputStr string
textureX int
textureY int
textureAngle float64
textureGeo matrix.Geometry
2013-12-08 09:02:35 +01:00
}
2013-12-08 08:19:24 +01:00
type Game struct {
2013-12-08 09:02:35 +01:00
inputX int
inputY int
inputPrevX int
inputPrevY int
counter int
drawInfo
2013-07-02 18:27:04 +02:00
}
2013-12-08 08:19:24 +01:00
func NewGame() *Game {
return &Game{
2013-12-08 09:02:35 +01:00
inputX: -1,
inputY: -1,
inputPrevX: -1,
inputPrevY: -1,
counter: 0,
drawInfo: drawInfo{
2013-12-08 15:03:00 +01:00
textures: map[string]graphics.TextureId{},
renderTargets: map[string]graphics.RenderTargetId{},
textureX: 0,
textureY: 0,
textureAngle: 0,
textureGeo: matrix.IdentityGeometry(),
2013-12-08 09:02:35 +01:00
},
2013-11-29 19:21:10 +01:00
}
}
2013-12-08 08:19:24 +01:00
func (game *Game) OnTextureCreated(e graphics.TextureCreatedEvent) {
if e.Error != nil {
panic(e.Error)
}
game.textures[e.Tag.(string)] = e.Id
}
2013-12-08 15:03:00 +01:00
func (game *Game) OnRenderTargetCreated(e graphics.RenderTargetCreatedEvent) {
if e.Error != nil {
panic(e.Error)
}
game.renderTargets[e.Tag.(string)] = e.Id
}
2013-12-08 08:19:24 +01:00
func (game *Game) OnInputStateUpdated(e ui.InputStateUpdatedEvent) {
2013-12-08 09:02:35 +01:00
game.inputX, game.inputY = e.X, e.Y
2013-07-02 18:27:04 +02:00
}
2013-12-08 15:03:00 +01:00
func (game *Game) isInitialized() bool {
if len(game.drawInfo.textures) < len(TexturePaths) {
return false
}
if len(game.drawInfo.renderTargets) < len(RenderTargetSizes) {
return false
}
return true
}
2013-12-08 08:19:24 +01:00
func (game *Game) Update() {
2013-12-08 15:03:00 +01:00
if !game.isInitialized() {
return
}
2013-12-08 13:03:30 +01:00
const textureWidth = 57
const textureHeight = 26
2013-12-08 09:02:35 +01:00
game.counter++
game.drawInfo.inputStr = fmt.Sprintf(`Input State:
X: %d
Y: %d`, game.inputX, game.inputY)
if game.inputPrevX != -1 && game.inputPrevY != -1 &&
game.inputX != -1 && game.inputY != -1 {
2013-12-08 13:03:30 +01:00
dx, dy := game.inputX-game.inputPrevX, game.inputY-game.inputPrevY
game.textureX += dx
game.textureY += dy
2013-11-29 19:21:10 +01:00
}
2013-12-08 13:03:30 +01:00
game.drawInfo.textureAngle = 2 * math.Pi * float64(game.counter) / 600
2013-12-08 15:03:00 +01:00
geo := matrix.IdentityGeometry()
geo.Translate(-textureWidth/2, -textureHeight/2)
geo.Rotate(game.drawInfo.textureAngle)
geo.Translate(textureWidth/2, textureHeight/2)
geo.Translate(float64(game.textureX), float64(game.textureY))
2013-12-08 13:03:30 +01:00
2013-12-08 15:03:00 +01:00
game.drawInfo.textureGeo = geo
2013-12-08 09:02:35 +01:00
// Update for the next frame.
game.inputPrevX, game.inputPrevY = game.inputX, game.inputY
2013-07-02 18:27:04 +02:00
}
2013-12-08 08:19:24 +01:00
func (game *Game) Draw(g graphics.Canvas) {
2013-12-08 15:03:00 +01:00
if !game.isInitialized() {
2013-12-08 08:19:24 +01:00
return
}
2013-12-08 15:03:00 +01:00
whole := game.drawInfo.renderTargets["whole"]
g.SetOffscreen(whole)
2013-12-08 17:57:53 +01:00
g.Fill(0x70, 0x90, 0xe0)
2013-12-08 09:02:35 +01:00
game.drawTexture(g, game.drawInfo.textureGeo, matrix.IdentityColor())
2013-12-08 11:38:22 +01:00
game.drawText(g, game.drawInfo.inputStr, 6, 6, &color.RGBA{0x0, 0x0, 0x0, 0x80})
game.drawText(g, game.drawInfo.inputStr, 5, 5, color.White)
2013-12-08 15:03:00 +01:00
g.ResetOffscreen()
g.DrawRenderTarget(whole, matrix.IdentityGeometry(), matrix.IdentityColor())
wholeGeo := matrix.IdentityGeometry()
2013-12-08 15:49:48 +01:00
wholeGeo.Scale(0.5, 0.5)
wholeGeo.Translate(256/2, 240/2)
wholeColor := matrix.IdentityColor()
wholeColor.Scale(&color.RGBA{0x80, 0x80, 0x80, 0x80})
g.DrawRenderTarget(whole, wholeGeo, wholeColor)
2013-07-02 18:27:04 +02:00
}
2013-12-08 11:38:22 +01:00
func (game *Game) drawText(g graphics.Canvas, text string, x, y int, clr color.Color) {
2013-07-04 16:57:53 +02:00
const letterWidth = 6
const letterHeight = 16
parts := []graphics.TexturePart{}
textX := 0
textY := 0
for _, c := range text {
if c == '\n' {
textX = 0
textY += letterHeight
continue
}
code := int(c)
x := (code % 32) * letterWidth
y := (code / 32) * letterHeight
source := graphics.Rect{x, y, letterWidth, letterHeight}
parts = append(parts, graphics.TexturePart{
LocationX: textX,
LocationY: textY,
Source: source,
})
textX += letterWidth
}
geometryMatrix := matrix.IdentityGeometry()
geometryMatrix.Translate(float64(x), float64(y))
colorMatrix := matrix.IdentityColor()
2013-12-08 11:38:22 +01:00
colorMatrix.Scale(clr)
2013-12-08 09:02:35 +01:00
g.DrawTextureParts(game.drawInfo.textures["text"], parts,
2013-07-04 16:57:53 +02:00
geometryMatrix, colorMatrix)
2013-07-02 18:27:04 +02:00
}
2013-12-08 09:02:35 +01:00
func (game *Game) drawTexture(g graphics.Canvas, geo matrix.Geometry, color matrix.Color) {
g.DrawTexture(game.drawInfo.textures["ebiten"], geo, color)
}