Mercurial > might-and-magic-trilogy
diff Weather.cpp @ 0:8b8875f5b359
Initial commit
author | Nomad |
---|---|
date | Fri, 05 Oct 2012 16:07:14 +0200 |
parents | |
children | a84fb3752681 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Weather.cpp Fri Oct 05 16:07:14 2012 +0200 @@ -0,0 +1,244 @@ +#include <stdlib.h> + +#include "Weather.h" +#include "Viewport.h" +#include "Render.h" + +#include "mm7_data.h" + + + + +struct Weather *pWeather; + + + +//----- (004C2AA6) -------------------------------------------------------- +int Weather::DrawSnow() +{ + unsigned __int16 *v1; // edi@1 + __int16 *v2; // esi@2 + int v3; // eax@2 + signed int v4; // eax@6 + int v5; // edx@8 + __int16 *v6; // esi@11 + __int16 *v7; // eax@11 + int v8; // ecx@11 + int v9; // eax@12 + int v10; // ecx@16 + int v11; // edx@18 + Weather *v12; // eax@20 + __int16 *v13; // esi@20 + int v14; // eax@21 + int v15; // eax@21 + int v16; // edx@23 + int v17; // eax@24 + int v18; // edx@26 + int v19; // ecx@27 + int v20; // eax@27 + char v21; // zf@27 + unsigned int v23; // [sp+Ch] [bp-20h]@1 + unsigned int v24; // [sp+10h] [bp-1Ch]@1 + unsigned int v25; // [sp+14h] [bp-18h]@1 + Weather *v26; // [sp+18h] [bp-14h]@1 + signed int v27; // [sp+18h] [bp-14h]@20 + unsigned int v28; // [sp+1Ch] [bp-10h]@1 + unsigned int v29; // [sp+20h] [bp-Ch]@1 + __int16 *v30; // [sp+24h] [bp-8h]@2 + signed int v31; // [sp+28h] [bp-4h]@1 + signed int v32; // [sp+28h] [bp-4h]@10 + + v26 = this; + v25 = viewparams->uScreenZ; + v28 = viewparams->uScreenY; + v31 = 0; + v1 = pRenderer->pTargetSurface; + v29 = viewparams->uScreenX; + v23 = viewparams->uScreenW; + v24 = viewparams->uScreenZ - viewparams->uScreenX; + do + { + v2 = &v26->field_0[2 * v31]; + v30 = &v26->field_0[2 * v31 + 1]; + *v2 += rand() % 3 + 1; + *v30 += rand() % 2 + 1; + v3 = *v2; + if ( v3 < (signed int)(v25 - 1) ) + { + if ( v3 < (signed int)v29 ) + *v2 = v25 - rand() % 8; + } + else + { + *v2 = v29 + rand() % 8; + } + v4 = *v30; + if ( v4 < (signed int)v28 || v4 >= (signed int)v23 ) + { + v5 = rand() % (signed int)(v24 - 2); + *v30 = v28; + *v2 = v29 + v5; + } + ++v31; + v1[*v2 + 640 * *v30] = 0xFFFFu; + } + while ( v31 < 700 ); + v32 = 700; + do + { + v6 = &v26->field_0[2 * v32]; + *v6 += rand() % 5 - 3; + v7 = &v26->field_0[2 * v32 + 1]; + v8 = *v6; + *v7 += 4; + if ( v8 < (signed int)v29 ) + { + LOWORD(v9) = v25 - rand() % 4 - 2; +LABEL_15: + *v6 = v9; + v7 = &v26->field_0[2 * v32 + 1]; + goto LABEL_16; + } + if ( v8 >= (signed int)(v25 - 2) ) + { + v9 = rand() % 4 + v29 + 2; + goto LABEL_15; + } +LABEL_16: + v10 = *v7; + if ( v10 < (signed int)v28 || v10 >= (signed int)(v23 - 1) ) + { + v11 = rand() % (signed int)(v24 - 2); + v26->field_0[2 * v32 + 1] = v28; + v7 = &v26->field_0[2 * v32 + 1]; + *v6 = v29 + v11; + } + *(&v1[640 * *v7 + 1] + *v6) = 0xFFFFu; + *(&v1[640 * *v7 + 641] + *v6) = 0xFFFFu; + v1[*v6 + 640 * (*v7 + 1)] = 0xFFFFu; + ++v32; + v1[*v6 + 640 * *v7] = 0xFFFFu; + } + while ( v32 < 950 ); + v12 = v26; + v27 = 50; + v13 = &v12->field_0[1901]; + do + { + v14 = rand(); + *v13 += 8; + *(v13 - 1) += v14 % 11 - 5; + v15 = *(v13 - 1); + if ( v15 < (signed int)v29 || v15 >= (signed int)(v25 - 5) ) + { + v16 = rand() % (signed int)(v24 - 5); + *v13 = v28; + *(v13 - 1) = v29 + v16; + } + v17 = *v13; + if ( v17 < (signed int)v28 || v17 >= (signed int)(v23 - 5) ) + { + v18 = rand() % (signed int)(v24 - 5); + *v13 = v28; + *(v13 - 1) = v29 + v18; + } + *(&v1[640 * *v13 + 1] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 641] + *(v13 - 1)) = 0xFFFFu; + v1[*(v13 - 1) + 640 * (*v13 + 1)] = 0xFFFFu; + v1[*(v13 - 1) + 640 * *v13] = 0xFFFFu; + *(&v1[640 * *v13 + 1281] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 1921] + *(v13 - 1)) = 0xFFFFu; + v1[*(v13 - 1) + 640 * (*v13 + 3)] = 0xFFFFu; + v1[*(v13 - 1) + 640 * (*v13 + 2)] = 0xFFFFu; + *(&v1[640 * *v13 + 3] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 643] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 642] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 2] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 1283] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 1923] + *(v13 - 1)) = 0xFFFFu; + *(&v1[640 * *v13 + 1922] + *(v13 - 1)) = 0xFFFFu; + v19 = *(v13 - 1); + v20 = 5 * *v13; + v13 += 2; + v21 = v27-- == 1; + *(&v1[128 * v20 + 1282] + v19) = 0xFFFFu; + } + while ( !v21 ); + return 0; +} + +//----- (004C2EA0) -------------------------------------------------------- +int Weather::Initialize() +{ + Weather *v1; // edi@1 + signed int v2; // esi@1 + signed int v3; // ebx@1 + signed int v4; // ebp@1 + + v1 = this; + v2 = 0; + v3 = pViewport->uScreenZ - pViewport->uScreenX - 4; + v4 = pViewport->uScreenW - pViewport->uScreenY - 4; + do + { + v1->field_0[2 * v2++] = LOWORD(pViewport->uViewportX) + rand() % v3; + *((short *)v1 + 2 * v2 - 1) = LOWORD(pViewport->uViewportY) + rand() % v4; + } + while ( v2 < 1000 ); + return 0; +} + +//----- (004C2EFA) -------------------------------------------------------- +int Weather::Draw() +{ + if (bRenderSnow) + DrawSnow(); + return 0; +} + +//----- (004C2F0B) -------------------------------------------------------- +bool Weather::_4C2F0B(__int16 a2) +{ + int v3; // edx@3 + signed int v4; // ebx@3 + unsigned int screen_width; // esi@3 + __int16 *v6; // eax@5 + signed int v7; // edi@5 + unsigned int screen_x; // [sp+0h] [bp-Ch]@3 + unsigned int screen_z_minus_4; // [sp+4h] [bp-8h]@3 + Weather *v10; // [sp+8h] [bp-4h]@1 + + v10 = this; + if ( this->bRenderSnow != 1 ) + return 0; + HIWORD(v3) = HIWORD(viewparams->uScreenX); + v4 = 0; + screen_width = viewparams->uScreenZ - viewparams->uScreenX; + screen_x = viewparams->uScreenX; + screen_z_minus_4 = viewparams->uScreenZ - 4; + + auto _this = this->field_0; + while ( 1 ) + { + v6 = &_this[2 * v4]; + *v6 += a2; + LOWORD(v3) = *v6; + v7 = *v6; + if ( v7 < (signed int)screen_z_minus_4 ) + { + if ( v7 >= (signed int)screen_x ) + goto LABEL_10; + v3 += screen_width; + } + else + { + v3 = v3 - screen_width + 4; + } + *v6 = v3; +LABEL_10: + ++v4; + if ( v4 >= 1000 ) + return 1; + //_this = v10; + } +} \ No newline at end of file