• <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>
            隨筆-38  評論-23  文章-0  trackbacks-0

                   所謂的GraphicsContext  我這么翻譯它吧:圖形設備上下文?..就像在使用OpenGL在win32的窗口里繪制的時候.曾使用的hrc = wglCreateContext(hdc)一樣.創建一個圖形設備上下文 ,然后使用wglMakeCurrent(hdc,hrc)設置當前使用的圖形設備一樣.在這之后 我們就可以使用OGL繪制圖形一樣.osg中的GraphicsContext 就是跟hrc一樣的.只是它將所有需要的內容集成在GraphicsContext這個類當中.這就是面向對象的封裝性>_<.

                  在打開osg/GraphicsContext的頭文件當中.我們可以找到這么一些函數 swapBuffers()  makeCurrent() 等與我們之前所說的可以說十分相同的.因此對于在OSG當中需要最終顯示圖形的地方就是這個GraphicsContext .

                  相對來說,我們通常的第一個例子:
            第一個例子

                  這個時候我們得到的是一個全屏的窗口.這是默認的創建的一個GraphicsContext.( 通常情況下只有一個).它是通過執行 Viewer::realize()函數創建的.  最后執行View::setUpViewAcrossAllScreens() 創建全屏的GraphicsContext你可詳看源碼 就可以發現它就是創建一個GraphicsContext..并把它附加到viewer 的主攝像機上..因此我們最后看到的結果就是在全屏上顯示一頭牛...假設沒有這個GraphicsContext 就會看不到.在后面我會用一副圖來說明攝像機與GraphicsContext得關系.這是至關重要的.因為.每個攝像機若需要顯示場景.則必須要有一個GraphicsContext.來負責顯示.不管是主攝像機還是從攝像機.(Viewer可以有多個攝像機).

                  

                 在我們了解了GraphicsContext之后.其實上面這個圖已經給我們一個很大的啟發了.其實最后的GraphicsContext應當是GraphicsWindowWIN32或者GraphicsWindowX11等三個中的一個.這是面向對象多態性的體現.. 因此.我們現在就要開始創建一個GraphicsContext了.
                
                  在創建之前.我也許需要說明一個.static GraphicsContext* GraphicsContext::createGraphicsContext(Traits _traits) 需要傳入一個Traits的變量.因此我們需要了解這個Traits.
                  Traits.是什么呢?它GraphicsContext一些特征.我羅列一些能夠表示這些特征的屬性就能夠非常直白的說明這個對象了.
                   _traits->x   //x偏移
                   _traits->y   //y偏移
                   _traits->width //寬度
                   _traits->height //高度
                   _traits->doubleBuffer //是否支持雙緩存
                   _traits->sharedContext //共享GraphicsContext
                   _traits->windowName   //窗口名稱
                   _traits->windowDecoration //是否支持窗口一些裝飾屬性..如最大化 最小化等
                 
                   _traits->inheritedWindowData //繼承自某個窗口句柄?        這個可以用于嵌入到QT.MFC等GUI系統中.

            因此只要設置這些內容.并調用上面的方法則會創建一個GraphicsContext. .而如上那個函數關于創建GraphicsContext實則應當是調用了窗口系統API 來創建的.見如下函數:
            創建窗口的API

            當你去詳細閱讀 GraphicsWindowWIN32.cpp 文件和GraphicsWindow 頭文件時.你會發覺設計的非常巧妙. 用static全局靜態變量和 宏定義實現這個非常宏偉的API獲得...
            Function


            GetInterface

                 因此 假設我們使用的是Window系統 那么所創建的GraphicsContext 則win32模式的.那么具體的窗口創建或者說嵌入等.請詳細看GraphicsWindowWIN32.cpp 我們可以非常熟悉的看到開頭部分所敘述的wgl等函數..很熟悉吧..
                 說了這么多.我們是否應當創建一個窗口來實踐一下呢? 這將在之后的代碼當中詳細說出..
                 為了渲染與顯示圖形.. 我們需要一個視景器.osgViewer::Viewer ..Viewer當中包含一個主攝像機.因此我們不必在創建一個攝像機了.好了.開始代碼的敘述.由于我們只是創建一個簡單的WIN32窗口 并沒有嵌入MFC.只需設置一些相關的值即可.
                
            Window

            最后許多方面的注釋將會在源代碼中給出.附源代碼下載: 下載地址
            posted on 2009-08-22 21:21 米游 閱讀(6221) 評論(0)  編輯 收藏 引用 所屬分類: OpenGL/OSG
            欧美一级久久久久久久大片| 无码人妻久久一区二区三区| AAA级久久久精品无码片| 久久久久久人妻无码| 99久久99久久精品国产片果冻| 理论片午午伦夜理片久久 | 无码人妻少妇久久中文字幕蜜桃| 一本色道久久88精品综合 | 国产精品99久久久精品无码| 久久精品国产99久久久古代| 狠狠色婷婷综合天天久久丁香| 蜜臀久久99精品久久久久久| 亚洲va久久久噜噜噜久久| 久久91精品久久91综合| 日韩久久久久中文字幕人妻| 精品乱码久久久久久久| 亚洲人AV永久一区二区三区久久| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久久久人妻一区精品 | 国内精品久久久久影院优| 久久精品国产亚洲7777| 99久久99这里只有免费的精品| 亚洲国产精品综合久久一线 | 波多野结衣久久精品| 国产精品成人精品久久久| 日产精品久久久久久久| 久久这里都是精品| 性做久久久久久久久久久| 国产免费福利体检区久久| 精品国产乱码久久久久久郑州公司| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久九色综合九色99伊人| 91久久精品91久久性色| 亚洲午夜无码久久久久| 欧美激情一区二区久久久| 一本色综合久久| 久久免费看黄a级毛片| 久久99精品久久久久久9蜜桃| 国产精品久久久久久福利漫画| 狠狠色丁香久久婷婷综合蜜芽五月 | 久久99精品综合国产首页|