GetDIBits:那个像素在哪里? (x,y坐标)

时间:2013-03-06 02:17:40

标签: windows winapi bitmap gdi

所以,我正在使用以下应用程序测试以下函数FindPixel。 HWNDCOLORREF是我用Spy ++和Color Cop确定的用于调试的常量;该程序的最终版本将自动找到这些。

我已经确认此算法中确定是否颜色存在的部分有效(即:如果颜色存在于窗口中的任何位置,那么if语句最终为真,如果它不是if语句永远不会是真的),但是,我无法弄清楚如何隔离发生哪个像素。行SetCursorPos(rect.left+i, rect.top+i2);不会将鼠标移动到正确位置附近的任何位置。

我正在调试此窗口的窗口完全是白色,除了一个像素值为16776960.该函数可以判断它在那里,但是(i,i2)的值不是(x,y)坐标它发生的地方。

这里有什么我想念的吗?

#include <Windows.h>
void FindPixel(HWND hWnd, COLORREF target)
{
        HDC hDC = GetDC(hWnd);
        HDC memDC = CreateCompatibleDC (hDC);
        BYTE *ScreenData = NULL;
        HBITMAP hBitmap;
        BITMAPINFOHEADER bmHeader = {0};
        RECT rect;
        int width, height;
        int i, i2;
        GetWindowRect(hWnd, &rect);
        width = rect.right-rect.left;
        height = rect.bottom-rect.top;
        ScreenData = (BYTE*)malloc(4*width*height);
        hBitmap = CreateCompatibleBitmap(hDC, width, height);
        bmHeader.biSize = sizeof(BITMAPINFOHEADER);
        bmHeader.biPlanes = 1;
        bmHeader.biBitCount = 24;
        bmHeader.biWidth = width;
        bmHeader.biHeight = -height;
        bmHeader.biCompression = BI_RGB;
        SelectObject(memDC, hBitmap);
        BitBlt(memDC, 0, 0, width, height, hDC, 0, 0, SRCCOPY);

        GetDIBits(hDC, hBitmap, 0, height, ScreenData, (BITMAPINFO*)&bmHeader, DIB_RGB_COLORS);
        //      i=0;
        for(i = 0; i < width; i++)
        {
                for(i2 = 0; i2 < height; i2++)
                {
                        if(RGB((ScreenData[3*((i2*width)+i)+2]),(ScreenData[3*((i2*width)+i)+1]), ScreenData[3*((i2*width)+i)])==target)
                        {
                                SetCursorPos(rect.left+i, rect.top+i2);
                                DeleteObject(hBitmap);
                                DeleteDC(memDC);
                                free(ScreenData);
                                ReleaseDC(hWnd, hDC);
                                return;
                        }
                }
        }
        DeleteObject(hBitmap);
        DeleteDC(memDC);
        free(ScreenData);
        ReleaseDC(hWnd, hDC);
}

int APIENTRY WinMain(HINSTANCE hi, HINSTANCE hpi, LPSTR lpcl, int nsc)
{
        const COLORREF px = 16776960;
        const HWND hWnd = (HWND)0x000C04BC;
        Sleep(1000);
        FindPixel(hWnd, px);
        return 0;
}

1 个答案:

答案 0 :(得分:0)

问题确实是我没有考虑到这一步。这是工作循环:

stride = ((((width * 24) + 31) & ~31) >> 3);

totalpx = stride*height;
for(i = 0; i < totalpx; i++)
{
    //int x = i % width;
    //int y = ((i-x)/width);
    if(RGB(
        (ScreenData[(3*i)+2]),
        (ScreenData[(3*i)+1]),
        (ScreenData[(3*i)+0]))==target)
    {       
        int x = i % stride;
        int y = ((i-x)/width);
        SetCursorPos(rect.left+x,rect.top+y);
        DeleteObject(hBitmap);
        DeleteDC(memDC);
        free(ScreenData);
        ReleaseDC(hWnd, hDC);
        return;
    }

}