From 17ef52a5cf210b809911d0ee116f212bc5f0eda5 Mon Sep 17 00:00:00 2001 From: thefish Date: Fri, 1 Nov 2019 19:59:12 +0300 Subject: [PATCH] fix supid viewport bug --- .../precomputed_shade/precomputed_shade.go | 7 ++++++- engine/gamemap/level.go | 6 ++++++ engine/mob/mob.go | 8 ++++++-- engine/screens/game.go | 2 +- ui/mainwindow/viewport.go | 20 +++++++++---------- 5 files changed, 29 insertions(+), 14 deletions(-) diff --git a/engine/fov/precomputed_shade/precomputed_shade.go b/engine/fov/precomputed_shade/precomputed_shade.go index e1a4dbf..eca682e 100644 --- a/engine/fov/precomputed_shade/precomputed_shade.go +++ b/engine/fov/precomputed_shade/precomputed_shade.go @@ -195,7 +195,9 @@ func (ps *precomputedShade) PrecomputeFovMap() { } func (ps *precomputedShade) recalc(level *gamemap.Level, initCoords types.Coords, radius int) { - + for i, _ := range ps.CellList { + ps.CellList[i].lit = 0 + } ps.originCoords = initCoords if radius > ps.MaxTorchRadius { @@ -250,6 +252,7 @@ func (ps *precomputedShade) recalc(level *gamemap.Level, initCoords types.Coords func (ps *precomputedShade) ComputeFov(level *gamemap.Level, initCoords types.Coords, radius int) { + level.SetAllInvisible() ps.recalc(level, initCoords, radius) for _, cell := range ps.CellList { @@ -260,6 +263,7 @@ func (ps *precomputedShade) ComputeFov(level *gamemap.Level, initCoords types.Co continue } level.GetTile(cs).Visible = true + level.GetTile(cs).Explored = true } //light walls, crutch @@ -273,6 +277,7 @@ func (ps *precomputedShade) ComputeFov(level *gamemap.Level, initCoords types.Co (maybeNb.X == cell.X || maybeNb.Y == cell.Y) && maybeNb.lit > 0 { //magic constant! level.GetTile(cs).Visible = true + level.GetTile(cs).Explored = true } } } diff --git a/engine/gamemap/level.go b/engine/gamemap/level.go index bb749c3..fd38d60 100644 --- a/engine/gamemap/level.go +++ b/engine/gamemap/level.go @@ -58,6 +58,12 @@ func NewLevel(ctx util.ClientCtx, branch string, depth int) *Level { return l } +func (l *Level) SetAllInvisible() { + for idx, _ := range l.Tiles { + l.Tiles[idx].Visible = false + } +} + type Room struct { *types.Rect Center types.Coords diff --git a/engine/mob/mob.go b/engine/mob/mob.go index 21eef57..309ffbb 100644 --- a/engine/mob/mob.go +++ b/engine/mob/mob.go @@ -1,6 +1,9 @@ package mob -import "lab.zaar.be/thefish/alchemyst-go/engine/types" +import ( + "fmt" + "lab.zaar.be/thefish/alchemyst-go/engine/types" +) type Mob struct { *types.Appearance @@ -9,7 +12,8 @@ type Mob struct { } func (m *Mob) Walk(dx, dy int) { - + m.Coords = types.Coords{m.X + dx, m.Y + dy} + fmt.Printf("new coords: %d, %d\n", m.Coords.X, m.Coords.Y) } func (m *Mob) Render() { diff --git a/engine/screens/game.go b/engine/screens/game.go index 9a32e80..a91f5e0 100644 --- a/engine/screens/game.go +++ b/engine/screens/game.go @@ -42,7 +42,7 @@ func (ts *GameScreen) HandleInput(input string) { ts.state.Player.Walk(-1, 1) break case "n", "3": - ts.state.Player.Walk(-1, 3) + ts.state.Player.Walk(1, 1) break default: ts.mw.GetLayer("base").ClearArea(0, 3, 40, 1) diff --git a/ui/mainwindow/viewport.go b/ui/mainwindow/viewport.go index ec15208..4d97eac 100644 --- a/ui/mainwindow/viewport.go +++ b/ui/mainwindow/viewport.go @@ -32,7 +32,7 @@ func NewViewPort(x, y, w, h int, layer *Layer) *ViewPort { Fov: computedFov, } - vp.PlayerTorchRadius = 9 + vp.PlayerTorchRadius = 11 vp.animateTiles = time.NewTicker(time.Second / 12) return &vp @@ -56,11 +56,11 @@ func (vp *ViewPort) Move(state *gamestate.GameState) { if y < 0 { y = 0 } - if x > state.Level.W-vp.W { + if x > state.Level.W-vp.W - 1 { x = state.Level.W - vp.W - 1 } - if y > state.Level.H-vp.H { - x = state.Level.H - vp.H - 1 + if y > state.Level.H-vp.H - 1 { + y = state.Level.H - vp.H - 1 } if x != vp.cameraCoords.X || y != vp.cameraCoords.Y { state.FovRecompute <- struct{}{} @@ -101,12 +101,12 @@ func (vp *ViewPort) Render(state *gamestate.GameState) { if fovRecompute { vp.layer.ClearRect(vp.Rect) - fovRecompute = false + fovRecompute = true redraw = true vp.Fov.ComputeFov(state.Level, state.Player.Coords, vp.PlayerTorchRadius) } - if redraw { + //if redraw { //terrain for y := 0; y < vp.H; y++ { for x := 0; x < vp.W; x++ { @@ -114,14 +114,14 @@ func (vp *ViewPort) Render(state *gamestate.GameState) { if state.Level.InBounds(mapCoords) { tile := state.Level.GetTile(mapCoords) - if tile.Explored || tile.MustDraw || tile.Visible { + if tile.Explored || tile.Visible { vp.layer.PutToBase(x+vp.X, y+vp.Y, tile.GetChar(), tile.GetRawColor(), tile.GetRawBgColor()) } } } } //mobs - pc, err := vp.ToVPCoords(vp.PlayerCoords) + pc, err := vp.ToVPCoords(state.Player.Coords) _ = pc if err != nil { fmt.Println("error on getting player position") @@ -132,8 +132,8 @@ func (vp *ViewPort) Render(state *gamestate.GameState) { } //redraw = true - redraw = false + //redraw = false - } + //} }