• <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>
            隨筆 - 96  文章 - 255  trackbacks - 0
            <2008年2月>
            272829303112
            3456789
            10111213141516
            17181920212223
            2425262728291
            2345678

            E-mail:zbln426@163.com QQ:85132383 長期尋找對戰略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關網站

            我的個人網頁

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 492164
            • 排名 - 38

            最新評論

            閱讀排行榜

            評論排行榜

            作者:龍飛

            3.1:試驗——硬件渲染下關閉雙緩存。
            現象:front圖片出現不斷被“撕裂”的效果。

                    雙緩存的概念,是在計算機速度還不足以滿足“即時作圖”的情況下的一種技術。即,在屏幕(即前臺的幀緩存framebuffer)上顯示一幀圖片的同時,在后臺一個幀緩存的映射中作圖。這樣,只有當屏幕畫面需要改變的時候,后臺的緩存才交換到前臺來,這樣就避免了在前臺出現計算機“作圖”的過程。
                    關閉雙緩存之后,我們實際上看到的是計算機在不停的“作圖”——blit一次back,然后blit一次front,然后循環,所以被“撕裂”的畫面,實際上是back和front圖片“混合”的效果。
                    在軟件渲染的時候,為什么沒有雙緩存也不會出現這個問題呢?我的猜想是:圖片的像素數據實際上還是儲存在內存中的,無論是系統內存還是顯存,實際上都是通過一種影射提供給真正“成像”的幀緩存的。所以,實際上,無論軟渲染還是硬渲染,圖片實際上都是被“雙緩存”的,所不同的是,在使用硬件渲染的時候,SDL試圖給我們提供直接訪問硬件的接口,導致我們對創建在hw下的surface的操作,就類似在直接操作幀緩存,但是,我們是不是真的就直接訪問了幀緩存呢?

            3.2:試驗——單幀硬件渲染下打開雙緩存。
            現象:圖片出現閃爍。

                    閃爍實際上是圖片與一個空屏(全黑,0像素)交互顯示的結果。為了驗證這個猜想,我們可以嘗試blit同一個surface兩次,則可以解決這個問題。這個試驗其實更形象的顯示了什么是“雙”緩存,兩次blit可以讓兩個緩存都存儲上相同的圖片,渲染時候就不會出現閃爍。

            3.3:我們可以直接訪問緩存的地址嗎?

                    SDL官方推薦的那篇論文介紹可以通過pScreen->pixels查看像素緩存的地址,并且認為如果地址改變則映射交換緩存的實質是傳遞了數據結構的指針;而如果不變則是直接拷貝了數據結構的數據——事實真的是這樣嗎?
                    我們知道,pScreen是通過SDL_SetVideoMode()函數獲得的。這是一個特殊的surface,因為它既具有一般surface的屬性,而且也是SDL用于實際顯示的窗口surface。我們建立起pScreen的時候,并沒有賦予他任何的像素數據。
                    如果在軟件渲染的環境下,pScreen->pixels可以成功返回一個地址;但是在硬件渲染的環境下,pScreen->pixels則返回了空指針!這意味著什么?要么就真是一個空指針(因為pScreen實際上的像素數據為空),另外一個可能是——這個地址我們不可以訪問!我其實傾向于后者的解釋,因為軟件渲染下,同樣為空像素的pScreen并不返回空指針。所以,我的猜想是,SDL中,幀緩存并不能被直接訪問,但是我們可以訪問幀緩存的映射,并且模擬訪問幀緩存的效果。

            3.4:對于雙緩存現象的另外一種解釋。

                    在SDL官方推薦的那篇論文中,作者認為出現“撕裂”現象的原因是硬件加速與軟件的不同步。簡單來說,在軟件渲染情況下,語句被一條條逐步執行,比如:1、blit back;2、blit front;3、flip screen。這3個步驟,即使都需要一定的執行時間,也是有先后秩序的。但在硬件渲染環境下,這3條指令被程序直接仍給了顯卡,有可能前面兩次blit還沒執行完,就flip了。所以,作者認為,SDL_DOUBLEBUF位標的使用實際上是改變了SDL_Flip()的執行效果:無雙緩存的時候,將直接把當時的情況flip出來;打開雙緩存的時候,flip指令則成為了遞交了請求,然后不暫定的等待(所謂輪詢),直到所有的“作圖”指令執行完才顯示出來——似乎也說得過去,但是我以為如此解釋原理過于的復雜的。當然,也可能我對鳥語理解得不對,歡迎大家繼續討論這個話題。

            posted on 2008-02-15 17:35 lf426 閱讀(4125) 評論(4)  編輯 收藏 引用 所屬分類: SDL入門教程

            FeedBack:
            # 補充1 2008-02-15 18:15 lf426
            補充一個問題:當把一個surface blit 到另外一個surface上的時候,引起后者像素數據變化了嗎?或者說,源surface的數據“畫”到了目的surface上了嗎?我的試驗結果是,如果在blit后釋放源surface,程序會出現問題。這至少說明blit不是真正的“畫”圖。  回復  更多評論
              
            # re: SDL入門教程(四):3、SDL的軟、硬件渲染的深入試驗和分析 2010-10-16 20:58 fly
            對于實驗1.實驗結果,圖像平穩,并未有撕裂現象.用的代碼是上一節的.
            根據我的理解,對代碼做了以下修改:
            SCREEN_FLAGS = SDL_FULLSCREEN | SDL_HWSURFACE;
            去掉SDL_DOUBLEBUF.
            運行.圖片正常.

            對于實驗2.實驗結果并未出現閃爍.圖像平穩.
            恢復代碼.修改loopRender函數中的
            把源表面修改成任意相同的.
            if ( SDL_BlitSurface(pBack, pSrcRect, pScreen, pDstRect) != 0 )
            throw SDL_GetError();
            if ( SDL_BlitSurface(pBack, pSrcRect, pScreen, pDstRect) != 0 )
            throw SDL_GetError();


            我理解的對嗎?  回復  更多評論
              
            # re: SDL入門教程(四):3、SDL的軟、硬件渲染的深入試驗和分析[未登錄] 2011-06-16 08:54 wonder
            我和你做的一樣,也沒有出現作者說的實驗結果@fly
              回復  更多評論
              
            # re: SDL入門教程(四):3、SDL的軟、硬件渲染的深入試驗和分析 2011-08-04 17:32 waynewonk
            我出現了:去掉雙緩存,Front撕裂的情況。
            但是在單幀情況下沒有出現閃爍。  回復  更多評論
              
            亚洲香蕉网久久综合影视| 久久影视综合亚洲| 国产99久久精品一区二区| 国内精品久久久久影院优| 久久国产精品一区二区| 手机看片久久高清国产日韩| 久久人人爽人人人人片av| 国产精品美女久久久久网| 思思久久好好热精品国产 | 99久久免费只有精品国产| 亚洲国产精品成人AV无码久久综合影院 | 麻豆精品久久久一区二区| 久久久久久久91精品免费观看| 亚洲第一极品精品无码久久| 97热久久免费频精品99| 久久久久99精品成人片| 久久精品国产清高在天天线| 亚洲七七久久精品中文国产| 99久久国产免费福利| 精品久久久噜噜噜久久久| 久久久久久久精品妇女99| 91麻精品国产91久久久久| 亚洲AV无一区二区三区久久| 中文字幕无码av激情不卡久久| 久久99热精品| 久久精品国产91久久综合麻豆自制| 中文成人无码精品久久久不卡 | 久久久久亚洲精品无码网址 | 精品久久久久久中文字幕| 亚洲午夜久久久影院| 热久久最新网站获取| 亚洲精品97久久中文字幕无码| 精品久久久久久99人妻| 久久精品成人免费网站| 欧美综合天天夜夜久久| 国产成人综合久久综合| 久久91精品久久91综合| 波多野结衣中文字幕久久| 狠狠色婷婷久久一区二区三区| 久久精品a亚洲国产v高清不卡| 久久久久亚洲AV无码网站|