0

因此,我正在使用以下应用程序测试以下功能 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;
}
4

1 回答 1

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;
    }

}
于 2013-03-06T18:13:27.200 回答