fix supid viewport bug

This commit is contained in:
thefish 2019-11-01 19:59:12 +03:00
parent 529f5a5749
commit 17ef52a5cf
5 changed files with 29 additions and 14 deletions

View File

@ -195,7 +195,9 @@ func (ps *precomputedShade) PrecomputeFovMap() {
} }
func (ps *precomputedShade) recalc(level *gamemap.Level, initCoords types.Coords, radius int) { 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 ps.originCoords = initCoords
if radius > ps.MaxTorchRadius { 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) { func (ps *precomputedShade) ComputeFov(level *gamemap.Level, initCoords types.Coords, radius int) {
level.SetAllInvisible()
ps.recalc(level, initCoords, radius) ps.recalc(level, initCoords, radius)
for _, cell := range ps.CellList { for _, cell := range ps.CellList {
@ -260,6 +263,7 @@ func (ps *precomputedShade) ComputeFov(level *gamemap.Level, initCoords types.Co
continue continue
} }
level.GetTile(cs).Visible = true level.GetTile(cs).Visible = true
level.GetTile(cs).Explored = true
} }
//light walls, crutch //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.X == cell.X || maybeNb.Y == cell.Y) &&
maybeNb.lit > 0 { //magic constant! maybeNb.lit > 0 { //magic constant!
level.GetTile(cs).Visible = true level.GetTile(cs).Visible = true
level.GetTile(cs).Explored = true
} }
} }
} }

View File

@ -58,6 +58,12 @@ func NewLevel(ctx util.ClientCtx, branch string, depth int) *Level {
return l return l
} }
func (l *Level) SetAllInvisible() {
for idx, _ := range l.Tiles {
l.Tiles[idx].Visible = false
}
}
type Room struct { type Room struct {
*types.Rect *types.Rect
Center types.Coords Center types.Coords

View File

@ -1,6 +1,9 @@
package mob package mob
import "lab.zaar.be/thefish/alchemyst-go/engine/types" import (
"fmt"
"lab.zaar.be/thefish/alchemyst-go/engine/types"
)
type Mob struct { type Mob struct {
*types.Appearance *types.Appearance
@ -9,7 +12,8 @@ type Mob struct {
} }
func (m *Mob) Walk(dx, dy int) { 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() { func (m *Mob) Render() {

View File

@ -42,7 +42,7 @@ func (ts *GameScreen) HandleInput(input string) {
ts.state.Player.Walk(-1, 1) ts.state.Player.Walk(-1, 1)
break break
case "n", "3": case "n", "3":
ts.state.Player.Walk(-1, 3) ts.state.Player.Walk(1, 1)
break break
default: default:
ts.mw.GetLayer("base").ClearArea(0, 3, 40, 1) ts.mw.GetLayer("base").ClearArea(0, 3, 40, 1)

View File

@ -32,7 +32,7 @@ func NewViewPort(x, y, w, h int, layer *Layer) *ViewPort {
Fov: computedFov, Fov: computedFov,
} }
vp.PlayerTorchRadius = 9 vp.PlayerTorchRadius = 11
vp.animateTiles = time.NewTicker(time.Second / 12) vp.animateTiles = time.NewTicker(time.Second / 12)
return &vp return &vp
@ -56,11 +56,11 @@ func (vp *ViewPort) Move(state *gamestate.GameState) {
if y < 0 { if y < 0 {
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 x = state.Level.W - vp.W - 1
} }
if y > state.Level.H-vp.H { if y > state.Level.H-vp.H - 1 {
x = state.Level.H - vp.H - 1 y = state.Level.H - vp.H - 1
} }
if x != vp.cameraCoords.X || y != vp.cameraCoords.Y { if x != vp.cameraCoords.X || y != vp.cameraCoords.Y {
state.FovRecompute <- struct{}{} state.FovRecompute <- struct{}{}
@ -101,12 +101,12 @@ func (vp *ViewPort) Render(state *gamestate.GameState) {
if fovRecompute { if fovRecompute {
vp.layer.ClearRect(vp.Rect) vp.layer.ClearRect(vp.Rect)
fovRecompute = false fovRecompute = true
redraw = true redraw = true
vp.Fov.ComputeFov(state.Level, state.Player.Coords, vp.PlayerTorchRadius) vp.Fov.ComputeFov(state.Level, state.Player.Coords, vp.PlayerTorchRadius)
} }
if redraw { //if redraw {
//terrain //terrain
for y := 0; y < vp.H; y++ { for y := 0; y < vp.H; y++ {
for x := 0; x < vp.W; x++ { for x := 0; x < vp.W; x++ {
@ -114,14 +114,14 @@ func (vp *ViewPort) Render(state *gamestate.GameState) {
if state.Level.InBounds(mapCoords) { if state.Level.InBounds(mapCoords) {
tile := state.Level.GetTile(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()) vp.layer.PutToBase(x+vp.X, y+vp.Y, tile.GetChar(), tile.GetRawColor(), tile.GetRawBgColor())
} }
} }
} }
} }
//mobs //mobs
pc, err := vp.ToVPCoords(vp.PlayerCoords) pc, err := vp.ToVPCoords(state.Player.Coords)
_ = pc _ = pc
if err != nil { if err != nil {
fmt.Println("error on getting player position") fmt.Println("error on getting player position")
@ -132,8 +132,8 @@ func (vp *ViewPort) Render(state *gamestate.GameState) {
} }
//redraw = true //redraw = true
redraw = false //redraw = false
} //}
} }