• <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
            欧洲精品久久久av无码电影| 久久久网中文字幕| 久久精品国产亚洲av水果派| AV狠狠色丁香婷婷综合久久 | 久久天天躁狠狠躁夜夜躁2O2O| 麻豆亚洲AV永久无码精品久久 | AV无码久久久久不卡蜜桃| 狠狠色婷婷久久综合频道日韩 | 久久精品成人| 精品免费久久久久久久| 久久影视综合亚洲| 久久r热这里有精品视频| 午夜视频久久久久一区| 久久亚洲高清观看| 囯产精品久久久久久久久蜜桃| 欧美精品一本久久男人的天堂| 亚洲国产精品无码久久久蜜芽| 久久九九免费高清视频| 99久久精品午夜一区二区 | 一本色道久久综合亚洲精品| 99久久精品国产一区二区| 国产情侣久久久久aⅴ免费| 久久AV高潮AV无码AV| 无码人妻少妇久久中文字幕| 久久婷婷国产麻豆91天堂| 国产精品99精品久久免费| 亚洲中文久久精品无码ww16 | 亚洲色婷婷综合久久| 欧美亚洲国产精品久久| 久久九九久精品国产免费直播| 狠狠久久亚洲欧美专区| 久久久青草青青亚洲国产免观| 色欲综合久久躁天天躁蜜桃 | 久久AAAA片一区二区| 青青草国产成人久久91网| 久久久久国产精品| 国产精品视频久久| 欧美精品一本久久男人的天堂| 女人香蕉久久**毛片精品| 国产精品99久久久久久猫咪| 一本久久久久久久|