• <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)

            我參與的團隊

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 455286
            • 排名 - 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 閱讀(11889) 評論(0)  編輯 收藏 引用
            99热都是精品久久久久久| 伊色综合久久之综合久久| 久久久一本精品99久久精品66| 亚洲精品乱码久久久久久久久久久久 | 国产成人精品白浆久久69| 伊人久久精品线影院| 久久久黄色大片| 色综合久久中文综合网| 99久久这里只精品国产免费| 久久ww精品w免费人成| 香蕉久久影院| 久久99国产精品99久久| 亚洲Av无码国产情品久久| 国产精品久久久久影院嫩草| 久久毛片一区二区| 品成人欧美大片久久国产欧美| 亚洲精品白浆高清久久久久久| 久久久精品国产亚洲成人满18免费网站| 午夜天堂精品久久久久| 亚洲欧洲久久久精品| 国内精品久久久久久久coent| 亚洲AV无码久久| 久久婷婷五月综合国产尤物app| 久久精品99无色码中文字幕| 99国产精品久久久久久久成人热| 久久精品免费一区二区| 热久久最新网站获取| 久久午夜免费视频| 久久影院久久香蕉国产线看观看| 青青青青久久精品国产 | 亚洲中文精品久久久久久不卡| 久久久久无码中| 久久久久这里只有精品| 久久九九久精品国产免费直播| …久久精品99久久香蕉国产| 99久久免费国产精品热| 国产精品久久久久久福利69堂| 国内精品久久九九国产精品| 久久精品国产99国产电影网| 狠狠色丁香久久综合婷婷| 99久久人人爽亚洲精品美女|