mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-24 17:54:59 +01:00
Remove unnecessary intersectRect() function
This function checked the intersection of rectangles, but it used floats for some reason when its only caller used ints. There's already an intersection function (UtilityClass::intersects()), so we should be using that one instead in order to minimize code duplication. Graphics::Hitest() is used for per-pixel collision detection, directly checking the pixels of both entities' sprites. I checked with one of my TASes and it still syncs, so I'm pretty sure this won't cause any issues.
This commit is contained in:
parent
154e81292e
commit
627e971e90
3 changed files with 3 additions and 8 deletions
|
@ -1396,7 +1396,9 @@ bool Graphics::Hitest(SDL_Surface* surface1, point p1, SDL_Surface* surface2, po
|
||||||
int r2_bottom = p2.y;
|
int r2_bottom = p2.y;
|
||||||
int r2_top = p2.y + surface2->h;
|
int r2_top = p2.y + surface2->h;
|
||||||
|
|
||||||
bool intersection = intersectRect(r1_left, r1_right, r1_bottom, r1_top, r2_left, r2_right, r2_bottom, r2_top);
|
SDL_Rect rect1 = {p1.x, p1.y, surface1->w, surface1->h};
|
||||||
|
SDL_Rect rect2 = {p2.x, p2.y, surface2->w, surface2->h};
|
||||||
|
bool intersection = help.intersects(rect1, rect2);
|
||||||
|
|
||||||
if(intersection)
|
if(intersection)
|
||||||
{
|
{
|
||||||
|
|
|
@ -501,11 +501,6 @@ void FillRect( SDL_Surface* _surface, SDL_Rect rect, int rgba )
|
||||||
SDL_FillRect(_surface, &rect, rgba);
|
SDL_FillRect(_surface, &rect, rgba);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool intersectRect( float left1, float right1, float bottom1, float top1, float left2, float right2, float bottom2, float top2 )
|
|
||||||
{
|
|
||||||
return !( left2 > right1 || right2 < left1 || top2 < bottom1 || bottom2 > top1);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OverlaySurfaceKeyed( SDL_Surface* _src, SDL_Surface* _dest, Uint32 _key )
|
void OverlaySurfaceKeyed( SDL_Surface* _src, SDL_Surface* _dest, Uint32 _key )
|
||||||
{
|
{
|
||||||
// const SDL_PixelFormat& fmt = *(_src->format);
|
// const SDL_PixelFormat& fmt = *(_src->format);
|
||||||
|
|
|
@ -39,8 +39,6 @@ void FillRect( SDL_Surface* surface, SDL_Rect& rect, const int r, int g, int b )
|
||||||
|
|
||||||
void FillRect( SDL_Surface* surface, SDL_Rect rect, int rgba );
|
void FillRect( SDL_Surface* surface, SDL_Rect rect, int rgba );
|
||||||
|
|
||||||
bool intersectRect(float left1, float right1, float bottom1, float top1, float left2, float right2, float bottom2, float top2);
|
|
||||||
|
|
||||||
void OverlaySurfaceKeyed(SDL_Surface* _src, SDL_Surface* _dest, Uint32 _key);
|
void OverlaySurfaceKeyed(SDL_Surface* _src, SDL_Surface* _dest, Uint32 _key);
|
||||||
|
|
||||||
void ScrollSurface(SDL_Surface* _src, int pX, int py);
|
void ScrollSurface(SDL_Surface* _src, int pX, int py);
|
||||||
|
|
Loading…
Add table
Reference in a new issue