Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

A whole new iteration of RallyMKA #42

Merged
merged 40 commits into from
May 14, 2023
Merged
Changes from all commits
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
3b2685a
WIP use new model format
mokiat Jun 26, 2022
9491f2c
Fix static entity transformations
mokiat Jun 27, 2022
6ab11b5
Switch to new unified game api
mokiat Jul 10, 2022
780aa8b
Align car construction to new API
mokiat Aug 29, 2022
01dbbb1
Align some stuff to 64bit
mokiat Aug 29, 2022
991e608
WIP: Use new game API
mokiat Sep 2, 2022
fd450d7
Align part of the code with new lacking API
mokiat Sep 6, 2022
6d14010
WIP changes
mokiat Mar 16, 2023
ebdabc2
Add loading widget
mokiat Mar 19, 2023
2bcaa4a
Change to new user interface
mokiat Mar 19, 2023
6c4caf8
Add licenses and credits
mokiat Mar 22, 2023
a9d157a
Rework home screen
mokiat Mar 29, 2023
9e23f14
Improve play screen
mokiat Mar 31, 2023
c7ea376
Add more user interface features
mokiat Apr 1, 2023
6ab3885
Make UI improvements
mokiat Apr 2, 2023
b2cee83
Handle different environments
mokiat Apr 3, 2023
98f8a3a
Add new app icon
mokiat Apr 8, 2023
8aeeca6
Support mouse and keyboard
mokiat Apr 8, 2023
59c1a49
Add mouse and keyboard images
mokiat Apr 8, 2023
4adf5ed
Add gamepad image
mokiat Apr 9, 2023
c007077
Rework credits
mokiat Apr 9, 2023
194e898
Reuse resource set
mokiat Apr 23, 2023
c4d744e
Enhance profiling tesks
mokiat Apr 23, 2023
e2586b1
Handle exit menu escape button
mokiat Apr 26, 2023
ff56701
Auto-focus licenses scroll
mokiat Apr 26, 2023
112a81f
Add new skybox images
mokiat Apr 29, 2023
362c86b
Attach lights to car
mokiat Apr 30, 2023
9a9774d
Prep web for itch
mokiat May 2, 2023
a43d9bc
Reduce collision corrections
mokiat May 2, 2023
4f09163
Adjustments to new vehicle model
mokiat May 6, 2023
e897412
Adjust for suspension model
mokiat May 7, 2023
8ea53ac
Add new suv model
mokiat May 8, 2023
5b1c72f
Add home screen model
mokiat May 8, 2023
09e8af9
Adjust light angle
mokiat May 8, 2023
b817b92
Bump dependencies
mokiat May 13, 2023
0a26720
Set to maximized
mokiat May 13, 2023
578233a
Add new forest level
mokiat May 13, 2023
9388ca5
Update license command
mokiat May 13, 2023
528c32b
Fix licenses
mokiat May 14, 2023
f80996b
Update README
mokiat May 14, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .github/workflows/go.yml
Original file line number Diff line number Diff line change
@@ -21,9 +21,9 @@ jobs:
uses: actions/checkout@v2

- name: Setup Go
uses: actions/setup-go@v2.1.3
uses: actions/setup-go@v3
with:
go-version: 1.18
go-version: 1.19

- name: Install Linux Packages
if: matrix.os == 'ubuntu-latest'
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -9,3 +9,6 @@

# Distribution
/dist

# Go
trace.out
38 changes: 6 additions & 32 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
# Rally MKA [![Go Report Card](https://goreportcard.com/badge/github.com/mokiat/rally-mka)](https://goreportcard.com/report/github.com/mokiat/rally-mka) [![Go Reference](https://pkg.go.dev/badge/github.com/mokiat/rally-mka@master.svg)](https://pkg.go.dev/github.com/mokiat/rally-mka@master)

Rally MKA is a really old game/demo of mine ported to Go for fun and as a way to experiment with new concepts.
Rally MKA is a really old game/demo of mine ported to Go for fun and as a way to experiment with new concepts. It is also a showcase for the [lacking](https://github.com/mokiat/lacking) game engine.

[![Game Screenshot](preview.png)](https://mokiat.itch.io/rally-mka)

[![Game Screenshot](preview.png)](http://mokiat.com/rally-mka/)

## User's Guide

### Browser

Use the following link to try the game in the browser:
http://mokiat.com/rally-mka/
You can play the game on [itch.io](https://mokiat.itch.io/rally-mka).

The preferred browser is [Chrome](https://www.google.com/chrome/), which at the time of writing appears to best support WebGL2, WebAssembly and Game Controllers.

@@ -19,27 +19,13 @@ Check the [Releases](https://github.com/mokiat/rally-mka/releases) section for r

The requirement is that your OS supports `OpenGL 4.6`.

### Controls

Use the following keyboard keys when playing:

- `Left Arrow` - Steer left
- `Right Arrow` - Steer right
- `Up Arrow` - Accelerate
- `Down Arrow` - Decelerate
- `a`, `s`, `d`, `w` - Rotate camera
- `q`, `e` - Zoom in/out camera
- `Enter` - Flip car

In addition, the game supports using a Game Controller.

## Developer's Guide

This section describes how to setup the project on your machine and compile it yourself.

### Prerequisites

- You need [Go 1.18](https://golang.org/dl/) or newer.
- You need [Go 1.20](https://golang.org/dl/) or newer.
- You need the [Git LFS](https://git-lfs.github.com/) plugin. As the project contains large images and models, this is the official way on how not to clog a repository.
- Follow the instructions on the [GLFW for Go](https://github.com/go-gl/glfw) repository and make sure you can run the [GLFW examples](https://github.com/go-gl/example) on your platform.
- Make sure you have [Task](https://taskfile.dev/) installed, as this project uses Taskfiles.
@@ -87,7 +73,7 @@ This section describes how to setup the project on your machine and compile it y
task wasm
```

1. Run HTTP server
1. Run an HTTP server

```sh
task web
@@ -104,15 +90,3 @@ All source code in this project is licensed under [Apache License v2](LICENSE).
### Assets

Assets (images, models, textures, etc.) are distributed under the [Creative Commons Attribution 4.0 International](http://creativecommons.org/licenses/by/4.0/) license.

## Special Thanks

The following projects and individuals have contributed significantly to the project:

- **[The Go Team](https://go.dev/)** for making Go programming language.
- **[GLFW for Go](https://github.com/go-gl/glfw)** for making it possible to use GLFW and OpenGL in Go.
- **[LearnOpenGL](https://learnopengl.com/)** for the amazing tutorials.
- **[Poly Haven](https://polyhaven.com/)** for the excellent free images.
- **[Erin Catto](https://github.com/erincatto)** for all the presentations and articles that were used as reference for the physics engine.
- **[Bo0mer](https://github.com/Bo0mer)** for the panoramic image that was used to generate the original `city` skybox images.
- And everyone else whose repository has been used as a dependency.
41 changes: 33 additions & 8 deletions Taskfile.yml
Original file line number Diff line number Diff line change
@@ -2,21 +2,25 @@ version: '3'

tasks:

licenses:
cmds:
- go run github.com/google/go-licenses@v1.6.0 report --template ./resources/licenses.tmpl ./cmd/rallymka ./cmd/rallypack | fold -w 80 -s > ./resources/licenses.txt

pack:
cmds:
- go run './cmd/rallypack'

webpack:
cmds:
- mkdir -p 'assets/web'
- cp 'resources/icon.png' 'assets/web/favicon.png'
- cp 'resources/ui/images/icon.png' 'assets/web/favicon.png'
- cp 'resources/web/main.css' 'assets/web/main.css'
- cp 'resources/web/main.js' 'assets/web/main.js'
- cp 'resources/web/index.html' 'assets/index.html'
- cp "$(go env GOROOT)/misc/wasm/wasm_exec.js" 'assets/web'

pack:
cmds:
- go run './cmd/rallypack'

assets:
deps: [webpack, pack]
deps: [pack, webpack]

run:
cmds:
@@ -31,8 +35,29 @@ tasks:
GOOS: js
GOARCH: wasm
cmds:
- go build -o './assets/web/main.wasm' './cmd/rallywasm'
- go build -o './assets/web/main.wasm' './cmd/rallymka'

web:
cmds:
- go run 'github.com/mokiat/httpserv@master' -dir './assets' -host '127.0.0.1'
- go run 'github.com/mokiat/httpserv@v1.0.0' -dir './assets' -host '127.0.0.1'

profile-cpu:
cmds:
- go tool pprof 'http://localhost:6060/debug/pprof/profile?seconds=30'

profile-alloc:
cmds:
- go tool pprof 'http://localhost:6060/debug/pprof/allocs?seconds=30'

profile-heap:
cmds:
- go tool pprof 'http://localhost:6060/debug/pprof/heap?seconds=30'

profile-snap:
cmds:
- go tool pprof 'http://localhost:6060/debug/pprof/heap'

trace:
cmds:
- curl -o trace.out 'http://localhost:6060/debug/pprof/trace?seconds=30'
- go tool trace trace.out
43 changes: 43 additions & 0 deletions cmd/rallymka/app_cgo.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
//go:build !js

package main

import (
"fmt"

glapp "github.com/mokiat/lacking-gl/app"
glgame "github.com/mokiat/lacking-gl/game"
glrender "github.com/mokiat/lacking-gl/render"
glui "github.com/mokiat/lacking-gl/ui"
"github.com/mokiat/lacking/app"
"github.com/mokiat/lacking/game"
"github.com/mokiat/lacking/game/asset"
"github.com/mokiat/lacking/ui"
"github.com/mokiat/lacking/ui/mat"
"github.com/mokiat/lacking/util/resource"
gameui "github.com/mokiat/rally-mka/internal/ui"
)

func runApplication() error {
registry, err := asset.NewDirRegistry(".")
if err != nil {
return fmt.Errorf("failed to initialize registry: %w", err)
}

renderAPI := glrender.NewAPI()
gameController := game.NewController(registry, renderAPI, glgame.NewShaderCollection())
resourceLocator := mat.WrappedResourceLocator(resource.NewFileLocator("./resources"))
uiCfg := ui.NewConfig(resourceLocator, renderAPI, glui.NewShaderCollection())
uiController := ui.NewController(uiCfg, func(w *ui.Window) {
gameui.BootstrapApplication(w, gameController)
})

cfg := glapp.NewConfig("Rally MKA", 1024, 576)
cfg.SetFullscreen(true)
cfg.SetMaximized(false)
cfg.SetMinSize(1024, 576)
cfg.SetVSync(true)
cfg.SetIcon("resources/ui/images/icon.png")
cfg.SetMaximized(true)
return glapp.Run(cfg, app.NewLayeredController(gameController, uiController))
}
27 changes: 5 additions & 22 deletions cmd/rallywasm/main.go → cmd/rallymka/app_js.go
Original file line number Diff line number Diff line change
@@ -1,56 +1,39 @@
//go:build js && wasm
//go:build js

package main

import (
"fmt"
"os"

jsapp "github.com/mokiat/lacking-js/app"
jsgame "github.com/mokiat/lacking-js/game"
jsrender "github.com/mokiat/lacking-js/render"
jsui "github.com/mokiat/lacking-js/ui"
"github.com/mokiat/lacking/app"
"github.com/mokiat/lacking/game"
"github.com/mokiat/lacking/game/asset"
"github.com/mokiat/lacking/game/graphics"
"github.com/mokiat/lacking/log"
"github.com/mokiat/lacking/ui"
"github.com/mokiat/lacking/ui/mat"
"github.com/mokiat/lacking/util/resource"
"github.com/mokiat/rally-mka/internal/game"
gameui "github.com/mokiat/rally-mka/internal/ui"
"github.com/mokiat/rally-mka/resources"
)

func main() {
log.Info("Started")
if err := runApplication(); err != nil {
log.Error("Crashed: %v", err)
os.Exit(1)
}
log.Info("Stopped")
}

func runApplication() error {
registry, err := asset.NewWebRegistry(".")
if err != nil {
return fmt.Errorf("failed to initialize registry: %w", err)
}
resourceLocator := mat.WrappedResourceLocator(resource.NewFSLocator(resources.UI))
renderAPI := jsrender.NewAPI()
graphicsEngine := graphics.NewEngine(renderAPI, jsgame.NewShaderCollection())
gameController := game.NewController(registry, graphicsEngine)
gameController := game.NewController(registry, renderAPI, jsgame.NewShaderCollection())
uiCfg := ui.NewConfig(resourceLocator, renderAPI, jsui.NewShaderCollection())
uiController := ui.NewController(uiCfg, func(w *ui.Window) {
gameui.BootstrapApplication(w, gameController)
})

cfg := jsapp.NewConfig("screen")
cfg.AddGLExtension("EXT_color_buffer_float")

controller := app.NewLayeredController(
gameController,
uiController,
)
return jsapp.Run(cfg, controller)
cfg.SetFullscreen(false)
return jsapp.Run(cfg, app.NewLayeredController(gameController, uiController))
}
39 changes: 0 additions & 39 deletions cmd/rallymka/main.go
Original file line number Diff line number Diff line change
@@ -1,22 +1,9 @@
package main

import (
"fmt"
"os"

glapp "github.com/mokiat/lacking-gl/app"
glgame "github.com/mokiat/lacking-gl/game"
glrender "github.com/mokiat/lacking-gl/render"
glui "github.com/mokiat/lacking-gl/ui"
"github.com/mokiat/lacking/app"
"github.com/mokiat/lacking/game/asset"
"github.com/mokiat/lacking/game/graphics"
"github.com/mokiat/lacking/log"
"github.com/mokiat/lacking/ui"
"github.com/mokiat/lacking/ui/mat"
"github.com/mokiat/lacking/util/resource"
"github.com/mokiat/rally-mka/internal/game"
gameui "github.com/mokiat/rally-mka/internal/ui"
)

func main() {
@@ -27,29 +14,3 @@ func main() {
}
log.Info("Stopped")
}

func runApplication() error {
cfg := glapp.NewConfig("Rally MKA", 1024, 576)
cfg.SetVSync(true)
cfg.SetIcon("resources/icon.png")

registry, err := asset.NewDirRegistry(".")
if err != nil {
return fmt.Errorf("failed to initialize registry: %w", err)
}

renderAPI := glrender.NewAPI()
graphicsEngine := graphics.NewEngine(renderAPI, glgame.NewShaderCollection())
gameController := game.NewController(registry, graphicsEngine)
resourceLocator := mat.WrappedResourceLocator(resource.NewFileLocator("./resources"))
uiCfg := ui.NewConfig(resourceLocator, renderAPI, glui.NewShaderCollection())
uiController := ui.NewController(uiCfg, func(w *ui.Window) {
gameui.BootstrapApplication(w, gameController)
})

controller := app.NewLayeredController(
gameController,
uiController,
)
return glapp.Run(cfg, controller)
}
Loading