纹理贴图的干扰问题

源代码下载

前几天对旋转闪屏这个问题很头疼,网上都是些Win32demo,我又分不清它移植到MFC上到底哪里出毛病了,今天总算找到了一篇有价值的文章,分析了它的代码,发现自己以前写的那个MFC里的框架基本上是对的,旋转也是采用定时器的方式来实现的,只是在设置像素格式的时候犯了一个小错误,才导致了闪屏的现象,修改后就没有这个毛病了。

      但今天又发现了一个奇怪的现象:如果要画两个物体,第一个不用纹理贴图,第2个要纹理贴图,我就发现第一个的颜色会干扰到纹理贴图的,结果两个物体的颜色都变得很怪了,怎么能让画完第一个物体后,它的颜色不对第2个产生影响呢?

200780901.jpg

      我想了这么一个办法:画完第一个物体后就:glColor3f(1.0f,1.0f,1.0f);可这样第2个是没有受到干扰了,但第一个又被干扰了。。。

200780902.jpg

接着向susu请教了下,她说可以在绘制每个物体前应该把当前状态先保存到堆栈中,再等绘制完后取出原来的状态,这样就可以避免相互干扰了。我试了下,可效果发现和上面一样,第2个是没有受到干扰了,但第一个又被干扰了。。。

None.gif int  COpenGLDemoView::DrawGLScene()                                   
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {// Here's Where We Do All The Drawing
InBlock.gif
    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);    // Clear Screen And Depth Buffer
InBlock.gif
    glPushAttrib(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT|GL_CURRENT_BIT);
InBlock.gif    glPushMatrix();
InBlock.gif    glShadeModel(GL_SMOOTH);
InBlock.gif    glLoadIdentity();                                    
// Reset The Current Modelview Matrix
InBlock.gif
    glTranslatef(-1.5f,0.0f,-6.0f);//物体左移1.5,向内移6,相当于移动镜头一样,让物体进入镜头中
InBlock.gif
    glRotatef(rTri,0.0f,1.0f,0.0f);
InBlock.gif    glBegin(GL_TRIANGLES);                            
// 绘制三角形
InBlock.gif
    glColor3f(1.0f,0.0f,0.0f);            // 红色
InBlock.gif
        glVertex3f( 0.0f1.0f0.0f);            // 三角形的上顶点 (前侧面)
InBlock.gif
        glColor3f(0.0f,1.0f,0.0f);            // 绿色
InBlock.gif
        glVertex3f(-1.0f,-1.0f1.0f);            // 三角形的左下顶点 (前侧面)
InBlock.gif
        glColor3f(0.0f,0.0f,1.0f);            // 蓝色
InBlock.gif
        glVertex3f( 1.0f,-1.0f1.0f);            // 三角形的右下顶点 (前侧面)
InBlock.gif
            glColor3f(1.0f,0.0f,0.0f);            // 红色
InBlock.gif
        glVertex3f( 0.0f1.0f0.0f);            // 三角形的上顶点 (右侧面)
InBlock.gif
        glColor3f(0.0f,0.0f,1.0f);            // 蓝色
InBlock.gif
        glVertex3f( 1.0f,-1.0f1.0f);            // 三角形的左下顶点 (右侧面)
InBlock.gif
        glColor3f(0.0f,1.0f,0.0f);            // 绿色
InBlock.gif
        glVertex3f( 1.0f,-1.0f-1.0f);            // 三角形的右下顶点 (右侧面)
InBlock.gif
            glColor3f(1.0f,0.0f,0.0f);            // 红色
InBlock.gif
        glVertex3f( 0.0f1.0f0.0f);            // 三角形的上顶点 (后侧面)
InBlock.gif
        glColor3f(0.0f,1.0f,0.0f);            // 绿色
InBlock.gif
        glVertex3f( 1.0f,-1.0f-1.0f);            // 三角形的左下顶点 (后侧面)
InBlock.gif
        glColor3f(0.0f,0.0f,1.0f);            // 蓝色
InBlock.gif
        glVertex3f(-1.0f,-1.0f-1.0f);            // 三角形的右下顶点 (后侧面)
InBlock.gif
glColor3f(1.0f,0.0f,0.0f);            // 红色
InBlock.gif
        glVertex3f( 0.0f1.0f0.0f);            // 三角形的上顶点 (左侧面)
InBlock.gif
        glColor3f(0.0f,0.0f,1.0f);            // 蓝色
InBlock.gif
        glVertex3f(-1.0f,-1.0f,-1.0f);            // 三角形的左下顶点 (左侧面)
InBlock.gif
        glColor3f(0.0f,1.0f,0.0f);            // 绿色
InBlock.gif
        glVertex3f(-1.0f,-1.0f1.0f);            // 三角形的右下顶点 (左侧面
InBlock.gif
    glEnd();                    &n
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值