如何像mfc的打印预览一样将view中的内容分页写入到自己的bmp中?

zfplay 2000-02-13 10:44:00
如何像mfc的打印预览一样将view中的内容分页写入到自己的bmp中?也就是说,假若我的view中有一些内容,在打印预览中有5页纸,我如何将这5页纸的内容保存为5个bmp文件?
...全文
111 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
建立一个位图,和一个兼容DC,这个兼容DC选中你建立的位图,然后用这个兼容DC取代打印输出或预览的DC,即所有的操作都输出到你建立的兼容DC上,这样所有的操作就都保存到你建立的位图上了,再把这个位图存盘。我编的这个程序可以把 hWnd 窗口的 Client 区域存盘到 bmp 文件里,文件名 szFName,如果 hWnd = HWND_DESKTOP 可以保存整个屏幕的内容,可以做参考。

int SaveClientToFile(HWND hWnd, LPCTSTR szFName)
{
HDC hDC, hMemDC;
HANDLE hBits, hFile;
HBITMAP hBitmap, hTmpBmp;
HPALETTE hPal;
LPVOID lpBits;
RGBQUAD RGBQuad;
DWORD ImgSize, plSize, dwWritten;
int i, CRes, Height, Width;
BITMAPFILEHEADER bmFH;
LPBITMAPINFO pBmInfo, pBmInfoMem;
LPLOGPALETTE lp;

if((hFile = CreateFile(szFName, GENERIC_WRITE,0,NULL,CREATE_ALWAYS,FILE_ATTRIBUTE_NORMAL,NULL)) == NULL)
return 1;

SetCursor(LoadCursor(NULL, IDC_WAIT));
if(hWnd==HWND_DESKTOP)
{
Width = GetSystemMetrics(SM_CXSCREEN);
Height = GetSystemMetrics(SM_CYSCREEN);
}
else
{
RECT rc;
GetClientRect(hWnd,&rc);
Width = rc.right-rc.left;
Height = rc.bottom-rc.top;
}

hDC = GetDC(hWnd);
hMemDC = CreateCompatibleDC(hDC);
hBitmap= CreateCompatibleBitmap(hDC, Width, Height);
hTmpBmp= CreateCompatibleBitmap(hDC, 8, 8);
pBmInfoMem = (LPBITMAPINFO)GlobalAlloc(GHND, sizeof(BITMAPINFO)+256*sizeof(RGBQUAD));
pBmInfo = (LPBITMAPINFO)GlobalLock(pBmInfoMem);
SelectObject(hMemDC, hBitmap);
BitBlt(hMemDC,0,0,Width,Height,hDC,0,0,SRCCOPY);
SelectObject(hMemDC, hTmpBmp);

ZeroMemory(pBmInfo, sizeof(BITMAPINFO));
pBmInfo->bmiHeader.biSize = (DWORD)sizeof(BITMAPINFOHEADER);
pBmInfo->bmiHeader.biWidth = Width;
pBmInfo->bmiHeader.biHeight = Height;
pBmInfo->bmiHeader.biPlanes = 1;
pBmInfo->bmiHeader.biBitCount = (WORD)GetDeviceCaps(hDC, BITSPIXEL);
pBmInfo->bmiHeader.biCompression = BI_RGB;
GetDIBits(hDC, hBitmap, 0,Height, NULL, pBmInfo, DIB_RGB_COLORS);
if(!pBmInfo->bmiHeader.biSizeImage)
pBmInfo->bmiHeader.biSizeImage = ((((pBmInfo->bmiHeader.biWidth * pBmInfo->bmiHeader.biBitCount) + 31) & ~31) / 8)
* pBmInfo->bmiHeader.biHeight;
CRes = GetDeviceCaps(hDC, SIZEPALETTE);
plSize = CRes*sizeof(RGBQUAD);
ImgSize= pBmInfo->bmiHeader.biSizeImage;

bmFH.bfType = 0x4d42; //"BM"
bmFH.bfOffBits = plSize + sizeof(BITMAPINFOHEADER) + sizeof(BITMAPFILEHEADER);
bmFH.bfSize = ImgSize + bmFH.bfOffBits;
bmFH.bfReserved1 = 0;
bmFH.bfReserved2 = 0;

WriteFile(hFile, &bmFH, sizeof(BITMAPFILEHEADER), &dwWritten, NULL);
WriteFile(hFile, &(pBmInfo->bmiHeader), sizeof(BITMAPINFOHEADER), &dwWritten, NULL);

if(CRes)
{
hPal=(HPALETTE)GlobalAlloc(GHND, sizeof(LOGPALETTE) + (CRes*sizeof(PALETTEENTRY)));
lp=(LPLOGPALETTE)GlobalLock(hPal);
lp->palNumEntries=(WORD)CRes;
lp->palVersion=0x0300;
GetSystemPaletteEntries(hDC, 0, CRes, lp->palPalEntry);
RGBQuad.rgbReserved=0;
for(i=0; i<CRes; i++)
{
RGBQuad.rgbRed = lp->palPalEntry[i].peRed;
RGBQuad.rgbGreen = lp->palPalEntry[i].peGreen;
RGBQuad.rgbBlue = lp->palPalEntry[i].peBlue;
WriteFile(hFile, &RGBQuad, sizeof(RGBQUAD), &dwWritten, NULL);
}
GlobalUnlock(hPal);
GlobalFree(hPal);
}

hBits = GlobalAlloc(GHND, pBmInfo->bmiHeader.biSizeImage);
lpBits = (LPVOID)GlobalLock(hBits);
GetDIBits(hDC, hBitmap, 0,Height, lpBits, pBmInfo, DIB_RGB_COLORS);
WriteFile(hFile,lpBits,ImgSize,&dwWritten,NULL);
GlobalUnlock(hBits);
GlobalFree(hBits);

GlobalUnlock(pBmInfo);
GlobalFree(pBmInfoMem);
DeleteObject(hTmpBmp);
DeleteObject(hBitmap);
DeleteDC(hMemDC);
ReleaseDC(hWnd,hDC);
CloseHandle(hFile);
SetCursor(LoadCursor(NULL,IDC_ARROW));

return 0;
}

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧