Microsoft MVP성태의 닷넷 이야기
글쓴 사람
jhp (hopa0228 at naver.com)
홈페이지
첨부 파일
 

DWORD _Base = (DWORD)GetModuleHandle("game.exe");

DWORD tmBase = _Base + 0x7FCE40;
DWORD _angle = _Base + 0x7F1484;
DWORD _CamPos = _Base + 0x7F148C;
DWORD cBone = _Base + 0x1720A0;
DWORD GAbase = _Base + 0x7C969C;

class _Angle
{
public:
    char _0x1[0x2CC];
    float ySub;
    float Yaxis;
    char _0x001[0xB4];
    float Xaxis;
};
class cSkeleton
{
public:
    char _0x0000[0x80];
    D3DXVECTOR3 BoneCords; // 0x80
};
class CgameBase
{
public:
    char _0x0004[0xB57C];
    int Index; // 0xB57C
    int GameType; // 0xB580
    int _0x0045;// 0xB584
    int Rounds; // 0xB588
};
class PlayerLoop
{
public:
    char _0x01[0x1C48F0];
    int lctnView;
    int none1;
    int none2;
    int isAlive;
};
class __PLR
{
public:

    _Angle* AAAngle()
    {
        return *(_Angle**)(_angle);
    }



    D3DXVECTOR3 MyCamPos = *(D3DXVECTOR3*)_CamPos;
    DWORD PlayerIndex(int i)
    {
        DWORD result = *(PDWORD)tmBase;
        if (!result)
            return 0;

        result = *(PDWORD)(result + 0xC);
        if (!result)
            return 0;

        result = *(PDWORD)(result + 0x4);
        if (!result)
            return 0;

        result = *(PDWORD)(result + (i * 4) + 4);
        if (!result)
            return 0;

        result = *(PDWORD)(result + 0x80C);
        if (!result)
            return 0;

        result = *(PDWORD)(result + 0x170);
        if (!result)
            return 0;

        return *(PDWORD)(result + 0x4);
    }

    CgameBase* GetGameBase()
    {
        return *(CgameBase**)GAbase;
    }

    DWORD GetTeamBase()
    {
        DWORD Ptr1 = *(PDWORD)tmBase;
        if (Ptr1 == 0)
            return 0;
        return Ptr1 = *(PDWORD)(Ptr1 + 0x10);
    }
    int GetMyIndex()
    {
        CgameBase* pPlayerBase = GetGameBase();
        if (!pPlayerBase)
            return 0;

        return pPlayerBase->Index;
    }
    bool isTeammate(int i)
    {
        int MyPlayer = *(PDWORD)(GetTeamBase() + 4 * GetMyIndex() + 0x548);
        int Entity = *(PDWORD)(GetTeamBase() + 4 * i + 0x548);

        if (MyPlayer == Entity)
            return true;

        return false;
    }
    DWORD PlayerLoopBase()
    {
        DWORD result = *(PDWORD)tmBase;
        if (!result)
            return 0;

        result = *(PDWORD)(result + 0xC);
        if (!result)
            return 0;

        return *(PDWORD)(result + 0x4);
    }
    PlayerLoop* GetPlrByLoop(int i)
    {
        DWORD BasePtr = PlayerLoopBase();

        if (BasePtr == 0)
            return 0;

        return *(PlayerLoop**)(BasePtr + (i * 4) + 4);
    }

};
extern __PLR plr;
__PLR plr;
D3DXVECTOR3 _GetBone(int i, LPSTR szBoneName)
{

    typedef cSkeleton* (__thiscall* tGetBonePtr)(DWORD, LPSTR);
    tGetBonePtr GetBonePtr = (tGetBonePtr)cBone;
    cSkeleton *pGetBone = GetBonePtr(plr.PlayerIndex(i), szBoneName);

    return pGetBone->BoneCords;
}

void AimToTarget(D3DXVECTOR3 MyPlayer, D3DXVECTOR3 Entity, D3DXVECTOR3 &Aim) // math for who asking for it !
{
    double Target[3] = { (MyPlayer.x - Entity.x), (MyPlayer.y - Entity.y), (MyPlayer.z - Entity.z) }; // for x y z
    double hyp = sqrt(Target[0] * Target[0] + Target[2] * Target[2]);

    Aim.x = (float)(atanf(Target[2] / Target[0]) * -1.0f); // this is for Y_Sub, important !
    Aim.y = (float)(asinf(Target[1] / hyp) * 57.29573671972f);
    Aim.z = 0.0f; // keep it 0

    // Math for map_world.. to fix it here we go..
    if (Target[0] >= 0.0) { Aim.x -= 180.0f / 57.29573671972f; }

}

void Aimbot()
{

    D3DXVECTOR3 MY_CAM = plr.MyCamPos;
    D3DXVECTOR3 i_Aim;

    _Angle* MY_Angle = plr.AAAngle();
    float xAxis = MY_Angle->Xaxis;
    float yAxis = MY_Angle->Yaxis;
    float ySub = MY_Angle->ySub;

    for (int i = 0; i < 16; i++)
    {
        PlayerLoop* Players = plr.GetPlrByLoop(i);
        if (Players)
        {
            if (plr.isTeammate(i)) continue; // ignore teammate
            if (!Players->isAlive) continue; // ignore deadbody.
            if (i == plr.GetMyIndex()) continue; // ignore myplayer.

            D3DXVECTOR3 Entity_Head = _GetBone(i, "Bip01 Neck");
            if (GetAsyncKeyState(VK_RBUTTON) & 0x8000) // Hotkey for aimbot..
            {
                AimToTarget(MY_CAM, Entity_Head, i_Aim);

                MY_Angle->Xaxis = i_Aim.x;
                MY_Angle->Yaxis = i_Aim.y;
                MY_Angle->ySub = i_Aim.y * -1; // important !
            }
        }
    }


}



이런 저런 글들을 읽어봐도 너무 어렵네요 ㅜㅜ








[최초 등록일: ]
[최종 수정일: 10/30/2018]


비밀번호

댓글 작성자
 



2018-10-30 10시30분
글쎄요, 저도 저것만 봐서는 뭐라고 조언해 드릴 것이 없군요. 아래의 글을 참고하시고,

MIT 라이선스로 무료 공개된 Detours API 후킹 라이브러리
; http://www.sysnet.pe.kr/2/0/11764

예제 프로젝트에 있는 sleep5 프로젝트를 잘 분석하셔서 원하는 목적에 맞게 접목하시면 될 것입니다.
정성태
2018-11-03 04시08분
[ jhp] 답변감사드립니다. 아직 내공이 부족해서 그런지 계속 해봐도 모르겠네요 ㅠㅠ
혹시 윈도우모드로 프로그램을 실행시키게 만드는 소스가 있나요?
[guest]
2018-11-03 06시53분
Detours의 samples 폴더에 보면 traceapi라는 예제가 있습니다. 그 예제가 윈도우가 있는 예제일 것입니다.
정성태
2018-11-04 02시57분
덧글 질문을 다시 읽어 보니, 아마도 Full Screen으로 뜨는 게임 프로그램을 "Windowed" 모드로 뜨도록 만드는 소스가 있는지를 물어보는 것 같은데요, 그런 용도로 나온 예제 코드는 없습니다. 아마도 웹을 검색해 보면 나올 수도 있겠지만 후킹과 관련된 것이라 찾기가 쉽지는 않을 것입니다.

참고로, Detours로 한다면 COM 후킹 예제 소스를 보고 구현해야 할 것입니다. 또한 대상 게임 프로그램이 사용하는 DirectX 버전에 따라 사용하는 COM 인터페이스가 다르기 때문에 그런 부분도 조정해야 할 것입니다. 혹시나 성공하시거든 관련해서 블로그 글 하나 써서 공유해 주시면 다른 분들에게도 멋진 참고 자료가 될 것입니다. ^^
정성태

... 31  32  33  34  35  [36]  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4966포플러3/30/20189565    답변글 [답변]: C# 응용프로그램 (Winform)에서 unhandledexception 발생시 프로그램이 죽는 현상 이외에 재부팅될 수도 있을까요? [1]
4961김민욱3/26/201810480레이더 뷰어의 구현 방법(이미지 확대 축소 관련) [2]
4960hurd...3/18/201810160OCX 관련한 질문을 드리고자 합니다. [1]
4959익명3/10/20189192교재 199page 델리게이트와 object를 이용한 범용 정렬 코드 [1]
4957멍멍이2/13/20189777System.Console - WriteLine함수의 제너릭 사용 [1]
4956김성대2/12/20189107asp.net 질문입니다. [1]
4955웅이2/12/20189622[삭제] WPF에서 list 속도 향상하는 방법이 있을까요?
4954초보자2/8/201811382FFT Library 사용 [1]
4950ASP열공2/5/20189132asp.net 과 C# 을 이용해서 홈페이지 만드는 질문입니다. [1]
4951ASP열공2/6/201810103    답변글 [답변]: asp.net 과 C# 을 이용해서 홈페이지 만드는 질문입니다. [1]
4952ASP열공2/7/20189251        답변글 [답변]: [답변]: asp.net 과 C# 을 이용해서 홈페이지 만드는 질문입니다. [1]
4953ASP열공2/7/20188770            답변글 [답변]: [답변]: [답변]: asp.net 과 C# 을 이용해서 홈페이지 만드는 질문입니다.
4949김성대1/31/201810471비동기 질문입니다. [3]파일 다운로드1
494880511/31/20189235C# 7.1책 보다가 질문드립니다 [1]
4947김성대1/30/201810501[삭제] 비동기 질문입니다. [2]파일 다운로드2
4946윤현수1/29/201810022비동기 TCP통신 데이터 문제 [4]파일 다운로드1
4945김성대1/26/20188539비동기 질문입니다. [1]파일 다운로드1
4944popo1/25/20187973[삭제] 스레드 안에서 Window Visibility 변경시 DialogResult 오류 질문
4943김성대1/22/20188944FromAsync 질문입니다. [1]
4942박현일1/19/201810543WPF 공부중 모르는 문법이 있어서요~^^; [2]
4941김성대1/18/20188806비동기예약어 실행오류관련입니다. [1]
4940plzh...1/10/20189725webbrowser2 를 이용한 sns 로그인 구현 관련 문의 [2]
4939이성일1/4/201811202ClickOnce 배포 후 업데이트 시 발생하는 오류에 대해 질문 드립니다. [2]
4938김성대1/3/20189286채팅 프로그램관련 질문입니다. [9]파일 다운로드1
4937Ques...1/3/201811644C# CPU 사용량 한계치 늘리는 방법 [2]
4936무개1/3/20188787책 내용 인용하는 것에 관한 질문이있습니다. [1]파일 다운로드1
... 31  32  33  34  35  [36]  37  38  39  40  41  42  43  44  45  ...