GarageEngine alternatives and similar packages
Based on the "Game Development" category.
Alternatively, view GarageEngine alternatives based on common mentions on social networks and blogs.
-
Pitaya
Scalable game server framework with clustering support and client libraries for iOS, Android, Unity and others through the C SDK. -
tile
Tile is a 2D grid engine, built with data and cache friendly ways, includes pathfinding and observers.
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of GarageEngine or a related project?
README
GarageEngine
This is a 2d game engine written in Go working on OpenGL. Its an Entity/Component based engine and right now contains lots of features such as: Font,Sprites,Texture packing,Physics,Depth layers,Scenes and more. It feels like Unity3d and share the same names: Scene,Coroutines,Components,Transform,GameObjects etc...
This is an educational project, I'm learning as I go, I cannot promise backwards compatibility at this point. the name will be probably changed.
Install:
You need to download glfw&glew libraries.
Windows: Use mingw and compile glew.
Linux:
sudo apt-get update
sudo apt-get install build-essential binutils-gold freeglut3 freeglut3-dev libglew-dev libglfw-dev libxrandr2 libxrandr-dev libglew libglew1.8
go get github.com/vova616/GarageEngine
To-Do list
Clean project: Name changing Engine -> engine etc... Function changing -> SetWorldPositionf -> SetWorldPosition2d etc... Atlas,Font - Clean whatever we can. Material - Think of design that does not require lots of work when creating custom shaders. Physics - Think of a better design for arbiter and clean & polish stuff. Scene - Get scene by name. Tree Behaviours - Clean & polish & new features. Camera - support multiple cameras. Rendering - support auto-batching. Coroutine - try to fix the bug that you cannot access to textures in Coroutines. Readme - explain Tree Behaviours. Learn from - https://github.com/runningwild/haunts . Comments - lacks tons of it.
Dependencies
github.com/go-gl/gl github.com/go-gl/glfw github.com/vova616/chipmunk "github.com/vova616/freetype-go/freetype"
Coroutines(they might be deprecated):
The useage is same as unity coroutines. Use Behaviour Trees, its better and faster.
Behaviour Trees:
Example in SpaceCookies/game/EnemeyAI.go
SpaceCookies
Mini game to test the engine, it will host server on port 123 then you connect to it. Make sure your executable file is in the same folder with the data folder.
Videos:
http://www.youtube.com/watch?v=iMMbf6SRb9Q http://www.youtube.com/watch?v=BMRlY9dFVLg
Coroutines Example:
func (sp *PlayerController) Start() {
as := StartCoroutine(func() { sp.AutoShoot() })
StartCoroutine(func() {
cr.Sleep(3)
cr.YieldCoroutine(as) //wait for as to finish
for i := 0; i < 10; i++ {
cr.Skip()
cr.Skip()
cr.Skip()
sp.Shoot()
}
})
}
func (sp *PlayerController) AutoShoot() {
for i := 0; i < 3; i++ {
cr.Sleep(3)
sp.Shoot()
}
}
func (sp *PlayerController) AutoShoot2() {
for i := 0; i < 3; i++ {
for i:=0;i<3*60;i++ {
cr.Skip() //Frame skip
}
sp.Shoot()
}
}
func (sp *PlayerController) AutoShoot3() {
for i := 0; i < 3; i++ {
done := make(chan bool)
go func() {
<-time.After(time.Second * 3)
done <- true
}()
cr.YieldUntil(done)
sp.Shoot()
}
}