• <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>
            posts - 19,  comments - 21,  trackbacks - 0

            ?

            顯示圖形如何避免閃爍,如何提高顯示效率是問(wèn)得比較多的問(wèn)題。而且多數(shù)人認(rèn)為MFC的繪圖函數(shù)效率很低,總是想尋求其它的解決方案。
            MFC的繪圖效率的確不高但也不差,而且它的繪圖函數(shù)使用非常簡(jiǎn)單,只要使用方法得當(dāng),再加上一些技巧,用MFC可以得到效率很高的繪圖程序。
            我想就我長(zhǎng)期(呵呵當(dāng)然也只有2年多)使用MFC繪圖的經(jīng)驗(yàn)談?wù)勎业囊恍┯^點(diǎn)。

            1、顯示的圖形為什么會(huì)閃爍?
            ???我們的繪圖過(guò)程大多放在OnDraw或者OnPaint函數(shù)中,OnDraw在進(jìn)行屏幕顯示時(shí)是由OnPaint進(jìn)行調(diào)用的。當(dāng)窗口由于任何原因需要重繪時(shí),總是先用背景色將顯示區(qū)清除,然后才調(diào)用OnPaint,而背景色往往與繪圖內(nèi)容反差很大,這樣在短時(shí)間內(nèi)背景色與顯示圖形的交替出現(xiàn),使得顯示窗口看起來(lái)在閃。如果將背景刷設(shè)置成NULL,這樣無(wú)論怎樣重繪圖形都不會(huì)閃了。當(dāng)然,這樣做會(huì)使得窗口的顯示亂成一團(tuán),因?yàn)橹乩L時(shí)沒(méi)有背景色對(duì)原來(lái)繪制的圖形進(jìn)行清除,而又疊加上了新的圖形。有的人會(huì)說(shuō),閃爍是因?yàn)槔L圖的速度太慢或者顯示的圖形太復(fù)雜造成的,其實(shí)這樣說(shuō)并不對(duì),繪圖的顯示速度對(duì)閃爍的影響不是根本性的。例如在OnDraw(CDC *pDC)中這樣寫(xiě):
            pDC->MoveTo(0,0);
            pDC->LineTo(100,100);
            這個(gè)繪圖過(guò)程應(yīng)該是非常簡(jiǎn)單、非常快了吧,但是拉動(dòng)窗口變化時(shí)還是會(huì)看見(jiàn)閃爍。其實(shí)從道理上講,畫(huà)圖的過(guò)程越復(fù)雜越慢閃爍應(yīng)該越少,因?yàn)槔L圖用的時(shí)間與用背景清除屏幕所花的時(shí)間的比例越大人對(duì)閃爍的感覺(jué)會(huì)越不明顯。比如:清楚屏幕時(shí)間為1s繪圖時(shí)間也是為1s,這樣在10s內(nèi)的連續(xù)重畫(huà)中就要閃爍5次;如果清楚屏幕時(shí)間為1s不變,而繪圖時(shí)間為9s,這樣10s內(nèi)的連續(xù)重畫(huà)只會(huì)閃爍一次。這個(gè)也可以試驗(yàn),在OnDraw(CDC *pDC)中這樣寫(xiě):
            for(int i=0;i<100000;i++)
            {
            pDC->MoveTo(0,i);
            pDC->LineTo(1000,i);
            }
            呵呵,程序有點(diǎn)變態(tài),但是能說(shuō)明問(wèn)題。
            ???說(shuō)到這里可能又有人要說(shuō)了,為什么一個(gè)簡(jiǎn)單圖形看起來(lái)沒(méi)有復(fù)雜圖形那么閃呢?這是因?yàn)閺?fù)雜圖形占的面積大,重畫(huà)時(shí)造成的反差比較大,所以感覺(jué)上要閃得厲害一些,但是閃爍頻率要低。那為什么動(dòng)畫(huà)的重畫(huà)頻率高,而看起來(lái)卻不閃?這里,我就要再次強(qiáng)調(diào)了,閃爍是什么?閃爍就是反差,反差越大,閃爍越厲害。因?yàn)閯?dòng)畫(huà)的連續(xù)兩個(gè)幀之間的差異很小所以看起來(lái)不閃。如果不信,可以在動(dòng)畫(huà)的每一幀中間加一張純白的幀,不閃才怪呢。


            2、如何避免閃爍
            ???在知道圖形顯示閃爍的原因之后,對(duì)癥下藥就好辦了。首先當(dāng)然是去掉MFC提供的背景繪制過(guò)程了。實(shí)現(xiàn)的方法很多,
            * 可以在窗口形成時(shí)給窗口的注冊(cè)類(lèi)的背景刷付NULL
            * 也可以在形成以后修改背景
            ???static CBrush brush(RGB(255,0,0));
            ???SetClassLong(this->m_hWnd,GCL_HBRBACKGROUND,(LONG)(HBRUSH)brush);
            * 要簡(jiǎn)單也可以重載OnEraseBkgnd(CDC* pDC)直接返回TRUE
            ???這樣背景沒(méi)有了,結(jié)果圖形顯示的確不閃了,但是顯示也象前面所說(shuō)的一樣,變得一團(tuán)亂。怎么辦?這就要用到雙緩存的方法了。雙緩沖就是除了在屏幕上有圖形進(jìn)行顯示以外,在內(nèi)存中也有圖形在繪制。我們可以把要顯示的圖形先在內(nèi)存中繪制好,然后再一次性的將內(nèi)存中的圖形按照一個(gè)點(diǎn)一個(gè)點(diǎn)地覆蓋到屏幕上去(這個(gè)過(guò)程非??欤?yàn)槭欠浅R?guī)整的內(nèi)存拷貝)。這樣在內(nèi)存中繪圖時(shí),隨便用什么反差大的背景色進(jìn)行清除都不會(huì)閃,因?yàn)榭床灰?jiàn)。當(dāng)貼到屏幕上時(shí),因?yàn)閮?nèi)存中最終的圖形與屏幕顯示圖形差別很小(如果沒(méi)有運(yùn)動(dòng),當(dāng)然就沒(méi)有差別),這樣看起來(lái)就不會(huì)閃。


            3、如何實(shí)現(xiàn)雙緩沖
            ???首先給出實(shí)現(xiàn)的程序,然后再解釋,同樣是在OnDraw(CDC *pDC)中:

            CDC MemDC; //首先定義一個(gè)顯示設(shè)備對(duì)象
            CBitmap MemBitmap;//定義一個(gè)位圖對(duì)象

            //隨后建立與屏幕顯示兼容的內(nèi)存顯示設(shè)備
            MemDC.CreateCompatibleDC(NULL);
            //這時(shí)還不能繪圖,因?yàn)闆](méi)有地方畫(huà) ^_^
            //下面建立一個(gè)與屏幕顯示兼容的位圖,至于位圖的大小嘛,可以用窗口的大小
            MemBitmap.CreateCompatibleBitmap(pDC,nWidth,nHeight);

            //將位圖選入到內(nèi)存顯示設(shè)備中
            //只有選入了位圖的內(nèi)存顯示設(shè)備才有地方繪圖,畫(huà)到指定的位圖上
            CBitmap *pOldBit=MemDC.SelectObject(&MemBitmap);

            //先用背景色將位圖清除干凈,這里我用的是白色作為背景
            //你也可以用自己應(yīng)該用的顏色
            MemDC.FillSolidRect(0,0,nWidth,nHeight,RGB(255,255,255));

            //繪圖
            MemDC.MoveTo(……);
            MemDC.LineTo(……);

            //將內(nèi)存中的圖拷貝到屏幕上進(jìn)行顯示
            pDC->BitBlt(0,0,nWidth,nHeight,&MemDC,0,0,SRCCOPY);

            //繪圖完成后的清理
            MemBitmap.DeleteObject();
            MemDC.DeleteDC();

            上面的注釋?xiě)?yīng)該很詳盡了,廢話就不多說(shuō)了。

            ?

            posted on 2006-09-09 17:23 halCode 閱讀(1003) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): VC/MFC

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(7)

            隨筆分類(lèi)

            隨筆檔案

            文章分類(lèi)

            文章檔案

            相冊(cè)

            編程資源

            不務(wù)正業(yè)

            找工作

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久久无码一区二区三区| 久久久精品久久久久特色影视| 国产精品日韩深夜福利久久| 久久精品水蜜桃av综合天堂| 嫩草伊人久久精品少妇AV| 久久久无码精品亚洲日韩京东传媒 | 九九精品99久久久香蕉| 无码人妻久久久一区二区三区| 97久久国产露脸精品国产| 久久久久久伊人高潮影院| 亚洲AV无码久久精品成人| 久久久精品人妻一区二区三区蜜桃| 中文字幕久久久久人妻| 久久精品亚洲中文字幕无码麻豆| 久久亚洲精精品中文字幕| 99久久99久久久精品齐齐| 国产亚洲精品自在久久| 中文字幕亚洲综合久久| 久久精品一区二区影院| 最新久久免费视频| 久久亚洲精精品中文字幕| 大蕉久久伊人中文字幕| 日日狠狠久久偷偷色综合0| 久久精品国产亚洲AV影院| 久久影院综合精品| 国产三级观看久久| 亚洲伊人久久精品影院| 久久精品国产精品青草app| 亚洲&#228;v永久无码精品天堂久久 | 久久国产影院| 麻豆一区二区99久久久久| 99久久精品无码一区二区毛片| 香蕉久久夜色精品国产尤物| 久久99精品国产自在现线小黄鸭| 亚洲综合久久综合激情久久 | 亚洲精品国产成人99久久| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 狠狠干狠狠久久| 久久久久久久女国产乱让韩| 99久久精品国产毛片| 久久综合亚洲欧美成人|