2020-01-01 21:29:24 +01:00
|
|
|
#ifndef GRAPHICSUTIL_H
|
|
|
|
#define GRAPHICSUTIL_H
|
|
|
|
|
2020-07-19 06:21:27 +02:00
|
|
|
#include <SDL.h>
|
2020-01-01 21:29:24 +01:00
|
|
|
|
|
|
|
struct colourTransform
|
|
|
|
{
|
|
|
|
Uint32 colour;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
void setRect(SDL_Rect& _r, int x, int y, int w, int h);
|
|
|
|
|
|
|
|
SDL_Surface* GetSubSurface( SDL_Surface* metaSurface, int x, int y, int width, int height );
|
|
|
|
|
|
|
|
Uint32 ReadPixel( SDL_Surface *surface, int x, int y );
|
|
|
|
|
|
|
|
SDL_Surface * ScaleSurface( SDL_Surface *Surface, int Width, int Height, SDL_Surface * Dest = NULL );
|
|
|
|
|
|
|
|
void BlitSurfaceStandard( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _dest, SDL_Rect* _destRect );
|
|
|
|
|
|
|
|
void BlitSurfaceColoured( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _dest, SDL_Rect* _destRect, colourTransform& ct );
|
|
|
|
|
2020-06-30 00:05:57 +02:00
|
|
|
void BlitSurfaceTinted( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _dest, SDL_Rect* _destRect, colourTransform& ct );
|
|
|
|
|
2020-01-01 21:29:24 +01:00
|
|
|
void FillRect( SDL_Surface* surface, const int x, const int y, const int w, const int h, const int r, int g, int b );
|
|
|
|
|
|
|
|
void FillRect( SDL_Surface* surface, const int r, int g, int b );
|
|
|
|
|
|
|
|
void FillRect( SDL_Surface* surface, const int color );
|
|
|
|
|
|
|
|
void FillRect( SDL_Surface* surface, const int x, const int y, const int w, const int h, int rgba );
|
|
|
|
|
|
|
|
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 );
|
|
|
|
|
2021-02-26 00:26:12 +01:00
|
|
|
void ClearSurface(SDL_Surface* surface);
|
|
|
|
|
2020-01-01 21:29:24 +01:00
|
|
|
void ScrollSurface(SDL_Surface* _src, int pX, int py);
|
|
|
|
|
|
|
|
SDL_Surface * FlipSurfaceVerticle(SDL_Surface* _src);
|
Explicitly declare void for all void parameter functions (#628)
Apparently in C, if you have `void test();`, it's completely okay to do
`test(2);`. The function will take in the argument, but just discard it
and throw it away. It's like a trash can, and a rude one at that. If you
declare it like `void test(void);`, this is prevented.
This is not a problem in C++ - doing `void test();` and `test(2);` is
guaranteed to result in a compile error (this also means that right now,
at least in all `.cpp` files, nobody is ever calling a void parameter
function with arguments and having their arguments be thrown away).
However, we may not be using C++ in the future, so I just want to lay
down the precedent that if a function takes in no arguments, you must
explicitly declare it as such.
I would've added `-Wstrict-prototypes`, but it produces an annoying
warning message saying it doesn't work in C++ mode if you're compiling
in C++ mode. So it can be added later.
2021-02-25 23:23:59 +01:00
|
|
|
void UpdateFilter(void);
|
2020-01-01 21:29:24 +01:00
|
|
|
SDL_Surface* ApplyFilter( SDL_Surface* _src );
|
|
|
|
|
|
|
|
#endif /* GRAPHICSUTIL_H */
|