最近绘制老犯同样的错误,记录下:
1.MemDC中的MemBmp大小一定要设定好,经常设小了,后面的绘不出来,同时最后dc.bitblt时,大小一定要和MemBmp 一致,同样经常是MemBmp必变了,bitblt的rcDest没变,结果还是绘不出来。
2.MemDC上绘制是在(0,0, MemBmp.width, MemBmp.Height)区域上绘的,经常rc设成dc所在窗口的坐标了。
3.MemDC.SelectObject,可以在选了bmp,同时再选pen,当然不是再选bmp,不然原来的画布就被换成新的bmp了,那就白画了
4.MemDC中可以再次多缓冲,当然这时
CDC MemDc2 ;
MemDc2 .CreateCompatibleDC(&MemDc) ;//它就把MemDc当成它的dc了,所以我们可以在MemDc2中SelectObject,再绘到MemDc中
5.去掉焦点的虚线框,除了要把WM_SETFOUCE干掉,还得设定焦点到其他窗口,经常是不设,想破脑袋也没反应过来,靠,怎么虚框还在!
6.MemDc中当然可以使用gdi+,这时gdi+初始化的句柄是(MemDc.GetSafeHdc()) ;经常写成(dc.GetSafeHdc()),结果gdi+是直接以dc的那个坐标系来绘了。
7.gdi+经常存在资源未释放的BUG
如:Image::FromStream:MSDN:The FromStream method creates a new Image object based on a stream
所以必须delete
如 IStream::Release 在MSDN解释是is similar to a close funtion on a file,Once released, the stream object is no longer valid and cannot be used
网上很多代码说
IStream* pstm; HRESULT ht = CreateStreamOnHGlobal(m_hMem,FALSE,&pstm); pstm->Release();说什么释放IStream指针,同时释放了m_hMem
其实这是在CreateStreamOnHGlobal的第二个参数设为true的情况下,MSDN:If set to TRUE, the final release will automatically free the hGlobal parameter.