双缓冲可以解决刷图闪烁的问题。
实现原理: 我们建立一个兼容的dc , 在这个兼容的dc上画图,传入图片等操作,最后一次性拷贝到我们的目标DC上。这样就不会闪烁。
1.创建一个和绘图窗口一样大的兼容dc
CDC memDC;
memDC.CreateCompatibleDC (pDC);
memDC.CreateCompatibleDC (pDC);
2 获取实际显示窗口的dc
CDC* pDC = GetDlgItem(IDC_STATIC_IMG)->GetDC();
3 在兼容dc上画图(包括导入图片等)
CBitmap menbitmap ;
menbitmap.CreateCompatibleBitmap(pDC,m_WndPosRect.Width(),m_WndPosRect.Height());
CBitmap* pOldBmp = memDC.SelectObject (&menbitmap);
//::SelectObject(memDC.GetSafeHdc(),menbitmap);
::SetStretchBltMode(memDC.GetSafeHdc(),COLORONCOLOR);//防止失真
::StretchDIBits(memDC.GetSafeHdc(),m_WndPosRect.left,m_WndPosRect.top,m_WndPosRect.Width(),m_WndPosRect.Height(),
0,0,bmInfo1->bmiHeader.biWidth,bmInfo1->bmiHeader.biHeight,*pBmpPixelBuffer1,
bmInfo1,DIB_RGB_COLORS,SRCCOPY);
memDC.MoveTo(0,m_WndPosRect.Height()/2);
memDC.LineTo(m_WndPosRect.Width(),m_WndPosRect.Height()/2);
memDC.MoveTo(m_WndPosRect.Width()/2,0);
memDC.LineTo(m_WndPosRect.Width()/2,m_WndPosRect.Height());
memDC.Rectangle(100,100,200,200);
menbitmap.CreateCompatibleBitmap(pDC,m_WndPosRect.Width(),m_WndPosRect.Height());
CBitmap* pOldBmp = memDC.SelectObject (&menbitmap);
//::SelectObject(memDC.GetSafeHdc(),menbitmap);
::SetStretchBltMode(memDC.GetSafeHdc(),COLORONCOLOR);//防止失真
::StretchDIBits(memDC.GetSafeHdc(),m_WndPosRect.left,m_WndPosRect.top,m_WndPosRect.Width(),m_WndPosRect.Height(),
0,0,bmInfo1->bmiHeader.biWidth,bmInfo1->bmiHeader.biHeight,*pBmpPixelBuffer1,
bmInfo1,DIB_RGB_COLORS,SRCCOPY);
memDC.MoveTo(0,m_WndPosRect.Height()/2);
memDC.LineTo(m_WndPosRect.Width(),m_WndPosRect.Height()/2);
memDC.MoveTo(m_WndPosRect.Width()/2,0);
memDC.LineTo(m_WndPosRect.Width()/2,m_WndPosRect.Height());
memDC.Rectangle(100,100,200,200);
4 一次想将兼容dc 拷贝到实际dc上
pDC->BitBlt(0, 0, m_WndPosRect.Width(), m_WndPosRect.Height(),&memDC, 0, 0, SRCCOPY);
5清理工作
DeleteDC(memDC);
::ReleaseDC(GetDlgItem(IDC_STATIC_IMG)->m_hWnd,*pDC);
::ReleaseDC(GetDlgItem(IDC_STATIC_IMG)->m_hWnd,*pDC);