Sign in to follow this  
razieliyo

SDL color issues for per pixel collision.

Recommended Posts

razieliyo    121
Hi.

I'm trying to implement a per pixel collision function. I load the image with SDL_LoadBMP and then, set the transparent color with SDL_SetColorKey call. The next step is to store that key color with SDL_MapRGB inside a Uint32 (I think that matters for my issue). That member is which I'm going to use then to check if the pixel is "free" or not.

Everything seemed to fit, but I noticed that in the pixel array, the "free" color is, for example (magenta 0xFF00FF) 0xFFFF00FF, but the one that is created with SDL_MapRGB is 0xFF00FF. One more byte for the pixel array format, so I thought it was because of the alpha data that I missed when creating the transparent color with SDL_MapRGB. Tried with SDL_MapRGB and passing 255 or 0 as alpha argument.

Anyway, the problem persists. When I create the color with SDL_MapRGBA, the data stored is still 0xFF00FF, and the pixel array is 0xFFFF00FF.

Any idea about what's going wrong? Can it be a format issue? I've thought of discarding that 2 extra bytes with an AND bit operation, but don't know if it is very safe, and if it were, I don't think it's a good solution for my problem, there should be more sdl-color-format theory behind this.

MORE INFO: I'm accesing pixel array with, say:
[CODE]
// in constructor...
transparent = SDL_MapRGBA (255, 00, 255, 255); // also tried with alpha 0

// ..more code..
Uint32 *pix = (Uint32 *) surf->pixels;
// bla bla bla
if (pix[y*width + x] == transparent) return true;
[/CODE] to access pixel in (x,y) coordinates, maybe this is wrong, but don't really think so.

Thanks. Edited by razieliyo

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

Sign in to follow this