forked from danong/mhw-dps-overlay
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmhw.cs
180 lines (149 loc) · 6.59 KB
/
mhw.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
// Decompiled with JetBrains decompiler
// Type: mhw
// Assembly: mhw_dps_wpf, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
// MVID: 9AF2A04E-56DA-4D52-9297-848C4FCE5E85
// Assembly location: C:\Users\Daniel\Desktop\mhw_damage_meter_1_0.exe
using System;
using System.Diagnostics;
using System.Runtime.InteropServices;
using System.Text;
public static class mhw
{
public static long loc1 = -1;
public static long loc2 = -1;
public static long loc3 = -1;
public static long loc4 = -1;
[DllImport("kernel32.dll")]
private static extern bool ReadProcessMemory(IntPtr hProcess, IntPtr lpBaseAddress, byte[] lpBuffer, int dwSize, ref int lpNumberOfBytesRead);
private static bool ReadProcessMemory(IntPtr hProcess, IntPtr lpBaseAddress, byte[] lpBuffer)
{
int lpNumberOfBytesRead = 0;
return mhw.ReadProcessMemory(hProcess, lpBaseAddress, lpBuffer, lpBuffer.Length, ref lpNumberOfBytesRead);
}
public static ulong read_ulong(IntPtr hProcess, IntPtr lpBaseAddress)
{
byte[] lpBuffer = new byte[8];
mhw.ReadProcessMemory(hProcess, lpBaseAddress, lpBuffer);
return BitConverter.ToUInt64(lpBuffer, 0);
}
public static uint read_uint(IntPtr hProcess, IntPtr lpBaseAddress)
{
byte[] lpBuffer = new byte[4];
mhw.ReadProcessMemory(hProcess, lpBaseAddress, lpBuffer);
return BitConverter.ToUInt32(lpBuffer, 0);
}
public static int dword_to_int(ref byte[] array)
{
return (int)array[0] + ((int)array[1] << 8) + ((int)array[2] << 16) + ((int)array[3] << 24);
}
private static ulong asm_func1(Process proc, ulong rcx, uint edx)
{
int num1 = (int)mhw.read_uint(proc.Handle, (IntPtr)mhw.loc1);
ulong num2 = rcx;
int num3 = (int)edx;
rcx = (ulong)(uint)(num1 & num3) * 88UL;
return num2 + 72UL + rcx;
}
public static int[] get_team_dmg(Process proc)
{
int[] numArray = new int[4];
byte[] array = new byte[4];
byte[] lpBuffer = new byte[8];
mhw.ReadProcessMemory(proc.Handle, (IntPtr)mhw.loc2, lpBuffer);
ulong num1 = BitConverter.ToUInt64(lpBuffer, 0) + 26288UL;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)mhw.loc3, lpBuffer);
ulong uint64_1 = BitConverter.ToUInt64(lpBuffer, 0);
for (int index = 0; index < 4; ++index)
{
mhw.ReadProcessMemory(proc.Handle, (IntPtr)((long)num1 + 4L * (long)index), array);
uint edx = mhw.read_uint(proc.Handle, (IntPtr)((long)num1 + 4L * (long)index));
ulong num2 = mhw.asm_func1(proc, uint64_1, edx);
if (num2 > 0UL)
{
mhw.ReadProcessMemory(proc.Handle, (IntPtr)((long)num2 + 72L), lpBuffer);
ulong uint64_2 = BitConverter.ToUInt64(lpBuffer, 0);
if (uint64_2 > 0UL)
{
int num3 = mhw.ReadProcessMemory(proc.Handle, (IntPtr)((long)uint64_2 + 72L), array) ? 1 : 0;
int num4 = mhw.dword_to_int(ref array);
if (num3 != 0 && num4 >= 0 && num4 <= 1048575)
numArray[index] = num4;
}
}
}
return numArray;
}
public static int get_player_seat_id(Process proc)
{
uint num1 = mhw.read_uint(proc.Handle, (IntPtr)mhw.loc4);
uint num2 = mhw.read_uint(proc.Handle, (IntPtr)((long)(num1 + 600U)));
int num3 = -1;
if (num2 > 4096U)
{
uint num4 = mhw.read_uint(proc.Handle, (IntPtr)((long)(num2 + 16U)));
if (num4 != 0U)
num3 = (int)mhw.read_uint(proc.Handle, (IntPtr)((long)(num4 + 49132U)));
}
return num3;
}
public static float get_monster_hp(Process proc)
{
byte[] lpBuffer = new byte[8];
mhw.ReadProcessMemory(proc.Handle, (IntPtr)0x143B20D98, lpBuffer);
ulong num1 = BitConverter.ToUInt64(lpBuffer, 0) + 0x168;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num1, lpBuffer);
ulong num2 = BitConverter.ToUInt64(lpBuffer, 0) + 0x8A8;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num2, lpBuffer);
ulong num3 = BitConverter.ToUInt64(lpBuffer, 0) + 0x3B0;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num3, lpBuffer);
ulong num4 = BitConverter.ToUInt64(lpBuffer, 0) + 0x18;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num4, lpBuffer);
ulong num5 = BitConverter.ToUInt64(lpBuffer, 0) + 0x58;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num5, lpBuffer);
ulong num6 = BitConverter.ToUInt64(lpBuffer, 0) + 0x64;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num6, lpBuffer);
return BitConverter.ToSingle(lpBuffer, 0);
}
public static float get_monster_max_hp(Process proc)
{
byte[] lpBuffer = new byte[8];
mhw.ReadProcessMemory(proc.Handle, (IntPtr)0x143B20D98, lpBuffer);
ulong num1 = BitConverter.ToUInt64(lpBuffer, 0) + 0x168;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num1, lpBuffer);
ulong num2 = BitConverter.ToUInt64(lpBuffer, 0) + 0x8A8;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num2, lpBuffer);
ulong num3 = BitConverter.ToUInt64(lpBuffer, 0) + 0x3B0;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num3, lpBuffer);
ulong num4 = BitConverter.ToUInt64(lpBuffer, 0) + 0x18;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num4, lpBuffer);
ulong num5 = BitConverter.ToUInt64(lpBuffer, 0) + 0x58;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num5, lpBuffer);
ulong num6 = BitConverter.ToUInt64(lpBuffer, 0) + 0x60;
mhw.ReadProcessMemory(proc.Handle, (IntPtr)num6, lpBuffer);
return BitConverter.ToSingle(lpBuffer, 0);
}
public static string[] get_team_player_names(Process proc)
{
string[] strArray = new string[4];
byte[] array = new byte[40];
int num = (int)mhw.read_uint(proc.Handle, (IntPtr)mhw.loc4) + 346693;
for (int index1 = 0; index1 < 4; ++index1)
{
Array.Resize<byte>(ref array, 40);
mhw.ReadProcessMemory(proc.Handle, (IntPtr)(num + 33 * index1), array);
int index2 = Array.FindIndex<byte>(array, (Predicate<byte>)(x => x == (byte)0));
switch (index2)
{
case -1:
case 0:
strArray[index1] = "";
break;
default:
Array.Resize<byte>(ref array, index2);
strArray[index1] = Encoding.UTF8.GetString(array);
break;
}
}
return strArray;
}
}