Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

In OpenGL ES, how do I load a texture that has transparent pixels?

Tags:

opengl-es

And then have display correctly? An example would be having a round ball in a rectangle while being able to see another texture in the background.

edit: At the moment, when I load the texture the transparent pixels from the source image are displayed as black.

like image 815
Dimitris Avatar asked Mar 04 '09 16:03

Dimitris


2 Answers

For iPhone and N95 this works:

If you are loading texture from raw data, set internal and source format to GL_RGBA.

glTexImage2D(GL_TEXTURE_2D, 0, 
    GL_RGBA,
    textureWidth,
    textureHeight, 
    0, 
    GL_RGBA,
    GL_UNSIGNED_BYTE,
    pointerToPixels);

And when rendering, enable alpha blend:

glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glEnable(GL_BLEND);
like image 170
Virne Avatar answered Dec 17 '22 10:12

Virne


The answer provided by @Virne is correct, and I was able to use it for Android devices with a few small modifications. The myImage object I used is a standard .png image with transparency.

I created the texture using this:

GLUtils.texImage2D(GL10.GL_TEXTURE_2D, 0, myImage, 0);

And (like Virne), I enabled alpha blend when rendering:

gl.glBlendFunc(GL10.GL_SRC_ALPHA, GL10.GL_ONE_MINUS_SRC_ALPHA);
gl.glEnable(GL10.GL_BLEND);
like image 31
theisenp Avatar answered Dec 17 '22 09:12

theisenp