mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-25 02:04:58 +01:00
Merge pull request #647 from InfoTeddy/general-bug-fixes-4
Copy blend mode to recreated surfaces, fixing room name background during menu animation in Flip Mode
This commit is contained in:
commit
1163a8cca4
1 changed files with 57 additions and 34 deletions
|
@ -11,6 +11,55 @@ void setRect( SDL_Rect& _r, int x, int y, int w, int h )
|
||||||
_r.h = h;
|
_r.h = h;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static SDL_Surface* RecreateSurfaceWithDimensions(
|
||||||
|
SDL_Surface* surface,
|
||||||
|
const int width,
|
||||||
|
const int height
|
||||||
|
) {
|
||||||
|
SDL_Surface* retval;
|
||||||
|
SDL_BlendMode blend_mode;
|
||||||
|
|
||||||
|
if (surface == NULL)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
retval = SDL_CreateRGBSurface(
|
||||||
|
surface->flags,
|
||||||
|
width,
|
||||||
|
height,
|
||||||
|
surface->format->BitsPerPixel,
|
||||||
|
surface->format->Rmask,
|
||||||
|
surface->format->Gmask,
|
||||||
|
surface->format->Bmask,
|
||||||
|
surface->format->Amask
|
||||||
|
);
|
||||||
|
|
||||||
|
if (retval == NULL)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
SDL_GetSurfaceBlendMode(surface, &blend_mode);
|
||||||
|
SDL_SetSurfaceBlendMode(retval, blend_mode);
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
static SDL_Surface* RecreateSurface(SDL_Surface* surface)
|
||||||
|
{
|
||||||
|
if (surface == NULL)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return RecreateSurfaceWithDimensions(
|
||||||
|
surface,
|
||||||
|
surface->w,
|
||||||
|
surface->h
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
SDL_Surface* GetSubSurface( SDL_Surface* metaSurface, int x, int y, int width, int height )
|
SDL_Surface* GetSubSurface( SDL_Surface* metaSurface, int x, int y, int width, int height )
|
||||||
{
|
{
|
||||||
// Create an SDL_Rect with the area of the _surface
|
// Create an SDL_Rect with the area of the _surface
|
||||||
|
@ -21,15 +70,10 @@ SDL_Surface* GetSubSurface( SDL_Surface* metaSurface, int x, int y, int width, i
|
||||||
area.h = height;
|
area.h = height;
|
||||||
|
|
||||||
//Convert to the correct display format after nabbing the new _surface or we will slow things down.
|
//Convert to the correct display format after nabbing the new _surface or we will slow things down.
|
||||||
SDL_Surface* preSurface = SDL_CreateRGBSurface(
|
SDL_Surface* preSurface = RecreateSurfaceWithDimensions(
|
||||||
SDL_SWSURFACE,
|
metaSurface,
|
||||||
width,
|
width,
|
||||||
height,
|
height
|
||||||
metaSurface->format->BitsPerPixel,
|
|
||||||
metaSurface->format->Rmask,
|
|
||||||
metaSurface->format->Gmask,
|
|
||||||
metaSurface->format->Bmask,
|
|
||||||
metaSurface->format->Amask
|
|
||||||
);
|
);
|
||||||
|
|
||||||
// Lastly, apply the area from the meta _surface onto the whole of the sub _surface.
|
// Lastly, apply the area from the meta _surface onto the whole of the sub _surface.
|
||||||
|
@ -103,8 +147,7 @@ SDL_Surface * ScaleSurface( SDL_Surface *_surface, int Width, int Height, SDL_Su
|
||||||
SDL_Surface *_ret;
|
SDL_Surface *_ret;
|
||||||
if(Dest == NULL)
|
if(Dest == NULL)
|
||||||
{
|
{
|
||||||
_ret = SDL_CreateRGBSurface(_surface->flags, Width, Height, _surface->format->BitsPerPixel,
|
_ret = RecreateSurfaceWithDimensions(_surface, Width, Height);
|
||||||
_surface->format->Rmask, _surface->format->Gmask, _surface->format->Bmask, _surface->format->Amask);
|
|
||||||
if(_ret == NULL)
|
if(_ret == NULL)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -132,8 +175,7 @@ SDL_Surface * ScaleSurface( SDL_Surface *_surface, int Width, int Height, SDL_Su
|
||||||
|
|
||||||
SDL_Surface * FlipSurfaceVerticle(SDL_Surface* _src)
|
SDL_Surface * FlipSurfaceVerticle(SDL_Surface* _src)
|
||||||
{
|
{
|
||||||
SDL_Surface * ret = SDL_CreateRGBSurface(_src->flags, _src->w, _src->h, _src->format->BitsPerPixel,
|
SDL_Surface * ret = RecreateSurface(_src);
|
||||||
_src->format->Rmask, _src->format->Gmask, _src->format->Bmask, _src->format->Amask);
|
|
||||||
if(ret == NULL)
|
if(ret == NULL)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -168,16 +210,7 @@ void BlitSurfaceColoured(
|
||||||
|
|
||||||
const SDL_PixelFormat& fmt = *(_src->format);
|
const SDL_PixelFormat& fmt = *(_src->format);
|
||||||
|
|
||||||
SDL_Surface* tempsurface = SDL_CreateRGBSurface(
|
SDL_Surface* tempsurface = RecreateSurface(_src);
|
||||||
SDL_SWSURFACE,
|
|
||||||
_src->w,
|
|
||||||
_src->h,
|
|
||||||
fmt.BitsPerPixel,
|
|
||||||
fmt.Rmask,
|
|
||||||
fmt.Gmask,
|
|
||||||
fmt.Bmask,
|
|
||||||
fmt.Amask
|
|
||||||
);
|
|
||||||
|
|
||||||
for(int x = 0; x < tempsurface->w; x++)
|
for(int x = 0; x < tempsurface->w; x++)
|
||||||
{
|
{
|
||||||
|
@ -209,16 +242,7 @@ void BlitSurfaceTinted(
|
||||||
|
|
||||||
const SDL_PixelFormat& fmt = *(_src->format);
|
const SDL_PixelFormat& fmt = *(_src->format);
|
||||||
|
|
||||||
SDL_Surface* tempsurface = SDL_CreateRGBSurface(
|
SDL_Surface* tempsurface = RecreateSurface(_src);
|
||||||
SDL_SWSURFACE,
|
|
||||||
_src->w,
|
|
||||||
_src->h,
|
|
||||||
fmt.BitsPerPixel,
|
|
||||||
fmt.Rmask,
|
|
||||||
fmt.Gmask,
|
|
||||||
fmt.Bmask,
|
|
||||||
fmt.Amask
|
|
||||||
);
|
|
||||||
|
|
||||||
for (int x = 0; x < tempsurface->w; x++) {
|
for (int x = 0; x < tempsurface->w; x++) {
|
||||||
for (int y = 0; y < tempsurface->h; y++) {
|
for (int y = 0; y < tempsurface->h; y++) {
|
||||||
|
@ -295,8 +319,7 @@ void UpdateFilter(void)
|
||||||
|
|
||||||
SDL_Surface* ApplyFilter( SDL_Surface* _src )
|
SDL_Surface* ApplyFilter( SDL_Surface* _src )
|
||||||
{
|
{
|
||||||
SDL_Surface* _ret = SDL_CreateRGBSurface(_src->flags, _src->w, _src->h, _src->format->BitsPerPixel,
|
SDL_Surface* _ret = RecreateSurface(_src);
|
||||||
_src->format->Rmask, _src->format->Gmask, _src->format->Bmask, _src->format->Amask);
|
|
||||||
|
|
||||||
int redOffset = rand() % 4;
|
int redOffset = rand() % 4;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue