Ebiten
tengo
Ebiten | tengo | |
---|---|---|
54 | 5 | |
9,889 | 3,454 | |
- | - | |
9.8 | 5.4 | |
2 days ago | 9 days ago | |
Go | Go | |
Apache License 2.0 | MIT License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Ebiten
-
Lag Is Never Where You Want It... Or Don't Want It
Reading ebiten docs and source code they very clearly state that writing RGBA bytes to an image is slow, and shouldn't really be done every frame, at least many times per frame. This is where I thought my performance was being lost, and it sent me looking for answers for ages. Turns out, I was wrong and right.
-
Making Games in Go for Absolute Beginners
I love Go, yet I've never thought of it as a language with usable game engines. I'm extremely happy to find I was very wrong about that!
I'm woefully behind the curve on compiling to WASM, though, and I've yet to experiment much with tinygo so I have no idea how far I would get in creating a game people could enjoy in a browser without having to download a big bundle of assets. It's reassuring to see WASM mentioned explicitly as a compilation target [1] by Ebitengine though.
[1] https://github.com/hajimehoshi/ebiten
-
Ho did/do you remove cgo?
For other OSes, see https://github.com/hajimehoshi/ebiten/issues/1162
-
Is there a love2d for c++?
What about learning Go with Ebiten? Or Rust with Bevy?
-
What would be the closest thing to Unity/Unreal C#/C++ for Go to create games/animations/visual work?
Actually, there is a game engine in Go. Ebiten(gine) is actually really popular and has already been used for a few games in production
-
How complex/big can I make games in Go?
Check out this thread, some of the linked repositories might be of help. https://github.com/hajimehoshi/ebiten/discussions/1527
-
Spaceshooter in Go
// consider having a laser type to deal with orientation, etc // basic information to draw sprites, track position and update position type Body struct { // positions x float64 y float64 // velocities vx float64 vy float64 // get height and width from sheet.xml using sp width int height int } type Enemy struct { Body sp int health int } type Laser struct { Body sp int } type Mode int const ( ModeTitle Mode = iota ModeGame ModeGameOver ) var ( arcadeFont font.Face smallArcadeFont font.Face ) // fonts and sizes func init() { tt, err := truetype.Parse(fonts.ArcadeN_ttf) if err != nil { log.Fatal(err) } const dpi = 72 arcadeFont = truetype.NewFace(tt, &truetype.Options{ Size: fontSize, DPI: dpi, Hinting: font.HintingFull, }) smallArcadeFont = truetype.NewFace(tt, &truetype.Options{ Size: smallFontSize, DPI: dpi, Hinting: font.HintingFull, }) } // in the future have a laser type struct, spriteImgNum, and number of animations type Game struct { mode Mode level int // tracks location of player and maybe health Player struct { Body health int laserType int canShoot bool sp int // consider adding in height and width of player object // all of the sprites seem to be the same // TODO set global width } PLasers []*Laser Enemies []*Enemy ELasers []*Laser gameoverCount int } // load images func init() { // sprites img, _, err := image.Decode(bytes.NewReader(resources.Sprites_png)) if err != nil { log.Fatal(err) } gameImages, _ = ebiten.NewImageFromImage(img, ebiten.FilterDefault) // backgrounds img, _, err = image.Decode(bytes.NewReader(resources.Starfieldreal_jpg)) if err != nil { log.Fatal(err) } bgImage, _ = ebiten.NewImageFromImage(img, ebiten.FilterDefault) } // background image logic from // # https://github.com/hajimehoshi/ebiten/blob/master/examples/infinitescroll/main.go var ( theViewport = &viewport{} ) type viewport struct { x16 int y16 int } func (p *viewport) Move() { w, h := bgImage.Size() maxX16 := w * 16 maxY16 := h * 16 p.x16 += w / 32 p.y16 += h / 32 p.x16 %= maxX16 p.y16 %= maxY16 }
-
Mac + opengl
I noticed a similar issue when I got my MBP with the framebuffer not matching the window size and this has to do with the DPI settings. This GitHub link helped me understand the issue better and I hope it can be of assistance to you https://github.com/hajimehoshi/ebiten/pull/1811
-
crten - a small tool to view your pixel art with a CRT screen effect
This program also demonstrates how great Ebitengine is and how you can port GLSL shaders to it almost 1 to 1.
-
Sharing Saturday #439
Basic gist: built in Go with ebitengine, medieval fantasy, pixel art
tengo
-
Making Games in Go for Absolute Beginners
> It also has a bunch of libraries for embedding scripting languages https://awesome-go.com/embeddable-scripting-languages, with Tengo _probably_ being the quickest https://github.com/d5/tengo
Yes, I noticed those packages recently. The problem is that there is little data about how reliable and maintainable goloader is going to be on the long term.
As I care about performance and security, I don't want a scripting language, but WASM seems to be a very promising possibility. I have made benchmarks with 2~3 WASM engines in Go, and so far I am not completely convinced about the quality and performance of the available APIs. Also, when compiling Golang to WASM, the native compiler is still abysmally bad and does not have full support for imports, so Tinygo is a must-have.
Anyway, modding is still a long term idea at this point, so hopefully the ecosystem will get more mature within a couple of years.
-
Looking for programming languages created with Go
- https://github.com/d5/tengo
-
Change go code behaviour at runtime
There are totally different things like https://github.com/d5/tengo but I don't know much about the docs, communities, or viability of them. Some like this one look very active and healthy. It might be worth considering.
-
Asking for advice to get deeper understanding of golang internals.
I started doing this a few years ago when I wanted to add programmability to another system I was working on, and didn't want Lua or anything else like that. I set it aside when other priorities arose, and didn't return to it when I saw that others had already done the same thing (yaegi, tengo).
What are some alternatives?
Pixel - A hand-crafted 2D game library in Go
otto - A JavaScript interpreter in Go (golang)
raylib-go - Go bindings for raylib, a simple and easy-to-use library to enjoy videogames programming.
gopher-lua - GopherLua: VM and compiler for Lua in Go
go-sdl2 - SDL2 binding for Go
goja - ECMAScript/JavaScript engine in pure Go
engo - Engo is an open-source 2D game engine written in Go.
expr - Expression language and expression evaluation for Go [Moved to: https://github.com/expr-lang/expr]
resolv - A Simple 2D Golang collision detection and resolution library for games
go-php - PHP bindings for the Go programming language (Golang)
Oak - A pure Go game engine
go-lua - A Lua VM in Go