fix supid viewport bug
This commit is contained in:
parent
529f5a5749
commit
17ef52a5cf
@ -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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
@ -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() {
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
||||||
|
|
||||||
}
|
//}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user