Compare commits
2 commits
5504db4e0f
...
f4c4339204
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f4c4339204 | ||
|
|
a6079103a4 |
8 changed files with 75 additions and 59 deletions
|
|
@ -1,6 +1,9 @@
|
||||||
use bevy::prelude::*;
|
use bevy::prelude::*;
|
||||||
|
|
||||||
use crate::{game::wall::WallTiles, tiles::Tile};
|
use crate::{
|
||||||
|
game::{player::Player, wall::WallTiles},
|
||||||
|
tiles::Tile,
|
||||||
|
};
|
||||||
|
|
||||||
#[derive(Component)]
|
#[derive(Component)]
|
||||||
pub struct Hand;
|
pub struct Hand;
|
||||||
|
|
@ -17,38 +20,39 @@ pub(crate) fn deal_hands(
|
||||||
mut commands: Commands,
|
mut commands: Commands,
|
||||||
walltiles: Single<&WallTiles>,
|
walltiles: Single<&WallTiles>,
|
||||||
walltiles_entity: Single<Entity, With<WallTiles>>,
|
walltiles_entity: Single<Entity, With<WallTiles>>,
|
||||||
|
players: Populated<Entity, With<Player>>,
|
||||||
) -> Result {
|
) -> Result {
|
||||||
let hand = walltiles.iter().collect::<Vec<_>>();
|
let mut wall = walltiles.iter().collect::<Vec<_>>();
|
||||||
|
|
||||||
commands
|
for player_entity in players {
|
||||||
.get_entity(*walltiles_entity)?
|
let hand = wall.split_off(13);
|
||||||
.remove_children(hand.last_chunk::<13>().unwrap());
|
|
||||||
|
|
||||||
commands.spawn((Hand, HandTiles(hand)));
|
commands
|
||||||
|
.get_entity(*walltiles_entity)?
|
||||||
|
.remove_children(&hand);
|
||||||
|
|
||||||
|
let handtiles = commands.spawn((Hand, HandTiles(hand))).id();
|
||||||
|
|
||||||
|
commands
|
||||||
|
.get_entity(player_entity)?
|
||||||
|
.add_children(&[handtiles]);
|
||||||
|
}
|
||||||
|
|
||||||
trace!("dealt hands");
|
trace!("dealt hands");
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn sort_hand(
|
#[allow(clippy::type_complexity)]
|
||||||
|
pub(crate) fn sort_hands(
|
||||||
mut commands: Commands,
|
mut commands: Commands,
|
||||||
tiles: Populated<&Tile>,
|
tiles: Populated<&Tile>,
|
||||||
handtiles_entity: Single<Entity, With<HandTiles>>,
|
mut hands: Populated<&mut Children, Changed<HandTiles>>,
|
||||||
handtiles: Single<&HandTiles, Changed<HandTiles>>,
|
|
||||||
) -> Result {
|
) -> Result {
|
||||||
let mut hand: Vec<_> = handtiles
|
for (mut children) in hands {
|
||||||
.iter()
|
children.sort_unstable_by_key(|e| tiles.get(*e).unwrap().suit);
|
||||||
.map(|e| -> Result<(_, _)> { Ok((tiles.get(e)?, e)) })
|
trace!("sorted a hand")
|
||||||
.collect::<Result<_>>()?;
|
}
|
||||||
|
|
||||||
hand.sort_by_key(|(t, _)| t.suit);
|
trace!("sort_hands");
|
||||||
|
|
||||||
let hand: Vec<_> = hand.iter().map(|(_, e)| *e).collect();
|
|
||||||
|
|
||||||
commands
|
|
||||||
.get_entity(*handtiles_entity)?
|
|
||||||
.replace_children(&hand);
|
|
||||||
|
|
||||||
trace!("sort_hand");
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,9 @@
|
||||||
use bevy::prelude::*;
|
use bevy::prelude::*;
|
||||||
|
|
||||||
use crate::tiles::{self, *};
|
use crate::{
|
||||||
|
game::player::MainPlayer,
|
||||||
|
tiles::{self, *},
|
||||||
|
};
|
||||||
|
|
||||||
pub mod hand;
|
pub mod hand;
|
||||||
pub mod player;
|
pub mod player;
|
||||||
|
|
@ -24,7 +27,7 @@ impl Plugin for Riichi {
|
||||||
.add_systems(Startup, tiles::init_tiles)
|
.add_systems(Startup, tiles::init_tiles)
|
||||||
.init_state::<GameState>()
|
.init_state::<GameState>()
|
||||||
.add_systems(OnEnter(GameState::Setup), (wall::build_wall, hand::deal_hands, setup_done).chain())
|
.add_systems(OnEnter(GameState::Setup), (wall::build_wall, hand::deal_hands, setup_done).chain())
|
||||||
.add_systems(Update, (hand::sort_hand).run_if(in_state(GameState::Play)))
|
.add_systems(Update, (hand::sort_hands).run_if(in_state(GameState::Play)))
|
||||||
// semicolon stopper
|
// semicolon stopper
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
@ -79,7 +82,7 @@ pub(crate) fn init_match(
|
||||||
player_count,
|
player_count,
|
||||||
});
|
});
|
||||||
|
|
||||||
let players = (1..=player_count)
|
let players = (2..=player_count)
|
||||||
.map(|i| {
|
.map(|i| {
|
||||||
(
|
(
|
||||||
player::Player {
|
player::Player {
|
||||||
|
|
@ -90,6 +93,13 @@ pub(crate) fn init_match(
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
commands.spawn_batch(players);
|
commands.spawn_batch(players);
|
||||||
|
let main_player = (
|
||||||
|
player::Player {
|
||||||
|
name: format!("Player {}", 1),
|
||||||
|
},
|
||||||
|
player::Points(starting),
|
||||||
|
);
|
||||||
|
commands.spawn((main_player, MainPlayer));
|
||||||
|
|
||||||
// *compass = Compass {
|
// *compass = Compass {
|
||||||
// prevalent_wind: Wind::Ton,
|
// prevalent_wind: Wind::Ton,
|
||||||
|
|
|
||||||
|
|
@ -6,12 +6,12 @@ use crate::{
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Component)]
|
#[derive(Component)]
|
||||||
pub(crate) struct Player {
|
pub struct Player {
|
||||||
pub(crate) name: String,
|
pub name: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn spawn_players(mut commands: Commands) {}
|
#[derive(Component)]
|
||||||
|
pub struct Points(pub isize);
|
||||||
|
|
||||||
#[derive(Component)]
|
#[derive(Component)]
|
||||||
pub(crate) struct Points(pub isize);
|
pub struct MainPlayer;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -43,7 +43,7 @@ fn main() {
|
||||||
tui_logger::init_logger(tui_logger::LevelFilter::Trace).unwrap();
|
tui_logger::init_logger(tui_logger::LevelFilter::Trace).unwrap();
|
||||||
tui_logger::set_env_filter_from_string(FILTERSTRING);
|
tui_logger::set_env_filter_from_string(FILTERSTRING);
|
||||||
|
|
||||||
app.add_plugins(tui::RiichiTui::default())
|
app.add_plugins(tui::RiichiTui)
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,8 +5,8 @@ use tui_logger::TuiLoggerWidget;
|
||||||
|
|
||||||
#[derive(Clone, Copy, PartialEq, Eq, Hash, Debug, Default, States)]
|
#[derive(Clone, Copy, PartialEq, Eq, Hash, Debug, Default, States)]
|
||||||
pub(crate) enum ConsoleState {
|
pub(crate) enum ConsoleState {
|
||||||
#[default]
|
|
||||||
Closed,
|
Closed,
|
||||||
|
#[default]
|
||||||
Open,
|
Open,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -110,11 +110,17 @@ pub(crate) fn input_system(
|
||||||
_ => {}
|
_ => {}
|
||||||
},
|
},
|
||||||
TuiState::InGame => match gs {
|
TuiState::InGame => match gs {
|
||||||
// GameState::None => todo!(),
|
GameState::Setup => match message.code {
|
||||||
GameState::Setup => todo!(),
|
_ => {}
|
||||||
GameState::Play => todo!(),
|
},
|
||||||
|
GameState::Play => match message.code {
|
||||||
|
KeyCode::Char('q') => {
|
||||||
|
exit.write_default();
|
||||||
|
}
|
||||||
|
_ => {}
|
||||||
|
},
|
||||||
GameState::Score => todo!(),
|
GameState::Score => todo!(),
|
||||||
_ => todo!()
|
_ => unreachable!("TuiState::InGame but GameState invalid")
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,32 +7,26 @@ use jong::tiles::Tile;
|
||||||
use crate::tui::render::tiles;
|
use crate::tui::render::tiles;
|
||||||
|
|
||||||
#[derive(Resource, Default)]
|
#[derive(Resource, Default)]
|
||||||
pub(crate) struct RenderedHand(pub(crate) Vec<Paragraph<'static>>);
|
pub(crate) struct RenderedHand(pub(crate) Vec<Vec<Paragraph<'static>>>);
|
||||||
|
|
||||||
pub(crate) fn render_changed_hand(
|
pub(crate) fn render_changed_hand(
|
||||||
hand: Single<&HandTiles, Changed<HandTiles>>,
|
hands: Populated<&Children, Changed<HandTiles>>,
|
||||||
tiles: Populated<&Tile>,
|
tiles: Populated<&Tile>,
|
||||||
mut target: ResMut<RenderedHand>,
|
mut target: ResMut<RenderedHand>,
|
||||||
) -> Result {
|
) -> Result {
|
||||||
|
let mut rendered = vec![];
|
||||||
|
|
||||||
|
for hand in hands {
|
||||||
|
let tiles = hand
|
||||||
|
.iter()
|
||||||
|
.map(|inhand| tiles.get(inhand).map(tiles::draw_tile).unwrap())
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
rendered.push(tiles);
|
||||||
|
}
|
||||||
|
|
||||||
|
target.0 = rendered;
|
||||||
|
|
||||||
trace!("render_changed_hand");
|
trace!("render_changed_hand");
|
||||||
|
|
||||||
render_hand(hand, tiles, target)?;
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
pub(crate) fn render_hand(
|
|
||||||
hand: Single<&HandTiles, Changed<HandTiles>>,
|
|
||||||
tiles: Populated<&Tile>,
|
|
||||||
mut target: ResMut<RenderedHand>,
|
|
||||||
) -> Result {
|
|
||||||
trace!("render_hand");
|
|
||||||
|
|
||||||
let hand_tiles = hand
|
|
||||||
.iter()
|
|
||||||
.map(|inhand| -> Result<_> { Ok(tiles.get(inhand).map(tiles::draw_tile)?) })
|
|
||||||
.collect::<Result<Vec<_>>>()?;
|
|
||||||
target.0 = hand_tiles;
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -17,8 +17,10 @@ pub(crate) fn draw_ingame(
|
||||||
let mut area = frame.area();
|
let mut area = frame.area();
|
||||||
area.height = 4;
|
area.height = 4;
|
||||||
let areas = layout.areas::<13>(area);
|
let areas = layout.areas::<13>(area);
|
||||||
for (tile, area) in rendered_hand.0.iter().zip(areas.iter()) {
|
if let Some(tiles) = rendered_hand.0.first() {
|
||||||
frame.render_widget(tile, *area);
|
for (tile, area) in tiles.iter().zip(areas.iter()) {
|
||||||
|
frame.render_widget(tile, *area);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue