Skip to content

Commit

Permalink
Merge branch 'main' into bincode
Browse files Browse the repository at this point in the history
  • Loading branch information
LuckyTurtleDev committed May 16, 2023
2 parents 0cefeb1 + d3ef2cd commit ffdd6fb
Show file tree
Hide file tree
Showing 23 changed files with 387 additions and 51 deletions.
1 change: 1 addition & 0 deletions .gitattributes
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Cargo.lock linguist-generated
39 changes: 39 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Test
2 changes: 2 additions & 0 deletions macro/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ pub fn include_map(input: TokenStream) -> TokenStream {
{
use m3_map::Map;
use m3_map::tiles::MapBaseTile;
use m3_map::Player;
use m3_map::tiles::ObjectTile;
// include the bytes so that the compiler knows to recompile when the
// map or tilesets changes
const _: &[u8] = ::core::include_bytes!(#path);
Expand Down
136 changes: 127 additions & 9 deletions map/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,16 +1,28 @@
use self_rust_tokenize::SelfRustTokenize;
use std::path::Path;
use std::{iter, path::Path};
use thiserror::Error;
use tiled::{LayerType, Loader};

pub mod tiles;
use tiles::{InvalidTileID, MapBaseTile};
use tiles::{InvalidTileID, MapBaseTile, ObjectTile, PlayerTile, Tile};

#[derive(Debug, SelfRustTokenize)]
#[derive(Clone, Debug, SelfRustTokenize)]
pub struct Player {
pub start: (u8, u8),
pub goal: Option<(u8, u8)>
}

#[derive(Clone, Debug, SelfRustTokenize)]
pub struct Map {
pub width: u8,
pub height: u8,
pub base_layer: Vec<Vec<MapBaseTile>>
pub base_layer: Vec<Vec<MapBaseTile>>,
pub object_layer: Vec<Vec<Option<ObjectTile>>>,
pub global_goal: Option<(u8, u8)>,
pub player_1: Player,
pub player_2: Option<Player>,
pub player_3: Option<Player>,
pub player_4: Option<Player>
}

#[derive(Error, Debug)]
Expand All @@ -28,15 +40,24 @@ pub enum MapError {
#[error("Map is to hight. Max size is 255x255 tiles")]
ToHight,
#[error("{0}")]
InvalidTileId(#[from] InvalidTileID)
InvalidTileId(#[from] InvalidTileID),
#[error("Map needs at least one player")]
NoPlayer
}

impl Map {
// this is ugly. Should i refactor this?
pub fn from_tmx(path: impl AsRef<Path>) -> Result<Self, MapError> {
let map = Loader::new().load_tmx_map(path)?;
let width: u8 = map.width.try_into().map_err(|_| MapError::ToWidth)?;
let height: u8 = map.height.try_into().map_err(|_| MapError::ToHight)?;
let mut base_layer = Vec::with_capacity(height as usize);
let mut object_layer = Vec::with_capacity(height as usize);
let mut global_goal = None;
let mut player_1 = None;
let mut player_2 = None;
let mut player_3 = None;
let mut player_4 = None;
for (i, layer) in map.layers().enumerate() {
match i {
0 => match layer.layer_type() {
Expand All @@ -55,23 +76,120 @@ impl Map {
},
_ => return Err(MapError::WrongLayer(i, "TileLayer".to_owned()))
},
1 => match layer.layer_type() {
LayerType::Tiles(tile_layer) => {
for x in 0..width {
let mut column = Vec::with_capacity(width as usize);
for y in 0..height {
let tile = match tile_layer.get_tile(x.into(), y.into()) {
Some(tile) => Some(ObjectTile::try_from(tile.id())?),
None => None
};
column.push(tile);
}
object_layer.push(column);
}
},
_ => return Err(MapError::WrongLayer(i, "TileLayer".to_owned()))
},
2 => match layer.layer_type() {
LayerType::Tiles(tile_layer) => {
for x in 0..width {
for y in 0..height {
if let Some(tile) =
tile_layer.get_tile(x.into(), y.into())
{
let tile = PlayerTile::try_from(tile.id())?;
match tile {
PlayerTile::Car1 => {
player_1 = Some(Player {
start: (x, y),
goal: None
})
},
PlayerTile::Car2 => {
player_2 = Some(Player {
start: (x, y),
goal: None
})
},
PlayerTile::Car3 => {
player_3 = Some(Player {
start: (x, y),
goal: None
})
},
PlayerTile::Car4 => {
player_4 = Some(Player {
start: (x, y),
goal: None
})
},
PlayerTile::GlobalGoal => {
global_goal = Some((x, y))
},
}
}
}
}
},
_ => return Err(MapError::WrongLayer(i, "TileLayer".to_owned()))
},
_ => return Err(MapError::ToManyLayers)
}
}
let player_1 = player_1.ok_or(MapError::NoPlayer)?;
Ok(Map {
width,
height,
base_layer
base_layer,
object_layer,
global_goal,
player_1,
player_2,
player_3,
player_4
})
}

/// return an iterator over all BasteTiles and its x and y postion
pub fn iter_base_layer(&self) -> impl Iterator<Item = (u8, u8, &MapBaseTile)> {
self.base_layer.iter().enumerate().flat_map(|(y, x_vec)| {
x_vec
self.base_layer.iter().enumerate().flat_map(|(x, y_vec)| {
y_vec
.iter()
.enumerate()
.map(move |(x, item)| (x as u8, y as u8, item))
.map(move |(y, item)| (x as u8, y as u8, item))
})
}

/// return an iterator over all ObjectTiles and its x and y postion
pub fn iter_object_layer(&self) -> impl Iterator<Item = (u8, u8, ObjectTile)> + '_ {
self.object_layer.iter().enumerate().flat_map(|(x, y_vec)| {
y_vec
.iter()
.enumerate()
.filter_map(move |(y, item)| item.map(|item| (x as u8, y as u8, item)))
})
}

/// return an iterator over all player goals tiles and its x and y postion
pub fn iter_player_goals(&self) -> impl Iterator<Item = (u8, u8, PlayerTile)> + '_ {
iter::once(self.global_goal)
.flat_map(|goal| goal.map(|(x, y)| (x, y, PlayerTile::GlobalGoal)))
}

/// return an iterator over all static Tiles and its x and y postion.
/// starting from the lowest layer
pub fn iter_all(&self) -> impl Iterator<Item = (u8, u8, Tile)> + '_ {
let base = self
.iter_base_layer()
.map(|(x, y, tile)| (x, y, Tile::MapBaseTile(tile.to_owned())));
let objects = self
.iter_object_layer()
.map(|(x, y, tile)| (x, y, Tile::MapObjectTile(tile.to_owned())));
let goals = self
.iter_player_goals()
.map(|(x, y, tile)| (x, y, Tile::PlayerTile(tile)));
base.chain(objects).chain(goals)
}
}
4 changes: 2 additions & 2 deletions map/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,12 @@ pub struct Opt {

fn main() {
let opt = Opt::parse();
let result = Map::from_tmx(&opt.file);
let result = Map::from_tmx(opt.file);
match result {
Err(err) => {
eprintln!("ERROR: {err}");
std::process::exit(1);
},
Ok(map) => println!("{map:#?}")
Ok(map) => println!("{map:#?}\nmap is valid")
}
}
60 changes: 53 additions & 7 deletions map/src/tiles.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,18 @@ use num_enum::TryFromPrimitive;
use self_rust_tokenize::SelfRustTokenize;
use thiserror::Error;

pub enum Tile {
MapBaseTile(MapBaseTile),
MapObjectTile(ObjectTile),
PlayerTile(PlayerTile)
}

#[derive(Debug, Copy, Clone, Error)]
pub enum InvalidTileID {
#[error("invalid tiel id {0}")]
InvalidId(u32)
}

///Store all Tiles, with can be used at the map background
#[derive(
Clone, Copy, Debug, Default, Eq, SelfRustTokenize, PartialEq, TryFromPrimitive,
Expand All @@ -10,19 +22,53 @@ use thiserror::Error;
pub enum MapBaseTile {
//numbers must match them from the Tiled tilesets
#[default]
Grass = 0,
Grass = 0
}

impl TryFrom<u32> for MapBaseTile {
type Error = InvalidTileID;
fn try_from(value: u32) -> Result<MapBaseTile, Self::Error> {
let value_u8: u8 = value
.try_into()
.map_err(|_| Self::Error::InvalidId(value))?;
Self::try_from_primitive(value_u8).map_err(|_| Self::Error::InvalidId(value))
}
}

///Store all Tiles, with can be place the layer above the background
#[derive(Clone, Copy, Debug, Eq, SelfRustTokenize, PartialEq, TryFromPrimitive)]
#[repr(u8)]
pub enum ObjectTile {
//numbers must match them from the Tiled tilesets
Stone = 1
}

#[derive(Debug, Copy, Clone, Error)]
pub enum InvalidTileID {
#[error("invalid tiel id {0}")]
InvalidId(u32)
impl TryFrom<u32> for ObjectTile {
type Error = InvalidTileID;
fn try_from(value: u32) -> Result<ObjectTile, Self::Error> {
let value_u8: u8 = value
.try_into()
.map_err(|_| Self::Error::InvalidId(value))?;
Self::try_from_primitive(value_u8).map_err(|_| Self::Error::InvalidId(value))
}
}

impl TryFrom<u32> for MapBaseTile {
///Store all Tiles, with can be place the layer above the background
#[derive(Clone, Copy, Debug, Eq, SelfRustTokenize, PartialEq, TryFromPrimitive)]
#[repr(u8)]
pub enum PlayerTile {
//numbers must match them from the Tiled tilesets
Car1 = 0,
Car2 = 1,
Car3 = 2,
Car4 = 3,
//goal, which can be used by all players
GlobalGoal = 4
}

impl TryFrom<u32> for PlayerTile {
type Error = InvalidTileID;
fn try_from(value: u32) -> Result<MapBaseTile, Self::Error> {
fn try_from(value: u32) -> Result<PlayerTile, Self::Error> {
let value_u8: u8 = value
.try_into()
.map_err(|_| Self::Error::InvalidId(value))?;
Expand Down
1 change: 1 addition & 0 deletions pc/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ log = "0.4.17"
m3-macro = { version = "0.1.0", path = "../macro" }
m3-map = { version = "0.1.0", path = "../map" }
m3-models = { version = "0.1.0", path = "../models" }
my-env-logger-style = "0.1.0"
num_enum = "0.6.1"
once_cell = { version = "1.17.1", features = ["parking_lot"] }
serialport = "4.2.0"
Expand Down
5 changes: 1 addition & 4 deletions pc/assets/img/BaseTiles/BaseTiles.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<tileset version="1.10" tiledversion="1.10.1" name="BaseTiles" tilewidth="256" tileheight="256" tilecount="2" columns="0">
<tileset version="1.10" tiledversion="1.10.1" name="BaseTiles" tilewidth="256" tileheight="256" tilecount="1" columns="0">
<grid orientation="orthogonal" width="1" height="1"/>
<tile id="0">
<image width="256" height="256" source="grass.png"/>
</tile>
<tile id="1">
<image width="256" height="256" source="stone.png"/>
</tile>
</tileset>
Binary file modified pc/assets/img/BaseTiles/grass.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed pc/assets/img/BaseTiles/stone.png
Binary file not shown.
7 changes: 7 additions & 0 deletions pc/assets/img/ObjectTiles/ObjectTiles.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<tileset version="1.10" tiledversion="1.10.1" name="ObjectTiles" tilewidth="256" tileheight="256" tilecount="1" columns="0">
<grid orientation="orthogonal" width="1" height="1"/>
<tile id="1">
<image width="256" height="256" source="stone.png"/>
</tile>
</tileset>
Binary file added pc/assets/img/ObjectTiles/stone.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading

0 comments on commit ffdd6fb

Please sign in to comment.