Revert "Windows Boundary Check exported as function (3 calls)"
This reverts commit cab35cb5e0
This commit is contained in:
parent
cab35cb5e0
commit
1a184471a7
37
asteroids.c
37
asteroids.c
@ -225,7 +225,12 @@ void BULLET_UpdateAlly(Bullet * bul, Asteroid * asts, int * astCount, Enemy * en
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
(bul->Location) = vectorAdd((bul->Location), (bul->Momentum)); // Move
|
(bul->Location) = vectorAdd((bul->Location), (bul->Momentum)); // Move
|
||||||
RECT_CheckBoundaries(&(bul->Location), &(bul->TargetRect)); // Check Boundaries
|
if ((bul->Location).x < 0.0f) (bul->Location).x = GAME_BoxWidth; // Check Boundaries
|
||||||
|
else if ((bul->Location).x > GAME_BoxWidth) (bul->Location).x = 0.0f;
|
||||||
|
if ((bul->Location).y < 0.0f) (bul->Location).y = GAME_BoxHeight;
|
||||||
|
else if ((bul->Location).y > GAME_BoxHeight) (bul->Location).y = 0.0f;
|
||||||
|
(bul->TargetRect).x = (int)round((bul->Location).x); // Update render Target
|
||||||
|
(bul->TargetRect).y = (int)round((bul->Location).y);
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < (*astCount); i++) { // Collide with Asteroids
|
for (i = 0; i < (*astCount); i++) { // Collide with Asteroids
|
||||||
if (!(asts[i].IsDestroyed)) {
|
if (!(asts[i].IsDestroyed)) {
|
||||||
@ -343,15 +348,6 @@ bool RECT_CircleCollide(SDL_Rect * rect1, SDL_Rect * rect2){
|
|||||||
return (distance(rect1, rect2) < round(((double)(rect1->w + rect2->w)) / 2.0f));
|
return (distance(rect1, rect2) < round(((double)(rect1->w + rect2->w)) / 2.0f));
|
||||||
}
|
}
|
||||||
|
|
||||||
void RECT_CheckBoundaries(Vector * location, SDL_Rect * Target){
|
|
||||||
if ((location->x) < -(Target->w)) (location->x) = GAME_BoxWidth; // Check Boundaries
|
|
||||||
else if ((location->x) > GAME_BoxWidth) (location->x) = -(Target->w);
|
|
||||||
if ((location->y) < -(Target->h)) (location->x) = GAME_BoxHeight;
|
|
||||||
else if ((location->y) > GAME_BoxHeight) (location->y) = -(Target->h);
|
|
||||||
(Target->x) = (int)round((location->x));
|
|
||||||
(Target->y) = (int)round((location->y));
|
|
||||||
}
|
|
||||||
|
|
||||||
double distance(SDL_Rect * r1, SDL_Rect * r2){
|
double distance(SDL_Rect * r1, SDL_Rect * r2){
|
||||||
double dx = (((double)(r2->x) + ((double)(r2->w) / 2.0f)) - ((double)(r1->x) + ((double)(r1->w) / 2.0f)));
|
double dx = (((double)(r2->x) + ((double)(r2->w) / 2.0f)) - ((double)(r1->x) + ((double)(r1->w) / 2.0f)));
|
||||||
double dy = (((double)(r2->y) + ((double)(r2->h) / 2.0f)) - ((double)(r1->y) + ((double)(r1->h) / 2.0f)));
|
double dy = (((double)(r2->y) + ((double)(r2->h) / 2.0f)) - ((double)(r1->y) + ((double)(r1->h) / 2.0f)));
|
||||||
@ -362,8 +358,14 @@ double distance(SDL_Rect * r1, SDL_Rect * r2){
|
|||||||
void ASTEROID_Update(Asteroid * ast){
|
void ASTEROID_Update(Asteroid * ast){
|
||||||
if (!(ast->IsDestroyed)) {
|
if (!(ast->IsDestroyed)) {
|
||||||
(ast->Rotation) += (ast->RotationValue); // Rotate
|
(ast->Rotation) += (ast->RotationValue); // Rotate
|
||||||
|
|
||||||
(ast->Location) = vectorAdd(ast->Location, ast->Momentum); // Update Position
|
(ast->Location) = vectorAdd(ast->Location, ast->Momentum); // Update Position
|
||||||
RECT_CheckBoundaries(&(ast->Location), &(ast->TargetRect)); // Reset position if object exits window
|
if ((ast->Location).x < -(ast->Size)) (ast->Location).x = GAME_BoxWidth; // Check Boundaries
|
||||||
|
else if ((ast->Location).x > GAME_BoxWidth) (ast->Location).x = -(ast->Size);
|
||||||
|
if ((ast->Location).y < -(ast->Size)) (ast->Location).y = GAME_BoxHeight;
|
||||||
|
else if ((ast->Location).y > GAME_BoxHeight) (ast->Location).y = -(ast->Size);
|
||||||
|
(ast->TargetRect).x = (int)round((ast->Location).x);
|
||||||
|
(ast->TargetRect).y = (int)round((ast->Location).y);
|
||||||
}
|
}
|
||||||
} // ASTEROID_Update
|
} // ASTEROID_Update
|
||||||
|
|
||||||
@ -412,8 +414,10 @@ void ENEMY_Update(Enemy * enm, Ship * targets, int targetCount){
|
|||||||
}
|
}
|
||||||
|
|
||||||
(enm->Location) = vectorAdd((enm->Location), (enm->Momentum)); // Update Position
|
(enm->Location) = vectorAdd((enm->Location), (enm->Momentum)); // Update Position
|
||||||
RECT_CheckBoundaries(&(enm->Location), &(enm->TargetRect)); // Check Boundaries
|
if ((enm->Location).x < -(enm->TargetRect).w) (enm->Location).x = GAME_BoxWidth;
|
||||||
|
else if ((enm->Location).x > GAME_BoxWidth + (enm->TargetRect).w) (enm->Location).x = 0.0f;
|
||||||
|
if ((enm->Location).y < -(enm->TargetRect).h) (enm->Location).y = GAME_BoxHeight;
|
||||||
|
else if ((enm->Location).y > GAME_BoxHeight + (enm->TargetRect).h) (enm->Location).y = 0.0f;
|
||||||
(enm->TargetRect).x = (int)round((enm->Location).x);
|
(enm->TargetRect).x = (int)round((enm->Location).x);
|
||||||
(enm->TargetRect).y = (int)round((enm->Location).y);
|
(enm->TargetRect).y = (int)round((enm->Location).y);
|
||||||
|
|
||||||
@ -500,7 +504,12 @@ void SHIP_Update(Ship * shp, Uint8 * keystate, Asteroid * asts, int * astCount,
|
|||||||
}
|
}
|
||||||
|
|
||||||
(shp->Location) = vectorAdd((shp->Location), (shp->Momentum)); // Update Position
|
(shp->Location) = vectorAdd((shp->Location), (shp->Momentum)); // Update Position
|
||||||
RECT_CheckBoundaries(&(shp->Location), &(shp->TargetRect_Gliding)); // Check Boundaries
|
if ((shp->Location).x < -(shp->TargetRect_Gliding).w) (shp->Location).x = GAME_BoxWidth;
|
||||||
|
else if ((shp->Location).x > GAME_BoxWidth + (shp->TargetRect_Gliding).w) (shp->Location).x = 0.0f;
|
||||||
|
if ((shp->Location).y < -(shp->TargetRect_Gliding).h) (shp->Location).y = GAME_BoxHeight;
|
||||||
|
else if ((shp->Location).y > GAME_BoxHeight + (shp->TargetRect_Gliding).h) (shp->Location).y = 0.0f;
|
||||||
|
(shp->TargetRect_Gliding).x = (int)round((shp->Location).x);
|
||||||
|
(shp->TargetRect_Gliding).y = (int)round((shp->Location).y);
|
||||||
(shp->TargetRect_Accelerating).x = (shp->TargetRect_Gliding).x;
|
(shp->TargetRect_Accelerating).x = (shp->TargetRect_Gliding).x;
|
||||||
(shp->TargetRect_Accelerating).y = (shp->TargetRect_Gliding).y;
|
(shp->TargetRect_Accelerating).y = (shp->TargetRect_Gliding).y;
|
||||||
|
|
||||||
|
16
asteroids.h
16
asteroids.h
@ -47,28 +47,30 @@ typedef struct asteroidStruct {
|
|||||||
void ASTEROIDS_InitializeGame(SDL_Renderer * renderer, int width, int height);
|
void ASTEROIDS_InitializeGame(SDL_Renderer * renderer, int width, int height);
|
||||||
void ASTEROIDS_DeinitializeGame();
|
void ASTEROIDS_DeinitializeGame();
|
||||||
void BULLET_Initialize(SDL_Renderer * renderer);
|
void BULLET_Initialize(SDL_Renderer * renderer);
|
||||||
void ENEMY_Initialize(SDL_Renderer * renderer);
|
|
||||||
void SHIP_Initialize(SDL_Renderer * renderer);
|
|
||||||
void ASTEROID_Initialize(SDL_Renderer * renderer);
|
|
||||||
void BULLET_Deinitialize();
|
void BULLET_Deinitialize();
|
||||||
void ENEMY_Deinitialize();
|
|
||||||
void ASTEROID_Deinitialize();
|
|
||||||
void SHIP_Deinitialize();
|
|
||||||
Bullet BULLET_Fire(Vector location, double direction, BulletType type);
|
Bullet BULLET_Fire(Vector location, double direction, BulletType type);
|
||||||
|
void BULLET_UpdateAlly(Bullet * bul, Asteroid * asts, int * astCount, Enemy * enemies, int * enemyCount);
|
||||||
|
void BULLET_UpdateEnemy(Bullet * bul, Ship * shp, int * shpCount);
|
||||||
|
void BULLET_Draw(Bullet * bul, SDL_Renderer * renderer);
|
||||||
|
void ASTEROID_Initialize(SDL_Renderer * renderer);
|
||||||
Asteroid ASTEROID_CreateRandom();
|
Asteroid ASTEROID_CreateRandom();
|
||||||
bool ASTEROID_TryDestroy(Asteroid * asts, int * astCount, int index);
|
bool ASTEROID_TryDestroy(Asteroid * asts, int * astCount, int index);
|
||||||
Asteroid ASTEROID_CreateFromSplit(Asteroid * creator);
|
Asteroid ASTEROID_CreateFromSplit(Asteroid * creator);
|
||||||
bool ASTEROID_CanSplit(Asteroid * ast);
|
bool ASTEROID_CanSplit(Asteroid * ast);
|
||||||
bool RECT_CircleCollide(SDL_Rect * rect1, SDL_Rect * rect2);
|
bool RECT_CircleCollide(SDL_Rect * rect1, SDL_Rect * rect2);
|
||||||
void RECT_CheckBoundaries(Vector * location, SDL_Rect * Target);
|
|
||||||
double distance(SDL_Rect * r1, SDL_Rect * r2);
|
double distance(SDL_Rect * r1, SDL_Rect * r2);
|
||||||
|
void ASTEROID_Deinitialize();
|
||||||
void ASTEROID_Update(Asteroid * ast);
|
void ASTEROID_Update(Asteroid * ast);
|
||||||
void ASTEROID_Draw(Asteroid * ast, SDL_Renderer * renderer);
|
void ASTEROID_Draw(Asteroid * ast, SDL_Renderer * renderer);
|
||||||
|
void ENEMY_Initialize(SDL_Renderer * renderer);
|
||||||
Enemy ENEMY_GetDefault();
|
Enemy ENEMY_GetDefault();
|
||||||
|
void ENEMY_Deinitialize();
|
||||||
void ENEMY_DestroyObject(Enemy * enm);
|
void ENEMY_DestroyObject(Enemy * enm);
|
||||||
void ENEMY_Update(Enemy * enm, Ship * targets, int targetCount);
|
void ENEMY_Update(Enemy * enm, Ship * targets, int targetCount);
|
||||||
void ENEMY_Draw(Enemy * enm, SDL_Renderer * renderer);
|
void ENEMY_Draw(Enemy * enm, SDL_Renderer * renderer);
|
||||||
|
void SHIP_Initialize(SDL_Renderer * renderer);
|
||||||
Ship SHIP_CreateDefault();
|
Ship SHIP_CreateDefault();
|
||||||
|
void SHIP_Deinitialize();
|
||||||
void SHIP_DestroyObject(Ship * shp);
|
void SHIP_DestroyObject(Ship * shp);
|
||||||
void SHIP_Update(Ship * shp, Uint8 * keystate, Asteroid * asts, int * astCount, Enemy * enemies, int * enemyCount);
|
void SHIP_Update(Ship * shp, Uint8 * keystate, Asteroid * asts, int * astCount, Enemy * enemies, int * enemyCount);
|
||||||
void SHIP_Draw(Ship * shp, SDL_Renderer * renderer);
|
void SHIP_Draw(Ship * shp, SDL_Renderer * renderer);
|
||||||
|
Loading…
Reference in New Issue
Block a user