wince 下指定区域截图 函数

拿来主义,加了点自己的东西。。可惜不知道为什么无法预览只有一片黑,只能在编辑器中打开查看截图。并且在图片的上部分有白点,有空再去研究

 

 

void CGPSDlg::CopyScreenToBitmap(LPRECT lpRect, const char * filename)
{
HDC hScrDC,  hMemDC;        //屏幕和内存设备描述表     
HBITMAP hBitmap,  hOldBitmap;//位图句柄     
int nX,  nY,  nX2,  nY2;  //选定区域坐标     
int nWidth,  nHeight;        //位图宽度和高度     
int xScrn,  yScrn;          //屏幕分辨率 
   
//为屏幕创建设备描述表 
hScrDC  =  CreateDC(L"DISPLAY",  NULL,  NULL,  NULL); 

// CPaintDC dc(this);
// hScrDC = dc.GetSafeHdc();
//
   
//  获得屏幕分辨率 
xScrn  =  GetDeviceCaps(hScrDC,  HORZRES); 
yScrn  =  GetDeviceCaps(hScrDC,  VERTRES); 
   
//  确保选定区域不为空矩形 
if  (!lpRect  ||  IsRectEmpty(lpRect)) 

nX  =  0; 
nY  =  0; 
nX2  =  xScrn; 
nY2  =  yScrn; 

else 

//  获得选定区域坐标 
nX  =  lpRect->left; 
nY  =  lpRect->top; 
nX2  =  lpRect->right; 
nY2  =  lpRect->bottom; 

//确保选定区域是可见的 
if  (nX  <  0) nX  =  0; 
if  (nY  <  0) nY  =  0; 
if  (nX2  >  xScrn) nX2  =  xScrn; 
if  (nY2  >  yScrn) nY2  =  yScrn; 

nWidth  = nX2 - nX; 
nHeight = nY2 - nY; 
   
//为屏幕设备描述表创建兼容的内存设备描述表 
hMemDC  =  CreateCompatibleDC(hScrDC); 
   
//创建一个与屏幕设备描述表兼容的位图 
hBitmap =  CreateCompatibleBitmap (hScrDC, nWidth, nHeight); 
   
//把新位图选到内存设备描述表中 
// hOldBitmap = (HBITMAP)SelectObject(hMemDC, hBitmap); 
   
//  把屏幕设备描述表拷贝到内存设备描述表中 
// BitBlt(hMemDC, 0, 0, nWidth, nHeight,hScrDC, nX, nY, SRCCOPY); 
   
//TextOut(hMemDC,100, 100,L"Rigel",sizeof("Rigel")); 
   
BYTE *lpBitmapBits = NULL;

BITMAPINFO RGB24BitsBITMAPINFO;
ZeroMemory(&RGB24BitsBITMAPINFO, sizeof(BITMAPINFO));
RGB24BitsBITMAPINFO.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
    RGB24BitsBITMAPINFO.bmiHeader.biWidth = nWidth;
    RGB24BitsBITMAPINFO.bmiHeader.biHeight = nHeight;
    RGB24BitsBITMAPINFO.bmiHeader.biPlanes = 1;
    RGB24BitsBITMAPINFO.bmiHeader.biBitCount = 24;

//得到屏幕位图的句柄 
// hBitmap = (HBITMAP)SelectObject(hMemDC, hOldBitmap); 

    HBITMAP directBmp = CreateDIBSection(hMemDC, (BITMAPINFO*)&RGB24BitsBITMAPINFO,
        DIB_RGB_COLORS, (void **)&lpBitmapBits, NULL, 0);
HGDIOBJ previousObject = SelectObject(hMemDC, directBmp);

// copy the screen dc to the memory dc
BitBlt(hMemDC, 0, 0, nWidth, nHeight, hScrDC, nX, nY, SRCCOPY);

//if you only want to get the every pixel color value,
//you can begin here and the following part of this function will be unuseful;
//the following part is in order to write file;

//bimap file header in order to write bmp file
BITMAPFILEHEADER bmBITMAPFILEHEADER;
ZeroMemory(&bmBITMAPFILEHEADER, sizeof(BITMAPFILEHEADER));
bmBITMAPFILEHEADER.bfType = 0x4d42; //bmp
    bmBITMAPFILEHEADER.bfOffBits = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER);
    bmBITMAPFILEHEADER.bfSize = bmBITMAPFILEHEADER.bfOffBits + ((nWidth*nHeight)*3); ///3=(24 / 8)

//write into file const TCHAR *
FILE *mStream = NULL;

if((mStream = fopen(filename, "wb")))

//write bitmap file header
fwrite(&bmBITMAPFILEHEADER, sizeof(BITMAPFILEHEADER), 1, mStream);
//write bitmap info
fwrite(&(RGB24BitsBITMAPINFO.bmiHeader), sizeof(BITMAPINFOHEADER), 1, mStream);
//write bitmap pixels data
fwrite(lpBitmapBits, 3*nWidth*nHeight, 1, mStream);
//close file
fclose(mStream);
}
   
//清除   
DeleteDC(hScrDC); 
DeleteDC(hMemDC); 
}

 

举例子:

 

   const char filename[] = "//Storage Card//1.bmp";
   CopyScreenToBitmap(m_rect[m_prePick], filename);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
SPI(Serial Peripheral Interface)是一种用于设备间通信的串行总线协议。在Windows CE(Wince)操作系统中,SPI驱动是一种控制和管理SPI接口设备的软件模块。下面是关于Wince下SPI驱动的回答: Spi驱动是Wince操作系统中用于控制和管理SPI设备的驱动程序。SPI总线是一种串行通信协议,常用于嵌入式系统中,通过该驱动程序可以实现与其他设备的高速通信。 Wince下的SPI驱动提供了对SPI接口的底层控制和管理功能。它允许操作系统与连接在SPI总线上的外设进行数据交换。SPI驱动负责配置和初始化SPI总线、传输数据、进行中断处理等操作。 Wince下的SPI驱动由操作系统提供,并且可以通过SPI函数库进行调用。应用程序可以通过调用特定的API函数与SPI驱动进行交互,并实现与SPI设备的通信。SPI驱动提供了一组API函数,用于设置SPI总线的工作模式、传输数据、控制引脚等。应用程序可以通过这些函数来完成对SPI设备的操作。 SPI驱动在Wince中的使用具有很高的灵活性和可扩展性。可以通过配置SPI驱动参数来适配不同的SPI设备。同时,SPI驱动还支持中断处理,可以实现实时响应和高效的数据传输。 总之,Wince下的SPI驱动是一种用于控制和管理SPI接口设备的软件模块,它提供了与SPI设备进行高速通信的功能,并具有灵活性和可扩展性,可以满足各种不同的应用需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值