summaryrefslogtreecommitdiff
path: root/csrc/tools_ui.c
diff options
context:
space:
mode:
authorIru Cai <mytbk920423@gmail.com>2018-09-06 23:00:50 +0800
committerIru Cai <mytbk920423@gmail.com>2018-09-06 23:00:50 +0800
commit566fe1806fed168edc9ab6e7ea7c07764520b377 (patch)
tree6d823e5aed679da6f95b08d8e52efb96afabd5b9 /csrc/tools_ui.c
parent4b40a9be0e33b11ca8ce1aa3e0e34d36d266c809 (diff)
downloadrich4-566fe1806fed168edc9ab6e7ea7c07764520b377.tar.xz
tools_ui
Diffstat (limited to 'csrc/tools_ui.c')
-rw-r--r--csrc/tools_ui.c109
1 files changed, 109 insertions, 0 deletions
diff --git a/csrc/tools_ui.c b/csrc/tools_ui.c
new file mode 100644
index 0000000..154547d
--- /dev/null
+++ b/csrc/tools_ui.c
@@ -0,0 +1,109 @@
+#include "player_info.h"
+
+void tools_ui()
+{
+ dl = players[current_player].f21;
+ if (dl != 1)
+ goto 0x447f82;
+
+ fcn.0041d546();
+ ebx = eax = read_mkf(mkf_panel, 11, NULL, NULL);
+ edi = eax;
+ fcn.00447c6e(0, eax, current_player);
+ edx = ebx + 0x18;
+ cl = players[current_player].traffic_method;
+ if (cl == 1) {
+ ebx += 0xc0;
+ fcn.00456280(edx, ebx, 0x145, 0x75);
+ b_48c556 = 0xe;
+ } else if (cl == 2) {
+ ebx += 0xcc;
+ fcn.00456280(edx, ebx, 0x145, 0x75);
+ b_48c556 = 0xe;
+ }
+ IDirectDrawSurface_Lock(pddrawsf2, 0, &sfdesc1, 1, 0);
+ st_46caec.f8 = sfdesc1.lpSurface;
+ /* struct st* */ dw_48c558 = fcn_00451a97(&st_46caec, NULL, 0, 40, 440, 440);
+ IDirectDrawSurface_Unlock(pddrawsf2, NULL);
+
+ do {
+ ebx = 1;
+
+ IDirectDrawSurface_Lock(pddrawsf2, 0, &sfdesc1, 1, 0);
+ fcn.004563f5(sfdesc1.lpSurface, edi + 0x18, 0xe, 0x82);
+ IDirectDrawSurface_Unlock(pddrawsf2, NULL);
+
+ esi = fcn_4018e7(toolsProc, 0);
+
+ IDirectDrawSurface_Lock(pddrawsf2, 0, &sfdesc1, 1, 0);
+ fcn.004563f5(sfdesc1.lpSurface, dw_48c558, 0, 40);
+ IDirectDrawSurface_Unlock(pddrawsf2, NULL);
+
+ RECT r1 = { .left = 0, .top = 40, .right = 440, .bottom = 480 };
+ IDirectDrawSurface_BltFast(pddrawsf1, 0, 40, pddrawsf2, &r1, 0x10);
+
+ if (esi != 0) {
+ ebx = call dword [esi*4 + 0x475dd5];
+ }
+ } while (ebx == 0);
+
+ free(edi);
+ free(dw_48c558);
+ return;
+447f82:
+ if ((dl & 6) == 0)
+ return;
+ if (byte [eax+0x496b7e] & 2 == 0)
+ return;
+ memset(esp+0x40, 0, 13);
+ ecx = 0;
+
+
+ esi = 0;
+ for (int i = 0; i < 13; i++) {
+ ebx = current_player * 15;
+ if (byte [ebx+i+0x49915c] == 0)
+ continue;
+ if (i == 9)
+ continue;
+ byte [esp+esi+0x38] = i+1;
+ esi++;
+ }
+ if (esi == 0)
+ return;
+ if (esi > 4) {
+ ebx = rand() % esi;
+ } else {
+ ebx = 0;
+ }
+
+ edi = 0;
+ int j = 0;
+
+ while (1) {
+ dh = byte [esp+ebx+0x38];
+ if (dh == 0)
+ return;
+ eax = 0;
+ al = dh;
+ eax = fcn.00420e9a(eax);
+ if (eax != 1) {
+ ebx++;
+ if (ebx == esi) {
+ ebx = 0;
+ }
+ j++;
+ if (j >= 4)
+ return;
+ continue;
+ }
+ break;
+ }
+ eax = 0;
+ al = byte [esp + ebx + 0x38];
+ sprintf(esp, str.use, dword [eax*8+0x47feda]);
+ fcn.00440cac(esp, 1500);
+ eax = 0;
+ al = byte [esp + ebx + 0x38];
+ call dword [eax*4 + 0x475dd5];
+}