• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            doing5552

            記錄每日點滴,不枉人生一世

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              73 Posts :: 0 Stories :: 94 Comments :: 0 Trackbacks

            公告

            常用鏈接

            留言簿(24)

            我參與的團隊

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 455713
            • 排名 - 49

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            今天忽然感悟到為什么在進行變換之前要用glPushMatrix();這個函數,而在變換完畢后有用glPopMatrix()這兩個函數了,趕緊記下來:

                我們在變換坐標的時候,使用的是glTranslatef(),glRotaef()等函數來操作,操作的是什么呢?操作的是當前矩陣,我們也知道,這些坐標變換(翻轉,旋轉也好)都是通過操作矩陣來實現的,而矩陣相乘是會疊加的,當你用完一個變換函數后,當前操作的矩陣就被改變了,當你還停留在變換以前的思維,我在這個地方繪制恰好是我想要的時候,你會發現再繪制出來的不是在你想要的位置,因為你在操作變換的時候,當前矩陣被改變了。

               比如你在默認情況下在原點畫了一個球,然后又進行了一個變換,比如用glTranslatef( 0.0, 0.0, 1.0 );沿z軸移動一定距離又畫了一個球,然后你想再在原點畫一個大一點的球覆蓋原來的那個,當你繪制的時候就會發現,你現在繪制的球已不在你想像的地方了。

            我們來做個實驗:

            代碼如下:

            void display()
            {
            glClear( GL_COLOR_BUFFER_BIT );
            glShadeModel( GL_SMOOTH );

            //現在原點繪制一個紅色正方形
            glColor3f( 1.0, 0.0, 0.0 );
            glRectf( -0.05, -0.05, 0.05, 0.05 );

            //glPushMatrix();

            //變換--沿x軸移動
                glTranslatef( 0.2, 0.0, 0.0 );

                //glPopMatrix();

            //再繪制一個正方形
            glColor3f( 0.0, 1.0, 0.0 );
            glRectf( -0.05, -0.05, 0.05, 0.05 );//這時,當我們還想在同樣位置繪制時,卻發現已經偏移

            glFlush();
            }

             

                當我們把glPushMatrxi()和glPopMatrix()注釋掉以后我們發現,當我們再想在同樣的位置繪制一個正方形的時候,就會發現已經按我們的glTransfef()所指定的沿x軸偏移了0.2個單位。

            而當我們不把兩句函數調用注釋掉時,運行發現,綠色的正方形覆蓋了原來的紅色的正方形。

             

            所以,這兩個函數的壓棧彈棧是有用地~~~~~~~~~~

            這兩個函數的具體的執行方式就不扯了,網上n多。

            知之為知之,不知百度之

            ~~~~~~~~~~~~吼吼~~~~~~~~~~

            續文:

            頓悟這點以后,晚上又突然想明白了另一個大問題:移動光源的位置。

            在頓悟以前,總覺得光源該怎么移動呢?那不是十分十分麻煩么,而且不知道怎么辦,現在明白了這個道理以后,光照的移動就簡單了。

            移動方式:

                  先pushMatrix()一下,然后在進行移動操作,然后旋轉操作,然后指定光源的位置,然后PopMatrix()一下,就完成了。

            測試代碼:

            #include <gl/glut.h>

            static int spin = 0;

            void init()
            {
            glShadeModel( GL_SMOOTH );
                glEnable( GL_LIGHTING );
            glEnable( GL_LIGHT0 );
            glEnable( GL_DEPTH_TEST );

            }

            void display()
            {
            glClear( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT );

            GLfloat position[] = { 0.0, 0.0, 1.5, 1.0 };

            glPushMatrix();
            glTranslatef( 0.0, 0.0, -5.0 );

            glPushMatrix();
            glRotated( (GLdouble)spin, 1.0, 0.0, 0.0 );
            glLightfv( GL_LIGHT0, GL_POSITION, position );
            glTranslated( 0.0, 0.0, 1.5 );
            glDisable( GL_LIGHTING );
            glColor3f( 0.0, 1.0, 0.0 );
            glutWireCube( 0.1 );//綠色的下框,代表光源位置
            glEnable( GL_LIGHTING );
            glPopMatrix();

            glutSolidSphere( 0.5, 40, 40 );//被光照的物體
            glPopMatrix();
            glFlush();
            }

            void reshape( int w, int h )
            {
                glViewport( 0, 0, (GLsizei)w, (GLsizei)h );
            glMatrixMode( GL_PROJECTION );
            glLoadIdentity();
            gluPerspective( 40.0, (GLfloat)w/(GLfloat)h, 1.0, 20.0 );
            glMatrixMode( GL_MODELVIEW );
            glLoadIdentity();
            }

            void mouse( int button, int state, int x, int y )
            {
            switch ( button )
            {
            case GLUT_LEFT_BUTTON:
               if ( state == GLUT_DOWN )
               {
                spin = ( spin + 30 ) % 360;
                glutPostRedisplay();
               }
               break;
            default:
               break;
            }
            }

            int main( int argc, char ** argv )
            {
            glutInit( &argc, argv );
            glutInitDisplayMode( GLUT_RGB | GLUT_SINGLE | GLUT_DEPTH );
            glutInitWindowPosition( 100, 100 );
            glutInitWindowSize( 500, 500 );
            glutCreateWindow( argv[0] );
            init();
            glutDisplayFunc( display );
            glutReshapeFunc( reshape );
            glutMouseFunc( mouse );
            glutMainLoop();
            return 0;
            }

            posted on 2009-01-08 21:30 doing5552 閱讀(11899) 評論(0)  編輯 收藏 引用
            久久精品成人一区二区三区| 久久精品午夜一区二区福利| 国产精自产拍久久久久久蜜| 99久久综合国产精品二区| 热RE99久久精品国产66热| 国产aⅴ激情无码久久| 狠狠干狠狠久久| 久久九九兔免费精品6| 久久国产乱子精品免费女| 人妻少妇精品久久| 青青青国产成人久久111网站| 2021国内久久精品| 久久综合九色综合久99| 精品久久久久久久| 久久这里只有精品18| 亚洲欧洲精品成人久久曰影片| 久久久精品一区二区三区| 久久精品亚洲精品国产色婷| 思思久久99热只有频精品66| 精品久久久久久无码人妻热| 久久99精品国产自在现线小黄鸭 | 亚洲欧美日韩精品久久亚洲区 | 久久九九久精品国产免费直播| 国内精品伊人久久久久网站| 97超级碰碰碰久久久久| 一本久道久久综合狠狠爱| 久久国内免费视频| 久久久国产视频| 亚洲国产成人精品91久久久| 免费精品久久久久久中文字幕| 国内精品伊人久久久久网站| 伊人丁香狠狠色综合久久| 青青草国产成人久久91网| 久久久久高潮毛片免费全部播放| 亚洲香蕉网久久综合影视| 久久婷婷五月综合国产尤物app| 亚洲精品无码久久久久sm| 亚洲精品乱码久久久久久久久久久久 | 国内精品伊人久久久久AV影院| 亚洲AV无一区二区三区久久| 色偷偷偷久久伊人大杳蕉|