mfc 双缓冲绘制背景




 void CMainPropertySheet::OnPaint()
 {
CPaintDC dc(this); // device context for painting
  


CRect rc,rect;
     CDC dcMem;
     GetClientRect(&rc);
     CBitmap bmp, *pOldBit; //内存中承载临时图象的位图
     bmp.CreateCompatibleBitmap(&dc,rc.Width(),rc.Height());
dcMem.CreateCompatibleDC(&dc); 
pOldBit = dcMem.SelectObject(&bmp);




CPropertyPage* pg=this->GetPage(m_btnDown-IDC_D_BTN); 
pg->MoveWindow(35+addw,14+addh,rc.Width()-addw-15,rc.Height()-addh-65); 

    rect.top = rc.top;
rect.bottom = 14+addh;
rect.left = rc.left;
rect.right = rc.right;
dcMem.FillSolidRect(rc,RGB(9,81,129));


rect.top =rc.Height()-52;
rect.bottom = rc.bottom;
rect.left = rc.left;
rect.right = rc.right;
dcMem.FillSolidRect(rect,RGB(186,207,220));


rect.top = 14+addh;
rect.bottom =rc.Height()-52;
rect.left = rc.left;
rect.right = 165;
dcMem.FillSolidRect(rect,RGB(32,110,158));


rect.top = 14+addh;
rect.bottom =rc.Height()-52;
rect.left = 165;
rect.right = rc.right;
dcMem.FillSolidRect(rect,RGB(255,255,255));
    dc.BitBlt(0,0,rc.Width(),rc.Height(),&dcMem,0,0,SRCCOPY);


  dcMem.SelectObject(pOldBit);

}

MFC双缓冲绘制可以避免屏幕闪烁,提高绘制效率。下面给出一个绘制仪表盘的示例: 1. 创建一个MFC工程,添加一个Dialog对话框。 2. 在Dialog类中添加以下成员变量: ```cpp private: CRect m_rcClient; // 客户区矩形区域 CBitmap m_bmpMem; // 内存位图 CDC m_dcMem; // 内存DC ``` 3. 在OnInitDialog函数中初始化内存DC和内存位图: ```cpp BOOL CMyDlg::OnInitDialog() { CDialogEx::OnInitDialog(); // 获取客户区矩形区域 GetClientRect(&m_rcClient); // 创建内存DC m_dcMem.CreateCompatibleDC(NULL); // 创建内存位图 m_bmpMem.CreateCompatibleBitmap(&m_dcMem, m_rcClient.Width(), m_rcClient.Height()); // 选择位图到内存DC m_dcMem.SelectObject(&m_bmpMem); return TRUE; } ``` 4. 在OnPaint函数中进行绘制操作: ```cpp void CMyDlg::OnPaint() { CPaintDC dc(this); // device context for painting // 使用双缓冲绘制 CDC dcMem; dcMem.CreateCompatibleDC(&dc); CBitmap bmpMem; bmpMem.CreateCompatibleBitmap(&dc, m_rcClient.Width(), m_rcClient.Height()); dcMem.SelectObject(&bmpMem); // 绘制仪表盘背景 CBrush brush; brush.CreateSolidBrush(RGB(255, 255, 255)); dcMem.FillRect(m_rcClient, &brush); // 绘制仪表盘指针 int cx = m_rcClient.Width() / 2; int cy = m_rcClient.Height() / 2; int r = min(cx, cy) - 10; double angle = 0.75 * M_PI + m_value * 1.5 * M_PI / 100; int x = cx + r * cos(angle); int y = cy - r * sin(angle); CPen pen; pen.CreatePen(PS_SOLID, 3, RGB(255, 0, 0)); dcMem.SelectObject(&pen); dcMem.MoveTo(cx, cy); dcMem.LineTo(x, y); // 将内存DC中的图像拷贝到屏幕DC中 dc.BitBlt(0, 0, m_rcClient.Width(), m_rcClient.Height(), &dcMem, 0, 0, SRCCOPY); } ``` 5. 在OnDestroy函数中释放资源: ```cpp void CMyDlg::OnDestroy() { CDialogEx::OnDestroy(); // 释放内存DC和内存位图 m_dcMem.DeleteDC(); m_bmpMem.DeleteObject(); } ``` 以上就是一个简单的MFC双缓冲绘制仪表盘的示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值