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

            Shuffy

            不斷的學習,不斷的思考,才能不斷的進步.Let's do better together!
            posts - 102, comments - 43, trackbacks - 0, articles - 19

            源代碼下載:OpenGL_ch2.rar 

            WGL – Windows OpenGL擴展層

            The WGL extension consists of a set of functions (wglCreateContext, wglDeleteContext etc.) and structures (such as PIXELFORMATDESCRIPTOR, GLYPHMETRICSFLOAT) etc. Thus every OpenGL implementation has a platform-specific portion which has to be set up and used according to the particular platform.

            設備上下文

            The Windows Graphical Device Interface (GDI) is capable of drawing to screen, to memory, to printers or to any other device that provides a GDI interface layer and that can process GDI calls. GDI accomplishes this by a rendering handle to the currently selected device, which is called the device context, or DC.

            繪制上下文

            A rendering context is the OpenGL equivalent of the GDI DC. All OpenGL calls are rendered to the device through a RC. The rendering context maintains OpenGL state variables such as current background color, current color etc. just as the DC maintains GDI state variables such as current pen, current brush etc.

            像素格式

            Pixel formats are the translation layer between OpenGL calls and the rendering operation that Windows performs.

            舉個例子,若像素格式只支持很少一部分顏色值,則OpenGL在用RGB(128,120,135)繪制一個像素時,就可能使用轉換后的值(128,128,128)來繪制.

            The pixel format selected essentially describes such things as how colors are displayed, depth of field resolution and what additional capabilities are supported by the rendering context created.

            第一個基于MFCOpenGL應用程

            開發環境:VC6.0

            1, 首先下載需要的GLUT頭文件,DLLLib文件,下載鏈接: glutdlls37beta.zip (149 kilobytes),解壓縮后把gltu.h放到"VC98/Include/GL"下,把glut.libglut32.lib放到"VC9/Lib" 下glut32.dllglut.dll放到你創建的應用程序的運行目錄下

            2, 創建一個MFC SDI應用程序,在項目屬性中加入所需要鏈接的庫文件

            1, stdafx.h中加入下列語句:

            //OpenGL Headers

            #include 
            <gl/gl.h>

            #include 
            <gl/glu.h>

            #include 
            <gl/glut.h>

            #include 
            <gl/glaux.h>

            2, 打開ClassWizard,選擇CCY457OpenGLView類,為下述消息加入消息處理函數:WM_CREATE (for OnCreate), WM_DESTROY (for OnDestroy), WM_SIZE (for OnSize), WM_ERASEBACKGROUND (for OnEraseBkground).

            3,在窗口創建之前我們必須設置窗口風格包含WS_CLIPCHILDREN WS_CLIPSIBLINGS,從而避免OpenGL繪制到其他窗口中去。這些應該放在PreCreateWindow()中。

            BOOL CCY457OpenGLView::PreCreateWindow(CREATESTRUCT& cs)
            {
                
            // TODO: Modify the Window class or styles here by modifying
                
            //  the CREATESTRUCT cs
                
            //An OpenGL Window must be created with the following flags
                cs.style |= WS_CLIPSIBLINGS | WS_CLIPCHILDREN;
                
            return CView::PreCreateWindow(cs);
            }

            4, CCY457OpenGLView.h中加入如下語句:

                HGLRC m_hRC;    //Rendering Context
                CDC* m_pDC;        //Device Context
                BOOL InitializeOpenGL();    //Initialize OpenGL
                BOOL SetupPixelFormat();    //Set up the Pixel Format
                void RenderScene();            //Render the Scene

            5, OnCreate中我們將通過建立像素格式和繪制上下文來初始化OpenGL. InitializeOpenGL()中會創建一個設備上下文(DC),為這個DC選擇一個像素格式,創建和這個DC相關的繪制上下文(RC,然后選擇這個RC.這個函數會調用SetupPixelFormat()來建立像素格式。

            int CCY457OpenGLView::OnCreate(LPCREATESTRUCT lpCreateStruct) 
            {
                
            if (CView::OnCreate(lpCreateStruct) == -1)
                    
            return -1;
                
            //Initialize OpenGL Here
                InitializeOpenGL();
                
            return 0;
            }

            BOOL CCY457OpenGLView::InitializeOpenGL()
            {
                
            //Get a DC for the Client Area
                m_pDC = new CClientDC(this);
                
            //Failure to Get DC
                if(m_pDC == NULL)
                {
                    MessageBox(
            "Error Obtaining DC");
                    
            return FALSE;
                }
                
            //Failure to set the pixel format
                if(!SetupPixelFormat())
                {
                    
            return FALSE;
                }
                
            //Create Rendering Context
                m_hRC = ::wglCreateContext (m_pDC->GetSafeHdc ());
                
            //Failure to Create Rendering Context
                if(m_hRC == 0)
                {
                    MessageBox(
            "Error Creating RC");
                    
            return FALSE;
                }
                
            //Make the RC Current
                if(::wglMakeCurrent (m_pDC->GetSafeHdc (), m_hRC)==FALSE)
                {
                    MessageBox(
            "Error making RC Current");
                    
            return FALSE;
                }
                
            //Specify Black as the clear color
                ::glClearColor(0.0f,0.0f,0.0f,0.0f);
                
            //Specify the back of the buffer as clear depth
                ::glClearDepth(1.0f);
                
            //Enable Depth Testing
                ::glEnable(GL_DEPTH_TEST);
                
            return TRUE;
            }
            //Setup Pixel Format
            /////////////////////////////////////////////////////////////////////////////
            BOOL CCY457OpenGLView::SetupPixelFormat()
            {
              
            static PIXELFORMATDESCRIPTOR pfd = 
                {
                    
            sizeof(PIXELFORMATDESCRIPTOR),  // size of this pfd
                    1,                              // version number
                    PFD_DRAW_TO_WINDOW |            // support window
                    PFD_SUPPORT_OPENGL |            // support OpenGL
                    PFD_DOUBLEBUFFER,                // double buffered
                    PFD_TYPE_RGBA,                  // RGBA type
                    24,                             // 24-bit color depth
                    000000,               // color bits ignored
                    0,                              // no alpha buffer
                    0,                              // shift bit ignored
                    0,                              // no accumulation buffer
                    0000,                     // accum bits ignored
                    16,                             // 16-bit z-buffer
                    0,                              // no stencil buffer
                    0,                              // no auxiliary buffer
                    PFD_MAIN_PLANE,                 // main layer
                    0,                              // reserved
                    000                         // layer masks ignored
                };
                
            int m_nPixelFormat = ::ChoosePixelFormat(m_pDC->GetSafeHdc(), &pfd);
                
            if ( m_nPixelFormat == 0 )
                {
                   
            return FALSE;
                }
                
            if ( ::SetPixelFormat(m_pDC->GetSafeHdc(), m_nPixelFormat, &pfd) == FALSE)
                {
                   
            return FALSE;
                }
                
            return TRUE;
            }

            6, OnSize()中一般用來設置視口和視錐,因為這些是和窗口大小相關的。基本操作包括設置視口,選擇投影矩陣,設置模型視圖矩陣。

            void CCY457OpenGLView::OnSize(UINT nType, int cx, int cy) 
            {
                CView::OnSize(nType, cx, cy);
                GLdouble aspect_ratio; 
            // width/height ratio
                
                
            if ( 0 >= cx || 0 >= cy )
                {
                    
            return;
                }
                
            // select the full client area
                ::glViewport(00, cx, cy);
                
            // compute the aspect ratio
                
            // this will keep all dimension scales equal
                aspect_ratio = (GLdouble)cx/(GLdouble)cy;
                
            // select the projection matrix and clear it
                ::glMatrixMode(GL_PROJECTION);
                ::glLoadIdentity();
                
            // select the viewing volume
                ::gluPerspective(45.0f, aspect_ratio, .01f, 200.0f);
                
                
            // switch back to the modelview matrix and clear it
                ::glMatrixMode(GL_MODELVIEW);
                ::glLoadIdentity();
            }

            7,在繪制場景時,一般包括如下步驟:1)清空緩存。2)繪制場景。3Flush掉渲染流水線。4)若設置了雙緩沖,則交換前后臺緩沖區。

            void CCY457OpenGLView::OnDraw(CDC* pDC)
            {
                CCY457OpenGLDoc
            * pDoc = GetDocument();
                ASSERT_VALID(pDoc);
                
            // Clear out the color & depth buffers
                ::glClear( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT );
                RenderScene();
                
            // Tell OpenGL to flush its pipeline
                ::glFinish();
                
            // Now Swap the buffers
                ::SwapBuffers( m_pDC->GetSafeHdc() );
            }
            void CCY457OpenGLView::RenderScene ()
            {
            //第一個玩具嘛,先空著,后面慢慢填
            }

            8,試試改變窗口的大小,你會看到很嚴重的閃爍,并且關閉程序后會報告內存泄露,因此我們這就來解決這兩個問題吧。

            發生閃爍的原因是Windows先繪制背景,然后再是OpenGL繪制,因為我們已經讓OpenGL負責清空背景色,因此我們不需要Windows去清空背景了

            BOOL CCY457OpenGLView::OnEraseBkgnd(CDC* pDC) 
            {
                
            //Tell Windows not to erase the background
                return TRUE;
            }

                 內存泄露的原因是我們在SetupPixelFormat()中使用了new運算符來為CClientDC對象分配內存,因此需要顯示delete掉。

            void CCY457OpenGLView::OnDestroy() 
            {
                CView::OnDestroy();
                
            //Make the RC non-current
                if(::wglMakeCurrent (0,0== FALSE)
                {
                    MessageBox(
            "Could not make RC non-current");
                }
                
                
            //Delete the rendering context
                if(::wglDeleteContext (m_hRC)==FALSE)
                {
                    MessageBox(
            "Could not delete RC");
                }
                
            //Delete the DC
                if(m_pDC)
                {
                    delete m_pDC;
                }
                
            //Set it to NULL
                m_pDC = NULL;
            }

             

            作者:洞庭散人

            出處:http://phinecos.cnblogs.com/    

            本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
            原文鏈接:http://www.cnblogs.com/phinecos/archive/2008/11/04/1326687.html
            久久精品三级视频| 97精品国产97久久久久久免费 | 国产精品视频久久| 国产精品久久一区二区三区| 久久久国产精品亚洲一区 | 久久99精品国产99久久6| 成人午夜精品久久久久久久小说| 色综合久久中文综合网| 香蕉久久影院| 久久久国产亚洲精品| 狠狠色丁香久久婷婷综合图片| 一本色道久久综合狠狠躁| 精品无码久久久久久尤物| 97久久超碰国产精品旧版| 69久久夜色精品国产69| 久久综合一区二区无码| 国产精品国色综合久久| 国产精品va久久久久久久| 久久精品卫校国产小美女| 精品99久久aaa一级毛片| 狠狠色婷婷久久一区二区三区| 色婷婷久久综合中文久久一本| 国内精品九九久久久精品| 久久成人国产精品免费软件| 久久99国产精品久久99| 亚洲中文字幕无码一久久区| 亚洲国产精品一区二区三区久久| 91精品国产9l久久久久| 人人狠狠综合久久亚洲88| 亚洲国产精品久久66| 久久亚洲中文字幕精品一区| 久久婷婷国产麻豆91天堂| 久久国产乱子伦精品免费强| 久久青青草原国产精品免费| 国产激情久久久久影院| 香蕉aa三级久久毛片| 久久精品国产AV一区二区三区| 精品多毛少妇人妻AV免费久久| 久久丫精品国产亚洲av不卡| 久久精品www人人爽人人| 国产亚洲成人久久|