merged AL-races
This commit is contained in:
@ -33,7 +33,7 @@ int character::get_gold() const {
|
||||
}
|
||||
|
||||
float character::get_hitrate() const {
|
||||
return base_hitrate;
|
||||
return base_hit_rate;
|
||||
}
|
||||
|
||||
bool character::is_hostile() const {
|
||||
@ -61,7 +61,7 @@ void character::set_gold(const int ngold) {
|
||||
}
|
||||
|
||||
void character::set_hitrate(const float nhitrate) {
|
||||
base_hitrate = nhitrate;
|
||||
base_hit_rate = nhitrate;
|
||||
}
|
||||
|
||||
void character::set_hostile(const bool is_hostile) {
|
||||
@ -174,3 +174,9 @@ result character::move_or_attack(const direction dir,
|
||||
|
||||
return this->attack(dir, chlist);
|
||||
}
|
||||
|
||||
|
||||
int calc_dmg(const int ATK, const int DEF) {
|
||||
return ceil((100 / (100 + DEF)) * ATK);
|
||||
}
|
||||
|
||||
|
@ -9,11 +9,14 @@
|
||||
#include <vector>
|
||||
#include <string>
|
||||
#include <memory>
|
||||
#include <math.h>
|
||||
|
||||
#include "constants.h"
|
||||
#include "position.h"
|
||||
#include "layer.h"
|
||||
#include "objects.h"
|
||||
#include "rng.h"
|
||||
|
||||
// #include "inventory.h" // Reserved for later
|
||||
|
||||
class character; // forward declaration
|
||||
@ -77,7 +80,7 @@ protected:
|
||||
int gold; // characters spawn with gold
|
||||
// inventory inventory; // Reserved
|
||||
|
||||
float base_hitrate; // requires: between [0,1]
|
||||
float base_hit_rate; // requires: between [0,1]
|
||||
|
||||
bool hostile;
|
||||
};
|
||||
@ -86,4 +89,7 @@ protected:
|
||||
position_list remove_from_list(const position_list &sorted_positions,
|
||||
position_list excluded);
|
||||
|
||||
|
||||
int calc_dmg(const int ATK, const int DEF);
|
||||
|
||||
#endif
|
||||
|
@ -4,12 +4,12 @@
|
||||
#include <ncurses.h>
|
||||
#include "position.h"
|
||||
|
||||
// IMPORTANT: panic is reserved for invalid results
|
||||
const int INF = 0x3F3F3F3F;
|
||||
|
||||
enum error {none};
|
||||
|
||||
// TODO: update result to include subject
|
||||
enum result {fine, died, go_down, hit, moved};
|
||||
enum result {fine, died, go_down, hit, moved, miss};
|
||||
|
||||
enum game_status {terminated, main_menu, in_game, options};
|
||||
|
||||
@ -34,16 +34,18 @@ enum stat_name {HP, ATK, DEF, hostile};
|
||||
const int LAYER_CNT = 4; // TODO: update as you go
|
||||
enum layer_num {map = 0, objects, characters, shop};
|
||||
|
||||
const int RACE_CNT = 2; // TODO: update as you go
|
||||
const int RACE_CNT = 4; // TODO: update as you go
|
||||
|
||||
enum race {unknown = 0, rshade /* TODO: fill out the other races (including enemies) */};
|
||||
enum race {unknown = 0, rshade, rvampire, goblin /* TODO: fill out the other races (including enemies) */};
|
||||
|
||||
// TODO: fill out the other races (including enemies)
|
||||
const int MAX_HP[RACE_CNT] = {0, 125};
|
||||
const int STARTING_HP[RACE_CNT] = {0, 125};
|
||||
const int STARTING_ATK[RACE_CNT] = {0, 25};
|
||||
const int STARTING_DEF[RACE_CNT] = {0, 25};
|
||||
const char CHARACTER_REP[RACE_CNT] = {'@', 'S'};
|
||||
const int MAX_HP[RACE_CNT] = {0, 125, INF, 110};
|
||||
const int STARTING_HP[RACE_CNT] = {0, 125, 50, 110};
|
||||
const int STARTING_ATK[RACE_CNT] = {0, 25, 25, 15};
|
||||
const int STARTING_DEF[RACE_CNT] = {0, 25, 25, 20};
|
||||
const char CHARACTER_REP[RACE_CNT] = {'@', 'S', 'V', 'G'};
|
||||
|
||||
|
||||
|
||||
const int DIRECTION_CNT = 8;
|
||||
// IMPORTANT: east is positive for x and SOUTH is positive for y
|
||||
|
30
src/goblin.cc
Normal file
30
src/goblin.cc
Normal file
@ -0,0 +1,30 @@
|
||||
#include "goblin.h"
|
||||
#include <algorithm>
|
||||
#include <math.h>
|
||||
|
||||
|
||||
result goblin::attack(const direction dir, const character_list &chlist) {
|
||||
position tmp{pos + MOVE[dir]};
|
||||
|
||||
for (auto &ch : chlist)
|
||||
if (tmp == ch->get_position()) {
|
||||
auto res = ch->get_hit(race, ATK, base_hit_rate);
|
||||
if (res == result::died) {
|
||||
gold += GAIN_GOLD;
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
return result::fine;
|
||||
}
|
||||
|
||||
result goblin::get_hit(const enum race &race, const int atk,
|
||||
const float hitrate) {
|
||||
if (rng.rand_num() <= hitrate * (float)RAND_MAX)
|
||||
HP = std::max(HP - calc_dmg(atk, DEF), 0);
|
||||
|
||||
if (HP == 0)
|
||||
return result::died;
|
||||
|
||||
return result::hit;
|
||||
}
|
16
src/goblin.h
Normal file
16
src/goblin.h
Normal file
@ -0,0 +1,16 @@
|
||||
#ifndef __GOBLIN_H__
|
||||
#define __GOBLIN_H__
|
||||
#include "characters.h"
|
||||
|
||||
const int GAIN_GOLD = 5;
|
||||
|
||||
class goblin final: public character {
|
||||
public:
|
||||
goblin(const position_list &available_positions); // spawn at a random place
|
||||
virtual result attack(const direction dir,
|
||||
const character_list &chlist) override;
|
||||
virtual result get_hit(const enum race &race, const int atk,
|
||||
const float hit_rate) override;
|
||||
};
|
||||
|
||||
#endif
|
@ -15,16 +15,12 @@ result shade::attack(const direction dir, character_list &chlist) {
|
||||
|
||||
for (auto &ch : chlist)
|
||||
if (tmp == ch.get_position()) {
|
||||
return ch.get_hit(race, ATK, base_hitrate);
|
||||
return ch.get_hit(race, ATK, base_hit_rate);
|
||||
}
|
||||
|
||||
return result::fine;
|
||||
}
|
||||
|
||||
int calc_dmg(const int ATK, const int DEF) {
|
||||
return ceil((100 / (100 + DEF)) * ATK);
|
||||
}
|
||||
|
||||
result shade::get_hit(const enum race &race, const int atk,
|
||||
const float hitrate) {
|
||||
if (rng.rand_num() <= hitrate * (float)RAND_MAX) // This is a hit!
|
||||
@ -35,3 +31,4 @@ result shade::get_hit(const enum race &race, const int atk,
|
||||
|
||||
return result::hit;
|
||||
}
|
||||
|
||||
|
@ -16,10 +16,10 @@ public:
|
||||
virtual result attack(const direction dir,
|
||||
character_list &chlist) override;
|
||||
virtual result get_hit(const enum race &race, const int atk,
|
||||
const float hitrate) override;
|
||||
const float hit_rate) override;
|
||||
};
|
||||
|
||||
// TODO: fill out the other races
|
||||
|
||||
// TODO: implement enemie movement
|
||||
|
||||
#endif
|
||||
|
30
src/vampire.cc
Normal file
30
src/vampire.cc
Normal file
@ -0,0 +1,30 @@
|
||||
#include "vampire.h"
|
||||
#include <algorithm>
|
||||
#include <math.h>
|
||||
|
||||
|
||||
result vampire::attack(const direction dir, const character_list &chlist) {
|
||||
position tmp{pos + MOVE[dir]};
|
||||
|
||||
for (auto &ch : chlist)
|
||||
if (tmp == ch->get_position()) {
|
||||
auto res = ch->get_hit(race, ATK, base_hit_rate);
|
||||
if (res != result::miss) {
|
||||
HP += GAIN_HP;
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
return result::fine;
|
||||
}
|
||||
|
||||
result vampire::get_hit(const enum race &race, const int atk,
|
||||
const float hitrate) {
|
||||
if (rng.rand_num() <= hitrate * (float)RAND_MAX)
|
||||
HP = std::max(HP - calc_dmg(atk, DEF), 0);
|
||||
|
||||
if (HP == 0)
|
||||
return result::died;
|
||||
|
||||
return result::hit;
|
||||
}
|
16
src/vampire.h
Normal file
16
src/vampire.h
Normal file
@ -0,0 +1,16 @@
|
||||
#ifndef __VAMPIRE_H__
|
||||
#define __VAMPIRE_H__
|
||||
#include "characters.h"
|
||||
|
||||
const int GAIN_HP = 5;
|
||||
|
||||
class vampire final: public character {
|
||||
public:
|
||||
vampire(const position_list &available_positions); // spawn at a random place
|
||||
virtual result attack(const direction dir,
|
||||
const character_list &chlist) override;
|
||||
virtual result get_hit(const enum race &race, const int atk,
|
||||
const float hit_rate) override;
|
||||
};
|
||||
|
||||
#endif
|
Reference in New Issue
Block a user