以下是一份 屏幕捕获SDK  文档,当取16 或 24 位时 可以使用 TBitmapInfo 来显示,如果4 或 8 位,具体该怎么设置 TBitmapInfo?
///    屏幕捕获SDK
///    当系统颜色和捕获位图颜色相同时,CPU占用最低,集成显卡资源占用比独立显卡高
///    返回值为DWORD时,无特别说明,均是0表示成功,其它值为错误码。
///    功能:开始屏幕捕获
///    参数:dwColorBit --- 需要捕获位图的颜色位数,只能是4, 8, 16, 24,当16位时,返回555位图
///          dwReserve --- 保留,必须是20072008
///          pRect --- 屏幕捕获区域,如果为NULL捕获全屏幕
DWORD  WINAPI  SC_Start(DWORD dwColorBit, DWORD dwReserve, RECT* pRect);///    功能:停止屏幕捕获
///    参数:无
DWORD  WINAPI  SC_Stop();///    功能:获得屏幕变化信息
///    参数:pRect --- 变化区域
///          pBuf --- 变化区域的位图,需保证缓冲大小能装下全屏幕位图,如 屏幕宽度*屏幕高度*颜色位数/8
DWORD  WINAPI  SC_GetChangeInfo(RECT* pRect, BYTE* pBuf);///    功能:获得全屏幕位图
///    参数:同上
DWORD  WINAPI  SC_GetFullScreen(RECT* pRect, BYTE* pBuf);///    功能:当取4或8位位图时取系统调色板, 只需调用一次
///    参数:pTable --- 当取位4色时缓冲长度为64字节,当取8位色时缓冲长度为1024字节
BOOL   WINAPI  SC_GetColorTable(PVOID pTable);
#endif////**********  sample   ************//////
/*
////  屏幕捕获线程
DWORD WINAPI ScreenThread(LPVOID lpParam)
{

DWORD   r;
DWORD   dwColor = 16;
RECT    rect;
BYTE*   pBuf;

r = SC_Start(dwColor, 20072008, NULL);
if(r)
{
AfxMessageBox("开始屏幕捕获失败.");
return 0;
} int nWidth = ::GetSystemMetrics(SM_CXSCREEN);
int nHeight = ::GetSystemMetrics(SM_CYSCREEN); pBuf = new BYTE[nWidth * nHeight * dwColor / 8];
if(pBuf == NULL)
{
    return 0;
}    if(dwColor == 4 || dwColor == 8)
{
    SC_GetColorTable(pBuf);
}


while(1)
{
r = SC_GetChangeInfo(&rect, pBuf);

if(r != 0)
{
///  屏幕没有变化
Sleep(25);
continue;
}

    ///  屏幕有变化,做相应的处理
}

delete []pBuf;
SC_Stop();
}
*/