用C++获取VSXu艺人的VU

Get VU of VSXu artiste with C++

到目前为止,这是我的代码:

#include "iostream"
#include "Windows.h"
#include "stdio.h"
using namespace std;



int main() {

    HWND hWnd = FindWindow(NULL,TEXT("Vovoid VSXu Artiste 0.4.0 [Windows 64-bit]"));
    if (hWnd == 0) {
        cerr << "Cannot find window "<< endl;
    }
    else {
        DWORD pId;
        GetWindowThreadProcessId(hWnd, &pId);
        cout << "Found Window at "<<pId << endl;
        HANDLE hProc = OpenProcess(PROCESS_ALL_ACCESS, FALSE, pId);
        HMODULE hModule = GetModuleHandle(TEXT("sound.rtaudio.dll"));

        if (hProc == 0) {
            cerr << "Cannot open process." << endl;
        }else if(hModule==0){
            DWORD error = GetLastError();
            cerr << "could not find Module -> error: " <<error<< endl;
        }
        else {
            float val = 0;
            int addr = 0x04D40000 + 0x19098;//should be sound.rtaudio.dll+ 0x19098
            while(TRUE){
                int suc = ReadProcessMemory(hProc, (LPVOID)addr, &val, (DWORD)sizeof(val), NULL);
                if (suc > 0) {
                    cout << "Success reading " << val << " of " << hex << addr << endl;
                    system("cls");
                }
                else {
                    DWORD error = GetLastError();
                    cerr << "fail " << error << endl;
                }
            }


        }
        CloseHandle(hProc);
    }
    cin.get();
    return 0;
}

我想用 C++ 和作弊引擎的帮助读取 VSXu Artiste 声音可视化程序的 VU(声卡音量)值。在您重新打开 VSXu 之前,它与 ReadProcessMemory(hProc, (LPVOID)addr, &val, (DWORD)sizeof(val), NULL); 一起工作得很好。这很明显,因为我的值在 Cheat Engine 中的地址是 "sound.rtaudio.dll+19098" 并且 DLL 加载到 "random" 地址。 在 Cheat Engine 中,您只需在内存查看器中按 Ctrl+G 并键入 DLL 的名称即可找到其基址。我已经在 C++ 中尝试过 GetModuleHandle 方法但没有成功:

HMODULE hModule = GetModuleHandle(TEXT("sound.rtaudio.dll"));

有没有人知道如何使用 C++ 获取 dll 的基址?

作弊引擎截图:http://oi57.tinypic.com/331k7sw.jpg

亲切的问候,

罗伯特

我想这个问题是因为您在自己的进程中调用 GetModuleHandle。您可以尝试的解决方案是使用:

GetModuleInformation,它会return MODULEINFO 中的基地址为:

lpBaseOfDll

The load address of the module.

要获取进程和模块句柄,您可以使用此处的示例代码:Enumerating All Modules For a Process