items
This commit is contained in:
parent
b3c7beec2b
commit
62f45b920f
22
TODO
22
TODO
@ -16,16 +16,22 @@ Basics:
|
|||||||
- ai
|
- ai
|
||||||
- dijkstra maps
|
- dijkstra maps
|
||||||
Tech:
|
Tech:
|
||||||
- fix connector position - 1 tile inside
|
+ fix connector position
|
||||||
|
- xecutors fov algo
|
||||||
|
- M.Kitsch fov algo
|
||||||
|
- milazzo fov algo
|
||||||
|
- naive bresenham algo
|
||||||
|
|
||||||
Assets and i18n:
|
Assets and i18n:
|
||||||
- move tile settings to json, generate from there (part of prefabs)
|
move tile settings to json:
|
||||||
|
+ tile export
|
||||||
|
- tile import
|
||||||
- prepare all interface entries for i18n
|
- prepare all interface entries for i18n
|
||||||
- all texts (terrain, mobs, quests) also in at least 2 languages
|
- all texts (terrain, mobs, quests) also in at least 2 languages
|
||||||
|
|
||||||
ECS & engine:
|
ECS & engine:
|
||||||
- implement time queue (how to deal with closures?) (?) github.com/thefish/scheduleq - get rid od time.Now inside
|
- systems message queue
|
||||||
|
- implement timeQueue (how to deal with closures?) (?) github.com/thefish/scheduleq - get rid od time.Now inside
|
||||||
- move all rendering to systems
|
- move all rendering to systems
|
||||||
- try to move input handling to systems
|
- try to move input handling to systems
|
||||||
|
|
||||||
@ -47,14 +53,12 @@ Dungeon and branches:
|
|||||||
Combat:
|
Combat:
|
||||||
- generate skeleton / intesines / muscle / eyes&ears & fingers from templates
|
- generate skeleton / intesines / muscle / eyes&ears & fingers from templates
|
||||||
- serializable
|
- serializable
|
||||||
- config in outer files
|
- config in json files
|
||||||
- mass
|
- mass
|
||||||
- damage from skill / mass / speed / material density
|
- damage from skill / mass / speed / material density
|
||||||
- no hitpoints! blood is the life source
|
- no hitpoints! blood is the life source
|
||||||
|
- pain is measure of nervous system load, lose conscience if its aboe threshold
|
||||||
|
|
||||||
|
|
||||||
Quest engine:
|
Quest engine:
|
||||||
- look at parsers like URQL etc
|
- look at parsers like URQL etc
|
||||||
- distorted Aschenputtel story / partisans / rapist prince / Grey Mountains
|
- distorted Aschenputtel story / partisans / rapist prince / Grey Mountains
|
||||||
|
|
@ -13,6 +13,7 @@ const ArmsComponent = "arms"
|
|||||||
const RangedComponent = "ranged"
|
const RangedComponent = "ranged"
|
||||||
const AmmoComponent = "ammo"
|
const AmmoComponent = "ammo"
|
||||||
const ArmorComponent = "armor"
|
const ArmorComponent = "armor"
|
||||||
|
const BackpackComponent = "backpack"
|
||||||
|
|
||||||
type Component interface {
|
type Component interface {
|
||||||
Type() string
|
Type() string
|
||||||
|
@ -21,3 +21,18 @@ func TypeInSlice(a string, list []string) bool {
|
|||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func DeleteFromEntitySlice(haystack []Entity, needle Entity) ([]Entity, Entity) {
|
||||||
|
var excluded Entity
|
||||||
|
for i, _ := range haystack {
|
||||||
|
if haystack[i] == needle {
|
||||||
|
excluded = haystack[i]
|
||||||
|
if len(haystack) - 1 > i {
|
||||||
|
haystack = append(haystack[:i], haystack[i+1:] ...)
|
||||||
|
} else {
|
||||||
|
haystack = haystack[:i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return haystack, excluded
|
||||||
|
}
|
@ -9,6 +9,6 @@ type Ammo struct {
|
|||||||
itemprops.DamageProfile
|
itemprops.DamageProfile
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Ammo) Type() string {
|
func (a Ammo) Type() string {
|
||||||
return ecs.AmmoComponent
|
return ecs.AmmoComponent
|
||||||
}
|
}
|
@ -6,6 +6,6 @@ type Armor struct {
|
|||||||
DefenceProfile struct{}
|
DefenceProfile struct{}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Armor) Type() string {
|
func (a Armor) Type() string {
|
||||||
return ecs.ArmorComponent
|
return ecs.ArmorComponent
|
||||||
}
|
}
|
||||||
|
33
engine/items/backpack.go
Normal file
33
engine/items/backpack.go
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
package items
|
||||||
|
|
||||||
|
import "lab.zaar.be/thefish/alchemyst-go/engine/ecs"
|
||||||
|
|
||||||
|
type Backpack struct {
|
||||||
|
MaxNumber int
|
||||||
|
MaxBulk int
|
||||||
|
MaxMass int
|
||||||
|
items []ecs.Entity
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b Backpack) Type() string {
|
||||||
|
return ecs.BackpackComponent
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Backpack) HasFreeSpace(Bulk, Mass int) bool {
|
||||||
|
totalBulk, totalMass := 0, 0
|
||||||
|
for i, _ := range b.items {
|
||||||
|
tmp := Controller.GetComponent(b.items[i], Carried{}.Type()).(Carried)
|
||||||
|
carried := tmp
|
||||||
|
totalBulk += carried.Bulk
|
||||||
|
totalMass += carried.Mass
|
||||||
|
}
|
||||||
|
if totalMass >= b.MaxMass {
|
||||||
|
//fixme return message along - 'too heavy'
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if totalBulk >= b.MaxMass {
|
||||||
|
//fixme return message along - 'doesnt fit to your backpack'
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
@ -1,6 +1,9 @@
|
|||||||
package items
|
package items
|
||||||
|
|
||||||
import "lab.zaar.be/thefish/alchemyst-go/engine/ecs"
|
import (
|
||||||
|
"lab.zaar.be/thefish/alchemyst-go/engine/ecs"
|
||||||
|
"lab.zaar.be/thefish/alchemyst-go/engine/types"
|
||||||
|
)
|
||||||
|
|
||||||
type CarriedFace interface {
|
type CarriedFace interface {
|
||||||
Drop()
|
Drop()
|
||||||
@ -12,16 +15,74 @@ type Carried struct {
|
|||||||
Bulk int //внешний размер, см3
|
Bulk int //внешний размер, см3
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Carried) Type() string {
|
func (c Carried) Type() string {
|
||||||
return ecs.CarriedComponent
|
return ecs.CarriedComponent
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Carried) Pickup() {}
|
func (c Carried) Pickup(who, what ecs.Entity) {
|
||||||
func (c *Carried) Drop() {}
|
// check if im lying on ground
|
||||||
|
if !Controller.HasComponent(what, ecs.CoordsComponent) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// something inexistent on map trying to pickup an item?!
|
||||||
|
if !Controller.HasComponent(who, ecs.CoordsComponent) {
|
||||||
|
//todo log error - investigate this situation
|
||||||
|
return
|
||||||
|
}
|
||||||
|
//check if who and what are on the same tile
|
||||||
|
whoCoords := Controller.GetComponent(who, ecs.CoordsComponent).(types.Coords)
|
||||||
|
whatCoords := Controller.GetComponent(what, ecs.CoordsComponent).(types.Coords)
|
||||||
|
if whoCoords != whatCoords {
|
||||||
|
//todo log error - something strange happened
|
||||||
|
return
|
||||||
|
}
|
||||||
|
//does not have inventory?
|
||||||
|
if !Controller.HasComponent(who, ecs.BackpackComponent) {
|
||||||
|
//todo send message - you cant carry items
|
||||||
|
return
|
||||||
|
}
|
||||||
|
bp := Controller.GetComponent(who, Backpack{}.Type()).(Backpack)
|
||||||
|
if !bp.HasFreeSpace(c.Bulk, c.Mass) {
|
||||||
|
//todo send message - does not fit to your inventory
|
||||||
|
return
|
||||||
|
}
|
||||||
|
//do not remove appearance
|
||||||
|
//remove coords instead (does not exist on map anymore)
|
||||||
|
Controller.RemoveComponent(what, ecs.CoordsComponent)
|
||||||
|
bp.items = append(bp.items, what)
|
||||||
|
}
|
||||||
|
|
||||||
func (c *Carried) GetMass() int {
|
func (c Carried) Drop(who, what ecs.Entity) {
|
||||||
|
var coords types.Coords
|
||||||
|
// something inexistent on map trying to drop an item?!
|
||||||
|
if !Controller.HasComponent(who, ecs.CoordsComponent) {
|
||||||
|
//todo log error - investigate this situation
|
||||||
|
return
|
||||||
|
} else {
|
||||||
|
coords = Controller.GetComponent(who, types.Coords{}.Type()).(types.Coords)
|
||||||
|
}
|
||||||
|
//does not have inventory?
|
||||||
|
if !Controller.HasComponent(who, ecs.BackpackComponent) {
|
||||||
|
//todo send message - you cant carry items
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
bp := Controller.GetComponent(who, Backpack{}.Type()).(Backpack)
|
||||||
|
var dropped ecs.Entity
|
||||||
|
bp.items, dropped = ecs.DeleteFromEntitySlice(bp.items, what)
|
||||||
|
if dropped != what {
|
||||||
|
//todo log error - something strange happened
|
||||||
|
return
|
||||||
|
}
|
||||||
|
//Give dropped back coordinated
|
||||||
|
Controller.AddComponent(dropped, coords)
|
||||||
|
//Controller.UpdateComponent(what, coords.Type(), coords) //even we need that?
|
||||||
|
Controller.UpdateComponent(who, bp.Type(), bp)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Carried) GetMass(what ecs.Entity) int {
|
||||||
return c.Mass
|
return c.Mass
|
||||||
}
|
}
|
||||||
func (c *Carried) GetBulk() int {
|
func (c *Carried) GetBulk(what ecs.Entity) int {
|
||||||
return c.Bulk
|
return c.Bulk
|
||||||
}
|
}
|
9
engine/items/common.go
Normal file
9
engine/items/common.go
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
package items
|
||||||
|
|
||||||
|
import "lab.zaar.be/thefish/alchemyst-go/engine/ecs"
|
||||||
|
|
||||||
|
var Controller ecs.Controller
|
||||||
|
|
||||||
|
func Init(ctrl ecs.Controller) {
|
||||||
|
Controller = ctrl
|
||||||
|
}
|
@ -6,6 +6,6 @@ type Ranged struct {
|
|||||||
RangeProfile struct{} //это зависимость дальности-скорости от характеристик и атрибутов
|
RangeProfile struct{} //это зависимость дальности-скорости от характеристик и атрибутов
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Ranged) Type() string {
|
func (r Ranged) Type() string {
|
||||||
return ecs.RangedComponent
|
return ecs.RangedComponent
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ type UsableFace interface {
|
|||||||
type Usable struct {}
|
type Usable struct {}
|
||||||
|
|
||||||
|
|
||||||
func (u *Usable) Type() string {
|
func (u Usable) Type() string {
|
||||||
return ecs.UsableComponent
|
return ecs.UsableComponent
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,6 +11,6 @@ type Wearable struct {
|
|||||||
Bodypart int //куда собстно одевать
|
Bodypart int //куда собстно одевать
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Wearable) Type() string {
|
func (w Wearable) Type() string {
|
||||||
return ecs.WearableComponent
|
return ecs.WearableComponent
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ type Coords struct {
|
|||||||
X, Y int
|
X, Y int
|
||||||
}
|
}
|
||||||
|
|
||||||
func (сс Coords) Type() string {
|
func (cc Coords) Type() string {
|
||||||
return ecs.CoordsComponent
|
return ecs.CoordsComponent
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user