<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    春天花會開

    ***********

    統計

    留言簿(4)

    閱讀排行榜

    評論排行榜

    2010年6月9日 #

    Windows GDI、GDI+ 繪圖 防閃爍

    “閃爍”的原因是擦除背景(用背景色重新填充)與繪制前景圖像之間有時間差,而且背景和前景顏色有差異,導致眼睛看上去好像在閃爍。
    “閃爍”并不主要是因為GDI或GDI+效率低造成的。

    解決這個問題需從兩個方面入手:1.縮短(或消除)前后景繪圖時間差,2.減少繪制次數
    1.縮短(或消除)前后景繪圖時間差
    OnEraseBkgnd(CDC* pDC)
    {
        return TRUE;
    }

    實際上背景填充是必須,否則前景圖像與殘留的背景混在一起非常雜亂,
    這里取消的步驟,其實移到繪圖過程了(見2.),合成一張完整圖像。

    2.減少繪制次數
    采用“雙緩沖”技術,先在內存緩沖區中完成繪圖,再貼到屏幕上
    另外如果緩沖圖像內容不是變化的,應存為成員對象之類,不要每次去畫
    一般在OnDraw(CDC* pDC)中完成
    ///////////////////////////--GDI --////////////////////////////////////
    int nWidth=1000;
    int nHeight=1000;
    CDC MemDC; //首先定義一個顯示設備對象
    CBitmap MemBitmap;//定義一個位圖對象
    //隨后建立與屏幕顯示兼容的內存顯示設備
    MemDC.CreateCompatibleDC(pDC); //這時還不能繪圖,因為沒有地方畫 ^_^
    //下面建立一個與屏幕顯示兼容的位圖,至于位圖的大小嘛,可以用窗口的大小
    //,也可以自己定義(如:有滾動條時就要大于當前窗口的大小,在BitBlt時決定拷貝內存的哪部分到屏幕上)

    MemBitmap.CreateCompatibleBitmap(pDC,nWidth,nHeight);
    //將位圖選入到內存顯示設備中
    //只有選入了位圖的內存顯示設備才有地方繪圖,畫到指定的位圖上

    CBitmap *pOldBit=MemDC.SelectObject(&MemBitmap);
    //先用背景色將位圖清除干凈,這里用原背景色作為背景
    //你也可以用自己應該用的顏色

    MemDC.FillSolidRect(0,0,nWidth,nHeight,pDC->GetBkColor());
    //繪圖
    CBrush brush(RGB(0,255,0));
     for(int i=0;i<50;i++)
     {
      for(int j=0;j<80;j++)
      {
       //MemDC.Rectangle(10*j,10*i,9,9);
       CRect rc(10*j,10*i,10*j+8,10*i+8);
       MemDC.FillRect(&rc,&brush);
      }
     }
    //將內存中的圖拷貝到屏幕上進行顯示
    pDC->BitBlt(0,0,nWidth,nHeight,&MemDC,0,0,SRCCOPY);
    //繪圖完成后的清理
    MemBitmap.DeleteObject();
    MemDC.DeleteDC();


    ///////////////////////////--GDI+ --////////////////////////////////////
     Bitmap* buf=new Bitmap(2000,2000) ;
     Graphics gc(buf);//Graphics.FromImage(buf);
     //反鋸齒
     //gc.SetSmoothingMode(SmoothingModeAntiAlias);
     SolidBrush bgbrush(Color(255,255,255,255));
     gc.FillRectangle(&bgbrush,0,0,2000,2000);//背景填充
     Pen      pen(Color(255, 0, 0, 255));
     SolidBrush sbrush(Color(255,0,255,255));
     for(int i=0;i<60;i++)
     {
      for(int j=0;j<60;j++)
       gc.FillRectangle(&sbrush,10*j,10*i,9,9);
     }
     Graphics G(pDC->GetSafeHdc()); 
     G.DrawImage(buf ,0,0);

     

    posted @ 2010-06-19 16:09 春天花會開 閱讀(2637) | 評論 (1)編輯 收藏

    Visual studio 2008/2010 MFC程序Menu、Toolbar字體偏小解決辦法

    首先,這是一個MFC的Bug
    http://connect.microsoft.com/VisualStudio/feedback/details/505466/mfc-visual-style-font-size-too-small-to-display-chinese-character-clearly-on-windows-xp

    解決時間暫時還不確定,臨時的方案如下:
    App在InitInstance中加入:

    LOGFONT logfont = {0};
    :: SystemParametersInfo(SPI_GETICONTITLELOGFONT, sizeof(LOGFONT), &logfont, 0);
    afxGlobalData.SetMenuFont(&logfont,true);

    注釋:

    字體的設置保存在一個全局變量afxGlobalData中,此變量定義AfxGlobals.h中。
    AFX_GLOBAL_DATA中有一個SetMenuFont可以設定字體屬性,影響Menu、Toolbar、Dock Pane等的caption字體。
    但是這個設置對tooltip無影響,臨時解決:在上面代碼基礎上在加入

    if(afxGlobalData.fontTooltip.GetSafeHandle() != NULL)
     {
      ::DeleteObject(afxGlobalData.fontTooltip.Detach());
     }
     afxGlobalData.fontTooltip.CreateFontIndirect(&logfont);

    posted @ 2010-06-09 08:49 春天花會開 閱讀(2411) | 評論 (2)編輯 收藏

    主站蜘蛛池模板: 日韩亚洲一区二区三区| 亚洲国产成人精品91久久久| 激情内射亚洲一区二区三区| 青柠影视在线观看免费| 亚洲高清在线播放| 最近2019免费中文字幕6| 亚洲邪恶天堂影院在线观看| 91香蕉国产线在线观看免费| 久久精品国产亚洲AV无码偷窥| 69视频免费观看l| 亚洲人色大成年网站在线观看| 国产免费av片在线看| 亚洲精品无码专区在线| 又爽又黄无遮挡高清免费视频| 成人免费网站久久久| 久久精品国产精品亚洲精品| h视频在线观看免费完整版| 久久亚洲最大成人网4438| 女人被免费视频网站| 一级日本高清视频免费观看| 亚洲av中文无码乱人伦在线播放| 久久国产色AV免费看| 亚洲夂夂婷婷色拍WW47| 亚洲福利在线播放| 免费人成在线观看网站品爱网 | 美女黄网站人色视频免费国产| 久久久久亚洲精品无码网址色欲 | 中文字幕视频免费| 亚洲国产成人无码AV在线| 伊人婷婷综合缴情亚洲五月| 最近免费中文在线视频| 国产精品成人亚洲| 国产精品久久久亚洲| 永久在线毛片免费观看| a级毛片毛片免费观看久潮| 亚洲制服丝袜中文字幕| 精品国产亚洲男女在线线电影 | 亚洲韩国—中文字幕| 成人毛片免费观看视频在线 | 中文字幕在线视频免费| 国产成人精品日本亚洲18图|