![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
LRESULT CALLBACK HookProc(int nCode, WPARAM wParam, LPARAM lParam)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedBlock.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(nCode==HSHELL_WINDOWCREATED)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
char buf[1024];
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD dwPid;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
GetWindowText((HWND)wParam,buf,1024);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(strcmp(buf,"legend of mir2")==0)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
GetClassName((HWND)wParam,buf,1024);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if( strcmp(buf,"TfrmMain")==0 ||
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//strcmp(buf,"TApplication")==0 ||
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
strcmp(buf,"TFrmMain")==0 )
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
GetWindowThreadProcessId((HWND)wParam,&dwPid);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(dwPid==GetCurrentProcessId())
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD d;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
d=(DWORD)my_DDrawwCreate;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
char bb[5];
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
bb[0]=bb[1]=bb[2]=bb[3]=bb[4]=(char)0x90;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD dwOldFlag;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x44c586,9,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
memcpy((void*)0x44c586,&d,4);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
memcpy((void*)0x44c58a,bb,5);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x44c586,9,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
return CallNextHookEx(g_hhook, nCode, wParam ,lParam);
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
void InstallHook()
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedBlock.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(g_hhook==NULL)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
g_hhook=SetWindowsHookEx(WH_SHELL,(HOOKPROC)HookProc,theApp.m_hInstance,0);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(g_hhook==NULL)
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
MessageBox(0,"SetWindowsHookEx Failed!!",NULL,MB_OK);
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
通过InstallHook来安装一个WH_SHELL类型的钩子 目的是在游戏窗口创建的第一时间取得控制权 然后通过改写相关代码来实现对DirectDrawCreate函数的拦截 使之流向我们设置的代码my_DDrawwCreate
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
HRESULT __stdcall my_DDrawwCreate(GUID*lpGUID,LPDIRECTDRAW*lplpDD,IUnknown*pUnkOuter)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedBlock.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
HRESULT retVal;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
HWND hWnd=NULL;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(hWnd==NULL)
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
hWnd=FindWindow("TfrmMain","legend of mir2");
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//if(hWnd==NULL)
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
// hWnd=FindWindow("TApplication","legend of mir2");
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(hWnd==NULL)
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
hWnd=FindWindow("TFrmMain","legend of mir2");
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
retVal=DirectDrawCreate(lpGUID,lplpDD,pUnkOuter);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(g_isWindowMir)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
LPDIRECTDRAW lpDD=*lplpDD;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD p1=(DWORD)*lplpDD;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD p2=*(DWORD*)p1;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)(p2+0x54))=(DWORD)(FARPROC)my_SetDisplayMode;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
old_SetCooperativeLevel=*((DWORD*)(p2+0x50));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)(p2+0x50))=(DWORD)(FARPROC)my_SetCooperativeLevel;
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD*psend;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
psend=(DWORD*)0x4fa720;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*psend=(DWORD)my_send;
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
AFX_MANAGE_STATE(AfxGetStaticModuleState());
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
pToolDlg=new CToolDialog;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
pToolDlg->Create(IDD_TOOL_DIALOG);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
pToolDlg->SetWindowText("太子");
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
pToolDlg->ShowWindow(pToolDlg->IsWindowVisible() ? SW_HIDE : SW_SHOW);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//数字显示
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
FARPROC p=(FARPROC)_DispFunc;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD dwP=(DWORD)p-0x47AA1B;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD dwOldFlag;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x47AA17,4,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)0x47AA17)=dwP;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x47AA17,4,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//取消程序自检验
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x45EC00,1,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((BYTE*)0x45EC00)=(BYTE)0xC3;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x45EC00,1,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//战斗退出
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4620E6,2,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((WORD*)0x4620E6)=(WORD)0x9090;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4620E6,2,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x462162,2,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((WORD*)0x462162)=(WORD)0x9090;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x462162,2,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4914CA,2,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((WORD*)0x4914CA)=(WORD)0x9090;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4914CA,2,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x491576,2,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((WORD*)0x491576)=(WORD)0x9090;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x491576,2,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//显物品id
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
p=(FARPROC)ShowItemId;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
dwP=(DWORD)p-0X0048C458;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//VirtualProtect((void*)0X0048C430,0x23,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//for(char i=0;i<0x23;i++)
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
// *((BYTE*)(0X0048C430+i))=0x90;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//VirtualProtect((void*)0X0048C430,0x23,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0X0048C454,4,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)(0X0048C454))=dwP;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0X0048C454,4,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//InstallGameHooks();
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedSubBlock.gif)
/**//*
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
p=(FARPROC)MagicLock;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
dwP=(DWORD)p-0x4627ab;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4627a7,4,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)0x4627a7)=dwP;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4627a7,4,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
p=(FARPROC)EatItem;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
dwP=(DWORD)p-0x4623a6;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4623a2,4,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)0x4623a2)=dwP;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4623a2,4,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
dwP=(DWORD)p-0x48c1e6;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x48c1e2,4,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)0x48c1e2)=dwP;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x48c1e2,4,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
dwP=(DWORD)p-0x48c223;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x48c21f,4,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((DWORD*)0x48c21f)=dwP;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x48c21f,4,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4674a6,1,PAGE_READWRITE,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
*((BYTE*)0x4674a6)=0xeb;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
VirtualProtect((void*)0x4674a6,1,dwOldFlag,&dwOldFlag);
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
*/
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
return retVal;
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
return DirectDrawCreate(lpGUID,lplpDD,pUnkOuter);
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
my_DDrawwCreate根据设置对SetDisplayMode及SetCooperativeLevel进行拦截 进行窗口化
然后修改游戏程序的相应代码来实现游戏功能的增强
最后附上相应的代码
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
const DWORD p1=0x44D8B4,p2=0x41834C,p3=0x406434,p_disp=0x4a09a0;
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
const DWORD old_proc=0x44d6cc;
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
const DWORD p4=0x44d104;
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
void DispText(DWORD _eax, LPCTSTR string, DWORD x, DWORD y, DWORD color=0xffffff, DWORD bcolor=0x0)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedBlock.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
delphi_string dstring;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//sprintf(dstring.text,"%s",string);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
strcpy(dstring.text,string);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
dstring.len=strlen(string);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD address=(DWORD)(dstring.text);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
_asm
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedSubBlock.gif)
/**//* mov eax, _eax
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
call p1
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
call p2
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push 1
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push eax
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
call p3*/
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push color
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push bcolor
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push address
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov ecx, y
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov edx, x
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, _eax
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
call p_disp
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
DWORD fps=0,last_tick_count=0,frame=0;
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
const DWORD p5=0x40f6a0;
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
DWORD last_time_pickup=0;
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
CString MenuItems[6];
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
BOOL eat_item=TRUE;
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
__stdcall DispFunc(DWORD _EAX)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedBlock.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(GetTickCount()-last_tick_count>1000)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
fps=frame;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
frame=0;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
last_tick_count=GetTickCount();
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
frame++;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
struct tm *now;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
char buf[128];
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
time_t tval;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
tval = time(NULL);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
now = localtime(&tval);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
strftime(buf,sizeof(buf),"太子辅助 时间:%I:%M:%S %p",now);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,340,454);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD p_hpmp=*(DWORD*)0x4F7EF8;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD hp,hpmax,mp,mpmax,exp,expmax,weight,weightmax,gold;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
hp=*((WORD*)(p_hpmp+0x3c));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
hpmax=*((WORD*)(p_hpmp+0x40));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mp=*((WORD*)(p_hpmp+0x3e));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mpmax=*((WORD*)(p_hpmp+0x42));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
exp=*((DWORD*)(p_hpmp+0x48));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
expmax=*((DWORD*)(p_hpmp+0x4c));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
weight=*((WORD*)(p_hpmp+0x50));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
weightmax=*((WORD*)(p_hpmp+0x52));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
gold=*((DWORD*)(p_hpmp+0x58));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"生命:%u/%u 魔法:%u/%u",hp,hpmax,mp,mpmax);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,25,550);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"鼠标:%u:%u",*(DWORD*)0x4F948C,*(DWORD*)0x4F9490);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,350,580);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"经验:%u/%u",exp,expmax);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,666,538);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"负重:%u/%u",weight,weightmax);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,666,571);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"金币:%u",gold);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,666,507);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"FPS=%u",fps);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,10,8,RGB(255,255,255),RGB(255,0,0));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//显示装备持久
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(bShowDura)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
item_in_mem*item=(item_in_mem*)0x4F7EFC;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
char namebuf[128];
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
int off;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
for(off=0;off<9;off++)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(item[off].magic!=0)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
memcpy(namebuf,item[off].name,item[off].magic);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
namebuf[item[off].magic]=(char)0;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"%s %u/%u",namebuf,item[off].dura,item[off].dura_max);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,10,26+off*16);
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//显示地面物品名字
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD i;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD count;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD get_droped_item=0x40F6A0;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD map_rect_left;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD map_rect_top;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD defx,defy;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD my_x,my_y;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
_asm
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, 004a42dch
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov edx, dword ptr [eax+0002ae54h]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov map_rect_left, edx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov edx, dword ptr [eax+0002ae58h]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov map_rect_top, edx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, 04F7DA4h
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax+08h]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov count, eax
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, 004A3E9Ch
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov edx, 0FFFFFFA0h
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sub edx, dword ptr [eax+00000098h]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
add edx, 00000010h
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
add edx, 0000000Eh
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov defx, edx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, 004A3E9Ch
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov edx, 0FFFFFFC0h
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sub edx, dword ptr [eax+0000009Ch]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov defy, edx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, 004A3E9Ch
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
movzx eax, word ptr [eax+08h]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov my_x, eax
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, 004A3E9Ch
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
movzx eax, word ptr [eax+0ah]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov my_y, eax
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
drop_item item;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD p,x,y;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
bool bChecked=false;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
for(i=0;i<count;i++)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
_asm
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, 04F7DA4h
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, dword ptr [eax]
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov edx, i
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
call get_droped_item
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov p, eax
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
memcpy(&item,(void*)p,sizeof(drop_item));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
x=(item.x - map_rect_left) * 48 + defx + 0;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
y=(item.y - map_rect_top - 1) * 32 + defy + 0;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(x>=0 && x<800 && y>=0 && y<600)//屏幕外的不显示
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
memcpy(buf,(void*)(p+sizeof(drop_item)+1),*(BYTE*)(p+sizeof(drop_item)));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
buf[*(BYTE*)(p+sizeof(drop_item))]=(char)0;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,x,y);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(!bChecked && item.x==my_x && item.y==my_y && GetTickCount()-last_time_pickup>100)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
last_time_pickup=GetTickCount();
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
SendPickUp();
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
bChecked=true;
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//数字显血
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD act_list;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD act;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
act_list=(*(DWORD*)0x4a3dd8);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
act_list=(*(DWORD*)act_list);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
act_list=(*(DWORD*)(act_list+0x5a854));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
count=(*(DWORD*)(act_list+0x8));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
typedef struct
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DWORD x,y,hp,hpmax;
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}act_struct;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
act_struct actor;
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
for(i=0;i<count;i++)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
_asm
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov eax, act_list
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov edx, i
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
call p5
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
mov act, eax
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
actor.x= (*(DWORD*)(act+0x8c));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
actor.y= (*(DWORD*)(act+0x90));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
actor.hp= (*( WORD*)(act+0x3c));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
actor.hpmax= (*( WORD*)(act+0x40));
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
if(actor.hpmax!=0)
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
sprintf(buf,"%u/%u",actor.hp,actor.hpmax);
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
DispText(_EAX,buf,actor.x-15,actor.y-20,RGB(0xff,0,0));
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/None.gif)
__declspec(naked) _DispFunc()
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![](http://www.cppblog.com/Images/OutliningIndicators/ContractedBlock.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
__asm
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://www.cppblog.com/Images/dot.gif)
{
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//保存参数
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push eax
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push edx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push ecx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
//调用自己的函数
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
push eax
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
call DispFunc
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
pop ecx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
pop edx
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
pop eax
![](http://www.cppblog.com/Images/OutliningIndicators/InBlock.gif)
jmp p_disp
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cppblog.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}