aboutsummaryrefslogtreecommitdiffstats
path: root/src/gameplay.cpp
diff options
context:
space:
mode:
authorsalaaad2 <arthurdurant263@gmail.com>2022-01-22 06:54:03 +0100
committersalaaad2 <arthurdurant263@gmail.com>2022-01-22 06:54:03 +0100
commitd5e16effbac565310c1a43869d8d1d72264b400c (patch)
tree3a452770afd9ec5608555cc6107ac876bfea4bef /src/gameplay.cpp
parentrework parsing and wave management (diff)
downloadthreshold-d5e16effbac565310c1a43869d8d1d72264b400c.tar.gz
threshold-d5e16effbac565310c1a43869d8d1d72264b400c.tar.bz2
threshold-d5e16effbac565310c1a43869d8d1d72264b400c.tar.xz
threshold-d5e16effbac565310c1a43869d8d1d72264b400c.tar.zst
threshold-d5e16effbac565310c1a43869d8d1d72264b400c.zip
Parsing: the great rework (tm) finally works as intended
Diffstat (limited to 'src/gameplay.cpp')
-rw-r--r--src/gameplay.cpp36
1 files changed, 23 insertions, 13 deletions
diff --git a/src/gameplay.cpp b/src/gameplay.cpp
index a522cba..276d9e9 100644
--- a/src/gameplay.cpp
+++ b/src/gameplay.cpp
@@ -11,6 +11,7 @@
#include <raylib.h>
#include <fstream>
#include <iostream>
+#include <memory>
#include <string>
#include "raymath.h"
@@ -36,8 +37,11 @@ Level* Game::parse(std::string const& path) {
}
if (tok == "BOSS") {
ifs >> tok;
- ret->nBoss = (tok == "0") ? 0 : 1;
- ret->bRadius = ret->mRadius;
+ ret->nBoss = std::atoi(tok.c_str());
+ ifs >> tok;
+ ret->bHp = std::atoi(tok.c_str());
+ ret->bRadius = 50;
+ std::cerr << "DEBUG: bosses : " << ret->nBoss << "\n";
}
if (tok == "NEXT") {
ifs >> tok;
@@ -112,6 +116,7 @@ Game::Game(std::string const& path) {
sourceRec = {0.0f, 0.0f, (float)frameWidth, (float)frameHeight};
origin = {(float)frameWidth, (float)frameHeight};
+ nEnemies = level->nTotal;
}
Game::~Game() {
@@ -125,6 +130,7 @@ void Game::draw() {
auto left = std::to_string(enemies->size());
for (auto& en : *enemies) {
+ DrawCircle(en.posX, en.posY, en.radius, GREEN);
if (en.hp <= 0)
DrawTextureEx(en.hurtTex,
(Vector2){en.posX - en.radius, en.posY - en.radius},
@@ -134,6 +140,12 @@ void Game::draw() {
(Vector2){en.posX - en.radius, en.posY - en.radius},
1.0f, 0.6f, WHITE);
}
+ if (en.hp > 1) {
+ for (auto j = 0; j < en.hp; j++) {
+ DrawRectangle(en.posX + (10 * j), en.posY - 100, 10, 10,
+ COOLPURPLE);
+ }
+ }
}
// Destination rectangle
Rectangle destRec = {player->posX, player->posY, frameWidth * 1.8f,
@@ -154,14 +166,8 @@ void Game::draw() {
i++) { // draw weapon ammo
DrawRectangle(40 + (i * 20), SCREENHEIGHT - 60, 10, 30, RED);
}
- if (enemies->at(0).hp >= 2) { // draw hp in boss stages
- for (auto i = 0; i < enemies->size(); i++) {
- if (enemies->at(i).hp >= 2) {
- for (auto j = 0; j < enemies->at(i).hp; j++) {
- DrawRectangle(400 + (j * 40), 80 + (i * 40), 40, 30,
- COOLPURPLE);
- }
- }
+ for (auto i = 0; i < enemies->size(); i++) {
+ if (enemies->at(i).hp >= 2) {
}
}
}
@@ -185,7 +191,9 @@ int Game::tick() {
// baddie logic
//
+ // std::cerr << "DEBUG: start baddie move loop \n";
for (auto en = enemies->begin(); en != enemies->end(); en++) {
+ // std::cerr << "DEBUG: direction :" << en->direction.x<< "\n";
if (en->hp > 0) {
if (en->posX >= SCREENWIDTH || en->posX <= 0) {
en->direction.x = -en->direction.x;
@@ -209,9 +217,10 @@ int Game::tick() {
en->posY += MINION_SPEED;
en->direction.y += 0.1f;
}
- if ((GetRandomValue(0, 100) ==
- 50) && // make enemy fire at random intervals
- (en->currentWeapon != nullptr)) {
+ if ((en->currentWeapon != nullptr) &&
+ (GetRandomValue(0, 100) ==
+ 50) // make enemy fire at random intervals
+ ) {
en->currentWeapon->bang(enemies, &(*en));
nEnemies++;
return (
@@ -223,6 +232,7 @@ int Game::tick() {
if (en->posX >= SCREENWIDTH || en->posX <= 0 ||
en->posY >= SCREENHEIGHT) {
enemies->erase(en);
+ std::cerr << "DEBUG: delete baddie" << std::endl;
return (0);
}
}