MadDog
Новичок
- Сообщения
- 26
- Репутация
- 0
Открываю Cheat Engine 6.1 процесс с игрой - game.exe.
Нахожу нужное мне значение....
Показывает что нужное значение лежит тут
<Address>god.dll+320155</Address>
делаю скрипт
он мне выдаёт что адрес у меня к примеру 7575096
а на самом деле он в этот момент - 0x04FE9638
как быть ?!
Нахожу нужное мне значение....
Показывает что нужное значение лежит тут
<Address>god.dll+320155</Address>
делаю скрипт
Код:
#include "NomadMemory.au3"
$ID = _MemoryOpen(ProcessExists("game.exe"))
$iPID = WinGetProcess("god")
$sModule = "god.dll"
$iOffset = "0x320155"
$baseADDR = _MemoryModuleGetBaseAddress($ID, $sModule) + $iOffset
MsgBox (0, "!", $baseADDR)
Func _MemoryModuleGetBaseAddress($iPID, $sModule)
If Not ProcessExists($iPID) Then Return SetError(1, 0, 0)
If Not IsString($sModule) Then Return SetError(2, 0, 0)
Local $PSAPI = DllOpen("psapi.dll")
;Get Process Handle
Local $hProcess
Local $PERMISSION = BitOR(0x0002, 0x0400, 0x0008, 0x0010, 0x0020) ; CREATE_THREAD, QUERY_INFORMATION, VM_OPERATION, VM_READ, VM_WRITE
If $iPID > 0 Then
Local $hProcess = DllCall("kernel32.dll", "ptr", "OpenProcess", "dword", $PERMISSION, "int", 0, "dword", $iPID)
If $hProcess[0] Then
$hProcess = $hProcess[0]
EndIf
EndIf
;EnumProcessModules
Local $Modules = DllStructCreate("ptr[1024]")
Local $aCall = DllCall($PSAPI, "int", "EnumProcessModules", "ptr", $hProcess, "ptr", DllStructGetPtr($Modules), "dword", DllStructGetSize($Modules), "dword*", 0)
If $aCall[4] > 0 Then
Local $iModnum = $aCall[4] / 4
Local $aTemp
For $i = 1 To $iModnum
$aTemp = DllCall($PSAPI, "dword", "GetModuleBaseNameW", "ptr", $hProcess, "ptr", Ptr(DllStructGetData($Modules, 1, $i)), "wstr", "", "dword", 260)
If $aTemp[3] = $sModule Then
DllClose($PSAPI)
Return Ptr(DllStructGetData($Modules, 1, $i))
EndIf
Next
EndIf
DllClose($PSAPI)
Return SetError(-1, 0, 0)
EndFunc
он мне выдаёт что адрес у меня к примеру 7575096
а на самом деле он в этот момент - 0x04FE9638
как быть ?!