Nah Pada Tutorial ini Saya akan memberikan Tutorial Lengkap Membuat cheat Point Blank.
Cheat yg akan kita buat sekarang yaitu ammo global.....
Pertama-tama kita mencari offset dan bytenya dan bahan-bahan yg harus disiapkan yaitu:
- Cheat Engine
- LS Yg di bugtrap kan
lalu setelah PB di BT in.
buka Cheat Engine kalian.
lalu pada Select a Proces To Open pilih lostsaga.exe
Selanjutnya adalah men scan NO Delay yg di bawah ini :
52 e8 eb ff 83 c4 8b 45 fc 8b 4d 08 89 88 09 00 00 8b e5 5d c2 04 00 ( Contoh )
Lihat dengan teliti AOB di atas.
ada beberapa yg ber spasi beberapa kali.
AOB di atas belum tentu tepat.
siapa tau nanti GM Maintenance mungkin AOB dia atas akan geser.
OK kita lanjutkan ke tutornya.
selanjutnya setelah kalian Scan AOB nya maka pada kolom address dan Value akan muncul 1 offset.
cara selanjutnya yaitu klik 2 kali address itu lalu akan pindah kebawah...
lalu klik kanan >> Change Record >> Address.
Maka akan muncul tulisan seperti di bawah ini:
lostsaga.exe+170165
170165 << ini adalah offset No Delayl Bulan lalu
mungkin akan geser.
ok seep.... mencari offset nya Succes .
sekarang kita mencari Byte on dan Byte Off nya.
Baca dngan jelas.
sekrang jgn tutup dulu CE nya
lau klik kanan pada address yg telah di scan tadi >> Browse this memory regoin.
tada....
Byte off nya udah di depan mata kalian...
52 E8 65 72 EB FF 83 C4 08 8B 45 FC 8B 4D 08 89 88 64 09 00 00 8B E5 5D C2 04 00 55 8B EC 51
89 4D.
ini adalah byte off bulan lalu...
itu masih dalam bentuk AOB jadi untuk mengubahnya menjadi Byte lihat di bawah ini :
BYTE AmmoOFF[33] = {0x52 ,0xE8 ,0x65 ,0x72 ,0xEB ,0xFF ,0x83 ,0xC4 ,0x08 ,0x8B ,0x45 ,0xFC ,0x8B ,0x4D ,0x08 ,0x89 ,0x88 ,0x64 ,0x09 ,0x00 ,0x00 ,0x8B ,0xE5 ,0x5D ,0xC2 ,0x04 ,0x00 ,0x55 ,0x8B ,0xEC ,0x51 ,0x89 ,0x4D};
jelaskan...??
sekarang kita cari byte on nya...
byte off no delay yaitu = C7 02 3C 00 00 00 ( Contoh )
byte on ada 33 byte jadi untuk melengkapinya dengan cara mengambil sebagian dari byte off nya ...
kan byte nya udah jadi 6 tuh jadi kita tinggal nambahin 27.
Eiitzz...
cara nambahinnya bukan sembarangan loh.....
kita harus main hitung-hitungan dulu.
C7 02 3C 00 00 00 52 E8 65 72 EB FF 83 C4 08 8B 45 FC 8B 4D 08 89 88 64 09 00 00 8B E5 5D C2 04 00
yg di atas itu belom sempurnah, kita harus hitung-hitungan dulu..
dan jgn lupa pake kalkulator hex eah...
caranya yaitu
pada byte ke 9 = 65.
cara mencarinya yaitu:
pada byte ke 3 di byte off nya di kurang 6
65 - 6 = 5F.
Lalu pada byte ke 24 = 64
Di ganti menjadi 68.
68 udah dari dulu....
jadi setelah main hitung-hitungan.
byte on nya menjadi :
C7 02 3C 00 00 00 52 E8 5F 72 EB FF 83 C4 08 8B 45 FC 8B 4D 08 89 88 68 09 00 00 8B E5 5D C2 04 00
BYTE AmmoON[33] = {0xC7, 0x02, 0x50, 0x00, 0x00, 0x00, 0x52 ,0xE8 ,0x5F ,0x72 ,0xEB ,0xFF ,0x83 ,0xC4 ,0x08 ,0x8B ,0x45 ,0xFC ,0x8B ,0x4D ,0x08 ,0x89 ,0x88 ,0x68 ,0x09 ,0x00 ,0x00 ,0x8B ,0xE5 ,0x5D ,0xC2 ,0x04 ,0x00};
Nah....
semuanya udah dapat kan...
sekarang tinggal di masukin ke Dev-C++ Atau MVC++.
Contoh:
Buka Dev-C++ kalian...
Lalu Pilih File >> New >> Project.
Pilih Empty Project.
lalu di bawahnya pilih C Project.
lalu masukkan nama projectnya.. terserah kalian.
lalu Tekan CTRL + N >> pilih Yes
lalu Tekan Alt + P >> pilih Win32 DLL >> Lalu Ok.
Lalu Masukkan SC di bawah ini:
--------------------------------------------------------------------------------------------
//==============================================================
// Created By : Ashifa
// Thanks to : Rizki-TEAM-|
// faceinteraction.com
// Not 4 share to Public
//==============================================================
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include <stdio.h>
#include <stdlib.h>
//============== Logger By Dj Ashifa =======================
#define OFS_AutoDC 0x322FDD
#define OFS_Nickname 0x105D2F
#define OFS_Rareitem 0xC2BB3C
#define OFS_PesoHack 0xAC1145
#define OFS_BomHook 0x44F826
#define OFS_1HitCrussade 0x4A2F31
#define OFS_UnlimitedHp 0x42FA11
#define OFS_Grade 0x108D2F
#define OFS_Skill 0x110D3F
#define OFS_JumpHack 0x2FD444
//=============================================================
LPTSTR ModulGame = "lostsaga.exe";
void Patch(void *adr, void *ptr, int size)
{
DWORD OldProtection;
VirtualProtect(adr,size,PAGE_EXECUTE_READWRITE, &OldProtection);
memcpy(adr,ptr,size);
VirtualProtect(adr,size,OldProtection, &OldProtection);
}
void WritePointer(unsigned long ulBase, int iOffset, int iValue)
{
if (!IsBadReadPtr((VOID*)ulBase, sizeof(unsigned long)))
{
if (!IsBadWritePtr((void*)(*(unsigned long*)ulBase + iOffset), sizeof(unsigned long)))
{
*(int*)(*(unsigned long*)ulBase + iOffset) = iValue;
}
}
}
DWORD WINAPI MemPacth(LPVOID param)
{
while (1) {
//==================== | Peso Hack | =============================//
if (GetAsyncKeyState(VK_HOME)&1) {
MessageBeep(MB_ICONINFORMATION);
DWORD adrAutoDC, adrMin2 = 0;
DWORD dwPB = (DWORD)GetModuleHandleA("lostsaga.exe")+0xAC1145 ;
if (dwPB > 0) {
adrAutoDC = dwPB + (DWORD)0xAC1145 ;
Patch((void *)(adrAutoDC),(void*)(PBYTE)"\x00\x8F", 2);
}
}
Sleep(5);
}
//====================================================================
//==================== Nick Name Hack =================================
if (GetAsyncKeyState(VK_INSERT)&1){
DWORD Nickname = (DWORD)GetModuleHandleA("lostsaga.exe")+0x49B0F8 ;
RiizwandaHack((void*)(Nickname+0x300),(int*)(PBYTE)"\x00\x00\x00\x00\x00\x00\x0F",7);
Sleep(5);
}
//================= Grade & Skill Hack ==================================
if (GetAsyncKeyState(VK_DELETE)&1){
DWORD GradeSkill = (DWORD)GetModuleHandleA("lostsaga.exe")+0x108D2F+0x110D2F ;
RiizwandaHack((void*)(GradeSkill+0x150),(int*)(PBYTE)"\x00\x00\xFF",3);
Sleep(5);
}
//====================================================================
//============== | 1 Hit Crussade |===================================
DWORD adr1hit, adrMin2 = 0;
DWORD CRUSSADE = (DWORD)GetModuleHandleA("lostsaga.exe")+0x4A2F31 ;
if (CRUSSADE > 0) {
adr1hit = CRUSSADE + (DWORD)0x4A2F31 ;
Patch((void *)(adr1hit),(void*)(PBYTE)"\x00\x00\3F", 3);
}
Sleep(5);
}
//=====================================================================
BOOL WINAPI DllMain ( HMODULE hDll, DWORD dwReason, LPVOID lpReserved )
{
if (dwReason == DLL_PROCESS_ATTACH)
{
DisableThreadLibraryCalls(hDll);
if(dwReason == DLL_PROCESS_ATTACH){
MessageBox(0, " ============= | Rizki|-TEAM-| ===============\n Fiture Hack :\n [-] Peso Hack : HOME\n [-] NickName Hack : INSERT\n [-] 1 Hit Crussade : Auto ON\n [-] Grade Hack : DELETE\n [-] Skill Hack : DELETE\n\n Created By :\n [-] Rizki H \n\n Thanks to :\n [-] All Member Rizki|-TEAM-|", "Rizki|-TEAM-|@2012 by Rizki Creations", MB_OKCANCEL + MB_ICONINFORMATION );
MessageBox(0, "Tekan Hotkey Pas ada Notice..", "Rizki|-TEAM-|@2012", MB_OKCANCEL + MB_ICONINFORMATION );
CreateThread(0, 0, (LPTHREAD_START_ROUTINE)MemPacth, 0, 0, 0);
char strDLLName [_MAX_PATH];
GetModuleFileName(hDll, strDLLName , _MAX_PATH);
if (strstr(strDLLName, "Rizki|-TEAM-|.dll") <= 0) {
MessageBox(0, "Dasar Mahoo !! Rename DLL !!", "PERHATIAN", 0);
ExitProcess(0);
}
}
else if(dwReason == DLL_PROCESS_DETACH)
{
}
}
return TRUE;
}
-------------------------------------------------------------------------------------------
Lalu Tinggal Di Rebuild deh..
dengan menekan CTRL + F11
ok...
Mudah-mudahan..
agan-agan semuanya yg membaca ini...
bisa mengerti dengan jelas...
jika ada kesalahan mohon di maafkan yeah ..
2 komentar: