aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/entities.rs31
-rw-r--r--src/main.rs19
2 files changed, 46 insertions, 4 deletions
diff --git a/src/entities.rs b/src/entities.rs
index 51cefc1..c3ec262 100644
--- a/src/entities.rs
+++ b/src/entities.rs
@@ -13,12 +13,13 @@ pub struct Character {
pub name: String,
pub class: String,
pub health: i32,
+ pub level: i32,
+ pub location: Point,
max_health: i32,
attack: i32,
dodge: i32,
luck: i32,
xp: i32,
- location: Point,
tile_type: TileType
}
@@ -29,6 +30,7 @@ pub trait Enemy {
attack: i32,
dodge: i32,
luck: i32,
+ level: i32,
location: Point
) -> Self;
@@ -102,7 +104,9 @@ impl Player for Character {
attack: i32,
dodge: i32,
luck: i32,
- location: Point
+ level: i32,
+ location: Point,
+ tile_type: TileType
) -> Character {
Character {
name: name,
@@ -113,6 +117,29 @@ impl Player for Character {
dodge: dodge,
luck: luck,
xp: 0,
+ level: 0,
+ location: location,
+ tile_type: TileType::Player
+ }
+ }
+
+ fn place(&mut self, location: Point) {
+ self.location = location;
+ }
+
+ fn select(&self, player_name: String, player_luck: i32) -> Self {
+ Self::new(
+ player_name,
+ self.class.to_string(),
+ self.health,
+ self.attack,
+ self.dodge,
+ self.luck + player_luck,
+ 0,
+ (0,0)
+ )
+ }
+
location: location,
tile_type: TileType::Player
}
diff --git a/src/main.rs b/src/main.rs
index f7e7f0f..9f5e45b 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -46,9 +46,10 @@ fn main() {
let mut dungeon = Dungeon::new(
window.get_max_x() as usize,
- window.get_max_y() as usize - 2,
+ window.get_max_y() as usize - 2, // allow 2 lines for game stats
5
);
+
dungeon.generate();
let start_location = dungeon.levels[0].get_start_point();
@@ -60,9 +61,9 @@ fn main() {
10,
10,
20,
+ 0,
start_location
);
- character.place(start_location);
render_level(&window, &dungeon.levels[0]);
@@ -71,7 +72,20 @@ fn main() {
loop {
// update actors
+
+
// update character
+ window.mv(window.get_max_y() - 2, 0);
+ window.clrtoeol();
+
+ window.refresh();
+
+ window.addstr(character.stats() + "\n");
+ window.addstr(character.info() + "\n");
+
+ window.mv(character.location.1 as i32,character.location.0 as i32);
+ window.refresh();
+ draw_block(&window, &world::TileType::Character);
window.refresh();
// get input and execute it
@@ -86,6 +100,7 @@ fn main() {
Some(_) => (),
None => (),
}
+ // actors actions (normally attack / interact if on same location as the character)
}
endwin();
}