diff options
Diffstat (limited to 'light-client/src/game.rs')
| -rw-r--r-- | light-client/src/game.rs | 37 | 
1 files changed, 27 insertions, 10 deletions
| diff --git a/light-client/src/game.rs b/light-client/src/game.rs index c9b20e56..ed1cb7fe 100644 --- a/light-client/src/game.rs +++ b/light-client/src/game.rs @@ -15,41 +15,58 @@      along with this program.  If not, see <https://www.gnu.org/licenses/>.  */ -use crate::atlas::SpriteRenderer; -use hurrycurry_protocol::{glam::IVec2, PacketC, TileIndex}; +use crate::{sprite_renderer::SpriteRenderer, tilemap::Tilemap}; +use hurrycurry_protocol::{ +    glam::{IVec2, Vec2}, +    PacketC, PlayerID, TileIndex, +};  use std::collections::HashMap;  pub struct Game { -    tiles: HashMap<IVec2, TileIndex>, +    tiles: HashMap<IVec2, Tile>, +    tilemap: Tilemap, +    players: HashMap<PlayerID, Player>, +} + +pub struct Tile { +    kind: TileIndex, +} +pub struct Player { +    character: i32, +    position: Vec2,  }  impl Game {      pub fn new() -> Self {          Self {              tiles: HashMap::new(), +            players: HashMap::new(), +            tilemap: Tilemap::default(),          }      } -    pub fn packet_in(&mut self, packet: PacketC) { +    pub fn packet_in(&mut self, packet: PacketC, renderer: &mut SpriteRenderer) {          match packet { +            PacketC::Data { data } => { +                self.tilemap.init(&data.tile_names, renderer.metadata()); +            }              PacketC::UpdateMap {                  tile,                  kind, -                neighbors: _, +                neighbors,              } => {                  if let Some(kind) = kind { -                    self.tiles.insert(tile, kind); +                    self.tiles.insert(tile, Tile { kind });                  } else {                      self.tiles.remove(&tile);                  } +                self.tilemap.set(tile, kind, neighbors);              }              _ => (),          }      } -    pub fn render(&self, ctx: &mut SpriteRenderer) { -        for (p, tile) in &self.tiles { -            ctx.draw_tile(*tile, *p) -        } +    pub fn draw(&self, ctx: &mut SpriteRenderer) { +        self.tilemap.draw(ctx)      }  } | 
