2022-09-11 10:16:50 +00:00
|
|
|
namespace hr {
|
|
|
|
|
|
|
|
namespace ads_game {
|
|
|
|
|
|
|
|
/** simulation speed */
|
2022-09-29 09:12:24 +00:00
|
|
|
ld ads_simspeed = TAU / 10;
|
|
|
|
ld ds_simspeed = M_PI / 10;
|
2022-09-28 20:10:09 +00:00
|
|
|
|
|
|
|
#define DS_(x) (main_rock ? ds_##x : ads_##x)
|
2022-09-11 10:16:50 +00:00
|
|
|
|
|
|
|
/** by how much do WAS keys accelerate */
|
2022-09-29 09:12:24 +00:00
|
|
|
ld ads_accel = 6 * ads_simspeed;
|
|
|
|
ld ds_accel = 15 * ds_simspeed;
|
2022-09-11 10:16:50 +00:00
|
|
|
|
2022-09-18 08:22:13 +00:00
|
|
|
/** cursor movement speed while paused */
|
2022-09-29 09:12:24 +00:00
|
|
|
ld pause_speed = 0.5;
|
2022-09-18 08:22:13 +00:00
|
|
|
|
|
|
|
/** time unit for time display */
|
2022-09-28 20:10:09 +00:00
|
|
|
ld ads_time_unit = TAU;
|
|
|
|
ld ds_time_unit = 1;
|
2022-09-18 08:22:13 +00:00
|
|
|
|
2022-09-17 13:16:04 +00:00
|
|
|
/** transform world coordinates to current view coordinates */
|
2022-09-11 10:16:50 +00:00
|
|
|
ads_matrix current;
|
|
|
|
|
2022-09-17 13:16:04 +00:00
|
|
|
/** transform world coordinates to ship coordinates (used when paused) */
|
|
|
|
ads_matrix current_ship;
|
|
|
|
|
2022-09-18 09:24:43 +00:00
|
|
|
/** hyperbolic cell closest to the current view/ship */
|
2022-09-18 15:02:15 +00:00
|
|
|
cell *vctr, *new_vctr, *vctr_ship;
|
2022-09-18 09:24:43 +00:00
|
|
|
|
2022-09-11 10:16:50 +00:00
|
|
|
/** world coordinates of vctr -- technically, this is a shiftmatrix */
|
2022-09-17 13:16:04 +00:00
|
|
|
ads_matrix vctrV, new_vctrV, vctrV_ship;
|
2022-09-11 10:16:50 +00:00
|
|
|
|
|
|
|
/** how far is vctr from the ship */
|
|
|
|
ld vctr_dist;
|
|
|
|
|
|
|
|
/** how is the ship shape rotated */
|
|
|
|
ld ang = 0;
|
|
|
|
|
|
|
|
/** ship's current proper time */
|
|
|
|
ld ship_pt;
|
|
|
|
|
2022-09-17 13:16:04 +00:00
|
|
|
/** paused camera's current proper time */
|
|
|
|
ld view_pt;
|
|
|
|
|
2022-09-12 10:57:52 +00:00
|
|
|
/** until when is the ship invincible */
|
|
|
|
ld invincibility_pt;
|
|
|
|
|
2022-09-11 10:16:50 +00:00
|
|
|
/** is the game paused */
|
|
|
|
bool paused;
|
|
|
|
|
|
|
|
/** auto-rotate the screen */
|
|
|
|
bool auto_rotate = false;
|
|
|
|
|
|
|
|
/** should we display the proper times of all objects */
|
|
|
|
bool view_proper_times = false;
|
|
|
|
|
|
|
|
/** format for displaying time */
|
|
|
|
const char *tformat = "%.2f";
|
|
|
|
|
|
|
|
void game_menu();
|
2022-09-18 08:22:25 +00:00
|
|
|
void restart();
|
2022-09-18 11:45:45 +00:00
|
|
|
void change_scale(ld s);
|
2022-09-11 10:16:50 +00:00
|
|
|
|
2022-09-11 11:42:51 +00:00
|
|
|
/** all the missiles and objects currently displayed */
|
2022-09-11 11:43:44 +00:00
|
|
|
vector<struct ads_object*> displayed;
|
2022-09-11 11:42:51 +00:00
|
|
|
|
2022-09-18 11:03:14 +00:00
|
|
|
/** how much should be the objects scaled */
|
2022-09-28 20:10:09 +00:00
|
|
|
ld ads_scale = 1;
|
|
|
|
ld ds_scale = 1;
|
2022-09-18 11:03:14 +00:00
|
|
|
|
2024-09-17 15:55:29 +00:00
|
|
|
ld time_scale = .1;
|
|
|
|
|
2022-09-11 11:42:51 +00:00
|
|
|
color_t missile_color = 0xFF0000FF;
|
|
|
|
|
2022-09-12 10:57:52 +00:00
|
|
|
bool game_over;
|
|
|
|
|
2024-10-01 20:15:29 +00:00
|
|
|
constexpr int score_types = 3;
|
|
|
|
|
2022-09-12 10:24:18 +00:00
|
|
|
struct player_data {
|
|
|
|
int hitpoints;
|
|
|
|
int ammo;
|
|
|
|
ld fuel;
|
|
|
|
ld oxygen;
|
2024-10-01 20:15:29 +00:00
|
|
|
int score[score_types];
|
2022-09-12 10:24:18 +00:00
|
|
|
};
|
|
|
|
|
2022-09-28 20:10:09 +00:00
|
|
|
ld ads_how_much_invincibility = TAU / 4;
|
|
|
|
ld ds_how_much_invincibility = TAU / 4;
|
2022-09-12 10:57:52 +00:00
|
|
|
|
2022-09-28 20:10:09 +00:00
|
|
|
player_data pdata, ads_max_pdata, ads_tank_pdata, ds_max_pdata, ds_tank_pdata;
|
2022-09-12 10:24:18 +00:00
|
|
|
|
2022-09-17 14:47:22 +00:00
|
|
|
bool auto_angle = true;
|
|
|
|
|
2022-09-18 10:58:18 +00:00
|
|
|
ld rock_density = 0.25;
|
|
|
|
ld rock_max_rapidity = 1.5;
|
|
|
|
|
2022-09-28 20:10:09 +00:00
|
|
|
ld ads_missile_rapidity = 3; // speed is tanh(3) = about 0.95c
|
|
|
|
ld ds_missile_rapidity = 3; // speed is tanh(3) = about 0.95c
|
2022-09-18 11:14:46 +00:00
|
|
|
|
|
|
|
ld crash_particle_rapidity = 1;
|
|
|
|
ld crash_particle_qty = 8;
|
|
|
|
ld crash_particle_life = .5;
|
|
|
|
|
|
|
|
ld fuel_particle_rapidity = 1;
|
|
|
|
ld fuel_particle_qty = 20;
|
|
|
|
ld fuel_particle_life = .15;
|
|
|
|
|
2022-09-18 08:22:13 +00:00
|
|
|
cell *starting_point;
|
|
|
|
|
2022-09-18 11:34:30 +00:00
|
|
|
int max_gen_per_frame = 3;
|
2024-09-17 16:26:14 +00:00
|
|
|
int draw_per_frame = 200;
|
2022-09-18 11:34:30 +00:00
|
|
|
|
2022-09-20 10:29:19 +00:00
|
|
|
/* for DS */
|
|
|
|
|
2022-09-28 19:26:43 +00:00
|
|
|
ads_object *main_rock;
|
|
|
|
|
2022-09-29 10:11:50 +00:00
|
|
|
extern string copyright_shown;
|
|
|
|
|
2023-08-08 10:05:18 +00:00
|
|
|
extern local_parameter_set lps_relhell, lps_relhell_space, lps_relhell_ads_spacetime, lps_relhell_ds_spacetime_pers, lps_relhell_ds_spacetime_klein;
|
2023-08-07 15:15:50 +00:00
|
|
|
|
2022-09-28 23:12:32 +00:00
|
|
|
int XSCALE = 48;
|
|
|
|
int YSCALE = 48;
|
2022-09-28 17:18:04 +00:00
|
|
|
int talpha = 32;
|
|
|
|
void init_textures();
|
|
|
|
void pick_textures();
|
|
|
|
void draw_textures();
|
2022-09-29 09:10:16 +00:00
|
|
|
void reset_textures();
|
|
|
|
|
|
|
|
void ds_restart();
|
|
|
|
void run_ads_game_std();
|
2024-06-25 15:11:06 +00:00
|
|
|
void add_ads_cleanup();
|
2022-09-29 09:10:16 +00:00
|
|
|
void run_ds_game();
|
2023-08-07 15:15:50 +00:00
|
|
|
void run_ds_game_std();
|
2024-06-25 15:11:06 +00:00
|
|
|
void add_ds_cleanup();
|
2022-10-09 11:15:57 +00:00
|
|
|
|
|
|
|
/** in the replay mode */
|
2023-02-03 14:28:37 +00:00
|
|
|
bool rev_replay;
|
2022-10-09 11:15:57 +00:00
|
|
|
bool in_replay;
|
|
|
|
void switch_replay();
|
2022-10-15 12:22:09 +00:00
|
|
|
void switch_pause();
|
2022-10-13 23:01:50 +00:00
|
|
|
void replay_animation();
|
|
|
|
|
2022-10-15 12:26:12 +00:00
|
|
|
bool in_spacetime();
|
|
|
|
void switch_spacetime();
|
|
|
|
void switch_spacetime_to(bool);
|
2022-10-13 23:01:50 +00:00
|
|
|
bool ads_draw_cell(cell *c, const shiftmatrix& V);
|
2022-10-15 12:23:53 +00:00
|
|
|
extern transmatrix Duality;
|
|
|
|
extern int use_duality;
|
2022-10-09 11:15:57 +00:00
|
|
|
|
2022-10-15 12:25:31 +00:00
|
|
|
ld spacetime_step = 0.1;
|
|
|
|
int spacetime_qty = 30;
|
2022-10-15 20:55:33 +00:00
|
|
|
|
|
|
|
color_t ghost_color = 0x800080FF;
|
|
|
|
|
2024-09-17 15:41:23 +00:00
|
|
|
/* types */
|
|
|
|
|
|
|
|
enum eObjType { oRock, oMissile, oParticle, oResource, oMainRock, oTurret, oTurretMissile };
|
2024-10-01 20:15:29 +00:00
|
|
|
enum eResourceType { rtNone, rtHull, rtAmmo, rtFuel, rtOxygen, rtGoldRocks, rtGoldGate, rtGoldTurret, rtGUARD };
|
2024-09-17 16:25:18 +00:00
|
|
|
enum eWalltype { wtNone, wtDestructible, wtSolid, wtGate, wtBarrier };
|
2024-09-17 15:41:23 +00:00
|
|
|
|
|
|
|
PPR obj_prio[7] = { PPR::MONSTER_BODY, PPR::ITEMa, PPR::ITEM_BELOW, PPR::ITEM, PPR::MONSTER_HEAD, PPR::MONSTER_BODY, PPR::ITEMa };
|
|
|
|
|
|
|
|
struct cell_to_draw {
|
|
|
|
cross_result center;
|
|
|
|
ld d;
|
|
|
|
cell *c;
|
|
|
|
ads_matrix V;
|
|
|
|
bool operator < (const cell_to_draw& c2) const { return d > c2.d; }
|
|
|
|
};
|
|
|
|
|
|
|
|
/** all cell_to_draw drawn currently */
|
|
|
|
std::unordered_map<cell*, cell_to_draw> cds, cds_last;
|
|
|
|
|
|
|
|
struct turret_state {
|
|
|
|
ld angle, dist;
|
|
|
|
int index;
|
|
|
|
ld err;
|
|
|
|
};
|
|
|
|
|
2024-10-01 20:15:29 +00:00
|
|
|
struct expiry_data {
|
|
|
|
int score;
|
|
|
|
int score_id;
|
|
|
|
};
|
|
|
|
|
2024-09-17 15:41:23 +00:00
|
|
|
struct ads_object {
|
|
|
|
eObjType type;
|
|
|
|
eResourceType resource;
|
|
|
|
cell *owner;
|
|
|
|
ads_matrix at;
|
|
|
|
color_t col;
|
2024-10-01 20:15:29 +00:00
|
|
|
expiry_data expire;
|
2024-09-17 15:41:23 +00:00
|
|
|
vector<ld>* shape;
|
|
|
|
ld last_shot;
|
|
|
|
int hlast;
|
|
|
|
|
|
|
|
map<ld, turret_state> turret_states;
|
|
|
|
|
|
|
|
ld life_start, life_end;
|
|
|
|
cross_result pt_main;
|
|
|
|
vector<cross_result> pts;
|
|
|
|
|
|
|
|
ads_object(eObjType t, cell *_owner, const ads_matrix& T, color_t _col) : type(t), owner(_owner), at(T), col(_col) {
|
|
|
|
life_start = -HUGE_VAL;
|
|
|
|
life_end = HUGE_VAL;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct shipstate {
|
|
|
|
ads_matrix at;
|
|
|
|
ads_matrix current;
|
|
|
|
ld start;
|
|
|
|
ld duration;
|
|
|
|
ld ang;
|
|
|
|
ads_matrix vctrV;
|
|
|
|
cell *vctr;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct cellinfo {
|
|
|
|
int mpd_terrain; /* 0 = fully generated terrain */
|
|
|
|
int rock_dist; /* rocks generated in this radius */
|
|
|
|
vector<std::unique_ptr<ads_object>> rocks;
|
|
|
|
vector<shipstate> shipstates;
|
|
|
|
eWalltype type;
|
|
|
|
cellinfo() {
|
|
|
|
mpd_terrain = 4;
|
|
|
|
rock_dist = -1;
|
|
|
|
type = wtNone;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-09-11 10:16:50 +00:00
|
|
|
}}
|