扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
作者:刘涛 来源:作者授权转载 2007年10月21日
关键字:
CdibView::OnImageDownScan() { CDibDoc *pDoc=GetDocument(); HDIB hdib; CClientDC pDC(this); hdib=pDoc->m_hDIB;//获取图像数据句柄; BITMAPINFOHEADER *lpDIBHdr;//位图信息头结构指针; BYTE *lpDIBBits;//指向位图像素灰度值的指针; HDC hDC=pDC.GetSafeHdc();//获取当前设备上下文的句柄; lpDIBHdr=( BITMAPINFOHEADER *)GlobalLock(hdib);//得到图像的位图头信息; lpDIBBits=(BYTE*)lpDIBHdr+sizeof(BITMAPINFOHEADER)+256*sizeof(RGBQUAD);//获取指向图像像素值; SetStretchBltMode(hDC,COLORONCOLOR); //显示图像; for(int i=0;i<lpDIBHdr->biHeight;i++) { //每次循环显示图象的“0”到“i”行数据; SetDIBitsToDevice (hDC,0,0,lpDIBHdr->biWidth, lpDIBHdr->biHeight, 0, 0,0, i, lpDIBBits,(LPBITMAPINFO)lpDIBHdr, DIB_RGB_COLORS ); DelayTime(50);//延迟; } GlobalUnlock(hdib); return; } |
…………………………………//由于篇幅的限制,省略了与上面的相同代码 Cbrush brush(crWhite);//定义一个“白色”的刷子; Cbrush *oldbrush=pDC->SelectObject(&brush); for(int i=0;i < lpDIBHdr->biHeight ;i++) {//每次循环将目标区域中的“0”到“i”行刷成“白色”; pDC->Rectangle(0,0,lpDIBHdr->biWidth,lpDIBHdr->biHeight); DelayTime(50); } ………………………………… |
………………………………… int m=8; int n=lpDIBHdr->biHeight/m;//图像的高度能够整除8; for(int l=1;l<=m;l++) for(int k=0;k<n;k++) { //每次循环依次显示图像中的k-1、k*m-1、…k*n-1行; StretchDIBits (hDC,0,4*k+l-1,lpDIBHdr->biWidth,1, 0, lpDIBHdr->biHeight-4*k-l+1,lpDIBHdr->biWidth,1, lpDIBBits,(LPBITMAPINFO)lpDIBHdr, DIB_RGB_COLORS, SRCCOPY);//juanlianxiaoguo DelayTime(50); } ………………………………… |
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者