青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-60  評論-111  文章-0  trackbacks-0
LRESULT CALLBACK HookProc(int nCode, WPARAM wParam, LPARAM lParam)
{
    
if(nCode==HSHELL_WINDOWCREATED)
    
{
        
char buf[1024];
        DWORD dwPid;
        GetWindowText((HWND)wParam,buf,
1024);
        
if(strcmp(buf,"legend of mir2")==0)
        
{
            GetClassName((HWND)wParam,buf,
1024);
            
if( strcmp(buf,"TfrmMain")==0 ||
                
//strcmp(buf,"TApplication")==0 ||
                strcmp(buf,"TFrmMain")==0 )
            
{
                GetWindowThreadProcessId((HWND)wParam,
&dwPid);
                
if(dwPid==GetCurrentProcessId())
                
{
                    DWORD d;
                    d
=(DWORD)my_DDrawwCreate;
                    
char bb[5];
                    bb[
0]=bb[1]=bb[2]=bb[3]=bb[4]=(char)0x90;
                    DWORD dwOldFlag;
                    VirtualProtect((
void*)0x44c586,9,PAGE_READWRITE,&dwOldFlag);
                    memcpy((
void*)0x44c586,&d,4);
                    memcpy((
void*)0x44c58a,bb,5);
                    VirtualProtect((
void*)0x44c586,9,dwOldFlag,&dwOldFlag);
                }

            }

        }

    }

    
return CallNextHookEx(g_hhook, nCode, wParam ,lParam);
}


void InstallHook()
{
    
if(g_hhook==NULL)
    
{
        g_hhook
=SetWindowsHookEx(WH_SHELL,(HOOKPROC)HookProc,theApp.m_hInstance,0);
        
if(g_hhook==NULL)
            MessageBox(
0,"SetWindowsHookEx Failed!!",NULL,MB_OK);
    }

}

通過InstallHook來安裝一個WH_SHELL類型的鉤子 目的是在游戲窗口創(chuàng)建的第一時間取得控制權(quán) 然后通過改寫相關(guān)代碼來實(shí)現(xiàn)對DirectDrawCreate函數(shù)的攔截 使之流向我們設(shè)置的代碼my_DDrawwCreate
HRESULT __stdcall my_DDrawwCreate(GUID*lpGUID,LPDIRECTDRAW*lplpDD,IUnknown*pUnkOuter)
{
    HRESULT retVal;
    HWND hWnd
=NULL;
    
if(hWnd==NULL)
        hWnd
=FindWindow("TfrmMain","legend of mir2");
    
//if(hWnd==NULL)
    
//    hWnd=FindWindow("TApplication","legend of mir2");
    if(hWnd==NULL)
        hWnd
=FindWindow("TFrmMain","legend of mir2");
    
{
        retVal
=DirectDrawCreate(lpGUID,lplpDD,pUnkOuter);

        
if(g_isWindowMir)
        
{
            LPDIRECTDRAW lpDD
=*lplpDD;
            DWORD p1
=(DWORD)*lplpDD;
            DWORD p2
=*(DWORD*)p1;
            
*((DWORD*)(p2+0x54))=(DWORD)(FARPROC)my_SetDisplayMode;
            old_SetCooperativeLevel
=*((DWORD*)(p2+0x50));
            
*((DWORD*)(p2+0x50))=(DWORD)(FARPROC)my_SetCooperativeLevel;
        }

        DWORD
*psend;
        psend
=(DWORD*)0x4fa720;
        
*psend=(DWORD)my_send;
        
{
            AFX_MANAGE_STATE(AfxGetStaticModuleState());
            pToolDlg
=new CToolDialog;
            pToolDlg
->Create(IDD_TOOL_DIALOG);
            pToolDlg
->SetWindowText("太子");
            pToolDlg
->ShowWindow(pToolDlg->IsWindowVisible() ? SW_HIDE : SW_SHOW);

            
//數(shù)字顯示
            FARPROC p=(FARPROC)_DispFunc;
            DWORD dwP
=(DWORD)p-0x47AA1B;
            DWORD dwOldFlag;
            VirtualProtect((
void*)0x47AA17,4,PAGE_READWRITE,&dwOldFlag);
            
*((DWORD*)0x47AA17)=dwP;
            VirtualProtect((
void*)0x47AA17,4,dwOldFlag,&dwOldFlag);
            
//取消程序自檢驗(yàn)
            VirtualProtect((void*)0x45EC00,1,PAGE_READWRITE,&dwOldFlag);
            
*((BYTE*)0x45EC00)=(BYTE)0xC3;
            VirtualProtect((
void*)0x45EC00,1,dwOldFlag,&dwOldFlag);
            
//戰(zhàn)斗退出
            VirtualProtect((void*)0x4620E6,2,PAGE_READWRITE,&dwOldFlag);
            
*((WORD*)0x4620E6)=(WORD)0x9090;
            VirtualProtect((
void*)0x4620E6,2,dwOldFlag,&dwOldFlag);

            VirtualProtect((
void*)0x462162,2,PAGE_READWRITE,&dwOldFlag);
            
*((WORD*)0x462162)=(WORD)0x9090;
            VirtualProtect((
void*)0x462162,2,dwOldFlag,&dwOldFlag);

            VirtualProtect((
void*)0x4914CA,2,PAGE_READWRITE,&dwOldFlag);
            
*((WORD*)0x4914CA)=(WORD)0x9090;
            VirtualProtect((
void*)0x4914CA,2,dwOldFlag,&dwOldFlag);

            VirtualProtect((
void*)0x491576,2,PAGE_READWRITE,&dwOldFlag);
            
*((WORD*)0x491576)=(WORD)0x9090;
            VirtualProtect((
void*)0x491576,2,dwOldFlag,&dwOldFlag);

            
//顯物品id
            p=(FARPROC)ShowItemId;
            dwP
=(DWORD)p-0X0048C458;
            
//VirtualProtect((void*)0X0048C430,0x23,PAGE_READWRITE,&dwOldFlag);
            
//for(char i=0;i<0x23;i++)
            
//{
            
//    *((BYTE*)(0X0048C430+i))=0x90;
            
//}
            
//VirtualProtect((void*)0X0048C430,0x23,dwOldFlag,&dwOldFlag);
            VirtualProtect((void*)0X0048C454,4,PAGE_READWRITE,&dwOldFlag);
            
*((DWORD*)(0X0048C454))=dwP;
            VirtualProtect((
void*)0X0048C454,4,dwOldFlag,&dwOldFlag);
            
//InstallGameHooks();
        }

/*
        p=(FARPROC)MagicLock;
        dwP=(DWORD)p-0x4627ab;
        VirtualProtect((void*)0x4627a7,4,PAGE_READWRITE,&dwOldFlag);
        *((DWORD*)0x4627a7)=dwP;
        VirtualProtect((void*)0x4627a7,4,dwOldFlag,&dwOldFlag);

        p=(FARPROC)EatItem;
        dwP=(DWORD)p-0x4623a6;
        VirtualProtect((void*)0x4623a2,4,PAGE_READWRITE,&dwOldFlag);
        *((DWORD*)0x4623a2)=dwP;
        VirtualProtect((void*)0x4623a2,4,dwOldFlag,&dwOldFlag);

        dwP=(DWORD)p-0x48c1e6;
        VirtualProtect((void*)0x48c1e2,4,PAGE_READWRITE,&dwOldFlag);
        *((DWORD*)0x48c1e2)=dwP;
        VirtualProtect((void*)0x48c1e2,4,dwOldFlag,&dwOldFlag);

        dwP=(DWORD)p-0x48c223;
        VirtualProtect((void*)0x48c21f,4,PAGE_READWRITE,&dwOldFlag);
        *((DWORD*)0x48c21f)=dwP;
        VirtualProtect((void*)0x48c21f,4,dwOldFlag,&dwOldFlag);

        VirtualProtect((void*)0x4674a6,1,PAGE_READWRITE,&dwOldFlag);
        *((BYTE*)0x4674a6)=0xeb;
        VirtualProtect((void*)0x4674a6,1,dwOldFlag,&dwOldFlag);
*/

        
return retVal;
    }

    
return DirectDrawCreate(lpGUID,lplpDD,pUnkOuter);
}

my_DDrawwCreate根據(jù)設(shè)置對SetDisplayMode及SetCooperativeLevel進(jìn)行攔截 進(jìn)行窗口化

然后修改游戲程序的相應(yīng)代碼來實(shí)現(xiàn)游戲功能的增強(qiáng)

最后附上相應(yīng)的代碼
const DWORD p1=0x44D8B4,p2=0x41834C,p3=0x406434,p_disp=0x4a09a0;
const DWORD old_proc=0x44d6cc;
const DWORD p4=0x44d104;
void DispText(DWORD _eax, LPCTSTR string, DWORD x, DWORD y, DWORD color=0xffffff, DWORD bcolor=0x0)
{
    delphi_string dstring;
    
//sprintf(dstring.text,"%s",string);
    strcpy(dstring.text,string);
    dstring.len
=strlen(string);
    DWORD address
=(DWORD)(dstring.text);
    _asm
    
{
/*        mov eax, _eax
        call p1
        call p2
        push 1
        push eax
        call p3
*/

        push color
        push bcolor
        push address
        mov ecx, y
        mov edx, x
        mov eax, _eax
        call p_disp
    }

}


DWORD fps
=0,last_tick_count=0,frame=0;
const DWORD p5=0x40f6a0;
DWORD last_time_pickup
=0;
CString MenuItems[
6];
BOOL eat_item
=TRUE;

__stdcall DispFunc(DWORD _EAX)
{
    
if(GetTickCount()-last_tick_count>1000)
    
{
        fps
=frame;
        frame
=0;
        last_tick_count
=GetTickCount();
    }

    frame
++;
    
struct tm *now;
    
char buf[128];
    time_t tval;
    tval 
= time(NULL);
    now 
= localtime(&tval);
    strftime(buf,
sizeof(buf),"太子輔助 時間:%I:%M:%S %p",now);
    DispText(_EAX,buf,
340,454);


    DWORD p_hpmp
=*(DWORD*)0x4F7EF8;
    DWORD hp,hpmax,mp,mpmax,exp,expmax,weight,weightmax,gold;
    hp
=*((WORD*)(p_hpmp+0x3c));
    hpmax
=*((WORD*)(p_hpmp+0x40));
    mp
=*((WORD*)(p_hpmp+0x3e));
    mpmax
=*((WORD*)(p_hpmp+0x42));
    exp
=*((DWORD*)(p_hpmp+0x48));
    expmax
=*((DWORD*)(p_hpmp+0x4c));
    weight
=*((WORD*)(p_hpmp+0x50));
    weightmax
=*((WORD*)(p_hpmp+0x52));
    gold
=*((DWORD*)(p_hpmp+0x58));

    sprintf(buf,
"生命:%u/%u  魔法:%u/%u",hp,hpmax,mp,mpmax);
    DispText(_EAX,buf,
25,550);
    sprintf(buf,
"鼠標(biāo):%u:%u",*(DWORD*)0x4F948C,*(DWORD*)0x4F9490);
    DispText(_EAX,buf,
350,580);

    sprintf(buf,
"經(jīng)驗(yàn):%u/%u",exp,expmax);
    DispText(_EAX,buf,
666,538);
    sprintf(buf,
"負(fù)重:%u/%u",weight,weightmax);
    DispText(_EAX,buf,
666,571);
    sprintf(buf,
"金幣:%u",gold);
    DispText(_EAX,buf,
666,507);
    sprintf(buf,
"FPS=%u",fps);
    DispText(_EAX,buf,
10,8,RGB(255,255,255),RGB(255,0,0));

    
//顯示裝備持久
    if(bShowDura)
    
{
        item_in_mem
*item=(item_in_mem*)0x4F7EFC;
        
char namebuf[128];
        
int off;
        
for(off=0;off<9;off++)
        
{
            
if(item[off].magic!=0)
            
{
                memcpy(namebuf,item[off].name,item[off].magic);
                namebuf[item[off].magic]
=(char)0;
                sprintf(buf,
"%s %u/%u",namebuf,item[off].dura,item[off].dura_max);
                DispText(_EAX,buf,
10,26+off*16);
            }

        }

    }

    
//顯示地面物品名字
    DWORD i;
    DWORD count;
    DWORD get_droped_item
=0x40F6A0;
    DWORD map_rect_left;
    DWORD map_rect_top;
    DWORD defx,defy;
    DWORD my_x,my_y;
    _asm
    
{
        mov eax, 004a42dch
        mov eax, dword ptr [eax]
        mov eax, dword ptr [eax]
        mov edx, dword ptr [eax
+0002ae54h]
        mov map_rect_left, edx
        mov edx, dword ptr [eax
+0002ae58h]
        mov map_rect_top, edx

        mov eax, 04F7DA4h
        mov eax, dword ptr [eax]
        mov eax, dword ptr [eax
+08h]
        mov count, eax

        mov eax, 004A3E9Ch
        mov eax, dword ptr [eax]
        mov eax, dword ptr [eax]
        mov edx, 0FFFFFFA0h
        sub edx, dword ptr [eax
+00000098h]
        add edx, 00000010h
        add edx, 0000000Eh
        mov defx, edx

        mov eax, 004A3E9Ch
        mov eax, dword ptr [eax]
        mov eax, dword ptr [eax]
        mov edx, 0FFFFFFC0h
        sub edx, dword ptr [eax
+0000009Ch]
        mov defy, edx

        mov eax, 004A3E9Ch
        mov eax, dword ptr [eax]
        mov eax, dword ptr [eax]
        movzx eax, word ptr [eax
+08h]
        mov my_x, eax

        mov eax, 004A3E9Ch
        mov eax, dword ptr [eax]
        mov eax, dword ptr [eax]
        movzx eax, word ptr [eax
+0ah]
        mov my_y, eax
    }

    drop_item item;
    DWORD p,x,y;
    
bool bChecked=false;
    
for(i=0;i<count;i++)
    
{
        _asm
        
{
            mov eax, 04F7DA4h
            mov eax, dword ptr [eax]
            mov edx, i
            call get_droped_item
            mov p, eax
        }

        memcpy(
&item,(void*)p,sizeof(drop_item));
        x
=(item.x - map_rect_left) * 48 + defx + 0;
        y
=(item.y - map_rect_top - 1* 32 + defy + 0;
        
if(x>=0 && x<800 && y>=0 && y<600)//屏幕外的不顯示
        {
            memcpy(buf,(
void*)(p+sizeof(drop_item)+1),*(BYTE*)(p+sizeof(drop_item)));
            buf[
*(BYTE*)(p+sizeof(drop_item))]=(char)0;
            DispText(_EAX,buf,x,y);
            
if(!bChecked && item.x==my_x && item.y==my_y && GetTickCount()-last_time_pickup>100)
            
{
                last_time_pickup
=GetTickCount();
                SendPickUp();
                bChecked
=true;
            }

        }

    }


    
//數(shù)字顯血
    DWORD act_list;
    DWORD act;
    act_list
=(*(DWORD*)0x4a3dd8);
    act_list
=(*(DWORD*)act_list);
    act_list
=(*(DWORD*)(act_list+0x5a854));
    count
=(*(DWORD*)(act_list+0x8));
    typedef 
struct
    
{
        DWORD x,y,hp,hpmax;
    }
act_struct;
    act_struct actor;
    
for(i=0;i<count;i++)
    
{
        _asm
        
{
            mov eax, act_list
            mov edx, i
            call p5
            mov act, eax
        }

        actor.x
=        (*(DWORD*)(act+0x8c));
        actor.y
=        (*(DWORD*)(act+0x90));
        actor.hp
=        (*( WORD*)(act+0x3c));
        actor.hpmax
=    (*( WORD*)(act+0x40));
        
if(actor.hpmax!=0)
        
{
            sprintf(buf,
"%u/%u",actor.hp,actor.hpmax);
            DispText(_EAX,buf,actor.x
-15,actor.y-20,RGB(0xff,0,0));
        }

    }

}


__declspec(naked) _DispFunc()
{
    __asm
    
{
        
//保存參數(shù)
        push eax
        push edx
        push ecx
        
//調(diào)用自己的函數(shù)
        push eax
        call DispFunc
        pop ecx
        pop edx
        pop eax
        jmp p_disp
    }

}

posted on 2007-08-28 23:59 shaker(太子) 閱讀(3272) 評論(5)  編輯 收藏 引用 所屬分類: C++

評論:
# re: 發(fā)一個mir2的內(nèi)掛代碼 2007-08-29 00:39 | TempStudent
記錄一下,我的Google Reader是這個時候收到的你的更新的。  回復(fù)  更多評論
  
# re: 發(fā)一個mir2的內(nèi)掛代碼 2007-09-03 18:32 | pscj
真強(qiáng)啊。嵌了那么多匯編還。看的暈  回復(fù)  更多評論
  
# re: 發(fā)一個mir2的內(nèi)掛代碼[未登錄] 2007-09-08 09:49 | Tiger
嘿嘿,我現(xiàn)在剛開始玩?zhèn)髌?br>有沒有脫機(jī)登錄之類的東西?有空指教一下
QQ:416050972  回復(fù)  更多評論
  
# re: 發(fā)一個mir2的內(nèi)掛代碼 2008-02-29 16:24 | Ramon
請教一下,哪個自校驗(yàn)的地址是怎么找出來的?  回復(fù)  更多評論
  
# re: 發(fā)一個mir2的內(nèi)掛代碼 2009-10-07 02:33 |
mir2.dat的代碼是多少啊,以前都不能用,謝謝 http://www.176335.com/index.htm 這是F的網(wǎng)站  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区三区黄色| 国产九色精品成人porny| 亚洲欧美日韩专区| 国产精品日韩| 午夜亚洲视频| 午夜精品美女自拍福到在线| 国产欧美日韩不卡免费| 久久久噜噜噜久噜久久| 米奇777在线欧美播放| 亚洲免费电影在线观看| 亚洲最新视频在线| 国产日韩精品一区二区三区在线| 久久国产日韩| 欧美jizzhd精品欧美喷水| 一本色道久久综合亚洲精品不| 在线视频中文亚洲| 国内精品美女在线观看| 最新国产成人在线观看| 国产精品国产三级欧美二区| 久久久xxx| 欧美精品在欧美一区二区少妇| 亚洲亚洲精品在线观看| 欧美一区二区精品在线| 99热这里只有精品8| 亚洲欧美久久久久一区二区三区| 激情久久久久| 亚洲无亚洲人成网站77777| 亚洲第一在线视频| 中文欧美在线视频| 亚洲高清资源| 午夜精品区一区二区三| 99热这里只有精品8| 久久久成人精品| 亚洲一区免费观看| 欧美成人一区二区| 久久久久久网站| 国产精品久久久久秋霞鲁丝| 欧美高清视频一区二区| 国产乱码精品一区二区三| 亚洲精品久久久久久久久久久| 国产在线精品一区二区夜色| 夜夜爽夜夜爽精品视频| 91久久精品国产91久久性色tv| 亚洲欧美日韩电影| 亚洲视频在线一区| 欧美精品激情blacked18| 久久久精品国产免费观看同学| 欧美图区在线视频| 亚洲毛片播放| 99精品久久免费看蜜臀剧情介绍| 久久婷婷国产麻豆91天堂| 午夜一区二区三区不卡视频| 欧美日韩国产色综合一二三四 | 国模叶桐国产精品一区| 99re热这里只有精品视频| 亚洲国产导航| 久久频这里精品99香蕉| 久久久久久精| 国产午夜久久久久| 亚洲欧美美女| 欧美一区二区三区久久精品| 国产精品久久久久久久久免费 | 午夜在线观看欧美| 夜夜嗨av一区二区三区免费区| 亚洲激情另类| 欧美jizz19hd性欧美| 欧美国产专区| 亚洲青涩在线| 欧美激情影音先锋| 亚洲美女黄色片| 亚洲一区999| 国产精品九九| 亚洲欧美日韩综合aⅴ视频| 欧美一级网站| 国模精品一区二区三区色天香| 久久久久久高潮国产精品视| 久久久午夜电影| 在线观看日韩www视频免费| 麻豆成人综合网| 亚洲精品久久久久久久久久久久 | 亚洲私人影院在线观看| 国产精品成人免费精品自在线观看| 一区二区三区四区国产| 亚洲综合不卡| 狠狠色噜噜狠狠色综合久 | 亚洲欧美综合另类中字| 久久精品视频免费观看| 1000部精品久久久久久久久| 欧美激情1区| 亚洲在线国产日韩欧美| 久久亚洲美女| 在线亚洲精品| 好男人免费精品视频| 欧美精品在线一区二区| 午夜视频在线观看一区二区三区| 蜜桃视频一区| 亚洲一区二区在线免费观看视频 | 欧美本精品男人aⅴ天堂| 一本久道久久综合狠狠爱| 久久成人资源| 亚洲欧洲在线免费| 国产精品理论片在线观看| 久久亚洲色图| 亚洲一区二区伦理| 欧美成年人视频| 亚洲欧美日韩在线不卡| 在线观看中文字幕亚洲| 国产精品成人一区二区网站软件| 久久久久欧美精品| 亚洲天堂av在线免费| 免费视频一区二区三区在线观看| 亚洲午夜精品久久久久久浪潮 | 欧美精品少妇一区二区三区| 亚洲欧美在线另类| 亚洲国产天堂久久综合网| 久久国产加勒比精品无码| 亚洲美女中文字幕| 一区二区三区在线视频观看| 国产精品国产三级国产普通话蜜臀 | 久久久精品久久久久| 在线综合+亚洲+欧美中文字幕| 免费欧美在线视频| 亚洲精品在线三区| 久久久久国产免费免费| 亚洲午夜一二三区视频| 亚洲国产va精品久久久不卡综合| 欧美一区二区成人| 亚洲一区综合| 夜夜爽www精品| 亚洲久久视频| 亚洲电影有码| 亚洲福利视频三区| 韩国三级电影一区二区| 国产视频久久久久久久| 国产精品久久久一区二区| 欧美日本免费| 欧美国产三级| 欧美黄色网络| 欧美精品三级| 欧美色视频一区| 欧美日韩福利在线观看| 欧美日韩国产一区二区三区| 欧美激情中文字幕在线| 欧美国产欧美综合| 欧美精品入口| 国产精品黄页免费高清在线观看| 欧美日韩高清在线播放| 欧美日韩视频在线| 欧美三区美女| 国产精品男人爽免费视频1| 欧美性做爰毛片| 国产伦精品一区二区三区照片91 | 老鸭窝毛片一区二区三区| 久久久久久精| 免费日韩av| 亚洲精品午夜精品| 夜夜嗨一区二区| 午夜久久福利| 老司机午夜精品视频在线观看| 免费人成精品欧美精品| 欧美三级日本三级少妇99| 国产精品亚洲人在线观看| 国产午夜精品全部视频播放| …久久精品99久久香蕉国产| 亚洲美女在线国产| 午夜精品久久久久影视| 久久色中文字幕| 亚洲国产成人在线视频| 一区二区精品国产| 香蕉久久国产| 欧美精品免费看| 国产精品推荐精品| 在线看视频不卡| 亚洲午夜精品久久| 久久综合图片| 亚洲免费观看| 久久精品伊人| 欧美欧美午夜aⅴ在线观看| 国产精品视频最多的网站| 亚洲国产精品美女| 性做久久久久久| 亚洲成人资源| 欧美一区免费| 欧美午夜精品久久久久免费视 | 国产精品久久久久av| 亚洲国产精品va在线看黑人动漫| 一本色道久久综合亚洲91| 久久成人18免费观看| 亚洲精品久久7777| 亚洲欧美福利一区二区| 免费观看成人www动漫视频| 国产伦精品一区二区三区免费 | 蜜桃av久久久亚洲精品| 欧美一区二区视频97| 久久精品国产v日韩v亚洲| 欧美激情日韩| 午夜欧美理论片| 欧美视频在线观看视频极品| 在线精品视频一区二区三四| 亚洲午夜电影|