OpenGL正确显示纹理

时间:2012-07-04 07:57:35

标签: opengl textures render-to-texture

我在两个实际上具有相同位置和位置的表面上渲染纹理。

在这种情况下,我想只显示其中一个纹理,而我会跟随

enter image description here

即。我只希望显示第一种材质的纹理。

所以我想知道在哪里寻找解决方案,我应该使用材料的混合吗?

2 个答案:

答案 0 :(得分:4)

这是一个非常古老的问题(z-fighting)因为卡片不确定要在前面绘制哪个对象。链接的维基百科文章有更多这方面的例子。

要解决此问题,请增加深度缓冲区的精度(位深度),减小视图的深度(远/近剪裁平面的距离)或添加微小偏移,使坐标不再精确(或几乎)相同。您也可以简单地禁用深度缓冲区(或清除它)以进行渲染(在这种情况下,最后渲染的内容将与其他所有内容重叠)。

答案 1 :(得分:1)

你的意思是你想一次显示几个纹理?然后使用多纹理。使用以下方法将两个纹理附加到一个Quad:

glMultiTexCoord2fARB(GL_TEXTURE0_ARB, 0.0f, 0.0f);
glMultiTexCoord2fARB(GL_TEXTURE1_ARB, 0.0f, 0.0f);

glTexEnvi一起玩,根据需要组合它们。如果您只想显示一个纹理,则在每个纹理上绘制两个带有单独纹理的四边形。并且随后将绘制四元女巫将是可见的。然后,如果您想要从一个转到另一个,请为每个四边形单独-(void)个,在每个四边形图之前使用glClearColor,然后按下按钮以调用例如-(void)quad1和按钮致电-(void)quad2

或者只使用深度缓冲区。

在您的情况下,我会使用多纹理,因为所有缓冲区对我来说都太难了。


我将展示我的代码将如何显示。

使用多纹理的代码:

glClear(GL_COLOR_BUFFER_BIT);

//Turn on blending and set glBlendFunc for your needs
glEnable(GL_BLEND);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);

//Describing multitexturing
glClientActiveTexture(GL_TEXTURE0_ARB); //Activating texture on unit 0
glActiveTexture(GL_TEXTURE0_ARB); //Activating texture on unit 0
glBindTexture(GL_TEXTURE_2D, Texture1); //Bind texture on unit 0
glEnable(GL_TEXTURE_2D); //Enable GL_TEXTURE_2D to set it's glTexEnvi for your needs
glTexEnvi( GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE ); //Edit glTexEnvi for your needs (link bellow code)
glTexEnvi( GL_TEXTURE_ENV, GL_COMBINE_ALPHA, GL_INTERPOLATE );

glClientActiveTexture(GL_TEXTURE1_ARB); //Activating texture on unit 1
glActiveTexture(GL_TEXTURE1_ARB); //Activating texture on unit 1
glBindTexture(GL_TEXTURE_2D, Texture2); //Bind texture on unit 0
glEnable(GL_TEXTURE_2D); //Enable GL_TEXTURE_2D to set it's glTexEnvi for your needs
glTexEnvi( GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE ); //Edit glTexEnvi for your needs (link bellow code)
glTexEnvi( GL_TEXTURE_ENV, GL_COMBINE_ALPHA, GL_REPLACE );

//Drawing quad with multi texture
glBegin(GL_QUADS);
glMultiTexCoord2fARB(GL_TEXTURE0_ARB, 0.0f, 0.0f); //Texture on unit 0 coords
glMultiTexCoord2fARB(GL_TEXTURE1_ARB, 0.0f, 0.0f); //Texture on unit 1 coords 
glVertex2f(0.0, 500);
glMultiTexCoord2fARB(GL_TEXTURE0_ARB, 0.0f, 1.0f); //Texture on unit 0 coords
glMultiTexCoord2fARB(GL_TEXTURE1_ARB, 0.0f, 1.0f); //Texture on unit 1 coords 
glVertex2f(0.0, 0.0);
glMultiTexCoord2fARB(GL_TEXTURE0_ARB, 1.0f, 1.0f); //Texture on unit 0 coords
glMultiTexCoord2fARB(GL_TEXTURE1_ARB, 1.0f, 1.0f); //Texture on unit 1 coords  
glVertex2f(800, 0.0);
glMultiTexCoord2fARB(GL_TEXTURE0_ARB, 1.0f, 0.0f); //Texture on unit 0 coords
glMultiTexCoord2fARB(GL_TEXTURE1_ARB, 1.0f, 0.0f); //Texture on unit 1 coords 
glVertex2f(800, 500);
glEnd();

//Disable GL_TEXTURE_2D. We don't need it anymore
glDisable(GL_TEXTURE_2D);
//Disable blending
glDisable(GL_BLEND);
//Flush everything
glFlush();

为每个纹理使用一个四边形的代码

-(void) drawQuad1 
{
glClear(GL_COLOR_BUFFER_BIT);
glEnable(GL_TEXTURE_2D);
glBindTexture(GL_TEXTURE_2D, Texture1);
glBegin(GL_QUADS);
    glTexCoord2f(0.0f, 0.0f); glVertex2f(0.0, 500);
    glTexCoord2f(0.0f, 1.0f); glVertex2f(0.0, 0.0);
    glTexCoord2f(1.0f, 1.0f); glVertex2f(800, 0.0);
    glTexCoord2f(1.0f, 0.0f); glVertex2f(800, 500);
glEnd();
glDisable(GL_TEXTURE_2D)
glFlush();
}

-(void) drawQuad2
{
glClear(GL_COLOR_BUFFER_BIT);
glEnable(GL_TEXTURE_2D);
glBindTexture(GL_TEXTURE_2D, Texture2);
glBegin(GL_QUADS);
    glTexCoord2f(0.0f, 0.0f); glVertex2f(0.0, 500);
    glTexCoord2f(0.0f, 1.0f); glVertex2f(0.0, 0.0);
    glTexCoord2f(1.0f, 1.0f); glVertex2f(800, 0.0);
    glTexCoord2f(1.0f, 0.0f); glVertex2f(800, 500);
glEnd();
glDisable(GL_TEXTURE_2D)
glFlush();
}

//and now when you want to draw `drawQuad1` you need to do `[self drawQuad1];`
//and where you want to draw `drawQuad2` you need to do `[self drawQuad2];`

有关glTexEnvi here的信息。它只是示例代码。写得快,可能会有错误。对不起,如果我忘了什么。只是我很久没有这样做了。写在Mac OS X上,所以如果你使用其他平台maby,你将不得不改变一些东西(不是opengl)。关于深度缓冲?我不知道如何使用它。所以我无法为你解释。抱歉。从未使用过它们。