aboutsummaryrefslogtreecommitdiff
path: root/go/client
diff options
context:
space:
mode:
authorFlorian Fischer <florian.fischer@muhq.space>2025-06-06 16:42:46 -0500
committerFlorian Fischer <florian.fischer@muhq.space>2025-08-20 15:57:18 +0200
commitbcffeac4c5086eba59448d4fe5d79bb786b05de2 (patch)
treecc0b3648f2b070c731225e88b42fb3f4adcb65da /go/client
parentc15142c3bcae4316c8580adb7a9f0b223e586ae9 (diff)
downloadmuhqs-game-bcffeac4c5086eba59448d4fe5d79bb786b05de2.tar.gz
muhqs-game-bcffeac4c5086eba59448d4fe5d79bb786b05de2.zip
refactor client activities
Make the activity stack explicit and move reusable activities to the activity package.
Diffstat (limited to 'go/client')
-rw-r--r--go/client/draft.go199
-rw-r--r--go/client/main.go17
-rw-r--r--go/client/sealed.go138
-rw-r--r--go/client/startMenu.go40
4 files changed, 32 insertions, 362 deletions
diff --git a/go/client/draft.go b/go/client/draft.go
deleted file mode 100644
index 3950094f..00000000
--- a/go/client/draft.go
+++ /dev/null
@@ -1,199 +0,0 @@
-package main
-
-import (
- "log"
-
- "github.com/hajimehoshi/ebiten/v2"
- "github.com/hajimehoshi/ebiten/v2/inpututil"
-
- "muhq.space/muhqs-game/go/game"
- "muhq.space/muhqs-game/go/ui"
-)
-
-type Draft struct {
- ui.Collection
- app *app
- player *game.Player
- ctrl *game.ChanPlayerControl
- draft *game.Draft
-
- setInput *ui.TextInput
- descInput *ui.TextInput
- deckList *ui.PocList
-}
-
-func NewDraft(width, height int, app *app) *Draft {
- d := &Draft{
- app: app,
- Collection: ui.Collection{Width: width, Height: height},
- }
-
- d.AddWidget(ui.NewFixedTextBox(
- (d.Width-START_BUTTON_WIDTH)/2-START_BUTTON_WIDTH,
- (d.Height-START_BUTTON_HEIGHT)/2-3*START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "sets:",
- ).Centering(true))
-
- d.setInput = ui.NewTextInput(
- (d.Width-START_BUTTON_WIDTH)/2,
- (d.Height-START_BUTTON_HEIGHT)/2-3*START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "base,magic,equipments",
- )
- d.AddWidget(d.setInput)
-
- d.AddWidget(ui.NewFixedTextBox(
- (d.Width-START_BUTTON_WIDTH)/2-START_BUTTON_WIDTH,
- (d.Height-START_BUTTON_HEIGHT)/2-2*START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "draft:",
- ).Centering(true))
-
- d.descInput = ui.NewTextInput(
- (d.Width-START_BUTTON_WIDTH)/2,
- (d.Height-START_BUTTON_HEIGHT)/2-2*START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "3x[2;8]",
- )
- d.AddWidget(d.descInput)
-
- d.AddWidget(ui.NewFixedTextBox(
- (d.Width-START_BUTTON_WIDTH)/2-START_BUTTON_WIDTH,
- (d.Height-START_BUTTON_HEIGHT)/2-START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "AI:",
- ).Centering(true))
-
- aiNInput := ui.NewNumberChoice(
- (d.Width-START_BUTTON_WIDTH)/2,
- (d.Height-START_BUTTON_HEIGHT)/2-START_BUTTON_HEIGHT,
- 1,
- nil,
- )
- d.AddWidget(aiNInput)
-
- d.AddWidget(ui.NewSimpleButton(
- (d.Width-START_BUTTON_WIDTH)/2,
- (d.Height-START_BUTTON_HEIGHT)/2,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "Start",
- func(*ui.SimpleButton) {
- d.startDraft(d.descInput.TextOrLabel(), d.setInput.TextOrLabel(), aiNInput.GetChoosen())
- }))
-
- startMenu := d.app.activities[len(d.app.activities)-1].(*StartMenu)
- d.player = game.NewDraftPlayer(startMenu.playerName)
- d.ctrl = game.NewChanPlayerControl(d.player)
- d.player.Ctrl = d.ctrl
-
- return d
-}
-
-func (d *Draft) Update() error {
- if n := d.ctrl.RecvNotification(); n != nil {
- log.Println("Received draft pick: %v\n", n)
- d.presentPack(n)
- }
-
- if err := ui.TouchManager.Update(); err != nil {
- return err
- }
-
- if err := d.Collection.Update(); err != nil {
- return err
- }
-
- if inpututil.IsKeyJustPressed(ebiten.KeyEscape) {
- d.app.popActivity()
- }
-
- return nil
-}
-
-func (d *Draft) presentPack(n *game.PlayerNotification) {
- pack := n.Context.(game.PileOfCards)
- grid := ui.NewCardGrid(0, 0, d.Width-SEALED_DECK_STRIP_WIDTH, d.Height, 0.5, pack).Columns(3)
- selectCard := func(x, y int) {
- _card := grid.FindObjectAt(x, y)
- if _card == nil {
- return
- }
-
- card := _card.(*game.Card)
- d.RemoveWidget(grid)
- d.ctrl.SendAction(game.NewDraftPick(d.player, pack, card))
- }
- grid.RegisterHandler("click", selectCard)
- d.AddWidget(grid)
-}
-
-func (d *Draft) Layout(width, height int) (int, int) {
- return d.Width, d.Height
-}
-
-func (d *Draft) startDraft(desc string, setList string, aiN int) {
-
- log.Printf("starting %s draft from '%s'\n", desc, setList)
-
- var sets []game.SetIdentifier
- var err error
- if sets, err = game.SetListToSets(setList); err != nil {
- d.setInput.Bg(ui.WarningBg)
- d.setInput.SetInput("")
- return
- }
-
- d.draft = game.NewDraft([]*game.Player{d.player}, desc, sets)
-
- log.Println(aiN)
- for _ = range aiN {
- log.Println("add ai")
- d.draft.AddRandomAi()
- }
-
- if !d.draft.Valid() {
- d.descInput.Bg(ui.WarningBg)
- d.descInput.SetInput("")
- return
- }
- d.Clear()
-
- d.deckList = ui.NewPocList(d.Width-SEALED_DECK_STRIP_WIDTH/2, d.Height-START_BUTTON_HEIGHT-20, d.player.Deck)
- d.deckList.Bg(ui.Gray)
- {
- cardsInDeck := 0
- d.deckList.RegisterHandler("update", func() error {
- if n := d.player.Deck.Size(); n > cardsInDeck {
- d.deckList.ForceRedraw()
- cardsInDeck = n
- }
- return nil
- })
- }
- d.AddWidget(d.deckList)
-
- d.AddWidget(ui.NewSimpleButton(
- d.Width-SEALED_DECK_STRIP_WIDTH/2-START_BUTTON_WIDTH/2,
- d.Height-START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "Done",
- func(*ui.SimpleButton) {
- d.done()
- }))
-
- go d.draft.Run()
-}
-
-func (d *Draft) done() {
- startMenu := d.app.activities[len(d.app.activities)-2].(*StartMenu)
- startMenu.deckInput.SetInput(d.player.Deck.ToList())
- d.app.popActivity()
-}
diff --git a/go/client/main.go b/go/client/main.go
index 4d46ed9a..b631269e 100644
--- a/go/client/main.go
+++ b/go/client/main.go
@@ -8,6 +8,7 @@ import (
"github.com/hajimehoshi/ebiten/v2"
+ "muhq.space/muhqs-game/go/activities"
"muhq.space/muhqs-game/go/font"
)
@@ -21,24 +22,14 @@ var startDeckPath string
type app struct {
windowWidth int
windowHeight int
-
- activities []ebiten.Game
-}
-
-func (a *app) pushActivity(activity ebiten.Game) {
- a.activities = append(a.activities, activity)
-}
-
-func (a *app) popActivity() {
- a.activities = a.activities[:len(a.activities)-1]
}
func (a *app) Update() error {
- return a.activities[len(a.activities)-1].Update()
+ return activities.CurActivity().Update()
}
func (a *app) Draw(screen *ebiten.Image) {
- a.activities[len(a.activities)-1].Draw(screen)
+ activities.CurActivity().Draw(screen)
}
func (a *app) Layout(outsideWidth, outsideHeight int) (int, int) {
@@ -86,7 +77,7 @@ func main() {
1 nautics/galley`
}
- app.pushActivity(startMenu)
+ activities.PushActivity(startMenu)
if err := ebiten.RunGame(app); err != nil {
if err != ebiten.Termination {
log.Fatal(err)
diff --git a/go/client/sealed.go b/go/client/sealed.go
deleted file mode 100644
index efe1006e..00000000
--- a/go/client/sealed.go
+++ /dev/null
@@ -1,138 +0,0 @@
-package main
-
-import (
- "github.com/hajimehoshi/ebiten/v2"
- "github.com/hajimehoshi/ebiten/v2/inpututil"
-
- "muhq.space/muhqs-game/go/game"
- "muhq.space/muhqs-game/go/ui"
-)
-
-const (
- SEALED_DECK_STRIP_WIDTH = 200
-)
-
-type sealed struct {
- ui.Collection
- app *app
-
- setInput *ui.TextInput
-
- pool game.PileOfCards
- deck game.PileOfCards
-}
-
-func NewSealed(width, height int, app *app) *sealed {
- s := &sealed{
- app: app,
- Collection: ui.Collection{Width: width, Height: height},
- }
-
- s.AddWidget(ui.NewFixedTextBox(
- (s.Width-START_BUTTON_WIDTH)/2-START_BUTTON_WIDTH,
- (s.Height-START_BUTTON_HEIGHT)/2-START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "sets:",
- ).Centering(true))
-
- s.setInput = ui.NewTextInput(
- (s.Width-START_BUTTON_WIDTH)/2,
- (s.Height-START_BUTTON_HEIGHT)/2-START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "base,equipments,magic",
- )
- s.AddWidget(s.setInput)
-
- s.AddWidget(ui.NewSimpleButton(
- (s.Width-START_BUTTON_WIDTH)/2,
- (s.Height-START_BUTTON_HEIGHT)/2,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "Start",
- func(*ui.SimpleButton) {
- s.startSealed(s.setInput.TextOrLabel())
- }))
-
- return s
-}
-
-func (s *sealed) Update() error {
- if err := ui.TouchManager.Update(); err != nil {
- return err
- }
-
- if err := s.Collection.Update(); err != nil {
- return err
- }
-
- if inpututil.IsKeyJustPressed(ebiten.KeyEscape) {
- s.app.popActivity()
- }
-
- return nil
-}
-
-func (s *sealed) Layout(width, height int) (int, int) {
- return s.Width, s.Height
-}
-
-func (s *sealed) startSealed(setList string) {
- sets, err := game.SetListToSets(setList)
- if err != nil {
- s.setInput.Bg(ui.WarningBg)
- s.setInput.SetInput("")
- return
- }
-
- s.pool = game.NewPileOfCards()
- s.deck = game.NewPileOfCards()
-
- s.Clear()
-
- for _, set := range sets {
- setDeck := game.NewDeck()
- for _, c := range game.NewDeckFromCardPaths(set.CardPaths()).Cards() {
- if c.IsBuyable() {
- setDeck.AddCard(c)
- }
- }
- setDeck.MoveInto(s.pool)
- }
-
- deckList := ui.NewPocList(s.Width-SEALED_DECK_STRIP_WIDTH/2, s.Height-START_BUTTON_HEIGHT-20, s.deck)
- deckList.Bg(ui.Gray)
- s.AddWidget(deckList)
-
- grid := ui.NewCardGrid(0, 0, s.Width-SEALED_DECK_STRIP_WIDTH, s.Height, 0.5, s.pool).Columns(3)
- selectCard := func(x, y int) {
- _card := grid.FindObjectAt(x, y)
- if _card == nil {
- return
- }
-
- card := _card.(*game.Card)
- s.pool.MoveCard(card, s.deck)
- grid.ForceRedraw()
- deckList.ForceRedraw()
- }
- grid.RegisterHandler("click", selectCard)
- s.AddWidget(grid)
-
- s.AddWidget(ui.NewSimpleButton(
- s.Width-SEALED_DECK_STRIP_WIDTH/2-START_BUTTON_WIDTH/2,
- s.Height-START_BUTTON_HEIGHT,
- START_BUTTON_WIDTH,
- START_BUTTON_HEIGHT,
- "Done",
- func(*ui.SimpleButton) {
- s.done()
- }))
-}
-
-func (s *sealed) done() {
- startMenu := s.app.activities[len(s.app.activities)-2].(*StartMenu)
- startMenu.deckInput.SetInput(s.deck.ToList())
- s.app.popActivity()
-}
diff --git a/go/client/startMenu.go b/go/client/startMenu.go
index 10fa8e1f..10b9e23d 100644
--- a/go/client/startMenu.go
+++ b/go/client/startMenu.go
@@ -3,6 +3,7 @@ package main
import (
"log"
+ "muhq.space/muhqs-game/go/activities"
"muhq.space/muhqs-game/go/game"
"muhq.space/muhqs-game/go/ui"
)
@@ -15,25 +16,28 @@ const (
DECK_LIST_HEIGHT = 500
)
-type StartMenu struct {
+type startMenu struct {
ui.Collection
app *app
deckInput *ui.TextInput
+ draft *activities.Draft
+ sealed *activities.Sealed
+
playerName string
startDeck string
remote string
mapPath string
}
-func NewStartMenu(app *app) *StartMenu {
- m := &StartMenu{app: app}
+func NewStartMenu(app *app) *startMenu {
+ m := &startMenu{app: app}
return m
}
-func (m *StartMenu) build() {
+func (m *startMenu) build() {
deckInput := ui.NewTextInput(
(m.Width-DECK_LIST_WIDTH)/2,
(m.Height-DECK_LIST_HEIGHT)/2,
@@ -101,8 +105,8 @@ func (m *StartMenu) build() {
START_BUTTON_HEIGHT,
"Sealed",
func(*ui.SimpleButton) {
- sealed := NewSealed(m.Width, m.Height, m.app)
- m.app.pushActivity(sealed)
+ sealed := activities.NewSealed(m.Width, m.Height)
+ activities.PushActivity(sealed)
}))
m.AddWidget(ui.NewSimpleButton(
@@ -112,8 +116,8 @@ func (m *StartMenu) build() {
START_BUTTON_HEIGHT,
"Draft",
func(*ui.SimpleButton) {
- draft := NewDraft(m.Width, m.Height, m.app)
- m.app.pushActivity(draft)
+ m.draft = activities.NewDraft(m.Width, m.Height, playerInput.Text())
+ activities.PushActivity(m.draft)
}))
m.AddWidget(ui.NewSimpleButton(
@@ -130,11 +134,23 @@ func (m *StartMenu) build() {
}))
}
-func (m *StartMenu) Update() error {
+func (m *startMenu) Update() error {
if m.Widgets() == nil {
m.build()
}
+ // Get the drafted deck
+ if m.draft != nil {
+ m.deckInput.SetInput(m.draft.GetDeckList())
+ m.draft = nil
+ }
+
+ // Get the sealed deck
+ if m.sealed != nil {
+ m.deckInput.SetInput(m.sealed.Deck.ToList())
+ m.sealed = nil
+ }
+
if err := ui.TouchManager.Update(); err != nil {
return err
}
@@ -142,11 +158,11 @@ func (m *StartMenu) Update() error {
return m.Collection.Update()
}
-func (m *StartMenu) Layout(width, height int) (int, int) {
+func (m *startMenu) Layout(width, height int) (int, int) {
return m.Width, m.Height
}
-func (m *StartMenu) startGame() {
+func (m *startMenu) startGame() {
var state game.State
if m.remote != "" {
log.Fatal("Remote games are currently not implemented")
@@ -162,5 +178,5 @@ func (m *StartMenu) startGame() {
g.gameState.AddNewAiPlayer("kraken", color)
}
- m.app.pushActivity(g.Start())
+ activities.PushActivity(g.Start())
}