fixed rectangles layout
This commit is contained in:
parent
ba4a36ffe5
commit
0bbce28469
3 changed files with 48 additions and 0 deletions
19
include/arc/graphics/rectangle.h
Normal file
19
include/arc/graphics/rectangle.h
Normal file
|
|
@ -0,0 +1,19 @@
|
||||||
|
#ifndef ARC_GRAPHICS_RECT_H_
|
||||||
|
#define ARC_GRAPHICS_RECT_H_
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "arc/graphics/color.h"
|
||||||
|
#include "arc/graphics/renderer.h"
|
||||||
|
#include "arc/math/rectangle.h"
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
void ARC_Rect_Render(ARC_Rect *rect, ARC_Renderer *renderer, ARC_Color *color);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // !ARC_GRAPHICS_RECT_H_
|
||||||
11
src/graphics/sdl/rectangle.c
Normal file
11
src/graphics/sdl/rectangle.c
Normal file
|
|
@ -0,0 +1,11 @@
|
||||||
|
#include "arc/graphics/rectangle.h"
|
||||||
|
#ifdef ARC_SDL
|
||||||
|
#include "arc/graphics/sdl/renderer.h"
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
void ARC_Rect_Render(ARC_Rect *rect, ARC_Renderer *renderer, ARC_Color *color){
|
||||||
|
SDL_SetRenderDrawColor(renderer->renderer, color->r, color->g, color->b, color->a);
|
||||||
|
SDL_RenderDrawRect(renderer->renderer, (SDL_Rect *) rect);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // ARC_SDL
|
||||||
18
src/math/rectangle.c
Normal file
18
src/math/rectangle.c
Normal file
|
|
@ -0,0 +1,18 @@
|
||||||
|
#include "arc/math/rectangle.h"
|
||||||
|
|
||||||
|
//VERY TEMP
|
||||||
|
#include <SDL.h>
|
||||||
|
|
||||||
|
int32_t ARC_Rect_Intersects(ARC_Rect *rect1, ARC_Rect *rect2){
|
||||||
|
if(rect1->x <= rect2->x + rect2->w && rect1->x + rect1->w >= rect2->x &&
|
||||||
|
rect1->y <= rect2->y + rect2->h && rect1->y + rect1->h >= rect2->y){
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t ARC_Rect_LineIntersects(ARC_Rect *rect, int32_t *x1, int32_t *y1, int32_t *x2, int32_t *y2){
|
||||||
|
//TODO: Replace soon
|
||||||
|
return SDL_IntersectRectAndLine((SDL_Rect *) rect, x1, y1, x2, y2);
|
||||||
|
}
|
||||||
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue