entity layer

This commit is contained in:
2023-07-04 22:58:23 +02:00
parent 93b2725c8a
commit e9c35f01ab
19 changed files with 364 additions and 353 deletions

View File

@@ -1,22 +1,22 @@
package domain
import (
"game/konstructor"
"game/konstructor/entity"
"image/color"
)
func (d *Domain) InitDialog() {
d.DialogMap = konstructor.DialogMap{
d.DialogMap = entity.DialogMap{
"TestDialog": {
Layout: konstructor.DialogLayout{
ChoiceFont: konstructor.FontLayout{
Layout: entity.DialogLayout{
ChoiceFont: entity.FontLayout{
DPI: 72,
Size: 24,
Color: color.White,
SelectedColor: color.RGBA{R: 0, G: 255, B: 0, A: 100},
},
},
Choices: []konstructor.DialogChoice{
Choices: []entity.DialogChoice{
{
ID: "one",
Label: "One",
@@ -30,11 +30,11 @@ func (d *Domain) InitDialog() {
}
}
func (d *Domain) GetDialog(name string) konstructor.Dialog {
func (d *Domain) GetDialog(name string) entity.Dialog {
value, _ := d.DialogMap[name]
return value
}
func (d *Domain) SetDialog(name string, dialog konstructor.Dialog) {
func (d *Domain) SetDialog(name string, dialog entity.Dialog) {
d.DialogMap[name] = dialog
}

View File

@@ -1,14 +1,14 @@
package domain
import (
"game/konstructor"
"game/konstructor/entity"
)
type Domain struct {
Context Context
MenuMap konstructor.MenuMap
DialogMap konstructor.DialogMap
Levels []konstructor.Level
MenuMap entity.MenuMap
DialogMap entity.DialogMap
Levels []entity.Level
}
func (d *Domain) Init() {

View File

@@ -1,28 +1,26 @@
package domain
import (
"game/konstructor"
)
import "game/konstructor/entity"
func (d *Domain) InitLevel() {
d.Levels = []konstructor.Level{
d.Levels = []entity.Level{
{
ID: "level_1",
Name: "Level I.",
Playgrounds: []konstructor.Playground{
Playgrounds: []entity.Playground{
{
Background: "level_1_playground_1.png",
Objects: []konstructor.Object{
Objects: []entity.Object{
{
ID: "test_object",
Position: konstructor.Position{
Position: entity.Position{
X: 10,
Y: 10,
Z: 0,
},
Type: konstructor.ObjectType{
Type: entity.ObjectType{
ID: "test_object_type",
RenderOptions: konstructor.RenderOptions{
RenderOptions: entity.RenderOptions{
Image: "test_object.png",
Width: 30,
Height: 30,
@@ -36,6 +34,6 @@ func (d *Domain) InitLevel() {
}
}
func (d *Domain) GetLevel(index int) konstructor.Level {
func (d *Domain) GetLevel(index int) entity.Level {
return d.Levels[index]
}

View File

@@ -2,24 +2,24 @@ package domain
import (
"fmt"
"game/konstructor"
"game/konstructor/entity"
"image/color"
"os"
)
func (d *Domain) InitMenu() {
d.MenuMap = konstructor.MenuMap{
d.MenuMap = entity.MenuMap{
"MainMenu": {
CurrentSelected: 0,
Layout: konstructor.MenuLayout{
MenuItemFont: konstructor.FontLayout{
Layout: entity.MenuLayout{
MenuItemFont: entity.FontLayout{
DPI: 72,
Size: 24,
Color: color.White,
SelectedColor: color.RGBA{R: 0, G: 255, B: 0, A: 100},
},
},
MenuItems: []konstructor.MenuItem{
MenuItems: []entity.MenuItem{
{
ID: "start",
Label: "Start Game",
@@ -39,15 +39,15 @@ func (d *Domain) InitMenu() {
},
"GameMenu": {
CurrentSelected: 0,
Layout: konstructor.MenuLayout{
MenuItemFont: konstructor.FontLayout{
Layout: entity.MenuLayout{
MenuItemFont: entity.FontLayout{
DPI: 72,
Size: 24,
Color: color.White,
SelectedColor: color.RGBA{R: 0, G: 255, B: 0, A: 100},
},
},
MenuItems: []konstructor.MenuItem{
MenuItems: []entity.MenuItem{
{
ID: "save",
Label: "Save Game",
@@ -63,12 +63,12 @@ func (d *Domain) InitMenu() {
}
}
func (d *Domain) GetMenu(name string) konstructor.Menu {
func (d *Domain) GetMenu(name string) entity.Menu {
value, _ := d.MenuMap[name]
return value
}
func (d *Domain) SetMenu(name string, menu konstructor.Menu) {
func (d *Domain) SetMenu(name string, menu entity.Menu) {
d.MenuMap[name] = menu
}

View File

@@ -0,0 +1,14 @@
package entity
import "github.com/hajimehoshi/ebiten"
type KeyMap struct {
Up ebiten.Key
Down ebiten.Key
Right ebiten.Key
Left ebiten.Key
Action0 ebiten.Key
Action1 ebiten.Key
Action2 ebiten.Key
Action3 ebiten.Key
}

View File

@@ -0,0 +1,30 @@
package entity
import "image/color"
type DialogMap map[string]Dialog
type DialogLayout struct {
Background string
ChoiceFont FontLayout
}
type DialogChoice struct {
ID string
Label string
Handler func()
}
type Dialog struct {
CurrentSelected int
Layout DialogLayout
Choices []DialogChoice
}
func (dialog *Dialog) GetChoiceColor(i int) color.Color {
if dialog.CurrentSelected == i {
return dialog.Layout.ChoiceFont.SelectedColor
} else {
return dialog.Layout.ChoiceFont.Color
}
}

View File

@@ -0,0 +1,10 @@
package entity
import "image/color"
type FontLayout struct {
DPI float64
Size float64
Color color.Color
SelectedColor color.Color
}

View File

@@ -0,0 +1,30 @@
package entity
import "image/color"
type MenuMap map[string]Menu
type MenuLayout struct {
Background string
MenuItemFont FontLayout
}
type MenuItem struct {
ID string
Label string
Handler func()
}
type Menu struct {
CurrentSelected int
Layout MenuLayout
MenuItems []MenuItem
}
func (menu *Menu) GetMenuItemColor(i int) color.Color {
if menu.CurrentSelected == i {
return menu.Layout.MenuItemFont.SelectedColor
} else {
return menu.Layout.MenuItemFont.Color
}
}

View File

@@ -1,8 +1,4 @@
package konstructor
import (
"github.com/hajimehoshi/ebiten"
)
package entity
type Position struct {
X int
@@ -67,11 +63,3 @@ type Level struct {
Name string
Playgrounds []Playground
}
func (e *Engine) PlaygroundDraw(screen *ebiten.Image) {
e.Domain.GetLevel(e.KContext.CurrentLevel)
}
func (e *Engine) PlaygroundUpdate() {
e.Domain.GetLevel(e.KContext.CurrentLevel)
}

View File

@@ -0,0 +1,11 @@
package entity
type ScreenSettings struct {
Width int
Height int
}
type Settings struct {
Name string
Screen *ScreenSettings
}

View File

@@ -1,4 +1,4 @@
package konstructor
package entity
type KContextScreen struct {
Type string

View File

@@ -2,26 +2,16 @@ package konstructor
import (
"fmt"
"game/konstructor/entity"
"reflect"
"github.com/hajimehoshi/ebiten"
"github.com/hajimehoshi/ebiten/inpututil"
)
type KeyMap struct {
Up ebiten.Key
Down ebiten.Key
Right ebiten.Key
Left ebiten.Key
Action0 ebiten.Key
Action1 ebiten.Key
Action2 ebiten.Key
Action3 ebiten.Key
}
type Controller struct {
PressedKey ebiten.Key
KeyMap KeyMap
KeyMap entity.KeyMap
}
func (c *Controller) Watch() {

View File

@@ -1,6 +1,7 @@
package konstructor
import (
"game/konstructor/entity"
"os"
"github.com/hajimehoshi/ebiten"
@@ -9,8 +10,8 @@ import (
type Engine struct {
Domain DomainInterface
Controller *Controller
Settings *Settings
KContext *KContext
Settings *entity.Settings
KContext *entity.KContext
}
func (e *Engine) Layout(outsideWidth, outsideHeight int) (int, int) {

View File

@@ -1,6 +1,7 @@
package konstructor
import (
"game/konstructor/entity"
"log"
"github.com/hajimehoshi/ebiten"
@@ -11,28 +12,18 @@ type ContextInterface interface {
type DomainInterface interface {
Init()
GetMenu(name string) Menu
SetMenu(name string, menu Menu)
GetDialog(name string) Dialog
SetDialog(name string, menu Dialog)
GetLevel(index int) Level
}
type ScreenSettings struct {
Width int
Height int
}
type Settings struct {
Name string
Screen *ScreenSettings
GetMenu(name string) entity.Menu
SetMenu(name string, menu entity.Menu)
GetDialog(name string) entity.Dialog
SetDialog(name string, menu entity.Dialog)
GetLevel(index int) entity.Level
}
type Konstructor struct {
Domain DomainInterface
Controller *Controller
Settings *Settings
KContext *KContext
Settings *entity.Settings
KContext *entity.KContext
}
func (k Konstructor) Init() {

View File

@@ -1,39 +1,10 @@
package konstructor
import (
"image/color"
"github.com/hajimehoshi/ebiten"
"github.com/hajimehoshi/ebiten/text"
)
type DialogMap map[string]Dialog
type DialogLayout struct {
Background string
ChoiceFont FontLayout
}
type DialogChoice struct {
ID string
Label string
Handler func()
}
type Dialog struct {
CurrentSelected int
Layout DialogLayout
Choices []DialogChoice
}
func (dialog *Dialog) GetChoiceColor(i int) color.Color {
if dialog.CurrentSelected == i {
return dialog.Layout.ChoiceFont.SelectedColor
} else {
return dialog.Layout.ChoiceFont.Color
}
}
func (e *Engine) DialogDraw(screen *ebiten.Image) {
dialog := e.Domain.GetDialog(e.KContext.Screen.Value)

View File

@@ -1,39 +1,10 @@
package konstructor
import (
"image/color"
"github.com/hajimehoshi/ebiten"
"github.com/hajimehoshi/ebiten/text"
)
type MenuMap map[string]Menu
type MenuLayout struct {
Background string
MenuItemFont FontLayout
}
type MenuItem struct {
ID string
Label string
Handler func()
}
type Menu struct {
CurrentSelected int
Layout MenuLayout
MenuItems []MenuItem
}
func (menu *Menu) GetMenuItemColor(i int) color.Color {
if menu.CurrentSelected == i {
return menu.Layout.MenuItemFont.SelectedColor
} else {
return menu.Layout.MenuItemFont.Color
}
}
func (e *Engine) MenuDraw(screen *ebiten.Image) {
menu := e.Domain.GetMenu(e.KContext.Screen.Value)
face := GetFontFace(menu.Layout.MenuItemFont)

View File

@@ -0,0 +1,13 @@
package konstructor
import (
"github.com/hajimehoshi/ebiten"
)
func (e *Engine) PlaygroundDraw(screen *ebiten.Image) {
e.Domain.GetLevel(e.KContext.CurrentLevel)
}
func (e *Engine) PlaygroundUpdate() {
e.Domain.GetLevel(e.KContext.CurrentLevel)
}

View File

@@ -2,11 +2,11 @@ package konstructor
import (
"bytes"
"game/konstructor/entity"
"image"
"io/ioutil"
"log"
"image/color"
_ "image/png"
"github.com/hajimehoshi/ebiten"
@@ -35,14 +35,7 @@ func LoadImage(path string) *ebiten.Image {
return out
}
type FontLayout struct {
DPI float64
Size float64
Color color.Color
SelectedColor color.Color
}
func GetFontFace(layout FontLayout) font.Face {
func GetFontFace(layout entity.FontLayout) font.Face {
tt, _ := opentype.Parse(fonts.MPlus1pRegular_ttf)
face, _ := opentype.NewFace(tt, &opentype.FaceOptions{
Size: layout.DPI,

12
main.go
View File

@@ -3,15 +3,15 @@ package main
import (
"game/domain"
"game/konstructor"
"game/konstructor/entity"
"github.com/hajimehoshi/ebiten"
)
func main() {
k := konstructor.Konstructor{
KContext: &konstructor.KContext{
Screen: konstructor.KContextScreen{
KContext: &entity.KContext{
Screen: entity.KContextScreen{
Type: "playground",
Value: "",
},
@@ -28,7 +28,7 @@ func main() {
},
},
Controller: &konstructor.Controller{
KeyMap: konstructor.KeyMap{
KeyMap: entity.KeyMap{
Up: ebiten.KeyUp,
Down: ebiten.KeyDown,
Right: ebiten.KeyRight,
@@ -39,9 +39,9 @@ func main() {
Action3: ebiten.KeyEscape,
},
},
Settings: &konstructor.Settings{
Settings: &entity.Settings{
Name: "Game",
Screen: &konstructor.ScreenSettings{
Screen: &entity.ScreenSettings{
Width: 640,
Height: 480,
},