1 | UNIT Unit4;
|
---|
2 | INTERFACE
|
---|
3 | USES
|
---|
4 | Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
|
---|
5 | Dialogs, StdCtrls, ExtCtrls, ComCtrls, StrUtils;
|
---|
6 | TYPE
|
---|
7 | TForm4 = Class(TForm)
|
---|
8 | Label1: TLabel;
|
---|
9 | edit_char: TEdit;
|
---|
10 | list: TListBox;
|
---|
11 | Label2: TLabel;
|
---|
12 | btn_demo: TButton;
|
---|
13 | check_freeze: TCheckBox;
|
---|
14 | timer_anim: TTimer;
|
---|
15 | check_global: TRadioButton;
|
---|
16 | check_local: TRadioButton;
|
---|
17 | updown: TUpDown;
|
---|
18 | group_anim: TGroupBox;
|
---|
19 | lbl_lvl: TLabel;
|
---|
20 | memo: TMemo;
|
---|
21 | PROCEDURE listClick(Sender: TObject);
|
---|
22 | PROCEDURE btn_demoClick(Sender: TObject);
|
---|
23 | PROCEDURE updownClick(Sender: TObject; Button: TUDBtnType);
|
---|
24 | PROCEDURE FormCreate(Sender: TObject);
|
---|
25 | PROCEDURE FormCloseQuery(Sender: TObject; var CanClose: Boolean);
|
---|
26 | PROCEDURE check_localClick(Sender: TObject);
|
---|
27 | PROCEDURE check_globalClick(Sender: TObject);
|
---|
28 | PROCEDURE timer_animTimer(Sender: TObject);
|
---|
29 | PROCEDURE check_freezeClick(Sender: TObject);
|
---|
30 | PRIVATE
|
---|
31 | PUBLIC
|
---|
32 | END;
|
---|
33 | VAR
|
---|
34 | Form4: TForm4;
|
---|
35 |
|
---|
36 | IMPLEMENTATION
|
---|
37 | USES Unit1, Unit2, Unit8;
|
---|
38 | VAR
|
---|
39 | demo_active:Boolean=False;
|
---|
40 | first_global:LongWord;
|
---|
41 | first_local:LongWord;
|
---|
42 | {$R *.dfm}
|
---|
43 |
|
---|
44 | PROCEDURE TForm4.check_freezeClick(Sender: TObject);
|
---|
45 | BEGIN
|
---|
46 | btn_demo.Caption:='Start demo';
|
---|
47 | demo_active:=False;
|
---|
48 | END;
|
---|
49 |
|
---|
50 | FUNCTION patch_loader_loaded:Boolean;
|
---|
51 | CONST check_for:LongWord=$0010656EE9;
|
---|
52 | address_at:LongWord=$4228ED;
|
---|
53 | BEGIN
|
---|
54 | IF Decode_Int(ReadMem(address_at,4))=check_for THEN result:=True
|
---|
55 | ELSE result:=False;
|
---|
56 | END;
|
---|
57 |
|
---|
58 | FUNCTION GetAnimAddress:LongWord;
|
---|
59 | VAR offset:LongWord;
|
---|
60 | BEGIN
|
---|
61 | IF Form4.check_global.Checked THEN BEGIN
|
---|
62 | offset:=animations_l0[Form4.list.ItemIndex+1].offset;
|
---|
63 | result:=first_global+offset;
|
---|
64 | END ELSE BEGIN
|
---|
65 | CASE lvlnumber OF
|
---|
66 | 1: offset:=animations_l1[Form4.list.ItemIndex+1].offset;
|
---|
67 | 2: offset:=animations_l2[Form4.list.ItemIndex+1].offset;
|
---|
68 | 3: offset:=animations_l3[Form4.list.ItemIndex+1].offset;
|
---|
69 | 4: offset:=animations_l4[Form4.list.ItemIndex+1].offset;
|
---|
70 | 5: offset:=animations_l5[Form4.list.ItemIndex+1].offset;
|
---|
71 | 6: offset:=animations_l6[Form4.list.ItemIndex+1].offset;
|
---|
72 | 7: offset:=animations_l7[Form4.list.ItemIndex+1].offset;
|
---|
73 | 8: offset:=animations_l8[Form4.list.ItemIndex+1].offset;
|
---|
74 | 9: offset:=animations_l9[Form4.list.ItemIndex+1].offset;
|
---|
75 | 10: offset:=animations_l10[Form4.list.ItemIndex+1].offset;
|
---|
76 | 11: offset:=animations_l11[Form4.list.ItemIndex+1].offset;
|
---|
77 | 12: offset:=animations_l12[Form4.list.ItemIndex+1].offset;
|
---|
78 | 13: offset:=animations_l13[Form4.list.ItemIndex+1].offset;
|
---|
79 | 14: offset:=animations_l14[Form4.list.ItemIndex+1].offset;
|
---|
80 | END;
|
---|
81 | result:=first_local+offset;
|
---|
82 | END;
|
---|
83 | END;
|
---|
84 |
|
---|
85 | PROCEDURE TForm4.timer_animTimer(Sender: TObject);
|
---|
86 | VAR struct3:LongWord;
|
---|
87 | buffer:byte_array;
|
---|
88 | address:LongWord;
|
---|
89 | BEGIN
|
---|
90 | IF _connected AND (lvlnumber>0) AND patch_loader_loaded THEN BEGIN
|
---|
91 | first_global:=Decode_Int(ReadMem($10F08,4));
|
---|
92 | first_local:=Decode_Int(ReadMem($10F0C,4));
|
---|
93 | struct3:=Decode_Int(ReadMem(PointerStruct3,4))+StrToInt(Form4.edit_char.Text)*$2838;
|
---|
94 | address:=GetAnimAddress;
|
---|
95 |
|
---|
96 | IF demo_active THEN BEGIN
|
---|
97 | IF Decode_Int(ReadMem(struct3+$1AF8,4))<>address THEN BEGIN
|
---|
98 | REPEAT
|
---|
99 | Form4.list.ItemIndex:=Form4.list.ItemIndex+1;
|
---|
100 | UNTIL (Pos('_tgt',Form4.list.Items.Strings[Form4.list.ItemIndex])=0);
|
---|
101 | address:=GetAnimAddress;
|
---|
102 | buffer:=Encode_Int(address);
|
---|
103 | WriteMem(struct3+$1AF8,4,buffer);
|
---|
104 | END;
|
---|
105 | END;
|
---|
106 | IF check_freeze.Checked THEN BEGIN
|
---|
107 | buffer:=Encode_Int(address);
|
---|
108 | WriteMem(struct3+$1AF8,4,buffer);
|
---|
109 | END;
|
---|
110 | END ELSE BEGIN
|
---|
111 | IF _connected AND (lvlnumber>0) AND (demo_active OR check_freeze.Checked) THEN BEGIN
|
---|
112 | MessageBox(Form4.Handle,PChar('Oni.exe is not patched.'),PChar('Error'),MB_OK);
|
---|
113 | END;
|
---|
114 | END;
|
---|
115 | END;
|
---|
116 |
|
---|
117 | PROCEDURE load_anim_list(anims:Array OF animation);
|
---|
118 | VAR i:Word;
|
---|
119 | BEGIN
|
---|
120 | Form4.list.Items.Clear;
|
---|
121 | FOR i:=0 TO High(anims) DO BEGIN
|
---|
122 | Form4.list.Items.Add(anims[i].name);
|
---|
123 | END;
|
---|
124 | END;
|
---|
125 |
|
---|
126 | PROCEDURE TForm4.check_globalClick(Sender: TObject);
|
---|
127 | BEGIN
|
---|
128 | IF check_global.Checked THEN BEGIN
|
---|
129 | load_anim_list(animations_l0);
|
---|
130 | END;
|
---|
131 | END;
|
---|
132 |
|
---|
133 | PROCEDURE TForm4.check_localClick(Sender: TObject);
|
---|
134 | BEGIN
|
---|
135 | IF check_local.Checked THEN BEGIN
|
---|
136 | IF lvlnumber>0 THEN BEGIN
|
---|
137 | CASE lvlnumber OF
|
---|
138 | 1: load_anim_list(animations_l1);
|
---|
139 | 2: load_anim_list(animations_l2);
|
---|
140 | 3: load_anim_list(animations_l3);
|
---|
141 | 4: load_anim_list(animations_l4);
|
---|
142 | 5: load_anim_list(animations_l5);
|
---|
143 | 6: load_anim_list(animations_l6);
|
---|
144 | 7: load_anim_list(animations_l7);
|
---|
145 | 8: load_anim_list(animations_l8);
|
---|
146 | 9: load_anim_list(animations_l9);
|
---|
147 | 10: load_anim_list(animations_l10);
|
---|
148 | 11: load_anim_list(animations_l11);
|
---|
149 | 12: load_anim_list(animations_l12);
|
---|
150 | 13: load_anim_list(animations_l13);
|
---|
151 | 14: load_anim_list(animations_l14);
|
---|
152 | END;
|
---|
153 | END ELSE BEGIN
|
---|
154 | check_global.Checked:=True;
|
---|
155 | END;
|
---|
156 | END;
|
---|
157 | END;
|
---|
158 |
|
---|
159 | PROCEDURE TForm4.FormCloseQuery(Sender: TObject; var CanClose: Boolean);
|
---|
160 | BEGIN
|
---|
161 | Self.Visible:=False;
|
---|
162 | CanClose:=False;
|
---|
163 | Form1.menu_Anims.Checked:=False;
|
---|
164 | END;
|
---|
165 |
|
---|
166 | PROCEDURE TForm4.FormCreate(Sender: TObject);
|
---|
167 | BEGIN
|
---|
168 | load_anim_list(animations_l0);
|
---|
169 | list.ItemIndex:=0;
|
---|
170 | updown.Max:=ais_controlled;
|
---|
171 | END;
|
---|
172 |
|
---|
173 | PROCEDURE TForm4.updownClick(Sender: TObject; Button: TUDBtnType);
|
---|
174 | BEGIN
|
---|
175 | Form4.edit_char.Text:=IntToStr(updown.Position);
|
---|
176 | END;
|
---|
177 |
|
---|
178 | PROCEDURE TForm4.btn_demoClick(Sender: TObject);
|
---|
179 | VAR struct3,address:LongWord;
|
---|
180 | buffer:byte_array;
|
---|
181 | BEGIN
|
---|
182 | IF demo_active THEN BEGIN
|
---|
183 | check_freeze.Checked:=False;
|
---|
184 | btn_demo.Caption:='Start demo';
|
---|
185 | demo_active:=False;
|
---|
186 | END ELSE BEGIN
|
---|
187 | check_freeze.Checked:=False;
|
---|
188 | btn_demo.Caption:='Stop demo';
|
---|
189 | demo_active:=True;
|
---|
190 | IF _connected AND (lvlnumber>0) AND patch_loader_loaded THEN BEGIN
|
---|
191 | first_global:=Decode_Int(ReadMem($10F08,4));
|
---|
192 | first_local:=Decode_Int(ReadMem($10F0C,4));
|
---|
193 | struct3:=Decode_Int(ReadMem(PointerStruct3,4))+StrToInt(Form4.edit_char.Text)*$2838;
|
---|
194 | address:=GetAnimAddress;
|
---|
195 | buffer:=Encode_Int(address);
|
---|
196 | WriteMem(struct3+$1AF8,4,buffer);
|
---|
197 | END ELSE BEGIN
|
---|
198 | IF _connected AND (lvlnumber>0) THEN BEGIN
|
---|
199 | MessageBox(Form4.Handle,PChar('Oni.exe is not patched.'),PChar('Error'),MB_OK);
|
---|
200 | END;
|
---|
201 | END;
|
---|
202 | END;
|
---|
203 | END;
|
---|
204 |
|
---|
205 | PROCEDURE TForm4.listClick(Sender: TObject);
|
---|
206 | VAR address:LongWord;
|
---|
207 | buffer:byte_array;
|
---|
208 | i:Byte;
|
---|
209 | temp:String;
|
---|
210 | old:LongWord;
|
---|
211 | BEGIN
|
---|
212 | IF _connected AND (lvlnumber>0) AND patch_loader_loaded THEN BEGIN
|
---|
213 | first_global:=Decode_Int(ReadMem($10F08,4));
|
---|
214 | first_local:=Decode_Int(ReadMem($10F0C,4));
|
---|
215 | address:=GetAnimAddress;
|
---|
216 | Form4.lbl_lvl.Caption:='Lvl required (@'+IntToHex(address,8)+'): '+IntToStr(Decode_Int(ReadMem(address+$176,1)));
|
---|
217 | // VirtualProtectEx(_ProcessHandle,address+$176,2,PAGE_READWRITE,old);
|
---|
218 | // MessageBox(Form4.Handle,PChar('BLA: '+IntToStr(GetLastError)+'#'+IntToHex(GetLastError,8)),PChar('Error'),MB_OK);
|
---|
219 | WriteMem(address+$176,1,Encode_Int(0));
|
---|
220 | // MessageBox(Form4.Handle,PChar('BLA: '+IntToStr(GetLastError)+'#'+IntToHex(GetLastError,8)),PChar('Error'),MB_OK);
|
---|
221 | Form4.memo.Lines.Clear;
|
---|
222 | temp:='';
|
---|
223 | buffer:=ReadMem(address,$D0);
|
---|
224 | FOR i:=0 TO ($D0 - 1) DO BEGIN
|
---|
225 | temp:=temp+IntToHex(buffer[i],2);
|
---|
226 | IF ((i+1) MOD $10)=0 THEN BEGIN
|
---|
227 | Form4.memo.Lines.Add(temp);
|
---|
228 | temp:='';
|
---|
229 | END;
|
---|
230 | END;
|
---|
231 | buffer:=ReadMem(address+$D0,$D0);
|
---|
232 | FOR i:=0 TO ($D0 - 1) DO BEGIN
|
---|
233 | temp:=temp+IntToHex(buffer[i],2);
|
---|
234 | IF ((i+1) MOD $10)=0 THEN BEGIN
|
---|
235 | Form4.memo.Lines.Add(temp);
|
---|
236 | temp:='';
|
---|
237 | END;
|
---|
238 | END;
|
---|
239 | END ELSE BEGIN
|
---|
240 | IF _connected AND (lvlnumber>0) THEN BEGIN
|
---|
241 | MessageBox(Form4.Handle,PChar('Oni.exe is not patched.'),PChar('Error'),MB_OK);
|
---|
242 | END;
|
---|
243 | END;
|
---|
244 | END;
|
---|
245 |
|
---|
246 | END.
|
---|