Rev 20 | Details | Compare with Previous | Last modification | View Log | RSS feed
| Rev | Author | Line No. | Line |
|---|---|---|---|
| 1 | pmbaty | 1 | #include "graphics.h" |
| 2 | |||
| 20 | pmbaty | 3 | #include "brender/brender.h" |
| 1 | pmbaty | 4 | #include "car.h" |
| 5 | #include "constants.h" |
||
| 6 | #include "controls.h" |
||
| 7 | #include "depth.h" |
||
| 8 | #include "displays.h" |
||
| 9 | #include "errors.h" |
||
| 10 | #include "finteray.h" |
||
| 11 | #include "flicplay.h" |
||
| 12 | #include "globvars.h" |
||
| 13 | #include "globvrpb.h" |
||
| 14 | #include "grafdata.h" |
||
| 15 | #include "harness/hooks.h" |
||
| 16 | #include "harness/os.h" |
||
| 17 | #include "harness/trace.h" |
||
| 18 | #include "init.h" |
||
| 19 | #include "input.h" |
||
| 20 | #include "loading.h" |
||
| 21 | #include "netgame.h" |
||
| 22 | #include "network.h" |
||
| 23 | #include "oil.h" |
||
| 24 | #include "opponent.h" |
||
| 25 | #include "pd/sys.h" |
||
| 26 | #include "pedestrn.h" |
||
| 27 | #include "piping.h" |
||
| 28 | #include "powerup.h" |
||
| 29 | #include "pratcam.h" |
||
| 30 | #include "replay.h" |
||
| 31 | #include "sound.h" |
||
| 32 | #include "spark.h" |
||
| 33 | #include "trig.h" |
||
| 34 | #include "utility.h" |
||
| 35 | #include "world.h" |
||
| 36 | #include <limits.h> |
||
| 37 | #include <stdlib.h> |
||
| 38 | |||
| 39 | #include <math.h> |
||
| 40 | |||
| 41 | int gPalette_munged; |
||
| 42 | int gColourValues[1]; |
||
| 43 | int gNext_transient; |
||
| 44 | int gCursor_x_offsets[8] = { |
||
| 45 | 6, |
||
| 46 | 8, |
||
| 47 | 16, |
||
| 48 | 36, |
||
| 49 | 6, |
||
| 50 | 8, |
||
| 51 | 16, |
||
| 52 | 36, |
||
| 53 | }; |
||
| 54 | int gCursor_y_offsets[8] = { |
||
| 55 | 26, |
||
| 56 | 19, |
||
| 57 | 12, |
||
| 58 | 5, |
||
| 59 | 26, |
||
| 60 | 19, |
||
| 61 | 12, |
||
| 62 | 5, |
||
| 63 | }; |
||
| 64 | int gCursor_gib_x_offsets[8] = { |
||
| 65 | 82, |
||
| 66 | 72, |
||
| 67 | 66, |
||
| 68 | 36, |
||
| 69 | 82, |
||
| 70 | 72, |
||
| 71 | 66, |
||
| 72 | 36, |
||
| 73 | }; |
||
| 74 | int gCursor_gib_y_offsets[8] = { |
||
| 75 | 74, |
||
| 76 | 86, |
||
| 77 | 93, |
||
| 78 | 106, |
||
| 79 | 74, |
||
| 80 | 86, |
||
| 81 | 93, |
||
| 82 | 106, |
||
| 83 | }; |
||
| 84 | int gCursor_giblet_sequence0[7] = { |
||
| 85 | 6, |
||
| 86 | 0, |
||
| 87 | 1, |
||
| 88 | 2, |
||
| 89 | 3, |
||
| 90 | 4, |
||
| 91 | 5, |
||
| 92 | }; |
||
| 93 | int gCursor_giblet_sequence1[5] = { |
||
| 94 | 4, |
||
| 95 | 6, |
||
| 96 | 7, |
||
| 97 | 8, |
||
| 98 | 9, |
||
| 99 | }; |
||
| 100 | int gCursor_giblet_sequence2[5] = { |
||
| 101 | 4, |
||
| 102 | 10, |
||
| 103 | 11, |
||
| 104 | 12, |
||
| 105 | 13, |
||
| 106 | }; |
||
| 107 | int gCursor_giblet_sequence3[5] = { |
||
| 108 | 4, |
||
| 109 | 14, |
||
| 110 | 15, |
||
| 111 | 16, |
||
| 112 | 17, |
||
| 113 | }; |
||
| 114 | int* gCursor_giblet_sequences[4] = { |
||
| 115 | gCursor_giblet_sequence0, |
||
| 116 | gCursor_giblet_sequence1, |
||
| 117 | gCursor_giblet_sequence2, |
||
| 118 | gCursor_giblet_sequence3, |
||
| 119 | }; |
||
| 120 | char* gFont_names[21] = { |
||
| 121 | "TYPEABLE", |
||
| 122 | "ORANGHED", |
||
| 123 | "BLUEHEAD", |
||
| 124 | "GREENHED", |
||
| 125 | "MEDIUMHD", |
||
| 126 | "TIMER", |
||
| 127 | "NEWHITE", |
||
| 128 | "NEWRED", |
||
| 129 | "NEWBIGGR", |
||
| 130 | "GRNDK", |
||
| 131 | "GRNLIT", |
||
| 132 | "GRYDK", |
||
| 133 | "GRYLIT", |
||
| 134 | "BUTTIN", |
||
| 135 | "BUTTOUT", |
||
| 136 | "LITPLAQ", |
||
| 137 | "DRKPLAQ", |
||
| 138 | "BUTTIN1", |
||
| 139 | "BUTTOUT1", |
||
| 140 | "LITPLAQ1", |
||
| 141 | "DRKPLAQ1" |
||
| 142 | }; |
||
| 143 | br_colour gRGB_colours[9] = { |
||
| 144 | 0u, |
||
| 145 | 16777215u, |
||
| 146 | 16711680u, |
||
| 147 | 65280u, |
||
| 148 | 255u, |
||
| 149 | 16776960u, |
||
| 150 | 65535u, |
||
| 151 | 16711935u, |
||
| 152 | 13649666u |
||
| 153 | }; |
||
| 154 | br_matrix34 gSheer_mat = { |
||
| 155 | { { 1.0, 0.0, 0.0 }, |
||
| 156 | { 0.0, 1.0, 0.0 }, |
||
| 157 | { 0.0, 0.0, 1.0 }, |
||
| 158 | { 0.0, 0.0, 0.0 } } |
||
| 159 | }; |
||
| 160 | br_matrix34 gIdentity34 = { |
||
| 161 | { { 1.0, 0.0, 0.0 }, |
||
| 162 | { 0.0, 1.0, 0.0 }, |
||
| 163 | { 0.0, 0.0, 1.0 }, |
||
| 164 | { 0.0, 0.0, 0.0 } } |
||
| 165 | }; |
||
| 166 | tShadow_level gShadow_level = eShadow_us_only; |
||
| 167 | br_scalar gShadow_hither_z_move; |
||
| 168 | br_scalar gShadow_hither_min_move; |
||
| 169 | /* clang-format off */ |
||
| 170 | // arrows pointing to 180, 202, 224, 246 degrees (step = 90 / 4 = 22(.5) degrees) |
||
| 171 | int gArrows[2][4][60] = |
||
| 172 | { |
||
| 173 | { |
||
| 174 | // inner arrow (=fill) |
||
| 175 | { 10, 0, 0, -1, 0, 1, 0, 0, -1, 0, -2, 0, 1, -1, 1, 1, 1, -2, 2, 2, 2, }, |
||
| 176 | { 11, 0, 0, -1, 0, 1, 0, 0, -1, 1, -1, 1, -2, -2, 1, -1, 1, 0, 1, 1, 1, 1, 2, }, |
||
| 177 | { 9, 0, 0, -2, 0, -1, 0, 1, 0, 0, -1, 1, -1, 2, -2, 0, 1, 0, 2, }, |
||
| 178 | { 11, 0, 0, -1, 0, 1, 0, -2, -1, -1, -1, 0, -1, 1, -1, 2, -1, -1, 1, 0, 1, -1, 2, }, |
||
| 179 | }, |
||
| 180 | { |
||
| 181 | // outer arrow (=border) |
||
| 182 | { 26, 1, -3, 1, -2, 1, -1, 2, -1, 2, 0, 2, 1, 3, 1, 3, 2, 3, 3, 2, 3, 1, 3, 1, 2, 0, 2, -1, 2, |
||
| 183 | -1, 3, -2, 3, -3, 3, -3, 2, -3, 1, -2, 1, -2, 0, -2, -1, -1, -1, -1, -2, -1, -3, 0, -3, }, |
||
| 184 | { 22, 0, -3, 1, -3, 2, -3, 2, -2, 2, -1, 2, 0, 2, 1, 2, 2, 2, 3, 1, 3, 0, 3, 0, 2, -1, 2, -2, 2, |
||
| 185 | -3, 2, -3, 1, -3, 0, -2, 0, -2, -1, -1, -1, -1, -2, 0, -2, }, |
||
| 186 | { 24, 1, -3, 2, -3, 3, -3, 3, -2, 3, -1, 2, -1, 2, 0, 2, 1, 1, 1, 1, 2, 1, 3, 0, 3, -1, 3, -1, 2, |
||
| 187 | -1, 1, -2, 1, -3, 1, -3, 0, -3, -1, -2, -1, -1, -1, -1, -2, 0, -2, 1, -2, }, |
||
| 188 | { 22, -3, -2, -2, -2, -1, -2, 0, -2, 1, -2, 2, -2, 3, -2, 3, -1, 3, 0, 2, 0, 2, 1, 1, 1, 1, 2, 0, 2, |
||
| 189 | 0, 3, -1, 3, -2, 3, -2, 2, -2, 1, -2, 0, -3, 0, -3, -1, }, |
||
| 190 | }, |
||
| 191 | }; |
||
| 192 | /* clang-format on */ |
||
| 193 | |||
| 194 | float gMap_render_x = 80.f; |
||
| 195 | float gMap_render_y = 6.f; |
||
| 196 | float gMap_render_width = 64.f; |
||
| 197 | float gMap_render_height = 40.f; |
||
| 198 | int gMouse_started; |
||
| 199 | int gFaded_palette; |
||
| 200 | int gAR_fudge_headups; |
||
| 201 | br_pixelmap* gCurrent_splash; |
||
| 202 | br_pixelmap* gCurrent_conversion_table; |
||
| 203 | int gMap_colours[4] = { 4, 0, 52, 132 }; |
||
| 204 | br_vector3 gShadow_points[8]; |
||
| 205 | tConcussion gConcussion; |
||
| 206 | tClip_details gShadow_clip_planes[8]; |
||
| 207 | br_actor* gLollipops[100]; |
||
| 208 | tWobble_spec gWobble_array[5]; |
||
| 209 | tSaved_table gSaved_shade_tables[100]; |
||
| 210 | tCursor_giblet gCursor_giblets[45]; |
||
| 211 | tTransient_bm gTransient_bitmaps[50]; |
||
| 212 | float gCosine_array[64]; |
||
| 213 | br_pixelmap* gCursors[8]; |
||
| 214 | br_pixelmap* gCursor_giblet_images[18]; |
||
| 215 | br_pixelmap* gEval_1; |
||
| 216 | br_pixelmap* gEval_2; |
||
| 217 | br_vector3 gShadow_light_z; |
||
| 218 | br_vector3 gShadow_light_x; |
||
| 219 | int gShadow_dim_amount; |
||
| 220 | int gNumber_of_lollipops; |
||
| 221 | br_vector3 gShadow_light_ray; |
||
| 222 | int gFancy_shadow; |
||
| 223 | br_model* gShadow_model; |
||
| 224 | br_actor* gShadow_actor; |
||
| 225 | int gShadow_clip_plane_count; |
||
| 226 | br_pixelmap* gPalette_conversion_table; |
||
| 227 | br_material* gShadow_material; |
||
| 228 | int gSaved_table_count; |
||
| 229 | int gCurrent_cursor_index; |
||
| 230 | int gPalette_index; |
||
| 231 | int gCursor_transient_index; |
||
| 232 | char* gScratch_pixels; |
||
| 233 | br_pixelmap* gScratch_palette; |
||
| 234 | int gLast_palette_change; |
||
| 235 | br_pixelmap* gOrig_render_palette; |
||
| 236 | br_pixelmap* gCurrent_palette; |
||
| 237 | br_pixelmap* gRender_palette; |
||
| 238 | float gCamera_to_horiz_angle; |
||
| 239 | int gColours[9]; |
||
| 240 | br_pixelmap* gFlic_palette; |
||
| 241 | tDR_font gFonts[21]; |
||
| 242 | char* gCurrent_palette_pixels; |
||
| 243 | int gWidth; |
||
| 244 | int gMap_render_height_i; |
||
| 245 | int gScreen_wobble_x; |
||
| 246 | int gScreen_wobble_y; |
||
| 247 | br_scalar gCurrent_ambience; |
||
| 248 | int gY_offset; |
||
| 249 | int gMap_render_width_i; |
||
| 250 | int gMouse_in_use; |
||
| 251 | int gHeight; |
||
| 252 | int gMouse_last_y_coord; |
||
| 253 | int gMouse_last_x_coord; |
||
| 254 | br_scalar gAmbient_adjustment; |
||
| 255 | int gMap_render_x_i; |
||
| 256 | int gX_offset; |
||
| 257 | int gMap_render_y_i; |
||
| 258 | int gMirror_on__graphics; // suffix added to avoid duplicate symbol |
||
| 259 | br_scalar gYon_squared; |
||
| 260 | |||
| 261 | #define SHADOW_D_IGNORE_FLAG 10000.0 |
||
| 262 | |||
| 263 | // IDA: void __cdecl TurnOnPaletteConversion() |
||
| 264 | void TurnOnPaletteConversion(void) { |
||
| 265 | LOG_TRACE("()"); |
||
| 266 | |||
| 267 | gCurrent_conversion_table = gPalette_conversion_table; |
||
| 268 | } |
||
| 269 | |||
| 270 | // IDA: void __cdecl TurnOffPaletteConversion() |
||
| 271 | void TurnOffPaletteConversion(void) { |
||
| 272 | LOG_TRACE("()"); |
||
| 273 | |||
| 274 | gCurrent_conversion_table = NULL; |
||
| 275 | } |
||
| 276 | |||
| 277 | // IDA: void __cdecl ResetLollipopQueue() |
||
| 278 | void ResetLollipopQueue(void) { |
||
| 279 | LOG_TRACE("()"); |
||
| 280 | |||
| 281 | gNumber_of_lollipops = 0; |
||
| 282 | } |
||
| 283 | |||
| 284 | // IDA: int __usercall AddToLollipopQueue@<EAX>(br_actor *pActor@<EAX>, int pIndex@<EDX>) |
||
| 285 | int AddToLollipopQueue(br_actor* pActor, int pIndex) { |
||
| 286 | LOG_TRACE("(%p, %d)", pActor, pIndex); |
||
| 287 | |||
| 288 | if (pIndex >= 0) { |
||
| 289 | gLollipops[pIndex] = pActor; |
||
| 290 | } else if (gNumber_of_lollipops >= 100) { |
||
| 291 | pIndex = -1; |
||
| 292 | } else { |
||
| 293 | gLollipops[gNumber_of_lollipops] = pActor; |
||
| 294 | pIndex = gNumber_of_lollipops; |
||
| 295 | gNumber_of_lollipops++; |
||
| 296 | } |
||
| 297 | return pIndex; |
||
| 298 | } |
||
| 299 | |||
| 300 | // IDA: void __cdecl RenderLollipops() |
||
| 301 | void RenderLollipops(void) { |
||
| 302 | int i; |
||
| 303 | int must_relink; |
||
| 304 | br_actor** the_actor; |
||
| 305 | br_actor* old_parent; |
||
| 306 | LOG_TRACE("()"); |
||
| 307 | |||
| 308 | for (i = 0, the_actor = gLollipops; i < gNumber_of_lollipops; i++, the_actor++) { |
||
| 309 | if ((*the_actor)->render_style == BR_RSTYLE_NONE) { |
||
| 310 | must_relink = (*the_actor)->parent != gDont_render_actor; |
||
| 311 | if (must_relink) { |
||
| 312 | old_parent = (*the_actor)->parent; |
||
| 313 | BrActorRelink(gDont_render_actor, *the_actor); |
||
| 314 | } |
||
| 315 | (*the_actor)->render_style = BR_RSTYLE_FACES; |
||
| 316 | SetPedMaterialForRender(*the_actor); |
||
| 317 | BrZbSceneRenderAdd(*the_actor); |
||
| 318 | (*the_actor)->render_style = BR_RSTYLE_NONE; |
||
| 319 | if (must_relink) { |
||
| 320 | BrActorRelink(old_parent, *the_actor); |
||
| 321 | } |
||
| 322 | } |
||
| 323 | } |
||
| 324 | } |
||
| 325 | |||
| 326 | // IDA: void __usercall DRDrawLine(br_pixelmap *pDestn@<EAX>, int pX1@<EDX>, int pY1@<EBX>, int pX2@<ECX>, int pY2, int pColour) |
||
| 327 | void DRDrawLine(br_pixelmap* pDestn, int pX1, int pY1, int pX2, int pY2, int pColour) { |
||
| 328 | //tU8* d_ptr; // Pierre-Marie Baty -- unused variable |
||
| 329 | //tS32 y_delta; // Pierre-Marie Baty -- unused variable |
||
| 330 | //tS32 x_delta; // Pierre-Marie Baty -- unused variable |
||
| 331 | //tU32 current_y; // Pierre-Marie Baty -- unused variable |
||
| 332 | //tU32 current_x; // Pierre-Marie Baty -- unused variable |
||
| 333 | //int row_bytes; // Pierre-Marie Baty -- unused variable |
||
| 334 | //int x; // Pierre-Marie Baty -- unused variable |
||
| 335 | //int y; // Pierre-Marie Baty -- unused variable |
||
| 336 | //int the_diff; // Pierre-Marie Baty -- unused variable |
||
| 337 | LOG_TRACE("(%p, %d, %d, %d, %d, %d)", pDestn, pX1, pY1, pX2, pY2, pColour); |
||
| 338 | |||
| 339 | BrPixelmapLine(pDestn, pX1, pY1, pX2, pY2, pColour); |
||
| 340 | } |
||
| 341 | |||
| 342 | // IDA: void __usercall DrawDigitAt(br_pixelmap *gImage@<EAX>, int pX@<EDX>, int pY@<EBX>, int pY_pitch@<ECX>, int pValue) |
||
| 343 | void DrawDigitAt(br_pixelmap* gImage, int pX, int pY, int pY_pitch, int pValue) { |
||
| 344 | LOG_TRACE("(%p, %d, %d, %d, %d)", gImage, pX, pY, pY_pitch, pValue); |
||
| 345 | |||
| 346 | DRPixelmapRectangleMaskedCopy(gBack_screen, pX, pY, gImage, 0, pY_pitch * pValue, gImage->width, pY_pitch); |
||
| 347 | } |
||
| 348 | |||
| 349 | // IDA: void __usercall DrawNumberAt(br_pixelmap *gImage@<EAX>, int pX@<EDX>, int pY@<EBX>, int pX_pitch@<ECX>, int pY_pitch, int pValue, int pDigit_count, int pLeading_zeroes) |
||
| 350 | void DrawNumberAt(br_pixelmap* gImage, int pX, int pY, int pX_pitch, int pY_pitch, int pValue, int pDigit_count, int pLeading_zeroes) { |
||
| 351 | int i; |
||
| 352 | int the_value; |
||
| 353 | LOG_TRACE("(%p, %d, %d, %d, %d, %d, %d, %d)", gImage, pX, pY, pX_pitch, pY_pitch, pValue, pDigit_count, pLeading_zeroes); |
||
| 354 | |||
| 355 | for (i = pDigit_count - 1; i >= 0; i--) { |
||
| 356 | the_value = pValue % 10; |
||
| 357 | pValue /= 10; |
||
| 358 | if (pValue || pLeading_zeroes || pDigit_count - 1 == i) { |
||
| 359 | DrawDigitAt(gImage, pX + pX_pitch * i, pY, pY_pitch, the_value); |
||
| 360 | } |
||
| 361 | } |
||
| 362 | } |
||
| 363 | |||
| 364 | // IDA: void __usercall BuildColourTable(br_pixelmap *pPalette@<EAX>) |
||
| 365 | void BuildColourTable(br_pixelmap* pPalette) { |
||
| 366 | int i; |
||
| 367 | int j; |
||
| 368 | int nearest_index = 0; |
||
| 369 | int red; |
||
| 370 | int green; |
||
| 371 | int blue; |
||
| 372 | float nearest_distance; |
||
| 373 | float distance; |
||
| 374 | LOG_TRACE("(%p)", pPalette); |
||
| 375 | |||
| 376 | #define SQR(i) i* i |
||
| 377 | |||
| 378 | for (i = 0; i < COUNT_OF(gRGB_colours); i++) { |
||
| 379 | nearest_distance = 196608.f; |
||
| 380 | red = (gRGB_colours[i] >> 16) & 0xFF; |
||
| 381 | green = (gRGB_colours[i] >> 8) & 0xFF; |
||
| 382 | blue = gRGB_colours[i] & 0xFF; |
||
| 383 | for (j = 0; j < 256; j++) { |
||
| 384 | distance = SQR((double)(signed int)(*((br_uint_8*)pPalette->pixels + 4 * j + 2) - red)); |
||
| 385 | distance += SQR((double)(signed int)(*((br_uint_8*)pPalette->pixels + 4 * j) - blue)); |
||
| 386 | distance += SQR((double)(signed int)(*((br_uint_8*)pPalette->pixels + 4 * j + 1) - green)); |
||
| 387 | if (distance < nearest_distance) { |
||
| 388 | nearest_index = j; |
||
| 389 | nearest_distance = distance; |
||
| 390 | } |
||
| 391 | } |
||
| 392 | gColours[i] = nearest_index; |
||
| 393 | } |
||
| 394 | } |
||
| 395 | |||
| 396 | // IDA: void __cdecl ClearConcussion() |
||
| 397 | void ClearConcussion(void) { |
||
| 398 | LOG_TRACE("()"); |
||
| 399 | |||
| 400 | gConcussion.concussed = 0; |
||
| 401 | } |
||
| 402 | |||
| 403 | // IDA: tS8* __usercall SkipLines@<EAX>(tS8 *pSource@<EAX>, int pCount@<EDX>) |
||
| 404 | tS8* SkipLines(tS8* pSource, int pCount) { |
||
| 405 | int i; |
||
| 406 | int j; |
||
| 407 | int number_of_chunks; |
||
| 408 | int chunk_length; |
||
| 409 | LOG_TRACE("(%p, %d)", pSource, pCount); |
||
| 410 | |||
| 411 | for (i = 0; i < pCount; ++i) { |
||
| 412 | number_of_chunks = *pSource++; |
||
| 413 | for (j = 0; j < number_of_chunks; j++) { |
||
| 414 | chunk_length = *pSource++; |
||
| 415 | if (chunk_length < 0) { |
||
| 416 | pSource -= chunk_length; |
||
| 417 | } |
||
| 418 | } |
||
| 419 | } |
||
| 420 | return pSource; |
||
| 421 | } |
||
| 422 | |||
| 423 | // IDA: void __usercall CopyWords(char *pDst@<EAX>, char *pSrc@<EDX>, int pN@<EBX>) |
||
| 424 | void CopyWords(char* pDst, char* pSrc, int pN) { |
||
| 425 | //tU16* dst; // Pierre-Marie Baty -- unused variable |
||
| 426 | //tU16* src; // Pierre-Marie Baty -- unused variable |
||
| 427 | LOG_TRACE("(\"%s\", \"%s\", %d)", pDst, pSrc, pN); |
||
| 428 | NOT_IMPLEMENTED(); |
||
| 429 | } |
||
| 430 | |||
| 431 | // IDA: void __usercall Copy8BitStripImageTo16Bit(br_pixelmap *pDest@<EAX>, br_int_16 pDest_x@<EDX>, br_int_16 pOffset_x@<EBX>, br_int_16 pDest_y@<ECX>, br_int_16 pOffset_y, tS8 *pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_uint_16 pWidth, br_uint_16 pHeight) |
||
| 432 | void Copy8BitStripImageTo16Bit(br_pixelmap* pDest, br_int_16 pDest_x, br_int_16 pOffset_x, br_int_16 pDest_y, br_int_16 pOffset_y, tS8* pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_uint_16 pWidth, br_uint_16 pHeight) { |
||
| 433 | //int i; // Pierre-Marie Baty -- unused variable |
||
| 434 | //int j; // Pierre-Marie Baty -- unused variable |
||
| 435 | //int height; // Pierre-Marie Baty -- unused variable |
||
| 436 | //int number_of_chunks; // Pierre-Marie Baty -- unused variable |
||
| 437 | //int old_x_byte; // Pierre-Marie Baty -- unused variable |
||
| 438 | //int x_byte; // Pierre-Marie Baty -- unused variable |
||
| 439 | //int off_the_left; // Pierre-Marie Baty -- unused variable |
||
| 440 | //int destn_width; // Pierre-Marie Baty -- unused variable |
||
| 441 | //int chunk_length; // Pierre-Marie Baty -- unused variable |
||
| 442 | //char* destn_ptr; // Pierre-Marie Baty -- unused variable |
||
| 443 | //char* destn_ptr2; // Pierre-Marie Baty -- unused variable |
||
| 444 | LOG_TRACE("(%p, %d, %d, %d, %d, %p, %d, %d, %d, %d)", pDest, pDest_x, pOffset_x, pDest_y, pOffset_y, pSource, pSource_x, pSource_y, pWidth, pHeight); |
||
| 445 | NOT_IMPLEMENTED(); |
||
| 446 | } |
||
| 447 | |||
| 448 | // IDA: void __usercall CopyStripImage(br_pixelmap *pDest@<EAX>, br_int_16 pDest_x@<EDX>, br_int_16 pOffset_x@<EBX>, br_int_16 pDest_y@<ECX>, br_int_16 pOffset_y, tS8 *pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_uint_16 pWidth, br_uint_16 pHeight) |
||
| 449 | void CopyStripImage(br_pixelmap* pDest, br_int_16 pDest_x, br_int_16 pOffset_x, br_int_16 pDest_y, br_int_16 pOffset_y, tS8* pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_uint_16 pWidth, br_uint_16 pHeight) { |
||
| 450 | int i; |
||
| 451 | int j; |
||
| 452 | int height; |
||
| 453 | int number_of_chunks; |
||
| 454 | int old_x_byte; |
||
| 455 | int x_byte; |
||
| 456 | int off_the_left; |
||
| 457 | //int destn_width; // Pierre-Marie Baty -- unused variable |
||
| 458 | int chunk_length; |
||
| 459 | char* destn_ptr; |
||
| 460 | char* destn_ptr2; |
||
| 461 | LOG_TRACE8("(%p, %d, %d, %d, %d, %p, %d, %d, %d, %d)", pDest, pDest_x, pOffset_x, pDest_y, pOffset_y, pSource, pSource_x, pSource_y, pWidth, pHeight); |
||
| 462 | |||
| 463 | height = *(uint16_t*)pSource; |
||
| 464 | pSource = pSource + 2; |
||
| 465 | if (pDest_y + pOffset_y >= 0) { |
||
| 466 | destn_ptr = (char*)pDest->pixels + pDest->row_bytes * (pDest_y + pOffset_y); |
||
| 467 | } else { |
||
| 468 | pSource = SkipLines(pSource, -pDest_y - pOffset_y); |
||
| 469 | destn_ptr = (char*)pDest->pixels; |
||
| 470 | height += pDest_y + pOffset_y; |
||
| 471 | pOffset_y = 0; |
||
| 472 | pDest_y = 0; |
||
| 473 | } |
||
| 474 | |||
| 475 | if (height + pDest_y + pOffset_y > pDest->height) { |
||
| 476 | height = pDest->height - pDest_y - pOffset_y; |
||
| 477 | } |
||
| 478 | off_the_left = pDest_x + pOffset_x; |
||
| 479 | if (off_the_left > 0) { |
||
| 480 | destn_ptr += off_the_left; |
||
| 481 | } |
||
| 482 | for (i = 0; i < height; i++) { |
||
| 483 | destn_ptr2 = destn_ptr; |
||
| 484 | number_of_chunks = *pSource; |
||
| 485 | pSource++; |
||
| 486 | x_byte = off_the_left; |
||
| 487 | for (j = 0; j < number_of_chunks; j++) { |
||
| 488 | chunk_length = *pSource; |
||
| 489 | pSource++; |
||
| 490 | if (chunk_length >= 0) { |
||
| 491 | old_x_byte = x_byte; |
||
| 492 | x_byte += chunk_length; |
||
| 493 | if (old_x_byte >= 0) { |
||
| 494 | destn_ptr2 += chunk_length; |
||
| 495 | } else if (x_byte > 0) { |
||
| 496 | destn_ptr2 += chunk_length + old_x_byte; |
||
| 497 | } |
||
| 498 | } else { |
||
| 499 | old_x_byte = x_byte; |
||
| 500 | x_byte += -chunk_length; |
||
| 501 | if (old_x_byte >= 0) { |
||
| 502 | if (pDest->width >= x_byte) { |
||
| 503 | memcpy(destn_ptr2, pSource, -chunk_length); |
||
| 504 | destn_ptr2 += -chunk_length; |
||
| 505 | } else if (old_x_byte < pDest->width) { |
||
| 506 | memcpy(destn_ptr2, pSource, pDest->width - old_x_byte); |
||
| 507 | } |
||
| 508 | } else if (x_byte > 0) { |
||
| 509 | memcpy(destn_ptr2, &pSource[-old_x_byte], -chunk_length + old_x_byte); |
||
| 510 | destn_ptr2 += -chunk_length + old_x_byte; |
||
| 511 | } |
||
| 512 | pSource += -chunk_length; |
||
| 513 | } |
||
| 514 | } |
||
| 515 | destn_ptr += pDest->row_bytes; |
||
| 516 | } |
||
| 517 | } |
||
| 518 | |||
| 519 | // IDA: void __usercall SetBRenderScreenAndBuffers(int pX_offset@<EAX>, int pY_offset@<EDX>, int pWidth@<EBX>, int pHeight@<ECX>) |
||
| 520 | void SetBRenderScreenAndBuffers(int pX_offset, int pY_offset, int pWidth, int pHeight) { |
||
| 521 | LOG_TRACE("(%d, %d, %d, %d)", pX_offset, pY_offset, pWidth, pHeight); |
||
| 522 | |||
| 523 | PDAllocateScreenAndBack(); |
||
| 524 | if (!pWidth) { |
||
| 525 | pWidth = gBack_screen->width; |
||
| 526 | } |
||
| 527 | if (!pHeight) { |
||
| 528 | pHeight = gBack_screen->height; |
||
| 529 | } |
||
| 530 | gRender_screen = DRPixelmapAllocateSub(gBack_screen, pX_offset, pY_offset, pWidth, pHeight); |
||
| 531 | gWidth = pWidth; |
||
| 532 | gHeight = pHeight; |
||
| 533 | gY_offset = pY_offset; |
||
| 534 | gX_offset = pX_offset; |
||
| 535 | if (gGraf_specs[gGraf_spec_index].doubled) { |
||
| 536 | gScreen->base_x = (gGraf_specs[gGraf_spec_index].phys_width - 2 * gGraf_specs[gGraf_spec_index].total_width) / 2; |
||
| 537 | gScreen->base_y = (gGraf_specs[gGraf_spec_index].phys_height - 2 * gGraf_specs[gGraf_spec_index].total_height) / 2; |
||
| 538 | } else { |
||
| 539 | gScreen->base_x = (gGraf_specs[gGraf_spec_index].phys_width - gGraf_specs[gGraf_spec_index].total_width) / 2; |
||
| 540 | gScreen->base_y = (gGraf_specs[gGraf_spec_index].phys_height - gGraf_specs[gGraf_spec_index].total_height) / 2; |
||
| 541 | } |
||
| 542 | |||
| 543 | gScreen->origin_x = 0; |
||
| 544 | gScreen->origin_y = 0; |
||
| 545 | if (gBack_screen == NULL) { |
||
| 546 | FatalError(kFatalError_AllocateOffScreenBuffer); |
||
| 547 | } |
||
| 548 | gDepth_buffer = BrPixelmapMatch(gBack_screen, BR_PMMATCH_DEPTH_16); |
||
| 549 | if (gDepth_buffer == NULL) { |
||
| 550 | FatalError(kFatalError_AllocateZBuffer); |
||
| 551 | } |
||
| 552 | BrZbBegin(gRender_screen->type, gDepth_buffer->type); |
||
| 553 | gBrZb_initialized = 1; |
||
| 554 | } |
||
| 555 | |||
| 556 | // IDA: void __cdecl SetIntegerMapRenders() |
||
| 557 | void SetIntegerMapRenders(void) { |
||
| 558 | LOG_TRACE("()"); |
||
| 559 | |||
| 560 | gMap_render_x_i = ((int)gMap_render_x) & ~3; |
||
| 561 | gMap_render_y_i = ((int)gMap_render_y) & ~1; |
||
| 562 | gMap_render_width_i = ((int)gMap_render_width) & ~3; |
||
| 563 | gMap_render_height_i = ((int)gMap_render_height) & ~1; |
||
| 564 | if (gReal_graf_data_index != 0) { |
||
| 565 | gMap_render_x_i = 2 * gMap_render_x_i; |
||
| 566 | gMap_render_y_i = 2 * gMap_render_y_i + 40; |
||
| 567 | gMap_render_width_i = 2 * gMap_render_width_i; |
||
| 568 | gMap_render_height_i = 2 * gMap_render_height_i; |
||
| 569 | } |
||
| 570 | } |
||
| 571 | |||
| 572 | // IDA: void __cdecl AdjustRenderScreenSize() |
||
| 573 | void AdjustRenderScreenSize(void) { |
||
| 574 | int switched_res; |
||
| 575 | LOG_TRACE("()"); |
||
| 576 | |||
| 577 | switched_res = SwitchToRealResolution(); |
||
| 578 | ReinitialiseRenderStuff(); |
||
| 579 | if (gMap_mode) { |
||
| 580 | gRender_screen->base_x = gMap_render_x_i; |
||
| 581 | gRender_screen->base_y = gMap_render_y_i; |
||
| 582 | gRender_screen->width = gMap_render_width_i; |
||
| 583 | gRender_screen->height = gMap_render_height_i; |
||
| 584 | } else { |
||
| 585 | gRender_screen->base_x = gProgram_state.current_render_left; |
||
| 586 | gRender_screen->base_y = gProgram_state.current_render_top; |
||
| 587 | gRender_screen->height = gProgram_state.current_render_bottom - gProgram_state.current_render_top; |
||
| 588 | gRender_screen->width = gProgram_state.current_render_right - gProgram_state.current_render_left; |
||
| 589 | } |
||
| 590 | if (gRender_screen->row_bytes == gRender_screen->width) { |
||
| 591 | gRender_screen->flags |= BR_PMF_ROW_WHOLEPIXELS; |
||
| 592 | } else { |
||
| 593 | gRender_screen->flags &= ~BR_PMF_ROW_WHOLEPIXELS; |
||
| 594 | } |
||
| 595 | gRender_screen->origin_x = gRender_screen->width / 2; |
||
| 596 | gRender_screen->origin_y = gRender_screen->height / 2; |
||
| 597 | gWidth = gRender_screen->width; |
||
| 598 | gHeight = gRender_screen->height; |
||
| 599 | ReinitialiseForwardCamera(); |
||
| 600 | if (switched_res) { |
||
| 601 | SwitchToLoresMode(); |
||
| 602 | } |
||
| 603 | } |
||
| 604 | |||
| 605 | // IDA: void __cdecl ScreenSmaller() |
||
| 606 | void ScreenSmaller(void) { |
||
| 607 | LOG_TRACE("()"); |
||
| 608 | |||
| 609 | if (!gMap_mode) { |
||
| 610 | if (gProgram_state.cockpit_on) { |
||
| 611 | ToggleCockpit(); |
||
| 612 | } |
||
| 613 | gRender_indent++; |
||
| 614 | if (gRender_indent > 8) { |
||
| 615 | gRender_indent = 8; |
||
| 616 | } |
||
| 617 | AdjustRenderScreenSize(); |
||
| 618 | } |
||
| 619 | } |
||
| 620 | |||
| 621 | // IDA: void __cdecl ScreenLarger() |
||
| 622 | void ScreenLarger(void) { |
||
| 623 | LOG_TRACE("()"); |
||
| 624 | |||
| 625 | if (!gMap_mode) { |
||
| 626 | if (gProgram_state.cockpit_on) { |
||
| 627 | ToggleCockpit(); |
||
| 628 | } |
||
| 629 | gRender_indent--; |
||
| 630 | if (gRender_indent < 0) { |
||
| 631 | gRender_indent = 0; |
||
| 632 | } |
||
| 633 | AdjustRenderScreenSize(); |
||
| 634 | } |
||
| 635 | } |
||
| 636 | |||
| 637 | // IDA: void __usercall DRSetPaletteEntries(br_pixelmap *pPalette@<EAX>, int pFirst_colour@<EDX>, int pCount@<EBX>) |
||
| 638 | void DRSetPaletteEntries(br_pixelmap* pPalette, int pFirst_colour, int pCount) { |
||
| 639 | LOG_TRACE("(%p, %d, %d)", pPalette, pFirst_colour, pCount); |
||
| 640 | if (pFirst_colour == 0) { |
||
| 641 | ((br_int_32*)pPalette->pixels)[0] = 0; |
||
| 642 | } |
||
| 643 | memcpy(gCurrent_palette_pixels + 4 * pFirst_colour, (char*)pPalette->pixels + 4 * pFirst_colour, 4 * pCount); |
||
| 644 | if (!gFaded_palette) { |
||
| 645 | PDSetPaletteEntries(pPalette, pFirst_colour, pCount); |
||
| 646 | } |
||
| 647 | gPalette_munged = 1; |
||
| 648 | } |
||
| 649 | |||
| 650 | // IDA: void __usercall DRSetPalette3(br_pixelmap *pThe_palette@<EAX>, int pSet_current_palette@<EDX>) |
||
| 651 | void DRSetPalette3(br_pixelmap* pThe_palette, int pSet_current_palette) { |
||
| 652 | LOG_TRACE("(%p, %d)", pThe_palette, pSet_current_palette); |
||
| 653 | |||
| 654 | if (pSet_current_palette) { |
||
| 655 | memcpy(gCurrent_palette_pixels, pThe_palette->pixels, 0x400u); |
||
| 656 | } |
||
| 657 | if (!gFaded_palette) { |
||
| 658 | PDSetPalette(pThe_palette); |
||
| 659 | } |
||
| 660 | if (pThe_palette != gRender_palette) { |
||
| 661 | gPalette_munged |= 1u; |
||
| 662 | } |
||
| 663 | } |
||
| 664 | |||
| 665 | // IDA: void __usercall DRSetPalette2(br_pixelmap *pThe_palette@<EAX>, int pSet_current_palette@<EDX>) |
||
| 666 | void DRSetPalette2(br_pixelmap* pThe_palette, int pSet_current_palette) { |
||
| 667 | ((br_int_32*)pThe_palette->pixels)[0] = 0; |
||
| 668 | if (pSet_current_palette) { |
||
| 669 | memcpy(gCurrent_palette_pixels, pThe_palette->pixels, 0x400u); |
||
| 670 | } |
||
| 671 | if (!gFaded_palette) { |
||
| 672 | PDSetPalette(pThe_palette); |
||
| 673 | } |
||
| 674 | if (pThe_palette != gRender_palette) { |
||
| 675 | gPalette_munged |= 1u; |
||
| 676 | } |
||
| 677 | } |
||
| 678 | |||
| 679 | // IDA: void __usercall DRSetPalette(br_pixelmap *pThe_palette@<EAX>) |
||
| 680 | void DRSetPalette(br_pixelmap* pThe_palette) { |
||
| 681 | DRSetPalette2(pThe_palette, 1); |
||
| 682 | } |
||
| 683 | |||
| 684 | // IDA: void __cdecl InitializePalettes() |
||
| 685 | void InitializePalettes(void) { |
||
| 686 | //int j; // Pierre-Marie Baty -- unused variable |
||
| 687 | gCurrent_palette_pixels = BrMemAllocate(0x400u, kMem_cur_pal_pixels); |
||
| 688 | gCurrent_palette = DRPixelmapAllocate(BR_PMT_RGBX_888, 1u, 256, gCurrent_palette_pixels, 0); |
||
| 689 | gRender_palette = BrTableFind("DRRENDER.PAL"); |
||
| 690 | if (gRender_palette == NULL) { |
||
| 691 | FatalError(kFatalError_RequiredPalette); |
||
| 692 | } |
||
| 693 | gOrig_render_palette = BrPixelmapAllocateSub(gRender_palette, 0, 0, gRender_palette->width, gRender_palette->height); |
||
| 694 | gOrig_render_palette->pixels = BrMemAllocate(0x400u, kMem_render_pal_pixels); |
||
| 695 | memcpy(gOrig_render_palette->pixels, gRender_palette->pixels, 0x400u); |
||
| 696 | gFlic_palette = BrTableFind("DRACEFLC.PAL"); |
||
| 697 | if (gFlic_palette == NULL) { |
||
| 698 | FatalError(kFatalError_RequiredPalette); |
||
| 699 | } |
||
| 700 | DRSetPalette(gFlic_palette); |
||
| 701 | gScratch_pixels = BrMemAllocate(0x400u, kMem_scratch_pal_pixels); |
||
| 702 | gScratch_palette = DRPixelmapAllocate(BR_PMT_RGBX_888, 1u, 256, gScratch_pixels, 0); |
||
| 703 | gPalette_conversion_table = BrTableFind("FLC2REND.TAB"); |
||
| 704 | gRender_shade_table = BrTableFind("DRRENDER.TAB"); |
||
| 705 | gEval_1 = LoadPixelmap("Evalu01.PIX"); |
||
| 706 | } |
||
| 707 | |||
| 708 | // IDA: void __usercall SwitchToPalette(char *pPal_name@<EAX>) |
||
| 709 | void SwitchToPalette(char* pPal_name) { |
||
| 20 | pmbaty | 710 | //br_pixelmap* the_palette; // Pierre-Marie Baty -- unused variable |
| 1 | pmbaty | 711 | LOG_TRACE("(\"%s\")", pPal_name); |
| 20 | pmbaty | 712 | NOT_IMPLEMENTED(); |
| 1 | pmbaty | 713 | } |
| 714 | |||
| 715 | // IDA: void __cdecl ClearEntireScreen() |
||
| 716 | void ClearEntireScreen(void) { |
||
| 717 | LOG_TRACE("()"); |
||
| 718 | |||
| 719 | if (gScreen) { |
||
| 720 | BrPixelmapFill(gScreen, gGraf_specs[gGraf_spec_index].black_value); |
||
| 721 | } |
||
| 722 | BrPixelmapFill(gBack_screen, gGraf_specs[gGraf_spec_index].black_value); |
||
| 723 | PDScreenBufferSwap(0); |
||
| 724 | } |
||
| 725 | |||
| 726 | // IDA: void __cdecl ClearWobbles() |
||
| 727 | void ClearWobbles(void) { |
||
| 728 | int i; |
||
| 729 | LOG_TRACE("()"); |
||
| 730 | |||
| 731 | for (i = 0; i < COUNT_OF(gWobble_array); i++) { |
||
| 732 | gWobble_array[i].time_started = 0; |
||
| 733 | } |
||
| 734 | } |
||
| 735 | |||
| 736 | // IDA: void __cdecl InitWobbleStuff() |
||
| 737 | void InitWobbleStuff(void) { |
||
| 738 | int i; |
||
| 739 | |||
| 740 | ClearWobbles(); |
||
| 741 | for (i = 0; i < COUNT_OF(gCosine_array); i++) { |
||
| 742 | gCosine_array[i] = cosf(i / 64.0f * DR_PI / 2.0f); |
||
| 743 | } |
||
| 744 | } |
||
| 745 | |||
| 746 | // IDA: void __cdecl NewScreenWobble(double pAmplitude_x, double pAmplitude_y, double pPeriod) |
||
| 747 | void NewScreenWobble(double pAmplitude_x, double pAmplitude_y, double pPeriod) { |
||
| 748 | int i; |
||
| 749 | int oldest_time; |
||
| 750 | int oldest_index; |
||
| 751 | LOG_TRACE("(%d, %d, %d)", pAmplitude_x, pAmplitude_y, pPeriod); |
||
| 752 | |||
| 753 | oldest_index = -1; |
||
| 754 | oldest_time = INT_MAX; |
||
| 755 | for (i = 0; i < COUNT_OF(gWobble_array); i++) { |
||
| 756 | if (gWobble_array[i].time_started == 0) { |
||
| 757 | oldest_index = i; |
||
| 758 | break; |
||
| 759 | } |
||
| 760 | if (gWobble_array[i].time_started < oldest_time) { |
||
| 761 | oldest_time = gWobble_array[i].time_started; |
||
| 762 | oldest_index = i; |
||
| 763 | } |
||
| 764 | } |
||
| 765 | gWobble_array[oldest_index].time_started = GetTotalTime(); |
||
| 766 | gWobble_array[oldest_index].amplitude_x = pAmplitude_x; |
||
| 767 | gWobble_array[oldest_index].amplitude_y = pAmplitude_y; |
||
| 768 | gWobble_array[oldest_index].period = pPeriod; |
||
| 769 | } |
||
| 770 | |||
| 771 | // IDA: void __usercall SetScreenWobble(int pWobble_x@<EAX>, int pWobble_y@<EDX>) |
||
| 772 | void SetScreenWobble(int pWobble_x, int pWobble_y) { |
||
| 773 | LOG_TRACE("(%d, %d)", pWobble_x, pWobble_y); |
||
| 774 | |||
| 775 | gScreen_wobble_y = pWobble_y; |
||
| 776 | gScreen_wobble_x = pWobble_x; |
||
| 777 | } |
||
| 778 | |||
| 779 | // IDA: void __cdecl ResetScreenWobble() |
||
| 780 | void ResetScreenWobble(void) { |
||
| 781 | LOG_TRACE("()"); |
||
| 782 | |||
| 783 | SetScreenWobble(0, 0); |
||
| 784 | } |
||
| 785 | |||
| 786 | // IDA: void __usercall CalculateWobblitude(tU32 pThe_time@<EAX>) |
||
| 787 | void CalculateWobblitude(tU32 pThe_time) { |
||
| 788 | int i; |
||
| 789 | tU32 time_going; |
||
| 790 | double angle; |
||
| 791 | double mod_angle; |
||
| 792 | double cosine_over_angle; |
||
| 793 | LOG_TRACE("(%d)", pThe_time); |
||
| 794 | |||
| 795 | if (gProgram_state.new_view != eView_undefined) { |
||
| 796 | return; |
||
| 797 | } |
||
| 798 | gScreen_wobble_x = 0; |
||
| 799 | gScreen_wobble_y = 0; |
||
| 800 | for (i = 0; i < COUNT_OF(gWobble_array); i++) { |
||
| 801 | if (gWobble_array[i].time_started != 0) { |
||
| 802 | time_going = pThe_time - gWobble_array[i].time_started; |
||
| 803 | if (time_going > 1000) { |
||
| 804 | gWobble_array[i].time_started = 0; |
||
| 805 | } else { |
||
| 806 | mod_angle = fmod(time_going / gWobble_array[i].period, TAU); |
||
| 807 | if (mod_angle > DR_3PI_OVER_2) { |
||
| 808 | cosine_over_angle = gCosine_array[(unsigned int)((TAU - mod_angle) / DR_PI * 128.0)]; |
||
| 809 | } else if (mod_angle > DR_PI) { |
||
| 810 | cosine_over_angle = -gCosine_array[(unsigned int)((mod_angle - DR_PI) / DR_PI * 128.0)]; |
||
| 811 | } else if (mod_angle > DR_PI_OVER_2) { |
||
| 812 | cosine_over_angle = -gCosine_array[(unsigned int)((DR_PI - mod_angle) / DR_PI * 128.0)]; |
||
| 813 | } else { |
||
| 814 | cosine_over_angle = gCosine_array[(unsigned int)(mod_angle / DR_PI * 128.0)]; |
||
| 815 | } |
||
| 816 | angle = cosine_over_angle / ((double)(pThe_time - gWobble_array[i].time_started) * 0.0035f + 1.0f); |
||
| 817 | gScreen_wobble_x = (gWobble_array[i].amplitude_x * angle + gScreen_wobble_x); |
||
| 818 | gScreen_wobble_y = (gWobble_array[i].amplitude_y * angle + gScreen_wobble_y); |
||
| 819 | } |
||
| 820 | } |
||
| 821 | } |
||
| 822 | if (gScreen_wobble_x > gCurrent_graf_data->cock_margin_x) { |
||
| 823 | gScreen_wobble_x = gCurrent_graf_data->cock_margin_x; |
||
| 824 | } else if (gScreen_wobble_x < -gCurrent_graf_data->cock_margin_x) { |
||
| 825 | gScreen_wobble_x = -gCurrent_graf_data->cock_margin_x; |
||
| 826 | } |
||
| 827 | if (gScreen_wobble_y > gCurrent_graf_data->cock_margin_y) { |
||
| 828 | gScreen_wobble_y = gCurrent_graf_data->cock_margin_y; |
||
| 829 | } else if (gScreen_wobble_y < -gCurrent_graf_data->cock_margin_y) { |
||
| 830 | gScreen_wobble_y = -gCurrent_graf_data->cock_margin_y; |
||
| 831 | } |
||
| 832 | PipeSingleScreenShake(gScreen_wobble_x, gScreen_wobble_y); |
||
| 833 | } |
||
| 834 | |||
| 835 | // IDA: void __usercall CalculateConcussion(tU32 pThe_time@<EAX>) |
||
| 836 | void CalculateConcussion(tU32 pThe_time) { |
||
| 837 | tU32 time_difference; |
||
| 838 | int i; |
||
| 839 | int j; |
||
| 840 | float the_amplitude; |
||
| 841 | float angle; |
||
| 842 | float mod_angle; |
||
| 843 | float cosine_over_angle; |
||
| 844 | LOG_TRACE("(%d)", pThe_time); |
||
| 845 | |||
| 846 | if (!gConcussion.concussed) { |
||
| 847 | return; |
||
| 848 | } |
||
| 849 | time_difference = pThe_time - gConcussion.time_started; |
||
| 850 | if (pThe_time - gConcussion.time_started > 2000) { |
||
| 851 | gConcussion.concussed = 0; |
||
| 852 | } else { |
||
| 853 | for (i = 0; i < 3; ++i) { |
||
| 854 | for (j = 0; j < 3; ++j) { |
||
| 855 | the_amplitude = gConcussion.amplitudes.m[i][j]; |
||
| 856 | if (the_amplitude != 0.0) { |
||
| 857 | mod_angle = fmodf(time_difference / gConcussion.periods.m[i][j], (float) TAU); // Pierre-Marie Baty -- added type cast |
||
| 858 | if (mod_angle > DR_3PI_OVER_2) { |
||
| 859 | cosine_over_angle = gCosine_array[(unsigned int)((TAU - mod_angle) / DR_PI * 128.f)]; |
||
| 860 | } else if (mod_angle > DR_PI) { |
||
| 861 | cosine_over_angle = -gCosine_array[(unsigned int)((mod_angle - DR_PI) / DR_PI * 128.f)]; |
||
| 862 | } else if (mod_angle > DR_PI_OVER_2) { |
||
| 863 | cosine_over_angle = -gCosine_array[(unsigned int)((DR_PI - mod_angle) / DR_PI * 128.f)]; |
||
| 864 | } else { |
||
| 865 | cosine_over_angle = gCosine_array[(unsigned int)(mod_angle / DR_PI * 128.f)]; |
||
| 866 | } |
||
| 867 | angle = cosine_over_angle / ((double)time_difference * 0.02f + 1.0f); |
||
| 868 | gCamera->t.t.mat.m[i][j] = angle * the_amplitude + gCamera->t.t.mat.m[i][j]; |
||
| 869 | gRearview_camera->t.t.mat.m[i][j] = angle * the_amplitude + gRearview_camera->t.t.mat.m[i][j]; |
||
| 870 | } |
||
| 871 | } |
||
| 872 | } |
||
| 873 | } |
||
| 874 | } |
||
| 875 | |||
| 876 | // IDA: void __cdecl SufferFromConcussion(float pSeriousness) |
||
| 877 | void SufferFromConcussion(float pSeriousness) { |
||
| 878 | int i; |
||
| 879 | int j; |
||
| 880 | LOG_TRACE("(%f)", pSeriousness); |
||
| 881 | |||
| 882 | for (i = 0; i < 3; i++) { |
||
| 883 | for (j = 0; j < 3; j++) { |
||
| 884 | gConcussion.amplitudes.m[i][j] = FRandomPosNeg(pSeriousness); |
||
| 885 | gConcussion.periods.m[i][j] = FRandomBetween(20.f, 100.f); |
||
| 886 | } |
||
| 887 | } |
||
| 888 | gConcussion.concussed = 1; |
||
| 889 | gConcussion.time_started = GetTotalTime(); |
||
| 890 | } |
||
| 891 | |||
| 892 | // IDA: void __usercall ProcessNonTrackActors(br_pixelmap *pRender_buffer@<EAX>, br_pixelmap *pDepth_buffer@<EDX>, br_actor *pCamera@<EBX>, br_matrix34 *pCamera_to_world@<ECX>, br_matrix34 *pOld_camera_matrix) |
||
| 893 | void ProcessNonTrackActors(br_pixelmap* pRender_buffer, br_pixelmap* pDepth_buffer, br_actor* pCamera, br_matrix34* pCamera_to_world, br_matrix34* pOld_camera_matrix) { |
||
| 894 | LOG_TRACE("(%p, %p, %p, %p, %p)", pRender_buffer, pDepth_buffer, pCamera, pCamera_to_world, pOld_camera_matrix); |
||
| 895 | |||
| 896 | BrZbSceneRenderAdd(gNon_track_actor); |
||
| 897 | } |
||
| 898 | |||
| 899 | // IDA: int __usercall OppositeColour@<EAX>(int pColour@<EAX>) |
||
| 900 | int OppositeColour(int pColour) { |
||
| 901 | int brightness; |
||
| 902 | LOG_TRACE("(%d)", pColour); |
||
| 903 | |||
| 904 | if (pColour < 224) { |
||
| 905 | if ((pColour & 0x7) < 4) { |
||
| 906 | brightness = 255; |
||
| 907 | } else { |
||
| 908 | brightness = 0; |
||
| 909 | } |
||
| 910 | } else { |
||
| 911 | if ((pColour & 0xf) < 8) { |
||
| 912 | brightness = 255; |
||
| 913 | } else { |
||
| 914 | brightness = 0; |
||
| 915 | } |
||
| 916 | } |
||
| 917 | return brightness; |
||
| 918 | } |
||
| 919 | |||
| 920 | // IDA: void __usercall DrawMapBlip(tCar_spec *pCar@<EAX>, tU32 pTime@<EDX>, br_matrix34 *pTrans@<EBX>, br_vector3 *pPos@<ECX>, int pColour) |
||
| 921 | void DrawMapBlip(tCar_spec* pCar, tU32 pTime, br_matrix34* pTrans, br_vector3* pPos, int pColour) { |
||
| 922 | br_vector3 map_pos; |
||
| 923 | int offset; |
||
| 924 | int* arrow_ptr; |
||
| 925 | int point_count; |
||
| 926 | int colours[2]; |
||
| 927 | int x; |
||
| 928 | int y; |
||
| 929 | int colour; |
||
| 930 | int i; |
||
| 931 | int j; |
||
| 932 | int temp; |
||
| 933 | int from_x; |
||
| 934 | int from_y; |
||
| 935 | int to_x; |
||
| 936 | int to_y; |
||
| 937 | int arrow_index; |
||
| 938 | tU32 time_diff; |
||
| 939 | tU32 period; |
||
| 940 | br_matrix34 car_in_map_space; |
||
| 941 | float bearing; |
||
| 942 | //float cos_factor; // Pierre-Marie Baty -- unused variable |
||
| 943 | //float sin_factor; // Pierre-Marie Baty -- unused variable |
||
| 944 | LOG_TRACE("(%p, %d, %p, %p, %d)", pCar, pTime, pTrans, pPos, pColour); |
||
| 945 | |||
| 946 | time_diff = pTime - gMap_mode; |
||
| 947 | BrMatrix34ApplyP(&map_pos, pPos, &gCurrent_race.map_transformation); |
||
| 948 | switch (gReal_graf_data_index) { |
||
| 949 | case 0: |
||
| 950 | break; |
||
| 951 | case 1: |
||
| 952 | map_pos.v[0] = map_pos.v[0] * 2.f; |
||
| 953 | map_pos.v[1] = map_pos.v[1] * 2.f + 40.f; |
||
| 954 | break; |
||
| 955 | default: |
||
| 956 | TELL_ME_IF_WE_PASS_THIS_WAY(); |
||
| 957 | } |
||
| 958 | period = 256; // Must be power of 2 |
||
| 959 | colours[0] = pColour; |
||
| 960 | colours[1] = OppositeColour(pColour); |
||
| 961 | BrMatrix34Mul(&car_in_map_space, pTrans, &gCurrent_race.map_transformation); |
||
| 962 | bearing = FastScalarArcTan2(car_in_map_space.m[2][0], car_in_map_space.m[2][1]); |
||
| 963 | |||
| 964 | // Calculate in which of the 16 directions, the arrow is pointing to |
||
| 965 | bearing = (360.f - bearing + 12.25) / 22.5f; |
||
| 966 | arrow_index = ((int)bearing) % 16; |
||
| 967 | |||
| 968 | // The player's blip blinks, others are shown permanently |
||
| 969 | if (pCar->driver != eDriver_local_human || (period & pTime) != 0) { |
||
| 970 | for (i = 0; i < COUNT_OF(colours); i++) { |
||
| 971 | colour = colours[i]; |
||
| 972 | point_count = gArrows[i][arrow_index & 0x3][0]; |
||
| 973 | arrow_ptr = &gArrows[i][arrow_index & 0x3][1]; |
||
| 974 | for (j = 0; j < point_count; j++, arrow_ptr += 2) { |
||
| 975 | if (arrow_index & 0x8) { |
||
| 976 | x = -arrow_ptr[0]; |
||
| 977 | y = -arrow_ptr[1]; |
||
| 978 | } else { |
||
| 979 | x = arrow_ptr[0]; |
||
| 980 | y = arrow_ptr[1]; |
||
| 981 | } |
||
| 982 | if (arrow_index & 0x4) { |
||
| 983 | temp = x; |
||
| 984 | x = -y; |
||
| 985 | y = temp; |
||
| 986 | } |
||
| 987 | BrPixelmapPixelSet(gBack_screen, map_pos.v[0] + x, map_pos.v[1] + y, colour); |
||
| 988 | } |
||
| 989 | } |
||
| 990 | } |
||
| 991 | // Draw a rectangle around the fox |
||
| 992 | colour = colours[!!(pTime & period)]; |
||
| 993 | if (gNet_mode != eNet_mode_none && gCurrent_net_game->type == eNet_game_type_foxy && gNet_players[gIt_or_fox].car == pCar) { |
||
| 994 | from_x = map_pos.v[0] - 8.f; |
||
| 995 | from_y = map_pos.v[1] - 8.f; |
||
| 996 | to_x = map_pos.v[0] + 8.f; |
||
| 997 | to_y = map_pos.v[1] + 8.f; |
||
| 998 | BrPixelmapLine(gBack_screen, from_x, from_y, to_x, from_y, colour); |
||
| 999 | BrPixelmapLine(gBack_screen, from_x, to_y, to_x, to_y, colour); |
||
| 1000 | BrPixelmapLine(gBack_screen, from_x, from_y, from_x, to_y, colour); |
||
| 1001 | BrPixelmapLine(gBack_screen, to_x, from_y, to_x, to_y, colour); |
||
| 1002 | } |
||
| 1003 | // To attract the player's attention, draw a rectangle around the player's position that decreases in size, |
||
| 1004 | if (time_diff <= 500 && pCar->driver == eDriver_local_human) { |
||
| 1005 | offset = ((500 - time_diff) * 70) / 500; |
||
| 1006 | from_x = map_pos.v[0] - offset - .5f; |
||
| 1007 | from_y = map_pos.v[1] - offset - .5f; |
||
| 1008 | to_x = map_pos.v[0] + offset + .5f; |
||
| 1009 | to_y = map_pos.v[1] + offset + .5f; |
||
| 1010 | BrPixelmapLine(gBack_screen, from_x, from_y, to_x, from_y, colour); |
||
| 1011 | BrPixelmapLine(gBack_screen, from_x, to_y, to_x, to_y, colour); |
||
| 1012 | BrPixelmapLine(gBack_screen, from_x, from_y, from_x, to_y, colour); |
||
| 1013 | BrPixelmapLine(gBack_screen, to_x, from_y, to_x, to_y, colour); |
||
| 1014 | } |
||
| 1015 | } |
||
| 1016 | |||
| 1017 | // IDA: void __usercall DrawMapSmallBlip(tU32 pTime@<EAX>, br_vector3 *pPos@<EDX>, int pColour@<EBX>) |
||
| 1018 | void DrawMapSmallBlip(tU32 pTime, br_vector3* pPos, int pColour) { |
||
| 1019 | br_vector3 map_pos; |
||
| 1020 | int offset; |
||
| 1021 | //tU32 time_diff; // Pierre-Marie Baty -- unused variable |
||
| 1022 | LOG_TRACE("(%d, %p, %d)", pTime, pPos, pColour); |
||
| 1023 | |||
| 1024 | if ((pTime & 0x100) == 0) { |
||
| 1025 | BrMatrix34ApplyP(&map_pos, pPos, &gCurrent_race.map_transformation); |
||
| 1026 | if (gReal_graf_data_index != 0) { |
||
| 1027 | map_pos.v[0] = 2.f * map_pos.v[0]; |
||
| 1028 | map_pos.v[1] = 2.f * map_pos.v[1] + 40.f; |
||
| 1029 | } |
||
| 1030 | offset = (int)map_pos.v[0] + gBack_screen->row_bytes * (int)map_pos.v[1]; |
||
| 1031 | ((br_uint_8*)gBack_screen->pixels)[offset] = pColour; |
||
| 1032 | } |
||
| 1033 | } |
||
| 1034 | |||
| 1035 | // IDA: void __usercall MungeClipPlane(br_vector3 *pLight@<EAX>, tCar_spec *pCar@<EDX>, br_vector3 *p1@<EBX>, br_vector3 *p2@<ECX>, br_scalar pY_offset) |
||
| 1036 | void MungeClipPlane(br_vector3* pLight, tCar_spec* pCar, br_vector3* p1, br_vector3* p2, br_scalar pY_offset) { |
||
| 1037 | br_vector3 v1; |
||
| 1038 | br_vector3 v2; |
||
| 1039 | br_vector3 v3; |
||
| 1040 | br_vector3 v4; |
||
| 1041 | br_scalar length; |
||
| 1042 | br_actor* new_clip; |
||
| 1043 | LOG_TRACE("(%p, %p, %p, %p, %f)", pLight, pCar, p1, p2, pY_offset); |
||
| 1044 | |||
| 1045 | BrMatrix34ApplyP(&v1, p1, &pCar->car_master_actor->t.t.mat); |
||
| 1046 | BrMatrix34ApplyP(&v2, p2, &pCar->car_master_actor->t.t.mat); |
||
| 1047 | BrVector3Sub(&v3, p2, p1); |
||
| 1048 | BrVector3Cross(&v4, &v3, pLight); |
||
| 1049 | if (fabsf(v4.v[0]) >= 0.01f || fabsf(v4.v[1]) >= 0.01f || fabsf(v4.v[2]) >= 0.01f) { |
||
| 1050 | BrVector3Copy(&v3, p1); |
||
| 1051 | v3.v[1] -= pY_offset; |
||
| 1052 | if (BrVector3Dot(&v3, &v4) > 0.f) { |
||
| 1053 | BrVector3Negate(&v4, &v4); |
||
| 1054 | } |
||
| 1055 | BrVector3Normalise(&v3, &v4); |
||
| 1056 | BrMatrix34ApplyV(&v4, &v3, &pCar->car_master_actor->t.t.mat); |
||
| 1057 | length = (v1.v[2] - v2.v[2]) * (v1.v[2] - v2.v[2]) + (v1.v[0] - v2.v[0]) * (v1.v[0] - v2.v[0]); |
||
| 1058 | |||
| 1059 | new_clip = gShadow_clip_planes[gShadow_clip_plane_count].clip; |
||
| 1060 | ((br_vector4*)new_clip->type_data)->v[0] = v4.v[0]; |
||
| 1061 | ((br_vector4*)new_clip->type_data)->v[1] = v4.v[1]; |
||
| 1062 | ((br_vector4*)new_clip->type_data)->v[2] = v4.v[2]; |
||
| 1063 | ((br_vector4*)new_clip->type_data)->v[3] = -BrVector3Dot(&v1, &v4); |
||
| 1064 | gShadow_clip_planes[gShadow_clip_plane_count].length = length; |
||
| 1065 | gShadow_clip_plane_count++; |
||
| 1066 | } |
||
| 1067 | } |
||
| 1068 | |||
| 1069 | // IDA: void __usercall TryThisEdge(tCar_spec *pCar@<EAX>, br_vector3 *pLight@<EDX>, int pIndex_1@<EBX>, br_scalar pSign_1, int pIndex_2, br_scalar pSign_2, int pPoint_index_1, int pPoint_index_2, br_scalar pY_offset) |
||
| 1070 | void TryThisEdge(tCar_spec* pCar, br_vector3* pLight, int pIndex_1, br_scalar pSign_1, int pIndex_2, br_scalar pSign_2, int pPoint_index_1, int pPoint_index_2, br_scalar pY_offset) { |
||
| 1071 | br_scalar dot_1; |
||
| 1072 | br_scalar dot_2; |
||
| 1073 | br_scalar mult; |
||
| 1074 | LOG_TRACE("(%p, %p, %d, %f, %d, %f, %d, %d, %f)", pCar, pLight, pIndex_1, pSign_1, pIndex_2, pSign_2, pPoint_index_1, pPoint_index_2, pY_offset); |
||
| 1075 | |||
| 1076 | dot_1 = pSign_1 * pLight->v[pIndex_1]; |
||
| 1077 | dot_2 = pSign_2 * pLight->v[pIndex_2]; |
||
| 1078 | mult = dot_1 * dot_2; |
||
| 1079 | if (mult < 0 || (mult == 0 && (dot_1 > 0 || dot_2 > 0))) { |
||
| 1080 | if (gShadow_clip_plane_count < 6) { |
||
| 1081 | MungeClipPlane(pLight, pCar, &gShadow_points[pPoint_index_1], &gShadow_points[pPoint_index_2], pY_offset); |
||
| 1082 | } |
||
| 1083 | } |
||
| 1084 | } |
||
| 1085 | |||
| 1086 | // IDA: br_scalar __usercall DistanceFromPlane@<ST0>(br_vector3 *pPos@<EAX>, br_scalar pA, br_scalar pB, br_scalar pC, br_scalar pD) |
||
| 1087 | br_scalar DistanceFromPlane(br_vector3* pPos, br_scalar pA, br_scalar pB, br_scalar pC, br_scalar pD) { |
||
| 1088 | //br_vector3 normal; // Pierre-Marie Baty -- unused variable |
||
| 1089 | LOG_TRACE("(%p, %f, %f, %f, %f)", pPos, pA, pB, pC, pD); |
||
| 1090 | |||
| 1091 | return fabsf((pPos->v[1] * pB + pPos->v[0] * pA + pPos->v[2] * pC + pD) / (pA * pA + pC * pC + pB * pB)); |
||
| 1092 | } |
||
| 1093 | |||
| 1094 | // IDA: void __cdecl DisableLights() |
||
| 1095 | void DisableLights(void) { |
||
| 1096 | //int i; // Pierre-Marie Baty -- unused variable |
||
| 1097 | LOG_TRACE("()"); |
||
| 1098 | NOT_IMPLEMENTED(); |
||
| 1099 | } |
||
| 1100 | |||
| 1101 | // IDA: void __cdecl EnableLights() |
||
| 1102 | void EnableLights(void) { |
||
| 1103 | //int i; // Pierre-Marie Baty -- unused variable |
||
| 1104 | LOG_TRACE("()"); |
||
| 1105 | NOT_IMPLEMENTED(); |
||
| 1106 | } |
||
| 1107 | |||
| 1108 | // IDA: void __usercall ProcessShadow(tCar_spec *pCar@<EAX>, br_actor *pWorld@<EDX>, tTrack_spec *pTrack_spec@<EBX>, br_actor *pCamera@<ECX>, br_matrix34 *pCamera_to_world_transform, br_scalar pDistance_factor) |
||
| 1109 | void ProcessShadow(tCar_spec* pCar, br_actor* pWorld, tTrack_spec* pTrack_spec, br_actor* pCamera, br_matrix34* pCamera_to_world_transform, br_scalar pDistance_factor) { |
||
| 1110 | int i; |
||
| 1111 | //int j; // Pierre-Marie Baty -- unused variable |
||
| 1112 | int face_count; |
||
| 1113 | //int force_shadow; // Pierre-Marie Baty -- unused variable |
||
| 1114 | //int models_used; // Pierre-Marie Baty -- unused variable |
||
| 1115 | //int point_to_use; // Pierre-Marie Baty -- unused variable |
||
| 1116 | int oily_count; |
||
| 1117 | int f_num; |
||
| 1118 | //br_vector3 pos; // Pierre-Marie Baty -- unused variable |
||
| 1119 | br_vector3 light_ray_car; |
||
| 1120 | //br_vector3 temp_v; // Pierre-Marie Baty -- unused variable |
||
| 1121 | br_vector3 shadow_points_world[8]; |
||
| 1122 | br_vector3 poly_centre; |
||
| 1123 | br_vector3 car_to_poly; |
||
| 1124 | br_vector3 ray; |
||
| 1125 | br_vector3 ray_pos; |
||
| 1126 | br_vector3 normal; |
||
| 1127 | //br_vector3 the_normal; // Pierre-Marie Baty -- unused variable |
||
| 1128 | br_vector3 pos_cam_space; |
||
| 1129 | //br_vector3* v0; // Pierre-Marie Baty -- unused variable |
||
| 1130 | br_vector3* v1; |
||
| 1131 | br_vector3* v2; |
||
| 1132 | br_vector4* clip_normal; |
||
| 1133 | br_scalar bounds_x_min; |
||
| 1134 | br_scalar bounds_x_max; |
||
| 1135 | br_scalar bounds_y_min; |
||
| 1136 | br_scalar bounds_y_max; |
||
| 1137 | br_scalar bounds_z_min; |
||
| 1138 | br_scalar bounds_z_max; |
||
| 1139 | //br_scalar height; // Pierre-Marie Baty -- unused variable |
||
| 1140 | br_scalar oily_size; |
||
| 1141 | br_scalar highest_underneath; |
||
| 1142 | br_scalar shadow_scaling_factor; |
||
| 1143 | br_scalar y_offset; |
||
| 1144 | //br_scalar most_neg_dotty; // Pierre-Marie Baty -- unused variable |
||
| 1145 | //br_scalar mr_dotty; // Pierre-Marie Baty -- unused variable |
||
| 1146 | br_scalar first_poly_below; |
||
| 1147 | br_scalar distance; |
||
| 1148 | br_scalar camera_hither_fudge; |
||
| 1149 | br_scalar camera_angle_additional_fudge; |
||
| 1150 | br_scalar ray_length; |
||
| 1151 | tBounds kev_bounds; |
||
| 1152 | tFace_ref the_list[100]; |
||
| 1153 | tFace_ref* face_ref; |
||
| 1154 | tFace_ref* list_ptr; |
||
| 1155 | //br_renderbounds_cbfn* old_call_back; // Pierre-Marie Baty -- unused variable |
||
| 1156 | br_camera* camera_ptr; |
||
| 1157 | br_actor* oily_actor; |
||
| 1158 | //br_model* model; // Pierre-Marie Baty -- unused variable |
||
| 1159 | br_material* material; |
||
| 1160 | br_vertex verts[48]; |
||
| 1161 | br_face faces[16]; |
||
| 1162 | LOG_TRACE("(%p, %p, %p, %p, %p, %f)", pCar, pWorld, pTrack_spec, pCamera, pCamera_to_world_transform, pDistance_factor); |
||
| 1163 | |||
| 1164 | #if defined(DETHRACE_FIX_BUGS) |
||
| 1165 | ray_length = 0.f; |
||
| 1166 | #endif |
||
| 1167 | f_num = 0; |
||
| 1168 | bounds_x_min = pCar->bounds[1].min.v[0] / WORLD_SCALE; |
||
| 1169 | bounds_x_max = pCar->bounds[1].max.v[0] / WORLD_SCALE; |
||
| 1170 | bounds_y_min = pCar->bounds[1].min.v[1] / WORLD_SCALE; |
||
| 1171 | bounds_y_max = pCar->bounds[1].max.v[1] / WORLD_SCALE; |
||
| 1172 | bounds_z_min = pCar->bounds[1].min.v[2] / WORLD_SCALE; |
||
| 1173 | bounds_z_max = pCar->bounds[1].max.v[2] / WORLD_SCALE; |
||
| 1174 | gShadow_points[0].v[0] = bounds_x_max; |
||
| 1175 | gShadow_points[0].v[1] = bounds_y_max; |
||
| 1176 | gShadow_points[0].v[2] = bounds_z_max; |
||
| 1177 | gShadow_points[1].v[0] = bounds_x_max; |
||
| 1178 | gShadow_points[1].v[1] = bounds_y_max; |
||
| 1179 | gShadow_points[1].v[2] = bounds_z_min; |
||
| 1180 | gShadow_points[2].v[0] = bounds_x_min; |
||
| 1181 | gShadow_points[2].v[1] = bounds_y_max; |
||
| 1182 | gShadow_points[2].v[2] = bounds_z_min; |
||
| 1183 | gShadow_points[3].v[0] = bounds_x_min; |
||
| 1184 | gShadow_points[3].v[1] = bounds_y_max; |
||
| 1185 | gShadow_points[3].v[2] = bounds_z_max; |
||
| 1186 | gShadow_points[4].v[0] = bounds_x_max; |
||
| 1187 | gShadow_points[4].v[1] = bounds_y_min; |
||
| 1188 | gShadow_points[4].v[2] = bounds_z_max; |
||
| 1189 | gShadow_points[5].v[0] = bounds_x_max; |
||
| 1190 | gShadow_points[5].v[1] = bounds_y_min; |
||
| 1191 | gShadow_points[5].v[2] = bounds_z_min; |
||
| 1192 | gShadow_points[6].v[0] = bounds_x_min; |
||
| 1193 | gShadow_points[6].v[1] = bounds_y_min; |
||
| 1194 | gShadow_points[6].v[2] = bounds_z_min; |
||
| 1195 | gShadow_points[7].v[0] = bounds_x_min; |
||
| 1196 | gShadow_points[7].v[1] = bounds_y_min; |
||
| 1197 | gShadow_points[7].v[2] = bounds_z_max; |
||
| 1198 | gShadow_clip_plane_count = 0; |
||
| 1199 | BrMatrix34TApplyV(&light_ray_car, &gShadow_light_ray, &pCar->car_master_actor->t.t.mat); |
||
| 1200 | y_offset = (bounds_y_max + bounds_y_min) / 2.0; |
||
| 1201 | TryThisEdge(pCar, &light_ray_car, 2, 1.0, 1, 1.0, 0, 3, y_offset); |
||
| 1202 | TryThisEdge(pCar, &light_ray_car, 2, -1.0, 1, 1.0, 1, 2, y_offset); |
||
| 1203 | TryThisEdge(pCar, &light_ray_car, 2, -1.0, 1, -1.0, 6, 5, y_offset); |
||
| 1204 | TryThisEdge(pCar, &light_ray_car, 2, 1.0, 1, -1.0, 7, 4, y_offset); |
||
| 1205 | TryThisEdge(pCar, &light_ray_car, 0, 1.0, 1, 1.0, 1, 0, y_offset); |
||
| 1206 | TryThisEdge(pCar, &light_ray_car, 0, -1.0, 1, 1.0, 2, 3, y_offset); |
||
| 1207 | TryThisEdge(pCar, &light_ray_car, 0, -1.0, 1, -1.0, 7, 6, y_offset); |
||
| 1208 | TryThisEdge(pCar, &light_ray_car, 0, 1.0, 1, -1.0, 4, 5, y_offset); |
||
| 1209 | TryThisEdge(pCar, &light_ray_car, 0, 1.0, 2, 1.0, 4, 0, y_offset); |
||
| 1210 | TryThisEdge(pCar, &light_ray_car, 0, -1.0, 2, 1.0, 3, 7, y_offset); |
||
| 1211 | TryThisEdge(pCar, &light_ray_car, 0, -1.0, 2, -1.0, 2, 6, y_offset); |
||
| 1212 | TryThisEdge(pCar, &light_ray_car, 0, 1.0, 2, -1.0, 5, 1, y_offset); |
||
| 1213 | for (i = 0; i < gShadow_clip_plane_count; ++i) { |
||
| 1214 | BrClipPlaneEnable(gShadow_clip_planes[i].clip); |
||
| 1215 | } |
||
| 1216 | face_count = GetPrecalculatedFacesUnderCar(pCar, &face_ref); |
||
| 1217 | |||
| 1218 | if (!gAction_replay_mode && pCar->number_of_wheels_on_ground >= 3 && face_count != 0) { |
||
| 1219 | highest_underneath = 0.0; |
||
| 1220 | } else { |
||
| 1221 | kev_bounds.original_bounds.min.v[0] = 1000.0; |
||
| 1222 | kev_bounds.original_bounds.min.v[1] = 1000.0; |
||
| 1223 | kev_bounds.original_bounds.min.v[2] = 1000.0; |
||
| 1224 | kev_bounds.original_bounds.max.v[0] = -1000.0; |
||
| 1225 | kev_bounds.original_bounds.max.v[1] = -1000.0; |
||
| 1226 | kev_bounds.original_bounds.max.v[2] = -1000.0; |
||
| 1227 | for (i = 0; i < COUNT_OF(shadow_points_world); i++) { |
||
| 1228 | BrMatrix34ApplyP(&shadow_points_world[i], &gShadow_points[i], &pCar->car_master_actor->t.t.mat); |
||
| 1229 | if (shadow_points_world[i].v[0] >= kev_bounds.original_bounds.min.v[0]) { |
||
| 1230 | if (shadow_points_world[i].v[0] > kev_bounds.original_bounds.max.v[0]) { |
||
| 1231 | kev_bounds.original_bounds.max.v[0] = shadow_points_world[i].v[0]; |
||
| 1232 | } |
||
| 1233 | } else { |
||
| 1234 | kev_bounds.original_bounds.min.v[0] = shadow_points_world[i].v[0]; |
||
| 1235 | } |
||
| 1236 | if (shadow_points_world[i].v[1] >= kev_bounds.original_bounds.min.v[1]) { |
||
| 1237 | if (shadow_points_world[i].v[1] > kev_bounds.original_bounds.max.v[1]) { |
||
| 1238 | kev_bounds.original_bounds.max.v[1] = shadow_points_world[i].v[1]; |
||
| 1239 | } |
||
| 1240 | } else { |
||
| 1241 | kev_bounds.original_bounds.min.v[1] = shadow_points_world[i].v[1]; |
||
| 1242 | } |
||
| 1243 | if (shadow_points_world[i].v[2] >= kev_bounds.original_bounds.min.v[2]) { |
||
| 1244 | if (shadow_points_world[i].v[2] > kev_bounds.original_bounds.max.v[2]) { |
||
| 1245 | kev_bounds.original_bounds.max.v[2] = shadow_points_world[i].v[2]; |
||
| 1246 | } |
||
| 1247 | } else { |
||
| 1248 | kev_bounds.original_bounds.min.v[2] = shadow_points_world[i].v[2]; |
||
| 1249 | } |
||
| 1250 | } |
||
| 1251 | kev_bounds.original_bounds.min.v[1] = kev_bounds.original_bounds.min.v[1] - 4.4000001; |
||
| 1252 | kev_bounds.mat = &gIdentity34; |
||
| 1253 | face_count = FindFacesInBox(&kev_bounds, the_list, 100); |
||
| 1254 | face_ref = the_list; |
||
| 1255 | highest_underneath = 1000.0; |
||
| 1256 | ray_length = kev_bounds.original_bounds.max.v[1] - kev_bounds.original_bounds.min.v[1]; |
||
| 1257 | ray.v[0] = 0.0; |
||
| 1258 | ray.v[1] = -ray_length; |
||
| 1259 | ray.v[2] = 0.0; |
||
| 1260 | ray_pos = pCar->car_master_actor->t.t.translate.t; |
||
| 1261 | ray_pos.v[1] = kev_bounds.original_bounds.max.v[1]; |
||
| 1262 | } |
||
| 1263 | if (face_count) { |
||
| 1264 | first_poly_below = -1000.0; |
||
| 1265 | i = 0; |
||
| 1266 | list_ptr = face_ref; |
||
| 1267 | for (i = 0; i < face_count; i++) { |
||
| 1268 | v1 = &list_ptr->v[1]; |
||
| 1269 | v2 = &list_ptr->v[2]; |
||
| 1270 | if (list_ptr->normal.v[1] >= -0.1 || (list_ptr->material && (list_ptr->material->flags & 0x1000) != 0)) { |
||
| 1271 | if (list_ptr->normal.v[1] < 0.0 || (list_ptr->material && ((list_ptr->material->identifier && list_ptr->material->identifier[0] == '!') || list_ptr->material->index_blend))) { |
||
| 1272 | list_ptr->d = SHADOW_D_IGNORE_FLAG; |
||
| 1273 | } else if ((list_ptr->v[0].v[1] > pCar->pos.v[1] || v1->v[1] > pCar->pos.v[1] || v2->v[1] > pCar->pos.v[1]) && list_ptr->normal.v[1] < 0.1) { |
||
| 1274 | list_ptr->d = SHADOW_D_IGNORE_FLAG; |
||
| 1275 | } |
||
| 1276 | } else { |
||
| 1277 | poly_centre.v[0] = v1->v[0] + list_ptr->v[0].v[0]; |
||
| 1278 | poly_centre.v[1] = v1->v[1] + list_ptr->v[0].v[1]; |
||
| 1279 | poly_centre.v[2] = v1->v[2] + list_ptr->v[0].v[2]; |
||
| 1280 | poly_centre.v[0] = v2->v[0] + poly_centre.v[0]; |
||
| 1281 | poly_centre.v[1] = v2->v[1] + poly_centre.v[1]; |
||
| 1282 | poly_centre.v[2] = v2->v[2] + poly_centre.v[2]; |
||
| 1283 | poly_centre.v[0] = poly_centre.v[0] / 3.0; |
||
| 1284 | poly_centre.v[1] = poly_centre.v[1] / 3.0; |
||
| 1285 | poly_centre.v[2] = poly_centre.v[2] / 3.0; |
||
| 1286 | poly_centre.v[1] = (v2->v[1] + v1->v[1] + list_ptr->v[0].v[1]) / 3.0; |
||
| 1287 | if (poly_centre.v[1] > first_poly_below) { |
||
| 1288 | car_to_poly.v[0] = poly_centre.v[0] - pCar->car_master_actor->t.t.mat.m[3][0]; |
||
| 1289 | car_to_poly.v[1] = poly_centre.v[1] - pCar->car_master_actor->t.t.mat.m[3][1]; |
||
| 1290 | car_to_poly.v[2] = poly_centre.v[2] - pCar->car_master_actor->t.t.mat.m[3][2]; |
||
| 1291 | |||
| 1292 | if (BrVector3Dot(&list_ptr->normal, &car_to_poly) > 0.0) { |
||
| 1293 | first_poly_below = poly_centre.v[1]; |
||
| 1294 | } |
||
| 1295 | } |
||
| 1296 | list_ptr->d = SHADOW_D_IGNORE_FLAG; |
||
| 1297 | } |
||
| 1298 | list_ptr++; |
||
| 1299 | } |
||
| 1300 | list_ptr = face_ref; |
||
| 1301 | for (i = 0; i < face_count; i++) { |
||
| 1302 | if (list_ptr->d != 10000.0) { |
||
| 1303 | if (list_ptr->v[0].v[1] >= first_poly_below || list_ptr->v[1].v[1] >= first_poly_below || list_ptr->v[2].v[1] >= first_poly_below) { |
||
| 1304 | if (gFancy_shadow) { |
||
| 1305 | faces[f_num].material = list_ptr->material; |
||
| 1306 | if (list_ptr->material && list_ptr->material->colour_map && (list_ptr->material->flags & BR_MATF_LIGHT) == 0) { |
||
| 1307 | list_ptr->material->flags |= BR_MATF_SMOOTH | BR_MATF_LIGHT; |
||
| 1308 | BrMaterialUpdate(list_ptr->material, BR_MATU_RENDERING); |
||
| 1309 | } |
||
| 1310 | } else { |
||
| 1311 | faces[f_num].material = gShadow_material; |
||
| 1312 | } |
||
| 1313 | |||
| 1314 | verts[3 * f_num].p = list_ptr->v[0]; |
||
| 1315 | verts[3 * f_num].map = *list_ptr->map[0]; |
||
| 1316 | verts[3 * f_num + 1].p = list_ptr->v[1]; |
||
| 1317 | verts[3 * f_num + 1].map = *list_ptr->map[1]; |
||
| 1318 | verts[3 * f_num + 2].p = list_ptr->v[2]; |
||
| 1319 | verts[3 * f_num + 2].map = *list_ptr->map[2]; |
||
| 1320 | faces[f_num].vertices[0] = 3 * f_num; |
||
| 1321 | faces[f_num].vertices[1] = 3 * f_num + 1; |
||
| 1322 | faces[f_num].vertices[2] = 3 * f_num + 2; |
||
| 1323 | f_num++; |
||
| 1324 | if (highest_underneath > 0.0) { |
||
| 1325 | CheckSingleFace(list_ptr, &ray_pos, &ray, &normal, &distance); |
||
| 1326 | if (distance < 1.0 && ray_length * distance < highest_underneath) { |
||
| 1327 | highest_underneath = ray_length * distance; |
||
| 1328 | } |
||
| 1329 | } |
||
| 1330 | if (f_num >= LEN(faces)) { |
||
| 1331 | break; |
||
| 1332 | } |
||
| 1333 | } |
||
| 1334 | } |
||
| 1335 | list_ptr++; |
||
| 1336 | } |
||
| 1337 | highest_underneath = highest_underneath - (bounds_y_max - bounds_y_min); |
||
| 1338 | if (highest_underneath < 2.2) { |
||
| 1339 | if (highest_underneath < 0.0) { |
||
| 1340 | highest_underneath = 0.0; |
||
| 1341 | } |
||
| 1342 | } else { |
||
| 1343 | highest_underneath = (br_scalar) 2.2; // Pierre-Marie Baty -- added type cast |
||
| 1344 | } |
||
| 1345 | if (gFancy_shadow) { |
||
| 1346 | gShadow_dim_amount = ((2.2 - highest_underneath) * 5.0 / 2.2 + 2.5); |
||
| 1347 | for (i = 0; i < gSaved_table_count; i++) { |
||
| 1348 | gSaved_shade_tables[i].original->height = 1; |
||
| 1349 | gSaved_shade_tables[i].original->pixels = (tU8*)gDepth_shade_table->pixels + gShadow_dim_amount * gDepth_shade_table->row_bytes; |
||
| 1350 | |||
| 1351 | BrTableUpdate(gSaved_shade_tables[i].original, BR_TABU_ALL); |
||
| 1352 | } |
||
| 1353 | } |
||
| 1354 | shadow_scaling_factor = (2.2 - highest_underneath) * 0.52 / 2.2 + 0.4; |
||
| 1355 | for (i = 0; i < gShadow_clip_plane_count; i++) { |
||
| 1356 | clip_normal = (br_vector4*)gShadow_clip_planes[i].clip->type_data; |
||
| 1357 | distance = DistanceFromPlane(&pCar->car_master_actor->t.t.euler.t, clip_normal->v[0], clip_normal->v[1], clip_normal->v[2], clip_normal->v[3]); |
||
| 1358 | gShadow_clip_planes[i].clip->t.t.mat.m[3][0] = (1.0 - shadow_scaling_factor) * distance * clip_normal->v[0]; |
||
| 1359 | gShadow_clip_planes[i].clip->t.t.mat.m[3][1] = (1.0 - shadow_scaling_factor) * distance * clip_normal->v[1]; |
||
| 1360 | gShadow_clip_planes[i].clip->t.t.mat.m[3][2] = (1.0 - shadow_scaling_factor) * distance * clip_normal->v[2]; |
||
| 1361 | } |
||
| 1362 | |||
| 1363 | camera_ptr = (br_camera*)gCamera->type_data; |
||
| 1364 | DRMatrix34TApplyP(&pos_cam_space, &pCar->car_master_actor->t.t.euler.t, &gCamera_to_world); |
||
| 1365 | if (pos_cam_space.v[2] >= 36.0 || pos_cam_space.v[2] >= camera_ptr->yon_z) { |
||
| 1366 | camera_hither_fudge = 0.0; |
||
| 1367 | } else { |
||
| 1368 | camera_angle_additional_fudge = sqr(camera_ptr->yon_z - camera_ptr->hither_z); |
||
| 1369 | camera_hither_fudge = camera_angle_additional_fudge * (pos_cam_space.v[2] * 1.0) / ((pos_cam_space.v[2] - camera_ptr->yon_z) * camera_ptr->yon_z * 65536.0); |
||
| 1370 | if (camera_hither_fudge < 0.0002) { |
||
| 1371 | camera_hither_fudge = (br_scalar) 0.0002; // Pierre-Marie Baty -- added type cast |
||
| 1372 | } |
||
| 1373 | camera_ptr->hither_z += camera_hither_fudge; |
||
| 1374 | } |
||
| 1375 | if (f_num) { |
||
| 1376 | BrZbSceneRenderBegin(gUniverse_actor, gCamera, gRender_screen, gDepth_buffer); |
||
| 1377 | gShadow_model->vertices = verts; |
||
| 1378 | gShadow_model->faces = faces; |
||
| 1379 | gShadow_model->nfaces = f_num; |
||
| 1380 | gShadow_model->nvertices = 3 * f_num; |
||
| 1381 | gShadow_actor->render_style = BR_RSTYLE_FACES; |
||
| 1382 | BrModelAdd(gShadow_model); |
||
| 1383 | BrZbSceneRenderAdd(gShadow_actor); |
||
| 1384 | BrModelRemove(gShadow_model); |
||
| 1385 | if (pCar->shadow_intersection_flags) { |
||
| 1386 | oily_count = GetOilSpillCount(); |
||
| 1387 | for (i = 0; i < oily_count; ++i) { |
||
| 1388 | if (((1 << i) & pCar->shadow_intersection_flags) != 0) { |
||
| 1389 | GetOilSpillDetails(i, &oily_actor, &oily_size); |
||
| 1390 | if (oily_actor) { |
||
| 1391 | MungeIndexedOilsHeightAboveGround(i); |
||
| 1392 | BrZbSceneRenderAdd(oily_actor); |
||
| 1393 | } |
||
| 1394 | } |
||
| 1395 | } |
||
| 1396 | } |
||
| 1397 | BrZbSceneRenderEnd(); |
||
| 1398 | } |
||
| 1399 | camera_ptr->hither_z -= camera_hither_fudge; |
||
| 1400 | for (i = 0; i < f_num; i++) { |
||
| 1401 | if (gFancy_shadow) { |
||
| 1402 | material = gShadow_model->faces[i].material; |
||
| 1403 | if (material) { |
||
| 1404 | if (material->colour_map && (material->flags & BR_MATF_LIGHT) != 0) { |
||
| 1405 | material->flags &= ~(BR_MATF_LIGHT | BR_MATF_PRELIT | BR_MATF_SMOOTH); |
||
| 1406 | BrMaterialUpdate(material, BR_MATU_RENDERING); |
||
| 1407 | } |
||
| 1408 | } |
||
| 1409 | } |
||
| 1410 | } |
||
| 1411 | } |
||
| 1412 | gShadow_actor->render_style = BR_RSTYLE_NONE; |
||
| 1413 | for (i = 0; i < gShadow_clip_plane_count; i++) { |
||
| 1414 | BrClipPlaneDisable(gShadow_clip_planes[i].clip); |
||
| 1415 | } |
||
| 1416 | } |
||
| 1417 | |||
| 1418 | // IDA: void __usercall RenderShadows(br_actor *pWorld@<EAX>, tTrack_spec *pTrack_spec@<EDX>, br_actor *pCamera@<EBX>, br_matrix34 *pCamera_to_world_transform@<ECX>) |
||
| 1419 | void RenderShadows(br_actor* pWorld, tTrack_spec* pTrack_spec, br_actor* pCamera, br_matrix34* pCamera_to_world_transform) { |
||
| 1420 | int i; |
||
| 1421 | int cat; |
||
| 1422 | int car_count; |
||
| 1423 | tCar_spec* the_car; |
||
| 1424 | br_vector3 camera_to_car; |
||
| 1425 | br_scalar distance_factor; |
||
| 1426 | LOG_TRACE("(%p, %p, %p, %p)", pWorld, pTrack_spec, pCamera, pCamera_to_world_transform); |
||
| 1427 | |||
| 1428 | if (gShadow_level == eShadow_none) { |
||
| 1429 | return; |
||
| 1430 | } |
||
| 1431 | for (cat = eVehicle_self;; ++cat) { |
||
| 1432 | if (gShadow_level == eShadow_everyone) { |
||
| 1433 | if (cat > 4) { |
||
| 1434 | break; |
||
| 1435 | } |
||
| 1436 | } else { |
||
| 1437 | if (cat > (gShadow_level == eShadow_us_and_opponents ? 3 : 0)) { |
||
| 1438 | break; |
||
| 1439 | } |
||
| 1440 | } |
||
| 1441 | |||
| 1442 | if (cat == eVehicle_self) { |
||
| 1443 | car_count = 1; |
||
| 1444 | } else { |
||
| 1445 | car_count = GetCarCount(cat); |
||
| 1446 | } |
||
| 1447 | for (i = 0; i < car_count; i++) { |
||
| 1448 | if (cat == eVehicle_self) { |
||
| 1449 | the_car = &gProgram_state.current_car; |
||
| 1450 | } else { |
||
| 1451 | the_car = GetCarSpec(cat, i); |
||
| 1452 | } |
||
| 1453 | if (!the_car->active) { |
||
| 1454 | continue; |
||
| 1455 | } |
||
| 1456 | |||
| 1457 | BrVector3Sub(&camera_to_car, (br_vector3*)gCamera_to_world.m[3], &the_car->car_master_actor->t.t.translate.t); |
||
| 1458 | distance_factor = BrVector3LengthSquared(&camera_to_car); |
||
| 1459 | if (gAction_replay_mode || distance_factor <= SHADOW_MAX_RENDER_DISTANCE) { |
||
| 1460 | ProcessShadow(the_car, gUniverse_actor, &gProgram_state.track_spec, gCamera, &gCamera_to_world, distance_factor); |
||
| 1461 | } |
||
| 1462 | } |
||
| 1463 | } |
||
| 1464 | if (gFancy_shadow) { |
||
| 1465 | for (i = 0; i < gSaved_table_count; i++) { |
||
| 1466 | gSaved_shade_tables[i].original->height = gSaved_shade_tables[i].copy->height; |
||
| 1467 | gSaved_shade_tables[i].original->pixels = gSaved_shade_tables[i].copy->pixels; |
||
| 1468 | BrTableUpdate(gSaved_shade_tables[i].original, 0x7FFF); |
||
| 1469 | } |
||
| 1470 | } |
||
| 1471 | } |
||
| 1472 | |||
| 1473 | // IDA: void __usercall FlashyMapCheckpoint(int pIndex@<EAX>, tU32 pTime@<EDX>) |
||
| 1474 | void FlashyMapCheckpoint(int pIndex, tU32 pTime) { |
||
| 1475 | //tCheckpoint* cp; // Pierre-Marie Baty -- unused variable |
||
| 1476 | static tU32 last_flash; |
||
| 1477 | static int flash_state; |
||
| 1478 | LOG_TRACE("(%d, %d)", pIndex, pTime); |
||
| 1479 | |||
| 1480 | if (pIndex >= 0 && pIndex < gCurrent_race.check_point_count && gRace_file_version > 0) { |
||
| 1481 | if (Flash(300, &last_flash, &flash_state)) { |
||
| 1482 | switch (gGraf_data_index) { |
||
| 1483 | case 0: |
||
| 1484 | DimRectangle(gBack_screen, |
||
| 1485 | gCurrent_race.checkpoints[pIndex].map_left[0], |
||
| 1486 | gCurrent_race.checkpoints[pIndex].map_top[0], |
||
| 1487 | gCurrent_race.checkpoints[pIndex].map_right[0], |
||
| 1488 | gCurrent_race.checkpoints[pIndex].map_bottom[0], |
||
| 1489 | 0); |
||
| 1490 | break; |
||
| 1491 | case 1: |
||
| 1492 | DimRectangle(gBack_screen, |
||
| 1493 | 2 * gCurrent_race.checkpoints[pIndex].map_left[0], |
||
| 1494 | 2 * gCurrent_race.checkpoints[pIndex].map_top[0] + 40, |
||
| 1495 | 2 * gCurrent_race.checkpoints[pIndex].map_right[0], |
||
| 1496 | 2 * gCurrent_race.checkpoints[pIndex].map_bottom[0] + 40, |
||
| 1497 | 0); |
||
| 1498 | break; |
||
| 1499 | default: |
||
| 1500 | TELL_ME_IF_WE_PASS_THIS_WAY(); |
||
| 1501 | } |
||
| 1502 | } |
||
| 1503 | } |
||
| 1504 | } |
||
| 1505 | |||
| 1506 | // IDA: int __usercall ConditionallyFillWithSky@<EAX>(br_pixelmap *pPixelmap@<EAX>) |
||
| 1507 | int ConditionallyFillWithSky(br_pixelmap* pPixelmap) { |
||
| 1508 | int bgnd_col; |
||
| 1509 | LOG_TRACE("(%p)", pPixelmap); |
||
| 1510 | |||
| 1511 | if (gProgram_state.current_depth_effect.sky_texture != NULL && (gLast_camera_special_volume == NULL || gLast_camera_special_volume->sky_col < 0)) { |
||
| 1512 | return 0; |
||
| 1513 | } |
||
| 1514 | |||
| 1515 | if (gProgram_state.current_depth_effect.type == eDepth_effect_fog || gSwap_depth_effect_type == eDepth_effect_fog) { |
||
| 1516 | bgnd_col = 255; |
||
| 1517 | } else if (gProgram_state.current_depth_effect.type && gSwap_depth_effect_type) { |
||
| 1518 | if (gLast_camera_special_volume && gLast_camera_special_volume->sky_col >= 0) { |
||
| 1519 | bgnd_col = gLast_camera_special_volume->sky_col; |
||
| 1520 | } else { |
||
| 1521 | bgnd_col = 0; |
||
| 1522 | } |
||
| 1523 | } else { |
||
| 1524 | bgnd_col = 0; |
||
| 1525 | } |
||
| 1526 | BrPixelmapFill(pPixelmap, bgnd_col); |
||
| 1527 | return 1; |
||
| 1528 | } |
||
| 1529 | |||
| 1530 | // IDA: void __usercall RenderAFrame(int pDepth_mask_on@<EAX>) |
||
| 1531 | void RenderAFrame(int pDepth_mask_on) { |
||
| 1532 | int cat; |
||
| 1533 | int i; |
||
| 1534 | int car_count; |
||
| 1535 | int flags; |
||
| 1536 | int x_shift; |
||
| 1537 | int y_shift; |
||
| 1538 | int cockpit_on; |
||
| 1539 | int real_origin_x = 0; |
||
| 1540 | int real_origin_y = 0; |
||
| 1541 | int real_base_x = 0; |
||
| 1542 | int real_base_y = 0; |
||
| 1543 | int map_timer_x; |
||
| 1544 | int map_timer_width; |
||
| 1545 | int ped_type; |
||
| 1546 | char* old_pixels; |
||
| 1547 | br_matrix34 old_camera_matrix; |
||
| 1548 | br_matrix34 old_mirror_cam_matrix; |
||
| 1549 | tU32 the_time; |
||
| 1550 | br_vector3* car_pos; |
||
| 1551 | br_vector3 pos; |
||
| 1552 | char the_text[256]; |
||
| 1553 | tCar_spec* car; |
||
| 1554 | LOG_TRACE("(%d)", pDepth_mask_on); |
||
| 1555 | |||
| 1556 | gRender_screen->pixels = gBack_screen->pixels; |
||
| 1557 | the_time = GetTotalTime(); |
||
| 1558 | old_pixels = gRender_screen->pixels; |
||
| 1559 | cockpit_on = gProgram_state.cockpit_on && gProgram_state.cockpit_image_index >= 0 && !gMap_mode; |
||
| 1560 | gMirror_on__graphics = gProgram_state.mirror_on && cockpit_on && gProgram_state.which_view == eView_forward; |
||
| 1561 | if (gMap_mode) { |
||
| 1562 | real_origin_x = gBack_screen->origin_x; |
||
| 1563 | real_origin_y = gBack_screen->origin_y; |
||
| 1564 | real_base_x = gBack_screen->base_x; |
||
| 1565 | real_base_y = gBack_screen->base_y; |
||
| 1566 | gBack_screen->origin_x = 0; |
||
| 1567 | gBack_screen->origin_y = 0; |
||
| 1568 | gBack_screen->base_x = 0; |
||
| 1569 | gBack_screen->base_y = 0; |
||
| 1570 | if (gCurrent_race.map_image != NULL) { |
||
| 1571 | if (gReal_graf_data_index) { |
||
| 1572 | BrPixelmapRectangleFill(gBack_screen, 0, 0, 640, 40, 0); |
||
| 1573 | BrPixelmapRectangleFill(gBack_screen, 0, 440, 640, 40, 0); |
||
| 1574 | DRPixelmapDoubledCopy( |
||
| 1575 | gBack_screen, |
||
| 1576 | gCurrent_race.map_image, |
||
| 1577 | gCurrent_race.map_image->width, |
||
| 1578 | gCurrent_race.map_image->height, |
||
| 1579 | 0, |
||
| 1580 | 40); |
||
| 1581 | } else { |
||
| 1582 | DRPixelmapCopy(gBack_screen, gCurrent_race.map_image); |
||
| 1583 | } |
||
| 1584 | } |
||
| 1585 | DimRectangle( |
||
| 1586 | gBack_screen, |
||
| 1587 | gMap_render_x_i - gCurrent_graf_data->map_render_x_marg, |
||
| 1588 | gMap_render_y_i - gCurrent_graf_data->map_render_y_marg, |
||
| 1589 | gMap_render_x_i + gMap_render_width_i + gCurrent_graf_data->map_render_x_marg, |
||
| 1590 | gMap_render_y_i + gMap_render_height_i + gCurrent_graf_data->map_render_y_marg, |
||
| 1591 | 1); |
||
| 1592 | } |
||
| 1593 | if (!gAction_replay_mode) { |
||
| 1594 | CalculateWobblitude(the_time); |
||
| 1595 | } |
||
| 1596 | if (cockpit_on) { |
||
| 1597 | if (-gScreen_wobble_x > gX_offset) { |
||
| 1598 | x_shift = -gX_offset; |
||
| 1599 | } else if (gScreen_wobble_x + gX_offset + gRender_screen->width > gBack_screen->width) { |
||
| 1600 | x_shift = gBack_screen->width - gRender_screen->width - gX_offset; |
||
| 1601 | } else { |
||
| 1602 | x_shift = gScreen_wobble_x; |
||
| 1603 | } |
||
| 1604 | if (-gScreen_wobble_y > gY_offset) { |
||
| 1605 | y_shift = -gY_offset; |
||
| 1606 | } else if (gScreen_wobble_y + gY_offset + gRender_screen->height > gBack_screen->height) { |
||
| 1607 | y_shift = gBack_screen->height - gRender_screen->height - gY_offset; |
||
| 1608 | } else { |
||
| 1609 | y_shift = gScreen_wobble_y; |
||
| 1610 | } |
||
| 1611 | } else { |
||
| 1612 | x_shift = 0; |
||
| 1613 | y_shift = 0; |
||
| 1614 | } |
||
| 1615 | BrMatrix34Copy(&old_camera_matrix, &gCamera->t.t.mat); |
||
| 1616 | if (gMirror_on__graphics) { |
||
| 1617 | BrMatrix34Copy(&old_mirror_cam_matrix, &gRearview_camera->t.t.mat); |
||
| 1618 | } |
||
| 1619 | if (cockpit_on) { |
||
| 1620 | gSheer_mat.m[2][1] = y_shift / (float)gRender_screen->height; |
||
| 1621 | gSheer_mat.m[2][0] = -x_shift / (float)gRender_screen->width; |
||
| 1622 | BrMatrix34Pre(&gCamera->t.t.mat, &gSheer_mat); |
||
| 1623 | gCamera->t.t.translate.t.v[0] -= gScreen_wobble_x * 1.5f / gRender_screen->width / WORLD_SCALE; |
||
| 1624 | gCamera->t.t.translate.t.v[1] += gScreen_wobble_y * 1.5f / gRender_screen->width / WORLD_SCALE; |
||
| 1625 | } |
||
| 1626 | gRender_screen->pixels = (char*)gRender_screen->pixels + x_shift + y_shift * gRender_screen->row_bytes; |
||
| 1627 | CalculateConcussion(the_time); |
||
| 1628 | BrPixelmapRectangleFill(gDepth_buffer, 0, 0, gRender_screen->width, gRender_screen->height, 0xFFFFFFFF); |
||
| 1629 | if (gRender_indent && !gMap_mode) { |
||
| 1630 | BrPixelmapRectangleFill( |
||
| 1631 | gBack_screen, |
||
| 1632 | 0, |
||
| 1633 | 0, |
||
| 1634 | gGraf_specs[gGraf_spec_index].total_width, |
||
| 1635 | gProgram_state.current_render_top, |
||
| 1636 | 0); |
||
| 1637 | BrPixelmapRectangleFill( |
||
| 1638 | gBack_screen, |
||
| 1639 | 0, |
||
| 1640 | gProgram_state.current_render_bottom, |
||
| 1641 | gGraf_specs[gGraf_spec_index].total_width, |
||
| 1642 | gGraf_specs[gGraf_spec_index].total_height - gProgram_state.current_render_bottom, |
||
| 1643 | 0); |
||
| 1644 | BrPixelmapRectangleFill( |
||
| 1645 | gBack_screen, |
||
| 1646 | 0, |
||
| 1647 | gProgram_state.current_render_top, |
||
| 1648 | gProgram_state.current_render_left, |
||
| 1649 | gProgram_state.current_render_bottom - gProgram_state.current_render_top, |
||
| 1650 | 0); |
||
| 1651 | BrPixelmapRectangleFill( |
||
| 1652 | gBack_screen, |
||
| 1653 | gProgram_state.current_render_right, |
||
| 1654 | gProgram_state.current_render_top, |
||
| 1655 | gGraf_specs[gGraf_spec_index].total_width - gProgram_state.current_render_right, |
||
| 1656 | gProgram_state.current_render_bottom - gProgram_state.current_render_top, |
||
| 1657 | 0); |
||
| 1658 | } |
||
| 1659 | gRendering_mirror = 0; |
||
| 1660 | DoSpecialCameraEffect(gCamera, &gCamera_to_world); |
||
| 1661 | if (!ConditionallyFillWithSky(gRender_screen) |
||
| 1662 | && !gProgram_state.cockpit_on |
||
| 1663 | && !(gAction_replay_camera_mode && gAction_replay_mode)) { |
||
| 1664 | ExternalSky(gRender_screen, gDepth_buffer, gCamera, &gCamera_to_world); |
||
| 1665 | } |
||
| 1666 | #if !defined(DETHRACE_FIX_BUGS) |
||
| 1667 | // in map mode, the scene is rendered 3 times. We have no idea why. |
||
| 1668 | for (i = 0; i < (gMap_mode ? 3 : 1); i++) |
||
| 1669 | #endif |
||
| 1670 | { |
||
| 1671 | RenderShadows(gUniverse_actor, &gProgram_state.track_spec, gCamera, &gCamera_to_world); |
||
| 1672 | BrZbSceneRenderBegin(gUniverse_actor, gCamera, gRender_screen, gDepth_buffer); |
||
| 1673 | ProcessNonTrackActors(gRender_screen, gDepth_buffer, gCamera, &gCamera_to_world, &old_camera_matrix); |
||
| 1674 | ProcessTrack(gUniverse_actor, &gProgram_state.track_spec, gCamera, &gCamera_to_world, 0); |
||
| 1675 | RenderLollipops(); |
||
| 1676 | |||
| 20 | pmbaty | 1677 | // dethrace: must flush gpu buffer before rendering depth effect into framebuffer |
| 1678 | gHarness_platform.Renderer_FlushBuffers(); |
||
| 1 | pmbaty | 1679 | DepthEffectSky(gRender_screen, gDepth_buffer, gCamera, &gCamera_to_world); |
| 1680 | DepthEffect(gRender_screen, gDepth_buffer, gCamera, &gCamera_to_world); |
||
| 1681 | if (!gAusterity_mode) { |
||
| 1682 | ProcessTrack(gUniverse_actor, &gProgram_state.track_spec, gCamera, &gCamera_to_world, 1); |
||
| 1683 | } |
||
| 1684 | RenderSplashes(); |
||
| 20 | pmbaty | 1685 | // dethrace: must flush gpu buffer before rendering smoke into framebuffer |
| 1686 | gHarness_platform.Renderer_FlushBuffers(); |
||
| 1 | pmbaty | 1687 | RenderSmoke(gRender_screen, gDepth_buffer, gCamera, &gCamera_to_world, gFrame_period); |
| 1688 | RenderSparks(gRender_screen, gDepth_buffer, gCamera, &gCamera_to_world, gFrame_period); |
||
| 1689 | RenderProximityRays(gRender_screen, gDepth_buffer, gCamera, &gCamera_to_world, gFrame_period); |
||
| 1690 | BrZbSceneRenderEnd(); |
||
| 1691 | } |
||
| 1692 | BrMatrix34Copy(&gCamera->t.t.mat, &old_camera_matrix); |
||
| 1693 | if (gMirror_on__graphics) { |
||
| 20 | pmbaty | 1694 | LOG_WARN_ONCE("rearview mirror not implemented"); |
| 1695 | // BrPixelmapFill(gRearview_depth_buffer, 0xFFFFFFFF); |
||
| 1696 | // gRendering_mirror = 1; |
||
| 1697 | // DoSpecialCameraEffect(gRearview_camera, &gRearview_camera_to_world); |
||
| 1698 | // ConditionallyFillWithSky(gRearview_screen); |
||
| 1699 | // BrZbSceneRenderBegin(gUniverse_actor, gRearview_camera, gRearview_screen, gRearview_depth_buffer); |
||
| 1700 | // ProcessNonTrackActors( |
||
| 1701 | // gRearview_screen, |
||
| 1702 | // gRearview_depth_buffer, |
||
| 1703 | // gRearview_camera, |
||
| 1704 | // &gRearview_camera_to_world, |
||
| 1705 | // &old_mirror_cam_matrix); |
||
| 1706 | // ProcessTrack(gUniverse_actor, &gProgram_state.track_spec, gRearview_camera, &gRearview_camera_to_world, 0); |
||
| 1707 | // RenderLollipops(); |
||
| 1708 | // DepthEffectSky(gRearview_screen, gRearview_depth_buffer, gRearview_camera, &gRearview_camera_to_world); |
||
| 1709 | // DepthEffect(gRearview_screen, gRearview_depth_buffer, gRearview_camera, &gRearview_camera_to_world); |
||
| 1710 | // if (!gAusterity_mode) { |
||
| 1711 | // ProcessTrack(gUniverse_actor, &gProgram_state.track_spec, gRearview_camera, &gRearview_camera_to_world, 1); |
||
| 1712 | // } |
||
| 1713 | // RenderSplashes(); |
||
| 1714 | // BrZbSceneRenderEnd(); |
||
| 1715 | // BrMatrix34Copy(&gRearview_camera->t.t.mat, &old_mirror_cam_matrix); |
||
| 1716 | // gRendering_mirror = 0; |
||
| 1 | pmbaty | 1717 | } |
| 1718 | if (gMap_mode) { |
||
| 1719 | if (gNet_mode == eNet_mode_none) { |
||
| 1720 | GetTimerString(the_text, 0); |
||
| 1721 | map_timer_width = DRTextWidth(&gFonts[2], the_text); |
||
| 1722 | map_timer_x = gCurrent_graf_data->map_timer_text_x - map_timer_width; |
||
| 1723 | BrPixelmapRectangleFill( |
||
| 1724 | gBack_screen, |
||
| 1725 | map_timer_x - gCurrent_graf_data->map_timer_border_x, |
||
| 1726 | gCurrent_graf_data->map_timer_text_y - gCurrent_graf_data->map_timer_border_y, |
||
| 1727 | map_timer_width + 2 * gCurrent_graf_data->map_timer_border_x, |
||
| 11 | pmbaty | 1728 | gFonts[kFont_BLUEHEAD].height + 2 * gCurrent_graf_data->map_timer_border_y, |
| 1 | pmbaty | 1729 | 0); |
| 1730 | TransDRPixelmapText( |
||
| 1731 | gBack_screen, |
||
| 1732 | map_timer_x, |
||
| 1733 | gCurrent_graf_data->map_timer_text_y, |
||
| 11 | pmbaty | 1734 | &gFonts[kFont_BLUEHEAD], |
| 1 | pmbaty | 1735 | the_text, |
| 1736 | gBack_screen->width); |
||
| 1737 | } |
||
| 1738 | the_time = PDGetTotalTime(); |
||
| 1739 | if (gNet_mode != eNet_mode_none) { |
||
| 1740 | if (gCurrent_net_game->type == eNet_game_type_checkpoint) { |
||
| 1741 | flags = gNet_players[gThis_net_player_index].score; |
||
| 1742 | for (i = 0; gCurrent_race.check_point_count > i; ++i) { |
||
| 1743 | if ((flags & 1) != 0) { |
||
| 1744 | FlashyMapCheckpoint(i, the_time); |
||
| 1745 | } |
||
| 1746 | flags >>= 1; |
||
| 1747 | } |
||
| 1748 | } else if (gCurrent_net_game->type == eNet_game_type_sudden_death |
||
| 1749 | && gNet_players[gThis_net_player_index].score >= 0) { |
||
| 1750 | FlashyMapCheckpoint( |
||
| 1751 | gNet_players[gThis_net_player_index].score % gCurrent_race.check_point_count, |
||
| 1752 | the_time); |
||
| 1753 | } |
||
| 1754 | } else { |
||
| 1755 | FlashyMapCheckpoint(gCheckpoint - 1, the_time); |
||
| 1756 | } |
||
| 1757 | if (gShow_peds_on_map || (gNet_mode != eNet_mode_none && gCurrent_net_game->options.show_powerups_on_map)) { |
||
| 1758 | for (i = 0; i < GetPedCount(); i++) { |
||
| 1759 | ped_type = GetPedPosition(i, &pos); |
||
| 1760 | if (ped_type > 0 && gShow_peds_on_map) { |
||
| 1761 | DrawMapSmallBlip(the_time, &pos, 52); |
||
| 1762 | } else if (ped_type < 0 && (gNet_mode != eNet_mode_none && gCurrent_net_game->options.show_powerups_on_map)) { |
||
| 1763 | DrawMapSmallBlip(the_time, &pos, 4); |
||
| 1764 | } |
||
| 1765 | } |
||
| 1766 | } |
||
| 1767 | if (gShow_opponents) { |
||
| 1768 | cat = eVehicle_opponent; |
||
| 1769 | } else { |
||
| 1770 | cat = eVehicle_self; |
||
| 1771 | } |
||
| 1772 | while (cat >= eVehicle_self) { |
||
| 1773 | if (cat) { |
||
| 1774 | car_count = GetCarCount(cat); |
||
| 1775 | } else { |
||
| 1776 | car_count = 1; |
||
| 1777 | } |
||
| 1778 | for (i = 0; i < car_count; i++) { |
||
| 1779 | if (cat) { |
||
| 1780 | car = GetCarSpec(cat, i); |
||
| 1781 | } else { |
||
| 1782 | car = &gProgram_state.current_car; |
||
| 1783 | } |
||
| 1784 | if (gNet_mode == eNet_mode_none || (!car->knackered && !NetPlayerFromCar(car)->wasted)) { |
||
| 1785 | if (cat) { |
||
| 1786 | car_pos = &GetCarSpec(cat, i)->car_master_actor->t.t.euler.t; |
||
| 1787 | } else { |
||
| 1788 | car_pos = &gSelf->t.t.euler.t; |
||
| 1789 | } |
||
| 1790 | if (gNet_mode) { |
||
| 1791 | DrawMapBlip( |
||
| 1792 | car, |
||
| 1793 | the_time, |
||
| 1794 | &car->car_master_actor->t.t.mat, |
||
| 1795 | car_pos, |
||
| 1796 | car->shrapnel_material[0]->index_range + car->shrapnel_material[0]->index_base - 1); |
||
| 1797 | } else if (car->knackered) { |
||
| 1798 | DrawMapBlip(car, the_time, &car->car_master_actor->t.t.mat, car_pos, 0); |
||
| 1799 | } else { |
||
| 1800 | DrawMapBlip(car, the_time, &car->car_master_actor->t.t.mat, car_pos, gMap_colours[cat]); |
||
| 1801 | } |
||
| 1802 | } |
||
| 1803 | } |
||
| 1804 | cat--; |
||
| 1805 | } |
||
| 1806 | gBack_screen->origin_x = real_origin_x; |
||
| 1807 | gBack_screen->origin_y = real_origin_y; |
||
| 1808 | gBack_screen->base_x = real_base_x; |
||
| 1809 | gBack_screen->base_y = real_base_y; |
||
| 1810 | } else { |
||
| 1811 | if (cockpit_on) { |
||
| 1812 | CopyStripImage( |
||
| 1813 | gBack_screen, |
||
| 1814 | -gCurrent_graf_data->cock_margin_x, |
||
| 1815 | gScreen_wobble_x, |
||
| 1816 | -gCurrent_graf_data->cock_margin_y, |
||
| 1817 | gScreen_wobble_y, |
||
| 1818 | gProgram_state.current_car.cockpit_images[gProgram_state.cockpit_image_index], |
||
| 1819 | 0, |
||
| 1820 | 0, |
||
| 1821 | gCurrent_graf_data->total_cock_width, |
||
| 1822 | gCurrent_graf_data->total_cock_height); |
||
| 1823 | if (gMirror_on__graphics) { |
||
| 1824 | BrPixelmapRectangleCopy( |
||
| 1825 | gBack_screen, |
||
| 1826 | gScreen_wobble_x + gProgram_state.current_car.mirror_left, |
||
| 1827 | gScreen_wobble_y + gProgram_state.current_car.mirror_top, |
||
| 1828 | gRearview_screen, |
||
| 1829 | -gRearview_screen->origin_x, |
||
| 1830 | -gRearview_screen->origin_y, |
||
| 1831 | gProgram_state.current_car.mirror_right - gProgram_state.current_car.mirror_left, |
||
| 1832 | gProgram_state.current_car.mirror_bottom - gProgram_state.current_car.mirror_top); |
||
| 1833 | } |
||
| 1834 | } |
||
| 1835 | DimAFewBits(); |
||
| 1836 | DoDamageScreen(the_time); |
||
| 1837 | if (!gAction_replay_mode || gAR_fudge_headups) { |
||
| 1838 | DoPratcam(the_time); |
||
| 1839 | DoHeadups(the_time); |
||
| 1840 | } |
||
| 1841 | DoInstruments(the_time); |
||
| 1842 | DoSteeringWheel(the_time); |
||
| 1843 | if (!gAction_replay_mode || gAR_fudge_headups) { |
||
| 1844 | DrawPowerups(the_time); |
||
| 1845 | } |
||
| 1846 | } |
||
| 1847 | if (gNet_mode != eNet_mode_none) { |
||
| 1848 | DisplayUserMessage(); |
||
| 1849 | } |
||
| 1850 | if (gAction_replay_mode && !gAR_fudge_headups) { |
||
| 1851 | DoActionReplayHeadups(); |
||
| 1852 | } |
||
| 1853 | if (gAction_replay_mode) { |
||
| 1854 | SynchronizeActionReplay(); |
||
| 1855 | } else { |
||
| 1856 | PipeFrameFinish(); |
||
| 1857 | } |
||
| 1858 | gRender_screen->pixels = old_pixels; |
||
| 1859 | if (!gPalette_fade_time || GetRaceTime() > gPalette_fade_time + 500) { |
||
| 1860 | PDScreenBufferSwap(0); |
||
| 1861 | } |
||
| 1862 | if (gAction_replay_mode) { |
||
| 1863 | DoActionReplayPostSwap(); |
||
| 1864 | } |
||
| 1865 | } |
||
| 1866 | |||
| 1867 | // IDA: void __cdecl InitPaletteAnimate() |
||
| 1868 | void InitPaletteAnimate(void) { |
||
| 1869 | LOG_TRACE("()"); |
||
| 1870 | |||
| 1871 | gLast_palette_change = 0; |
||
| 1872 | gPalette_index = 0; |
||
| 1873 | } |
||
| 1874 | |||
| 1875 | // IDA: void __cdecl RevertPalette() |
||
| 1876 | void RevertPalette(void) { |
||
| 1877 | |||
| 1878 | memcpy(gRender_palette->pixels, gOrig_render_palette->pixels, 0x400u); |
||
| 1879 | DRSetPalette3(gRender_palette, 1); |
||
| 1880 | } |
||
| 1881 | |||
| 1882 | // IDA: void __cdecl MungePalette() |
||
| 1883 | void MungePalette(void) { |
||
| 1884 | //tU8* p; // Pierre-Marie Baty -- unused variable |
||
| 1885 | //tU8* q; // Pierre-Marie Baty -- unused variable |
||
| 1886 | //int i; // Pierre-Marie Baty -- unused variable |
||
| 1887 | //float damage; // Pierre-Marie Baty -- unused variable |
||
| 1888 | //float throb_start; // Pierre-Marie Baty -- unused variable |
||
| 1889 | //float throb_end; // Pierre-Marie Baty -- unused variable |
||
| 1890 | //float throb_amount; // Pierre-Marie Baty -- unused variable |
||
| 1891 | //float throb_amount_dash; // Pierre-Marie Baty -- unused variable |
||
| 1892 | //float omega; // Pierre-Marie Baty -- unused variable |
||
| 1893 | //tU32 period; // Pierre-Marie Baty -- unused variable |
||
| 1894 | //tU32 the_time; // Pierre-Marie Baty -- unused variable |
||
| 1895 | //static int palette_spammed; // Pierre-Marie Baty -- unused variable |
||
| 1896 | //static float last_omega; // Pierre-Marie Baty -- unused variable |
||
| 1897 | //static tU32 next_repair_time; // Pierre-Marie Baty -- unused variable |
||
| 1898 | //static tU32 last_sound; // Pierre-Marie Baty -- unused variable |
||
| 1899 | LOG_TRACE("()"); |
||
| 1900 | NOT_IMPLEMENTED(); |
||
| 1901 | } |
||
| 1902 | |||
| 1903 | // IDA: void __cdecl ResetPalette() |
||
| 1904 | void ResetPalette(void) { |
||
| 1905 | LOG_TRACE("()"); |
||
| 1906 | |||
| 1907 | InitPaletteAnimate(); |
||
| 1908 | DRSetPalette(gRender_palette); |
||
| 1909 | } |
||
| 1910 | |||
| 1911 | // IDA: void __usercall Darken(tU8 *pPtr@<EAX>, unsigned int pDarken_amount@<EDX>) |
||
| 1912 | void Darken(tU8* pPtr, unsigned int pDarken_amount) { |
||
| 1913 | //unsigned int value; // Pierre-Marie Baty -- unused variable |
||
| 1914 | LOG_TRACE10("(%p, %d)", pPtr, pDarken_amount); |
||
| 1915 | |||
| 1916 | *pPtr = (pDarken_amount * *pPtr) / 256; |
||
| 1917 | } |
||
| 1918 | |||
| 1919 | // IDA: void __usercall SetFadedPalette(int pDegree@<EAX>) |
||
| 1920 | void SetFadedPalette(int pDegree) { |
||
| 1921 | int j; |
||
| 1922 | //br_pixelmap* the_palette; // Pierre-Marie Baty -- unused variable |
||
| 1923 | //char* the_pixels; // Pierre-Marie Baty -- unused variable |
||
| 1924 | LOG_TRACE10("(%d)", pDegree); |
||
| 1925 | |||
| 1926 | memcpy(gScratch_pixels, gCurrent_palette->pixels, 0x400u); |
||
| 1927 | for (j = 0; j < 256; j++) { |
||
| 1928 | Darken((tU8*)&gScratch_pixels[4 * j], pDegree); |
||
| 1929 | Darken((tU8*)&gScratch_pixels[4 * j + 1], pDegree); |
||
| 1930 | Darken((tU8*)&gScratch_pixels[4 * j + 2], pDegree); |
||
| 1931 | Darken((tU8*)&gScratch_pixels[4 * j + 3], pDegree); |
||
| 1932 | } |
||
| 1933 | DRSetPalette2(gScratch_palette, 0); |
||
| 1934 | } |
||
| 1935 | |||
| 1936 | // IDA: void __cdecl FadePaletteDown() |
||
| 1937 | void FadePaletteDown(void) { |
||
| 1938 | int i; |
||
| 1939 | int start_time; |
||
| 1940 | int the_time; |
||
| 1941 | LOG_TRACE("()"); |
||
| 1942 | |||
| 1943 | if (!gFaded_palette) { |
||
| 1944 | gFaded_palette = 1; |
||
| 1945 | MungeEngineNoise(); |
||
| 1946 | gFaded_palette = 0; |
||
| 1947 | start_time = PDGetTotalTime(); |
||
| 1948 | while (1) { |
||
| 1949 | the_time = PDGetTotalTime() - start_time; |
||
| 1950 | if (the_time >= 500) { |
||
| 1951 | break; |
||
| 1952 | } |
||
| 1953 | i = 256 - ((the_time * 256) / 500); |
||
| 1954 | SetFadedPalette(i); |
||
| 1955 | } |
||
| 1956 | SetFadedPalette(0); |
||
| 1957 | gFaded_palette = 1; |
||
| 1958 | } |
||
| 1959 | } |
||
| 1960 | |||
| 1961 | // IDA: void __cdecl FadePaletteUp() |
||
| 1962 | void FadePaletteUp(void) { |
||
| 1963 | int i; |
||
| 1964 | int start_time; |
||
| 1965 | int the_time; |
||
| 1966 | LOG_TRACE("()"); |
||
| 1967 | |||
| 1968 | if (gFaded_palette) { |
||
| 1969 | gFaded_palette = 0; |
||
| 1970 | start_time = PDGetTotalTime(); |
||
| 1971 | while (1) { |
||
| 1972 | the_time = PDGetTotalTime() - start_time; |
||
| 1973 | if (the_time >= 500) { |
||
| 1974 | break; |
||
| 1975 | } |
||
| 1976 | i = (the_time * 256) / 500; |
||
| 1977 | SetFadedPalette(i); |
||
| 1978 | } |
||
| 1979 | DRSetPalette(gCurrent_palette); |
||
| 1980 | } |
||
| 1981 | } |
||
| 1982 | |||
| 1983 | // IDA: void __cdecl KillSplashScreen() |
||
| 1984 | void KillSplashScreen(void) { |
||
| 1985 | |||
| 1986 | if (gCurrent_splash != NULL) { |
||
| 1987 | BrMapRemove(gCurrent_splash); |
||
| 1988 | BrPixelmapFree(gCurrent_splash); |
||
| 1989 | gCurrent_splash = NULL; |
||
| 1990 | FadePaletteDown(); |
||
| 1991 | ClearEntireScreen(); |
||
| 1992 | } |
||
| 1993 | } |
||
| 1994 | |||
| 1995 | // IDA: void __cdecl EnsureRenderPalette() |
||
| 1996 | void EnsureRenderPalette(void) { |
||
| 1997 | LOG_TRACE("()"); |
||
| 1998 | |||
| 1999 | if (gPalette_munged) { |
||
| 2000 | ResetPalette(); |
||
| 2001 | gPalette_munged = 0; |
||
| 2002 | } |
||
| 2003 | } |
||
| 2004 | |||
| 2005 | // IDA: void __usercall SplashScreenWith(char *pPixmap_name@<EAX>) |
||
| 2006 | void SplashScreenWith(char* pPixmap_name) { |
||
| 2007 | br_pixelmap* the_map; |
||
| 2008 | LOG_TRACE("(\"%s\")", pPixmap_name); |
||
| 2009 | |||
| 2010 | the_map = BrMapFind(pPixmap_name); |
||
| 2011 | if (gCurrent_splash == NULL || the_map != gCurrent_splash) { |
||
| 2012 | FadePaletteDown(); |
||
| 2013 | EnsureRenderPalette(); |
||
| 2014 | |||
| 2015 | if (gCurrent_splash != NULL) { |
||
| 2016 | KillSplashScreen(); |
||
| 2017 | } |
||
| 2018 | gCurrent_splash = the_map; |
||
| 2019 | if (the_map == NULL) { |
||
| 2020 | the_map = LoadPixelmap(pPixmap_name); |
||
| 2021 | gCurrent_splash = the_map; |
||
| 2022 | if (the_map != NULL) { |
||
| 2023 | BrMapAdd(the_map); |
||
| 2024 | } |
||
| 2025 | } |
||
| 2026 | if (gCurrent_splash != NULL) { |
||
| 2027 | BrPixelmapRectangleCopy( |
||
| 2028 | gBack_screen, |
||
| 2029 | 0, |
||
| 2030 | 0, |
||
| 2031 | gCurrent_splash, |
||
| 2032 | 0, |
||
| 2033 | 0, |
||
| 2034 | gCurrent_splash->width, |
||
| 2035 | gCurrent_splash->height); |
||
| 2036 | PDScreenBufferSwap(0); |
||
| 2037 | if (gFaded_palette) { |
||
| 2038 | FadePaletteUp(); |
||
| 2039 | } |
||
| 2040 | } |
||
| 2041 | } |
||
| 2042 | } |
||
| 2043 | |||
| 2044 | // IDA: void __cdecl EnsurePaletteUp() |
||
| 2045 | void EnsurePaletteUp(void) { |
||
| 2046 | |||
| 2047 | if (gFaded_palette) { |
||
| 2048 | FadePaletteUp(); |
||
| 2049 | } |
||
| 2050 | } |
||
| 2051 | |||
| 2052 | // IDA: br_uint_32 __cdecl AmbientificateMaterial(br_material *pMat, void *pArg) |
||
| 2053 | br_uint_32 AmbientificateMaterial(br_material* pMat, void* pArg) { |
||
| 2054 | float a; |
||
| 2055 | |||
| 2056 | a = pMat->ka + *(br_scalar*)pArg; |
||
| 2057 | if (a < 0.f) { |
||
| 2058 | a = 0.f; |
||
| 2059 | } else if (a > 0.99f) { |
||
| 2060 | a = 0.99f; |
||
| 2061 | } |
||
| 2062 | pMat->ka = a; |
||
| 2063 | return 0; |
||
| 2064 | } |
||
| 2065 | |||
| 2066 | // IDA: void __cdecl ChangeAmbience(br_scalar pDelta) |
||
| 2067 | void ChangeAmbience(br_scalar pDelta) { |
||
| 2068 | LOG_TRACE("(%f)", pDelta); |
||
| 2069 | |||
| 2070 | BrMaterialEnum("*", AmbientificateMaterial, &pDelta); |
||
| 2071 | } |
||
| 2072 | |||
| 2073 | // IDA: void __cdecl InitAmbience() |
||
| 2074 | void InitAmbience(void) { |
||
| 2075 | LOG_TRACE("()"); |
||
| 2076 | |||
| 2077 | gCurrent_ambience = gAmbient_adjustment; |
||
| 2078 | ChangeAmbience(gAmbient_adjustment); |
||
| 2079 | } |
||
| 2080 | |||
| 2081 | // IDA: void __usercall DRPixelmapRectangleMaskedCopy(br_pixelmap *pDest@<EAX>, br_int_16 pDest_x@<EDX>, br_int_16 pDest_y@<EBX>, br_pixelmap *pSource@<ECX>, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight) |
||
| 2082 | void DRPixelmapRectangleMaskedCopy(br_pixelmap* pDest, br_int_16 pDest_x, br_int_16 pDest_y, br_pixelmap* pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight) { |
||
| 2083 | int y_count; |
||
| 2084 | int x_count; |
||
| 2085 | int dest_row_wrap; |
||
| 2086 | int source_row_wrap; |
||
| 2087 | //int x_delta; // Pierre-Marie Baty -- unused variable |
||
| 2088 | tU8 the_byte; |
||
| 2089 | tU8* source_ptr; |
||
| 2090 | tU8* dest_ptr; |
||
| 2091 | tU8* conv_table; |
||
| 2092 | LOG_TRACE("(%p, %d, %d, %p, %d, %d, %d, %d)", pDest, pDest_x, pDest_y, pSource, pSource_x, pSource_y, pWidth, pHeight); |
||
| 2093 | |||
| 2094 | source_ptr = (tU8*)pSource->pixels + (pSource->row_bytes * pSource_y + pSource_x); |
||
| 2095 | dest_ptr = (tU8*)pDest->pixels + (pDest->row_bytes * pDest_y + pDest_x); |
||
| 2096 | source_row_wrap = pSource->row_bytes - pWidth; |
||
| 2097 | dest_row_wrap = pDest->row_bytes - pWidth; |
||
| 2098 | |||
| 2099 | if (pDest_y < 0) { |
||
| 2100 | pHeight += pDest_y; |
||
| 2101 | if (pHeight <= 0) { |
||
| 2102 | return; |
||
| 2103 | } |
||
| 2104 | source_ptr -= pDest_y * pSource->row_bytes; |
||
| 2105 | dest_ptr -= pDest_y * pDest->row_bytes; |
||
| 2106 | pDest_y = 0; |
||
| 2107 | } |
||
| 2108 | if (pDest_y >= pDest->height) { |
||
| 2109 | return; |
||
| 2110 | } |
||
| 2111 | if (pDest_y + pHeight > pDest->height) { |
||
| 2112 | pHeight = pDest->height - pDest_y; |
||
| 2113 | } |
||
| 2114 | if (pDest_x < 0) { |
||
| 2115 | pWidth += pDest_x; |
||
| 2116 | if (pWidth <= 0) { |
||
| 2117 | return; |
||
| 2118 | } |
||
| 2119 | source_ptr -= pDest_x; |
||
| 2120 | dest_ptr -= pDest_x; |
||
| 2121 | source_row_wrap -= pDest_x; |
||
| 2122 | dest_row_wrap -= pDest_x; |
||
| 2123 | pDest_x = 0; |
||
| 2124 | } |
||
| 2125 | if (pDest_x >= pDest->width) { |
||
| 2126 | return; |
||
| 2127 | } |
||
| 2128 | if (pDest_x + pWidth > pDest->width) { |
||
| 2129 | source_row_wrap += pDest_x + pWidth - pDest->width; |
||
| 2130 | dest_row_wrap += pDest_x + pWidth - pDest->width; |
||
| 2131 | pWidth = pDest->width - pDest_x; |
||
| 2132 | } |
||
| 2133 | // LOG_DEBUG("2 (src->width: %d, src->height: %d, pDest_x: %d, pDest_y: %d, pSource_x: %d, pSource_y: %d, pWidth: %d, pHeight: %d)", pSource->width, pSource->height, pDest_x, pDest_y, pSource_x, pSource_y, pWidth, pHeight); |
||
| 2134 | if (gCurrent_conversion_table != NULL) { |
||
| 2135 | conv_table = gCurrent_conversion_table->pixels; |
||
| 2136 | for (y_count = 0; y_count < pHeight; y_count++) { |
||
| 2137 | for (x_count = 0; x_count < pWidth; x_count++) { |
||
| 2138 | the_byte = *source_ptr; |
||
| 2139 | if (the_byte != 0) { |
||
| 2140 | *dest_ptr = conv_table[the_byte]; |
||
| 2141 | } |
||
| 2142 | source_ptr++; |
||
| 2143 | dest_ptr++; |
||
| 2144 | } |
||
| 2145 | source_ptr += source_row_wrap; |
||
| 2146 | dest_ptr += dest_row_wrap; |
||
| 2147 | } |
||
| 2148 | } else { |
||
| 2149 | for (y_count = 0; y_count < pHeight; y_count++) { |
||
| 2150 | for (x_count = 0; x_count < pWidth; x_count++) { |
||
| 2151 | the_byte = *source_ptr; |
||
| 2152 | if (the_byte != 0) { |
||
| 2153 | *dest_ptr = the_byte; |
||
| 2154 | } |
||
| 2155 | source_ptr++; |
||
| 2156 | dest_ptr++; |
||
| 2157 | } |
||
| 2158 | source_ptr += source_row_wrap; |
||
| 2159 | dest_ptr += dest_row_wrap; |
||
| 2160 | } |
||
| 2161 | } |
||
| 2162 | } |
||
| 2163 | |||
| 2164 | // IDA: void __usercall DRMaskedStamp(br_int_16 pDest_x@<EAX>, br_int_16 pDest_y@<EDX>, br_pixelmap *pSource@<EBX>) |
||
| 2165 | void DRMaskedStamp(br_int_16 pDest_x, br_int_16 pDest_y, br_pixelmap* pSource) { |
||
| 2166 | LOG_TRACE("(%d, %d, %p)", pDest_x, pDest_y, pSource); |
||
| 2167 | |||
| 2168 | DRPixelmapRectangleMaskedCopy(gBack_screen, |
||
| 2169 | pDest_x, |
||
| 2170 | pDest_y, |
||
| 2171 | pSource, |
||
| 2172 | 0, |
||
| 2173 | 0, |
||
| 2174 | pSource->width, |
||
| 2175 | pSource->height); |
||
| 2176 | } |
||
| 2177 | |||
| 2178 | // IDA: void __usercall DRPixelmapRectangleOnscreenCopy(br_pixelmap *pDest@<EAX>, br_int_16 pDest_x@<EDX>, br_int_16 pDest_y@<EBX>, br_pixelmap *pSource@<ECX>, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight) |
||
| 2179 | void DRPixelmapRectangleOnscreenCopy(br_pixelmap* pDest, br_int_16 pDest_x, br_int_16 pDest_y, br_pixelmap* pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight) { |
||
| 2180 | int y_count; |
||
| 2181 | int x_count; |
||
| 2182 | int dest_row_wrap; |
||
| 2183 | int source_row_wrap; |
||
| 2184 | //int x_delta; // Pierre-Marie Baty -- unused variable |
||
| 2185 | tU8 the_byte; |
||
| 2186 | tU8* source_ptr; |
||
| 2187 | tU8* dest_ptr; |
||
| 2188 | //tU8* conv_table; // Pierre-Marie Baty -- unused variable |
||
| 2189 | // LOG_TRACE("(%p, %d, %d, %p, %d, %d, %d, %d)", pDest, pDest_x, pDest_y, pSource, pSource_x, pSource_y, pWidth, pHeight); |
||
| 2190 | |||
| 2191 | source_row_wrap = pSource->row_bytes - pWidth; |
||
| 2192 | dest_row_wrap = pDest->row_bytes - pWidth; |
||
| 2193 | dest_ptr = (tU8*)pDest->pixels + (pDest->row_bytes * pDest_y + pDest_x); |
||
| 2194 | source_ptr = (tU8*)pSource->pixels + (pSource->row_bytes * pSource_y + pSource_x); |
||
| 2195 | |||
| 2196 | for (y_count = 0; y_count < pHeight; y_count++) { |
||
| 2197 | for (x_count = 0; x_count < pWidth; x_count++) { |
||
| 2198 | the_byte = *source_ptr; |
||
| 2199 | if (the_byte) { |
||
| 2200 | *dest_ptr = the_byte; |
||
| 2201 | } |
||
| 2202 | source_ptr++; |
||
| 2203 | dest_ptr++; |
||
| 2204 | } |
||
| 2205 | source_ptr += source_row_wrap; |
||
| 2206 | dest_ptr += dest_row_wrap; |
||
| 2207 | } |
||
| 2208 | } |
||
| 2209 | |||
| 2210 | // IDA: void __usercall DRPixelmapRectangleShearedCopy(br_pixelmap *pDest@<EAX>, br_int_16 pDest_x@<EDX>, br_int_16 pDest_y@<EBX>, br_pixelmap *pSource@<ECX>, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight, tX1616 pShear) |
||
| 2211 | void DRPixelmapRectangleShearedCopy(br_pixelmap* pDest, br_int_16 pDest_x, br_int_16 pDest_y, br_pixelmap* pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight, tX1616 pShear) { |
||
| 2212 | int y_count; |
||
| 2213 | int x_count; |
||
| 2214 | int dest_row_wrap; |
||
| 2215 | int source_row_wrap; |
||
| 2216 | //int x_delta; // Pierre-Marie Baty -- unused variable |
||
| 2217 | int last_shear_x; |
||
| 2218 | int current_shear_x; |
||
| 2219 | int shear_x_difference; |
||
| 2220 | int pWidth_orig; |
||
| 2221 | tU8 the_byte; |
||
| 2222 | tU8* source_ptr; |
||
| 2223 | tU8* dest_ptr; |
||
| 2224 | //tU8* conv_table; // Pierre-Marie Baty -- unused variable |
||
| 2225 | tX1616 current_shear; |
||
| 2226 | LOG_TRACE("(%p, %d, %d, %p, %d, %d, %d, %d, %d)", pDest, pDest_x, pDest_y, pSource, pSource_x, pSource_y, pWidth, pHeight, pShear); |
||
| 2227 | |||
| 2228 | current_shear = 0; |
||
| 2229 | last_shear_x = 0; |
||
| 2230 | source_ptr = (tU8*)pSource->pixels + pSource_x + pSource_y * pSource->row_bytes; |
||
| 2231 | dest_ptr = (tU8*)pDest->pixels + pDest_x + pDest_y * pDest->row_bytes; |
||
| 2232 | source_row_wrap = pSource->row_bytes - pWidth; |
||
| 2233 | dest_row_wrap = pDest->row_bytes - pWidth; |
||
| 2234 | if (pDest_y < 0) { |
||
| 2235 | pHeight += pDest_y; |
||
| 2236 | if (pHeight <= 0) { |
||
| 2237 | return; |
||
| 2238 | } |
||
| 2239 | source_ptr -= pDest_y * pSource->row_bytes; |
||
| 2240 | dest_ptr -= pDest_y * pDest->row_bytes; |
||
| 2241 | pDest_y = 0; |
||
| 2242 | } |
||
| 2243 | if (pDest->height > pDest_y) { |
||
| 2244 | if (pDest_y + pHeight > pDest->height) { |
||
| 2245 | pHeight = pDest->height - pDest_y; |
||
| 2246 | } |
||
| 2247 | if (pDest_x < 0) { |
||
| 2248 | pWidth += pDest_x; |
||
| 2249 | if (pWidth <= 0) { |
||
| 2250 | return; |
||
| 2251 | } |
||
| 2252 | source_ptr -= pDest_x; |
||
| 2253 | dest_ptr -= pDest_x; |
||
| 2254 | source_row_wrap -= pDest_x; |
||
| 2255 | dest_row_wrap -= pDest_x; |
||
| 2256 | pDest_x = 0; |
||
| 2257 | } |
||
| 2258 | if (pDest->width > pDest_x) { |
||
| 2259 | pWidth_orig = pWidth; |
||
| 2260 | for (y_count = 0; pHeight > y_count; ++y_count) { |
||
| 2261 | #if !defined(DETHRACE_FIX_BUGS) |
||
| 2262 | /* |
||
| 2263 | * The OG compares against pWidth instead of pWidth_orig, which |
||
| 2264 | * ends up clipped to the dest pixelmap width. This effectively |
||
| 2265 | * clips the consecutive rows of pixels along the shear, leaving |
||
| 2266 | * a visible gap on the screen. Instead, when comparing against |
||
| 2267 | * pWidth_orig, the clip takes place vertically along the dest |
||
| 2268 | * pixelmap edge, allowing all pixels to be displayed. |
||
| 2269 | * |
||
| 2270 | * Simulate OG behavior by overwriting pWidth_orig with pWidth. |
||
| 2271 | */ |
||
| 2272 | pWidth_orig = pWidth; |
||
| 2273 | #endif |
||
| 2274 | if (pDest_x + pWidth_orig > pDest->width) { |
||
| 2275 | shear_x_difference = pDest_x + pWidth - pDest->width; |
||
| 2276 | pWidth = pDest->width - pDest_x; |
||
| 2277 | source_row_wrap += shear_x_difference; |
||
| 2278 | dest_row_wrap += shear_x_difference; |
||
| 2279 | } |
||
| 2280 | for (x_count = 0; pWidth > x_count; ++x_count) { |
||
| 2281 | the_byte = *source_ptr++; |
||
| 2282 | if (the_byte) { |
||
| 2283 | *dest_ptr = the_byte; |
||
| 2284 | } |
||
| 2285 | ++dest_ptr; |
||
| 2286 | } |
||
| 2287 | current_shear_x = (current_shear >> 16) - last_shear_x; |
||
| 2288 | dest_ptr += dest_row_wrap + current_shear_x; |
||
| 2289 | last_shear_x = current_shear >> 16; |
||
| 2290 | source_ptr += source_row_wrap; |
||
| 2291 | current_shear += pShear; |
||
| 2292 | pDest_x += current_shear_x; |
||
| 2293 | if (pDest_x < 0) { |
||
| 2294 | pWidth += pDest_x; |
||
| 2295 | source_ptr -= pDest_x; |
||
| 2296 | dest_ptr -= pDest_x; |
||
| 2297 | source_row_wrap -= pDest_x; |
||
| 2298 | dest_row_wrap -= pDest_x; |
||
| 2299 | pDest_x = 0; |
||
| 2300 | } |
||
| 2301 | if (pDest->width <= pDest_x) { |
||
| 2302 | break; |
||
| 2303 | } |
||
| 2304 | } |
||
| 2305 | } |
||
| 2306 | } |
||
| 2307 | } |
||
| 2308 | |||
| 2309 | // IDA: void __usercall DRPixelmapRectangleVScaledCopy(br_pixelmap *pDest@<EAX>, br_int_16 pDest_x@<EDX>, br_int_16 pDest_y@<EBX>, br_pixelmap *pSource@<ECX>, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight) |
||
| 2310 | void DRPixelmapRectangleVScaledCopy(br_pixelmap* pDest, br_int_16 pDest_x, br_int_16 pDest_y, br_pixelmap* pSource, br_int_16 pSource_x, br_int_16 pSource_y, br_int_16 pWidth, br_int_16 pHeight) { |
||
| 2311 | int y_count; |
||
| 2312 | int x_count; |
||
| 2313 | int dest_row_wrap; |
||
| 2314 | int source_row_wrap; |
||
| 2315 | //int x_delta; // Pierre-Marie Baty -- unused variable |
||
| 2316 | tU8 the_byte; |
||
| 2317 | tU8* source_ptr; |
||
| 2318 | tU8* dest_ptr; |
||
| 2319 | tU32 source_y; |
||
| 2320 | tU32 source_y_delta; |
||
| 2321 | tU32 old_source_y; |
||
| 2322 | LOG_TRACE("(%p, %d, %d, %p, %d, %d, %d, %d)", pDest, pDest_x, pDest_y, pSource, pSource_x, pSource_y, pWidth, pHeight); |
||
| 2323 | |||
| 2324 | if (!pHeight) { |
||
| 2325 | return; |
||
| 2326 | } |
||
| 2327 | |||
| 2328 | source_row_wrap = pSource->row_bytes - pWidth; |
||
| 2329 | dest_row_wrap = pDest->row_bytes - pWidth; |
||
| 2330 | dest_ptr = (tU8*)pDest->pixels + (pDest->row_bytes * pDest_y + pDest_x); |
||
| 2331 | source_ptr = (tU8*)pSource->pixels + (pSource->row_bytes * pSource_y + pSource_x); |
||
| 2332 | |||
| 2333 | source_y = 0; |
||
| 2334 | source_y_delta = (pSource->height << 16) / pHeight - 0x10000; |
||
| 2335 | |||
| 2336 | for (y_count = 0; y_count < pHeight; y_count++) { |
||
| 2337 | for (x_count = 0; x_count < pWidth; x_count++) { |
||
| 2338 | the_byte = *source_ptr; |
||
| 2339 | if (the_byte) { |
||
| 2340 | *dest_ptr = the_byte; |
||
| 2341 | } |
||
| 2342 | source_ptr++; |
||
| 2343 | dest_ptr++; |
||
| 2344 | } |
||
| 2345 | old_source_y = source_y; |
||
| 2346 | source_y += source_y_delta; |
||
| 2347 | source_ptr += (((source_y >> 16) - (old_source_y >> 16)) * pSource->row_bytes) + source_row_wrap; |
||
| 2348 | dest_ptr += dest_row_wrap; |
||
| 2349 | } |
||
| 2350 | } |
||
| 2351 | |||
| 2352 | // IDA: void __cdecl InitTransientBitmaps() |
||
| 2353 | void InitTransientBitmaps(void) { |
||
| 2354 | int i; |
||
| 2355 | LOG_TRACE("()"); |
||
| 2356 | |||
| 2357 | for (i = 0; i < COUNT_OF(gTransient_bitmaps); i++) { |
||
| 2358 | gTransient_bitmaps[i].pixmap = NULL; |
||
| 2359 | gTransient_bitmaps[i].in_use = 0; |
||
| 2360 | } |
||
| 2361 | } |
||
| 2362 | |||
| 2363 | // IDA: int __usercall AllocateTransientBitmap@<EAX>(int pWidth@<EAX>, int pHeight@<EDX>, int pUser_data@<EBX>) |
||
| 2364 | int AllocateTransientBitmap(int pWidth, int pHeight, int pUser_data) { |
||
| 2365 | int bm_index; |
||
| 2366 | LOG_TRACE("(%d, %d, %d)", pWidth, pHeight, pUser_data); |
||
| 2367 | |||
| 2368 | for (bm_index = 0; bm_index < COUNT_OF(gTransient_bitmaps); bm_index++) { |
||
| 2369 | if (gTransient_bitmaps[bm_index].pixmap == NULL) { |
||
| 2370 | gTransient_bitmaps[bm_index].pixmap = DRPixelmapAllocate(BR_PMT_INDEX_8, pWidth + 8, pHeight, NULL, 0); |
||
| 2371 | gTransient_bitmaps[bm_index].in_use = 0; |
||
| 2372 | gTransient_bitmaps[bm_index].user_data = pUser_data; |
||
| 2373 | return bm_index; |
||
| 2374 | } |
||
| 2375 | } |
||
| 2376 | FatalError(kFatalError_FindSpareTransientBitmap); |
||
| 2377 | } |
||
| 2378 | |||
| 2379 | // IDA: void __usercall DeallocateTransientBitmap(int pIndex@<EAX>) |
||
| 2380 | void DeallocateTransientBitmap(int pIndex) { |
||
| 2381 | LOG_TRACE("(%d)", pIndex); |
||
| 2382 | |||
| 2383 | if (gTransient_bitmaps[pIndex].pixmap != NULL) { |
||
| 2384 | BrPixelmapFree(gTransient_bitmaps[pIndex].pixmap); |
||
| 2385 | gTransient_bitmaps[pIndex].pixmap = NULL; |
||
| 2386 | gTransient_bitmaps[pIndex].in_use = 0; |
||
| 2387 | } |
||
| 2388 | } |
||
| 2389 | |||
| 2390 | // IDA: void __cdecl DeallocateAllTransientBitmaps() |
||
| 2391 | void DeallocateAllTransientBitmaps(void) { |
||
| 2392 | int i; |
||
| 2393 | LOG_TRACE("()"); |
||
| 2394 | |||
| 2395 | for (i = 0; i < COUNT_OF(gTransient_bitmaps); i++) { |
||
| 2396 | DeallocateTransientBitmap(i); |
||
| 2397 | } |
||
| 2398 | } |
||
| 2399 | |||
| 2400 | // IDA: void __usercall RemoveTransientBitmaps(int pGraphically_remove_them@<EAX>) |
||
| 2401 | void RemoveTransientBitmaps(int pGraphically_remove_them) { |
||
| 2402 | int i; |
||
| 2403 | int order_number; |
||
| 2404 | |||
| 2405 | if (pGraphically_remove_them) { |
||
| 2406 | for (order_number = gNext_transient - 1; order_number >= 0; order_number--) { |
||
| 2407 | for (i = 0; i < COUNT_OF(gTransient_bitmaps); i++) { |
||
| 2408 | if (gTransient_bitmaps[i].pixmap != NULL && gTransient_bitmaps[i].order_number == order_number) { |
||
| 2409 | if (gTransient_bitmaps[i].in_use) { |
||
| 2410 | BrPixelmapRectangleCopy(gBack_screen, |
||
| 2411 | gTransient_bitmaps[i].x_coord, |
||
| 2412 | gTransient_bitmaps[i].y_coord, |
||
| 2413 | gTransient_bitmaps[i].pixmap, |
||
| 2414 | 0, |
||
| 2415 | 0, |
||
| 2416 | gTransient_bitmaps[i].pixmap->width, |
||
| 2417 | gTransient_bitmaps[i].pixmap->height); |
||
| 2418 | } |
||
| 2419 | break; |
||
| 2420 | } |
||
| 2421 | } |
||
| 2422 | } |
||
| 2423 | } |
||
| 2424 | gNext_transient = 0; |
||
| 2425 | } |
||
| 2426 | |||
| 2427 | // IDA: void __usercall SaveTransient(int pIndex@<EAX>, int pX_coord@<EDX>, int pY_coord@<EBX>) |
||
| 2428 | void SaveTransient(int pIndex, int pX_coord, int pY_coord) { |
||
| 2429 | LOG_TRACE("(%d, %d, %d)", pIndex, pX_coord, pY_coord); |
||
| 2430 | |||
| 2431 | gTransient_bitmaps[pIndex].x_coord = pX_coord & ~3; |
||
| 2432 | gTransient_bitmaps[pIndex].y_coord = pY_coord; |
||
| 2433 | gTransient_bitmaps[pIndex].in_use = 1; |
||
| 2434 | gTransient_bitmaps[pIndex].order_number = gNext_transient; |
||
| 2435 | gNext_transient++; |
||
| 2436 | BrPixelmapRectangleCopy(gTransient_bitmaps[pIndex].pixmap, |
||
| 2437 | 0, |
||
| 2438 | 0, |
||
| 2439 | gBack_screen, |
||
| 2440 | gTransient_bitmaps[pIndex].x_coord, |
||
| 2441 | gTransient_bitmaps[pIndex].y_coord, |
||
| 2442 | gTransient_bitmaps[pIndex].pixmap->width, |
||
| 2443 | gTransient_bitmaps[pIndex].pixmap->height); |
||
| 2444 | } |
||
| 2445 | |||
| 2446 | // IDA: void __usercall DrawCursorGiblet(tCursor_giblet *pGib@<EAX>) |
||
| 2447 | void DrawCursorGiblet(tCursor_giblet* pGib) { |
||
| 2448 | br_pixelmap* the_image; |
||
| 2449 | LOG_TRACE("(%p)", pGib); |
||
| 2450 | |||
| 2451 | SaveTransient(pGib->transient_index, pGib->x_coord, pGib->y_coord); |
||
| 2452 | the_image = gCursor_giblet_images[gCursor_giblet_sequences[pGib->sequence_index][pGib->current_giblet]]; |
||
| 2453 | DRPixelmapRectangleMaskedCopy(gBack_screen, |
||
| 2454 | pGib->x_coord, |
||
| 2455 | pGib->y_coord, |
||
| 2456 | the_image, |
||
| 2457 | 0, |
||
| 2458 | 0, |
||
| 2459 | the_image->width, |
||
| 2460 | the_image->height); |
||
| 2461 | } |
||
| 2462 | |||
| 2463 | // IDA: void __usercall ProcessCursorGiblets(int pPeriod@<EAX>) |
||
| 2464 | void ProcessCursorGiblets(int pPeriod) { |
||
| 2465 | int i; |
||
| 2466 | int kill_the_giblet; |
||
| 2467 | tU32 time_now; |
||
| 2468 | tCursor_giblet* gib; |
||
| 2469 | LOG_TRACE("(%d)", pPeriod); |
||
| 2470 | |||
| 2471 | time_now = PDGetTotalTime(); |
||
| 2472 | for (i = 0; i < COUNT_OF(gCursor_giblets); i++) { |
||
| 2473 | gib = &gCursor_giblets[i]; |
||
| 2474 | kill_the_giblet = 0; |
||
| 2475 | if (gib->current_giblet == -1) { |
||
| 2476 | continue; |
||
| 2477 | } |
||
| 2478 | if (!gib->landed && gib->e_t_a <= time_now) { |
||
| 2479 | gib->landed = 1; |
||
| 2480 | gib->the_speed = 0.f; |
||
| 2481 | } |
||
| 2482 | if (gib->landed) { |
||
| 2483 | gib->giblet_change_period -= pPeriod / 2; |
||
| 2484 | if (gib->giblet_change_period < 50) { |
||
| 2485 | gib->giblet_change_period = 50; |
||
| 2486 | } |
||
| 2487 | if (gib->giblet_change_period <= time_now - gib->last_giblet_change) { |
||
| 2488 | if (gCursor_giblet_sequences[gib->sequence_index][0] == gib->current_giblet) { |
||
| 2489 | gib->current_giblet = 1; |
||
| 2490 | } else { |
||
| 2491 | gib->current_giblet++; |
||
| 2492 | } |
||
| 2493 | gib->last_giblet_change = time_now; |
||
| 2494 | } |
||
| 2495 | gib->y_coord += pPeriod * gib->the_speed / 1000.f; |
||
| 2496 | if (gib->y_coord <= gGraf_data[gGraf_data_index].height) { |
||
| 2497 | if (gib->the_speed < gGraf_specs[gGraf_spec_index].total_height * 160 / 480) { |
||
| 2498 | gib->the_speed += pPeriod * gGraf_specs[gGraf_spec_index].total_height * 60 / 480 / 1000.f; |
||
| 2499 | } |
||
| 2500 | } else { |
||
| 2501 | kill_the_giblet = 1; |
||
| 2502 | } |
||
| 2503 | } else { |
||
| 2504 | if (gib->y_speed < gGraf_specs[gGraf_spec_index].total_height * 160 / 480) { |
||
| 2505 | gib->y_speed += pPeriod * gGraf_specs[gGraf_spec_index].total_height * 60 / 480 / 1000.f * 2.f; |
||
| 2506 | } |
||
| 2507 | gib->x_coord += pPeriod * gib->x_speed / 1000.f; |
||
| 2508 | gib->y_coord += pPeriod * gib->y_speed / 1000.f; |
||
| 2509 | if (gib->x_coord < 0.f || gib->x_coord >= gGraf_data[gGraf_spec_index].width || gib->y_coord < 0.f || gib->y_coord >= gGraf_data[gGraf_spec_index].height) { |
||
| 2510 | kill_the_giblet = 1; |
||
| 2511 | } |
||
| 2512 | } |
||
| 2513 | if (kill_the_giblet) { |
||
| 2514 | gib->current_giblet = -1; |
||
| 2515 | DeallocateTransientBitmap(gib->transient_index); |
||
| 2516 | } else { |
||
| 2517 | DrawCursorGiblet(gib); |
||
| 2518 | } |
||
| 2519 | } |
||
| 2520 | } |
||
| 2521 | |||
| 2522 | // IDA: int __usercall NewCursorGiblet@<EAX>(int pX_coord@<EAX>, int pY_coord@<EDX>, float pX_speed, float pY_speed, tU32 pDrop_time) |
||
| 2523 | int NewCursorGiblet(int pX_coord, int pY_coord, float pX_speed, float pY_speed, tU32 pDrop_time) { |
||
| 2524 | int i; |
||
| 2525 | int the_width; |
||
| 2526 | int the_height; |
||
| 2527 | int sequence_number; |
||
| 2528 | LOG_TRACE("(%d, %d, %f, %f, %d)", pX_coord, pY_coord, pX_speed, pY_speed, pDrop_time); |
||
| 2529 | |||
| 2530 | sequence_number = IRandomBetween(0, COUNT_OF(gCursor_giblet_sequences) - 1); |
||
| 2531 | if (pX_coord >= 0 && pX_coord < gGraf_data[gGraf_data_index].width && pY_coord >= 0 && pY_coord < gGraf_data[gGraf_data_index].height) { |
||
| 2532 | for (i = 0; i < COUNT_OF(gCursor_giblets); i++) { |
||
| 2533 | if (gCursor_giblets[i].current_giblet == -1) { |
||
| 2534 | the_width = gCursor_giblet_images[gCursor_giblet_sequences[sequence_number][1]]->width; |
||
| 2535 | the_height = gCursor_giblet_images[gCursor_giblet_sequences[sequence_number][1]]->height; |
||
| 2536 | gCursor_giblets[i].transient_index = AllocateTransientBitmap(the_width, the_height, 1); |
||
| 2537 | gCursor_giblets[i].current_giblet = 1; |
||
| 2538 | gCursor_giblets[i].sequence_index = sequence_number; |
||
| 2539 | gCursor_giblets[i].landed = 0; |
||
| 2540 | gCursor_giblets[i].x_coord = sequence_number * gGraf_specs[gGraf_spec_index].total_width / 640 - the_width / 2 + pX_coord; |
||
| 2541 | gCursor_giblets[i].y_coord = FRandomPosNeg(6.f) * gGraf_specs[gGraf_spec_index].total_height / 480 - the_height / 2 + pY_coord; |
||
| 2542 | gCursor_giblets[i].x_speed = pX_speed; |
||
| 2543 | gCursor_giblets[i].y_speed = pY_speed; |
||
| 2544 | gCursor_giblets[i].last_giblet_change = 0; |
||
| 2545 | gCursor_giblets[i].giblet_change_period = 1000; |
||
| 2546 | gCursor_giblets[i].e_t_a = PDGetTotalTime() + pDrop_time; |
||
| 2547 | return i; |
||
| 2548 | } |
||
| 2549 | } |
||
| 2550 | } |
||
| 2551 | return -1; |
||
| 2552 | } |
||
| 2553 | |||
| 2554 | // IDA: int __cdecl DoMouseCursor() |
||
| 2555 | int DoMouseCursor(void) { |
||
| 2556 | int x_coord; // Added by DethRace |
||
| 2557 | int y_coord; |
||
| 2558 | int mouse_moved; |
||
| 2559 | int new_required; |
||
| 2560 | //int giblet_index; // Pierre-Marie Baty -- unused variable |
||
| 2561 | int cursor_offset; |
||
| 2562 | int button_is_down; |
||
| 2563 | int giblet_chance; |
||
| 2564 | int giblet_count; |
||
| 2565 | tU32 this_call_time; |
||
| 2566 | static tU32 last_cursor_change; |
||
| 2567 | static tU32 last_call_time; |
||
| 2568 | static tU32 last_required_change; |
||
| 2569 | tS32 period; |
||
| 2570 | static int delta_x; |
||
| 2571 | static int required_cursor; |
||
| 2572 | static int zero_count; |
||
| 2573 | static int button_was_down; |
||
| 2574 | |||
| 2575 | period = 0; |
||
| 2576 | this_call_time = PDGetTotalTime(); |
||
| 2577 | if (last_call_time == 0) { |
||
| 2578 | period = 1000; |
||
| 2579 | } |
||
| 2580 | while (period <= 20) { |
||
| 2581 | this_call_time = PDGetTotalTime(); |
||
| 2582 | period = this_call_time - last_call_time; |
||
| 2583 | // added by dethrace to avoid 100% CPU usage |
||
| 2584 | gHarness_platform.Sleep(1); |
||
| 2585 | } |
||
| 2586 | GetMousePosition(&x_coord, &y_coord); |
||
| 2587 | mouse_moved = x_coord != gMouse_last_x_coord || y_coord != gMouse_last_y_coord; |
||
| 2588 | button_is_down = EitherMouseButtonDown(); |
||
| 2589 | cursor_offset = button_is_down ? 4 : 0; |
||
| 2590 | if (gMouse_in_use || mouse_moved) { |
||
| 2591 | gMouse_in_use = 1; |
||
| 2592 | if (gMouse_last_x_coord == x_coord) { |
||
| 2593 | if (zero_count >= 5) { |
||
| 2594 | delta_x = 0; |
||
| 2595 | } |
||
| 2596 | zero_count++; |
||
| 2597 | } else { |
||
| 2598 | zero_count = 0; |
||
| 2599 | delta_x = (x_coord - gMouse_last_x_coord) * 1000 / period; |
||
| 2600 | } |
||
| 2601 | if (delta_x < -10) { |
||
| 2602 | new_required = 0; |
||
| 2603 | } else if (delta_x < 11) { |
||
| 2604 | new_required = 2; |
||
| 2605 | } else { |
||
| 2606 | new_required = 3; |
||
| 2607 | } |
||
| 2608 | if (new_required != required_cursor && this_call_time - last_required_change >= 200) { |
||
| 2609 | last_required_change = this_call_time; |
||
| 2610 | required_cursor = new_required; |
||
| 2611 | } |
||
| 2612 | if (gCurrent_cursor_index != required_cursor && PDGetTotalTime() - last_cursor_change >= 50) { |
||
| 2613 | if (required_cursor < gCurrent_cursor_index) { |
||
| 2614 | gCurrent_cursor_index--; |
||
| 2615 | } else { |
||
| 2616 | gCurrent_cursor_index++; |
||
| 2617 | } |
||
| 2618 | last_cursor_change = PDGetTotalTime(); |
||
| 2619 | } |
||
| 2620 | giblet_chance = Chance(1.f + 20.f * (abs(x_coord - gMouse_last_x_coord) + abs(y_coord - gMouse_last_y_coord)) / (float)period, period); |
||
| 2621 | if (gProgram_state.sausage_eater_mode) { |
||
| 2622 | giblet_count = 0; |
||
| 2623 | } else { |
||
| 2624 | giblet_count = 6 * BooleanTo1Or0(button_is_down && !button_was_down) + BooleanTo1Or0(giblet_chance); |
||
| 2625 | } |
||
| 2626 | for (; giblet_count != 0; giblet_count--) { |
||
| 2627 | NewCursorGiblet( |
||
| 2628 | x_coord + gCursor_gib_x_offsets[gCurrent_cursor_index + cursor_offset] * gGraf_specs[gGraf_spec_index].total_width / 640, |
||
| 2629 | y_coord + gCursor_gib_y_offsets[gCurrent_cursor_index + cursor_offset] * gGraf_specs[gGraf_spec_index].total_height / 480, |
||
| 2630 | ((float)(x_coord - gMouse_last_x_coord)) / period * 1000.f / 4.f, |
||
| 2631 | ((float)(y_coord - gMouse_last_y_coord)) / period * 1000.f / 3.f, |
||
| 2632 | (button_is_down && !button_was_down) ? 50 : 400); |
||
| 2633 | } |
||
| 2634 | ProcessCursorGiblets(period); |
||
| 2635 | SaveTransient(gCursor_transient_index, |
||
| 2636 | x_coord - gCursor_x_offsets[gCurrent_cursor_index + cursor_offset] * gGraf_specs[gGraf_spec_index].total_width / 640, |
||
| 2637 | y_coord - gCursor_y_offsets[gCurrent_cursor_index + cursor_offset] * gGraf_specs[gGraf_spec_index].total_height / 480); |
||
| 2638 | DRPixelmapRectangleMaskedCopy(gBack_screen, |
||
| 2639 | x_coord - gCursor_x_offsets[gCurrent_cursor_index + cursor_offset] * gGraf_specs[gGraf_spec_index].total_width / 640, |
||
| 2640 | y_coord - gCursor_y_offsets[gCurrent_cursor_index + cursor_offset] * gGraf_specs[gGraf_spec_index].total_height / 480, |
||
| 2641 | gCursors[gCurrent_cursor_index + cursor_offset], |
||
| 2642 | 0, |
||
| 2643 | 0, |
||
| 2644 | gCursors[gCurrent_cursor_index + cursor_offset]->width, |
||
| 2645 | gCursors[gCurrent_cursor_index + cursor_offset]->height); |
||
| 2646 | } |
||
| 2647 | last_call_time = this_call_time; |
||
| 2648 | button_was_down = button_is_down; |
||
| 2649 | gMouse_last_x_coord = x_coord; |
||
| 2650 | gMouse_last_y_coord = y_coord; |
||
| 2651 | return mouse_moved; |
||
| 2652 | } |
||
| 2653 | |||
| 2654 | // IDA: int __cdecl AllocateCursorTransient() |
||
| 2655 | int AllocateCursorTransient(void) { |
||
| 2656 | int i; |
||
| 2657 | int largest_width; |
||
| 2658 | int largest_height; |
||
| 2659 | LOG_TRACE("()"); |
||
| 2660 | |||
| 2661 | largest_width = 0; |
||
| 2662 | largest_height = 0; |
||
| 2663 | for (i = 0; i < COUNT_OF(gCursors); i++) { |
||
| 2664 | if (largest_width < gCursors[i]->width) { |
||
| 2665 | largest_width = gCursors[i]->width; |
||
| 2666 | } |
||
| 2667 | if (largest_height < gCursors[i]->height) { |
||
| 2668 | largest_height = gCursors[i]->height; |
||
| 2669 | } |
||
| 2670 | } |
||
| 2671 | return AllocateTransientBitmap(largest_width, largest_height, 0); |
||
| 2672 | } |
||
| 2673 | |||
| 2674 | // IDA: void __cdecl StartMouseCursor() |
||
| 2675 | void StartMouseCursor(void) { |
||
| 2676 | int i; |
||
| 2677 | LOG_TRACE("()"); |
||
| 2678 | |||
| 2679 | gNext_transient = 0; |
||
| 2680 | gCursor_transient_index = AllocateCursorTransient(); |
||
| 2681 | GetMousePosition(&gMouse_last_x_coord, &gMouse_last_y_coord); |
||
| 2682 | gMouse_in_use = 0; |
||
| 2683 | gCurrent_cursor_index = 2; |
||
| 2684 | for (i = 0; i < COUNT_OF(gCursor_giblets); i++) { |
||
| 2685 | gCursor_giblets[i].current_giblet = -1; |
||
| 2686 | } |
||
| 2687 | gMouse_started = 1; |
||
| 2688 | } |
||
| 2689 | |||
| 2690 | // IDA: void __cdecl EndMouseCursor() |
||
| 2691 | void EndMouseCursor(void) { |
||
| 2692 | LOG_TRACE("()"); |
||
| 2693 | |||
| 2694 | RemoveTransientBitmaps(1); |
||
| 2695 | DeallocateAllTransientBitmaps(); |
||
| 2696 | gMouse_started = 0; |
||
| 2697 | } |
||
| 2698 | |||
| 2699 | // IDA: void __usercall LoadFont(int pFont_ID@<EAX>) |
||
| 2700 | void LoadFont(int pFont_ID) { |
||
| 2701 | tPath_name the_path; |
||
| 2702 | int i; |
||
| 2703 | int number_of_chars; |
||
| 2704 | FILE* f; |
||
| 2705 | tU32 the_size; |
||
| 2706 | LOG_TRACE("(%d)", pFont_ID); |
||
| 2707 | |||
| 2708 | if (gFonts[pFont_ID].images != NULL) { |
||
| 2709 | return; |
||
| 2710 | } |
||
| 2711 | |||
| 2712 | PathCat(the_path, gApplication_path, gGraf_specs[gGraf_spec_index].data_dir_name); |
||
| 2713 | PathCat(the_path, the_path, "FONTS"); |
||
| 2714 | PathCat(the_path, the_path, gFont_names[pFont_ID]); |
||
| 2715 | number_of_chars = strlen(the_path); |
||
| 2716 | strcat(the_path, ".PIX"); |
||
| 2717 | gFonts[pFont_ID].images = DRPixelmapLoad(the_path); |
||
| 2718 | |||
| 2719 | if (gFonts[pFont_ID].images == NULL) { |
||
| 2720 | FatalError(kFatalError_LoadFontImage_S, gFont_names[pFont_ID]); |
||
| 2721 | } |
||
| 2722 | if (!gFonts[pFont_ID].file_read_once) { |
||
| 2723 | strcpy(&the_path[number_of_chars + 1], "TXT"); |
||
| 2724 | |||
| 2725 | f = DRfopen(the_path, "rt"); |
||
| 2726 | if (f == NULL) { |
||
| 2727 | FatalError(kFatalError_LoadFontWidthTable_S, gFont_names[pFont_ID]); |
||
| 2728 | } |
||
| 2729 | |||
| 2730 | gFonts[pFont_ID].height = GetAnInt(f); |
||
| 2731 | gFonts[pFont_ID].width = GetAnInt(f); |
||
| 2732 | gFonts[pFont_ID].spacing = GetAnInt(f); |
||
| 2733 | gFonts[pFont_ID].offset = GetAnInt(f); |
||
| 2734 | gFonts[pFont_ID].num_entries = GetAnInt(f); |
||
| 2735 | if (gFonts[pFont_ID].width <= 0) { |
||
| 2736 | for (i = 0; i < gFonts[pFont_ID].num_entries; i++) { |
||
| 2737 | the_size = GetAnInt(f); |
||
| 2738 | gFonts[pFont_ID].width_table[i] = the_size; |
||
| 2739 | } |
||
| 2740 | } |
||
| 2741 | fclose(f); |
||
| 2742 | gFonts[pFont_ID].file_read_once = 1; |
||
| 2743 | } |
||
| 2744 | } |
||
| 2745 | |||
| 2746 | // IDA: void __usercall DisposeFont(int pFont_ID@<EAX>) |
||
| 2747 | void DisposeFont(int pFont_ID) { |
||
| 2748 | LOG_TRACE("(%d)", pFont_ID); |
||
| 2749 | if (gFonts[pFont_ID].images && (!TranslationMode() || (gAusterity_mode && FlicsPlayedFromDisk()))) { |
||
| 2750 | BrPixelmapFree(gFonts[pFont_ID].images); |
||
| 2751 | gFonts[pFont_ID].images = NULL; |
||
| 2752 | gFonts[pFont_ID].file_read_once = 0; |
||
| 2753 | } |
||
| 2754 | } |
||
| 2755 | |||
| 2756 | // IDA: void __cdecl InitDRFonts() |
||
| 2757 | void InitDRFonts(void) { |
||
| 2758 | int i; |
||
| 2759 | LOG_TRACE("()"); |
||
| 2760 | |||
| 2761 | for (i = 0; i < 21; i++) { |
||
| 2762 | gFonts[i].file_read_once = 0; |
||
| 2763 | gFonts[i].images = NULL; |
||
| 2764 | } |
||
| 2765 | } |
||
| 2766 | |||
| 2767 | // IDA: void __usercall DrawDropImage(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>, int pTop_clip@<ECX>, int pBottom_clip, int pOffset) |
||
| 2768 | void DrawDropImage(br_pixelmap* pImage, int pLeft, int pTop, int pTop_clip, int pBottom_clip, int pOffset) { |
||
| 2769 | int y; |
||
| 2770 | int src_y; |
||
| 2771 | int src_height; |
||
| 2772 | int y_diff; |
||
| 2773 | LOG_TRACE("(%p, %d, %d, %d, %d, %d)", pImage, pLeft, pTop, pTop_clip, pBottom_clip, pOffset); |
||
| 2774 | |||
| 2775 | BrPixelmapRectangleFill(gBack_screen, |
||
| 2776 | pLeft, |
||
| 2777 | pTop_clip, |
||
| 2778 | pImage->width, |
||
| 2779 | pBottom_clip - pTop_clip, |
||
| 2780 | 0); |
||
| 2781 | if (pOffset != 1000) { |
||
| 2782 | src_y = 0; |
||
| 2783 | src_height = pImage->height; |
||
| 2784 | y = pOffset + pTop; |
||
| 2785 | y_diff = pTop_clip - y; |
||
| 2786 | if (y_diff > 0) { |
||
| 2787 | src_height -= y_diff; |
||
| 2788 | y += y_diff; |
||
| 2789 | src_y = y_diff; |
||
| 2790 | } |
||
| 2791 | y_diff = pBottom_clip - y - pImage->height; |
||
| 2792 | if (y_diff < 0) { |
||
| 2793 | src_height += y_diff; |
||
| 2794 | } |
||
| 2795 | BrPixelmapRectangleCopy(gBack_screen, |
||
| 2796 | pLeft, |
||
| 2797 | y, |
||
| 2798 | pImage, |
||
| 2799 | 0, |
||
| 2800 | src_y, |
||
| 2801 | pImage->width, |
||
| 2802 | src_height); |
||
| 2803 | PDScreenBufferSwap(0); |
||
| 2804 | } |
||
| 2805 | } |
||
| 2806 | |||
| 2807 | // IDA: void __usercall DropInImageFromTop(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>, int pTop_clip@<ECX>, int pBottom_clip) |
||
| 2808 | void DropInImageFromTop(br_pixelmap* pImage, int pLeft, int pTop, int pTop_clip, int pBottom_clip) { |
||
| 2809 | tS32 start_time; |
||
| 2810 | tS32 the_time; |
||
| 2811 | int drop_distance; |
||
| 2812 | LOG_TRACE("(%p, %d, %d, %d, %d)", pImage, pLeft, pTop, pTop_clip, pBottom_clip); |
||
| 2813 | |||
| 2814 | start_time = PDGetTotalTime(); |
||
| 2815 | drop_distance = pImage->height - pTop_clip + pTop; |
||
| 2816 | while (1) { |
||
| 2817 | the_time = PDGetTotalTime(); |
||
| 2818 | if (the_time >= start_time + 100) { |
||
| 2819 | break; |
||
| 2820 | } |
||
| 2821 | DrawDropImage(pImage, |
||
| 2822 | pLeft, |
||
| 2823 | pTop, |
||
| 2824 | pTop_clip, |
||
| 2825 | pBottom_clip, |
||
| 2826 | (the_time - start_time - 100) * drop_distance / 100); |
||
| 2827 | } |
||
| 2828 | DrawDropImage(pImage, pLeft, pTop, pTop_clip, pBottom_clip, 0); |
||
| 2829 | } |
||
| 2830 | |||
| 2831 | // IDA: void __usercall DropOutImageThruBottom(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>, int pTop_clip@<ECX>, int pBottom_clip) |
||
| 2832 | void DropOutImageThruBottom(br_pixelmap* pImage, int pLeft, int pTop, int pTop_clip, int pBottom_clip) { |
||
| 2833 | tS32 start_time; |
||
| 2834 | tS32 the_time; |
||
| 2835 | int drop_distance; |
||
| 2836 | LOG_TRACE("(%p, %d, %d, %d, %d)", pImage, pLeft, pTop, pTop_clip, pBottom_clip); |
||
| 2837 | |||
| 2838 | start_time = PDGetTotalTime(); |
||
| 2839 | drop_distance = pBottom_clip - pTop; |
||
| 2840 | while (1) { |
||
| 2841 | the_time = PDGetTotalTime(); |
||
| 2842 | if (the_time >= start_time + 100) { |
||
| 2843 | break; |
||
| 2844 | } |
||
| 2845 | DrawDropImage(pImage, |
||
| 2846 | pLeft, |
||
| 2847 | pTop, |
||
| 2848 | pTop_clip, |
||
| 2849 | pBottom_clip, |
||
| 2850 | (the_time - start_time) * drop_distance / 100); |
||
| 2851 | } |
||
| 2852 | DrawDropImage(pImage, pLeft, pTop, pTop_clip, pBottom_clip, 1000); |
||
| 2853 | } |
||
| 2854 | |||
| 2855 | // IDA: void __usercall DropInImageFromBottom(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>, int pTop_clip@<ECX>, int pBottom_clip) |
||
| 2856 | void DropInImageFromBottom(br_pixelmap* pImage, int pLeft, int pTop, int pTop_clip, int pBottom_clip) { |
||
| 2857 | tS32 start_time; |
||
| 2858 | tS32 the_time; |
||
| 2859 | int drop_distance; |
||
| 2860 | LOG_TRACE("(%p, %d, %d, %d, %d)", pImage, pLeft, pTop, pTop_clip, pBottom_clip); |
||
| 2861 | |||
| 2862 | start_time = PDGetTotalTime(); |
||
| 2863 | drop_distance = pBottom_clip - pTop; |
||
| 2864 | while (1) { |
||
| 2865 | the_time = PDGetTotalTime(); |
||
| 2866 | if (the_time >= start_time + 100) { |
||
| 2867 | break; |
||
| 2868 | } |
||
| 2869 | DrawDropImage(pImage, |
||
| 2870 | pLeft, |
||
| 2871 | pTop, |
||
| 2872 | pTop_clip, |
||
| 2873 | pBottom_clip, |
||
| 2874 | (100 - the_time + start_time) * drop_distance / 100); |
||
| 2875 | } |
||
| 2876 | DrawDropImage(pImage, pLeft, pTop, pTop_clip, pBottom_clip, 0); |
||
| 2877 | } |
||
| 2878 | |||
| 2879 | // IDA: void __usercall DropOutImageThruTop(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>, int pTop_clip@<ECX>, int pBottom_clip) |
||
| 2880 | void DropOutImageThruTop(br_pixelmap* pImage, int pLeft, int pTop, int pTop_clip, int pBottom_clip) { |
||
| 2881 | tS32 start_time; |
||
| 2882 | tS32 the_time; |
||
| 2883 | int drop_distance; |
||
| 2884 | LOG_TRACE("(%p, %d, %d, %d, %d)", pImage, pLeft, pTop, pTop_clip, pBottom_clip); |
||
| 2885 | |||
| 2886 | start_time = PDGetTotalTime(); |
||
| 2887 | drop_distance = pImage->height - pTop_clip + pTop; |
||
| 2888 | while (1) { |
||
| 2889 | the_time = PDGetTotalTime(); |
||
| 2890 | if (the_time >= start_time + 100) { |
||
| 2891 | break; |
||
| 2892 | } |
||
| 2893 | DrawDropImage(pImage, |
||
| 2894 | pLeft, |
||
| 2895 | pTop, |
||
| 2896 | pTop_clip, |
||
| 2897 | pBottom_clip, |
||
| 2898 | (start_time - the_time) * drop_distance / 100); |
||
| 2899 | } |
||
| 2900 | DrawDropImage(pImage, pLeft, pTop, pTop_clip, pBottom_clip, 1000); |
||
| 2901 | } |
||
| 2902 | |||
| 2903 | // IDA: void __usercall DrawTellyLine(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>, int pPercentage@<ECX>) |
||
| 2904 | void DrawTellyLine(br_pixelmap* pImage, int pLeft, int pTop, int pPercentage) { |
||
| 2905 | int the_width; |
||
| 2906 | int the_height; |
||
| 2907 | LOG_TRACE("(%p, %d, %d, %d)", pImage, pLeft, pTop, pPercentage); |
||
| 2908 | |||
| 2909 | the_width = pImage->width; |
||
| 2910 | the_height = pImage->height / 2 + pTop; |
||
| 2911 | BrPixelmapLine(gBack_screen, pLeft, the_height, pLeft + the_width, the_height, 0); |
||
| 2912 | BrPixelmapLine(gBack_screen, the_width / 2 + pLeft - pPercentage * the_width / 200, the_height, the_width / 2 + pLeft + pPercentage * the_width / 200, the_height, 1); |
||
| 2913 | PDScreenBufferSwap(0); |
||
| 2914 | } |
||
| 2915 | |||
| 2916 | // IDA: void __usercall DrawTellyImage(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>, int pPercentage@<ECX>) |
||
| 2917 | void DrawTellyImage(br_pixelmap* pImage, int pLeft, int pTop, int pPercentage) { |
||
| 2918 | //int the_height; // Pierre-Marie Baty -- unused variable |
||
| 2919 | LOG_TRACE("(%p, %d, %d, %d)", pImage, pLeft, pTop, pPercentage); |
||
| 2920 | |||
| 2921 | BrPixelmapRectangleFill(gBack_screen, pLeft, pTop, pImage->width, pImage->height, 0); |
||
| 2922 | if (pPercentage != 1000) { |
||
| 2923 | DRPixelmapRectangleVScaledCopy( |
||
| 2924 | gBack_screen, |
||
| 2925 | pLeft, |
||
| 2926 | pTop + pImage->height * (100 - pPercentage) / 200, |
||
| 2927 | pImage, |
||
| 2928 | 0, |
||
| 2929 | 0, |
||
| 2930 | pImage->width, |
||
| 2931 | pPercentage * pImage->height / 100); |
||
| 2932 | PDScreenBufferSwap(0); |
||
| 2933 | } |
||
| 2934 | } |
||
| 2935 | |||
| 2936 | // IDA: void __usercall TellyInImage(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>) |
||
| 2937 | void TellyInImage(br_pixelmap* pImage, int pLeft, int pTop) { |
||
| 2938 | tS32 start_time; |
||
| 2939 | tS32 the_time; |
||
| 2940 | LOG_TRACE("(%p, %d, %d)", pImage, pLeft, pTop); |
||
| 2941 | |||
| 2942 | start_time = PDGetTotalTime(); |
||
| 2943 | while (1) { |
||
| 2944 | the_time = PDGetTotalTime(); |
||
| 2945 | if (start_time + 100 <= the_time) { |
||
| 2946 | break; |
||
| 2947 | } |
||
| 2948 | DrawTellyLine(pImage, pLeft, pTop, 100 * (the_time - start_time) / 100); |
||
| 2949 | } |
||
| 2950 | start_time = PDGetTotalTime(); |
||
| 2951 | while (1) { |
||
| 2952 | the_time = PDGetTotalTime(); |
||
| 2953 | if (start_time + 100 <= the_time) { |
||
| 2954 | break; |
||
| 2955 | } |
||
| 2956 | DrawTellyImage(pImage, pLeft, pTop, 100 * (the_time - start_time) / 100); |
||
| 2957 | } |
||
| 2958 | DrawTellyImage(pImage, pLeft, pTop, 100); |
||
| 2959 | } |
||
| 2960 | |||
| 2961 | // IDA: void __usercall TellyOutImage(br_pixelmap *pImage@<EAX>, int pLeft@<EDX>, int pTop@<EBX>) |
||
| 2962 | void TellyOutImage(br_pixelmap* pImage, int pLeft, int pTop) { |
||
| 2963 | tS32 start_time; |
||
| 2964 | tS32 the_time; |
||
| 2965 | //int drop_distance; // Pierre-Marie Baty -- unused variable |
||
| 2966 | LOG_TRACE("(%p, %d, %d)", pImage, pLeft, pTop); |
||
| 2967 | |||
| 2968 | start_time = PDGetTotalTime(); |
||
| 2969 | while (1) { |
||
| 2970 | the_time = PDGetTotalTime(); |
||
| 2971 | if (start_time + 100 <= the_time) { |
||
| 2972 | break; |
||
| 2973 | } |
||
| 2974 | DrawTellyImage(pImage, pLeft, pTop, 100 * (start_time + 100 - the_time) / 100); |
||
| 2975 | } |
||
| 2976 | DrawTellyImage(pImage, pLeft, pTop, 1000); |
||
| 2977 | |||
| 2978 | start_time = PDGetTotalTime(); |
||
| 2979 | while (1) { |
||
| 2980 | the_time = PDGetTotalTime(); |
||
| 2981 | if (start_time + 100 <= the_time) { |
||
| 2982 | break; |
||
| 2983 | } |
||
| 2984 | DrawTellyLine(pImage, pLeft, pTop, 100 * (start_time + 100 - the_time) / 100); |
||
| 2985 | } |
||
| 2986 | DrawTellyLine(pImage, pLeft, pTop, 0); |
||
| 2987 | } |
||
| 2988 | |||
| 2989 | // IDA: void __usercall SetShadowLevel(tShadow_level pLevel@<EAX>) |
||
| 2990 | void SetShadowLevel(tShadow_level pLevel) { |
||
| 2991 | LOG_TRACE("(%d)", pLevel); |
||
| 2992 | |||
| 2993 | gShadow_level = pLevel; |
||
| 2994 | } |
||
| 2995 | |||
| 2996 | // IDA: tShadow_level __cdecl GetShadowLevel() |
||
| 2997 | tShadow_level GetShadowLevel(void) { |
||
| 2998 | LOG_TRACE("()"); |
||
| 2999 | |||
| 3000 | return gShadow_level; |
||
| 3001 | } |
||
| 3002 | |||
| 3003 | // IDA: void __cdecl ToggleShadow() |
||
| 3004 | void ToggleShadow(void) { |
||
| 3005 | LOG_TRACE("()"); |
||
| 3006 | |||
| 3007 | gShadow_level++; |
||
| 3008 | if (gShadow_level == eShadow_everyone) { |
||
| 3009 | gShadow_level = eShadow_none; |
||
| 3010 | } |
||
| 3011 | switch (gShadow_level) { |
||
| 3012 | case eShadow_none: |
||
| 21 | pmbaty | 3013 | NewTextHeadupSlot(eHeadupSlot_misc, 0, 2000, -4, GetMiscString(kMiscString_NoShadows)); |
| 1 | pmbaty | 3014 | break; |
| 3015 | case eShadow_us_only: |
||
| 21 | pmbaty | 3016 | NewTextHeadupSlot(eHeadupSlot_misc, 0, 2000, -4, GetMiscString(kMiscString_ShadowUnderOwnCar)); |
| 1 | pmbaty | 3017 | break; |
| 3018 | case eShadow_us_and_opponents: |
||
| 21 | pmbaty | 3019 | NewTextHeadupSlot(eHeadupSlot_misc, 0, 2000, -4, GetMiscString(kMiscString_ShadowUnderMainCars)); |
| 1 | pmbaty | 3020 | break; |
| 3021 | case eShadow_everyone: |
||
| 21 | pmbaty | 3022 | NewTextHeadupSlot(eHeadupSlot_misc, 0, 2000, -4, GetMiscString(kMiscString_ShadowUnderAllCars)); |
| 1 | pmbaty | 3023 | break; |
| 3024 | default: |
||
| 3025 | return; |
||
| 3026 | } |
||
| 3027 | } |
||
| 3028 | |||
| 3029 | // IDA: void __cdecl InitShadow() |
||
| 3030 | void InitShadow(void) { |
||
| 3031 | int i; |
||
| 3032 | //br_vector3 temp_v; // Pierre-Marie Baty -- unused variable |
||
| 3033 | LOG_TRACE("()"); |
||
| 3034 | |||
| 3035 | for (i = 0; i < 8; i++) { |
||
| 3036 | gShadow_clip_planes[i].clip = BrActorAllocate(BR_ACTOR_CLIP_PLANE, NULL); |
||
| 3037 | BrActorAdd(gUniverse_actor, gShadow_clip_planes[i].clip); |
||
| 3038 | BrClipPlaneDisable(gShadow_clip_planes[i].clip); |
||
| 3039 | BrMatrix34Identity(&gShadow_clip_planes[i].clip->t.t.mat); |
||
| 3040 | } |
||
| 3041 | gFancy_shadow = 1; |
||
| 3042 | gShadow_material = BrMaterialFind("SHADOW.MAT"); |
||
| 3043 | BrVector3Set(&gShadow_light_ray, 0.f, -1.f, 0.f); |
||
| 3044 | BrVector3Set(&gShadow_light_z, -0.f, -0.f, -1.f); |
||
| 3045 | BrVector3Set(&gShadow_light_x, 1.f, 0.f, 0.f); |
||
| 3046 | |||
| 3047 | gShadow_model = BrModelAllocate("", 0, 0); |
||
| 3048 | gShadow_model->flags = BR_MODF_GENERATE_TAGS | BR_MODF_KEEP_ORIGINAL; |
||
| 3049 | gShadow_actor = BrActorAllocate(BR_ACTOR_MODEL, 0); |
||
| 3050 | gShadow_actor->model = gShadow_model; |
||
| 3051 | BrActorAdd(gUniverse_actor, gShadow_actor); |
||
| 3052 | } |
||
| 3053 | |||
| 3054 | // IDA: br_uint_32 __cdecl SaveShadeTable(br_pixelmap *pTable, void *pArg) |
||
| 3055 | br_uint_32 SaveShadeTable(br_pixelmap* pTable, void* pArg) { |
||
| 3056 | LOG_TRACE("(%p, %p)", pTable, pArg); |
||
| 3057 | |||
| 3058 | if (gSaved_table_count == COUNT_OF(gSaved_shade_tables)) { |
||
| 3059 | return 1; |
||
| 3060 | } |
||
| 3061 | gSaved_shade_tables[gSaved_table_count].original = pTable; |
||
| 3062 | gSaved_shade_tables[gSaved_table_count].copy = (br_pixelmap*)BrMemAllocate(sizeof(br_pixelmap), kMem_shade_table_copy); |
||
| 3063 | memcpy(gSaved_shade_tables[gSaved_table_count].copy, pTable, sizeof(br_pixelmap)); |
||
| 3064 | gSaved_table_count++; |
||
| 3065 | return 0; |
||
| 3066 | } |
||
| 3067 | |||
| 3068 | // IDA: void __cdecl SaveShadeTables() |
||
| 3069 | void SaveShadeTables(void) { |
||
| 3070 | LOG_TRACE("()"); |
||
| 3071 | |||
| 3072 | PossibleService(); |
||
| 3073 | gSaved_table_count = 0; |
||
| 3074 | BrTableEnum("*", SaveShadeTable, 0); |
||
| 3075 | } |
||
| 3076 | |||
| 3077 | // IDA: void __cdecl DisposeSavedShadeTables() |
||
| 3078 | void DisposeSavedShadeTables(void) { |
||
| 3079 | int i; |
||
| 3080 | LOG_TRACE("()"); |
||
| 3081 | |||
| 3082 | for (i = 0; i < gSaved_table_count; i++) { |
||
| 3083 | BrMemFree(gSaved_shade_tables[i].copy); |
||
| 3084 | } |
||
| 3085 | } |
||
| 3086 | |||
| 3087 | // IDA: void __cdecl ShadowMode() |
||
| 3088 | void ShadowMode(void) { |
||
| 3089 | LOG_TRACE("()"); |
||
| 3090 | |||
| 3091 | gFancy_shadow = !gFancy_shadow; |
||
| 3092 | if (gFancy_shadow) { |
||
| 21 | pmbaty | 3093 | NewTextHeadupSlot(eHeadupSlot_misc, 0, 2000, -4, "Translucent shadow"); |
| 1 | pmbaty | 3094 | } else { |
| 21 | pmbaty | 3095 | NewTextHeadupSlot(eHeadupSlot_misc, 0, 2000, -4, "Solid shadow"); |
| 1 | pmbaty | 3096 | } |
| 3097 | } |
||
| 3098 | |||
| 3099 | // IDA: int __cdecl SwitchToRealResolution() |
||
| 3100 | int SwitchToRealResolution(void) { |
||
| 3101 | LOG_TRACE("()"); |
||
| 3102 | |||
| 3103 | if (gGraf_data_index == gReal_graf_data_index) { |
||
| 3104 | return 0; |
||
| 3105 | } |
||
| 3106 | gGraf_data_index = gReal_graf_data_index; |
||
| 3107 | gGraf_spec_index = gReal_graf_data_index; |
||
| 3108 | gCurrent_graf_data = &gGraf_data[gReal_graf_data_index]; |
||
| 3109 | PDSwitchToRealResolution(); |
||
| 3110 | return 1; |
||
| 3111 | } |
||
| 3112 | |||
| 3113 | // IDA: int __cdecl SwitchToLoresMode() |
||
| 3114 | int SwitchToLoresMode(void) { |
||
| 3115 | LOG_TRACE("()"); |
||
| 3116 | if (!gGraf_data_index || gGraf_data_index != gReal_graf_data_index) { |
||
| 3117 | return 0; |
||
| 3118 | } |
||
| 3119 | gGraf_data_index = 0; |
||
| 3120 | gGraf_spec_index = 0; |
||
| 3121 | gCurrent_graf_data = gGraf_data; |
||
| 3122 | PDSwitchToLoresMode(); |
||
| 3123 | return 1; |
||
| 3124 | } |
||
| 3125 | |||
| 3126 | // IDA: void __usercall DRPixelmapDoubledCopy(br_pixelmap *pDestn@<EAX>, br_pixelmap *pSource@<EDX>, int pSource_width@<EBX>, int pSource_height@<ECX>, int pX_offset, int pY_offset) |
||
| 3127 | void DRPixelmapDoubledCopy(br_pixelmap* pDestn, br_pixelmap* pSource, int pSource_width, int pSource_height, int pX_offset, int pY_offset) { |
||
| 3128 | tU16* sptr; |
||
| 3129 | tU16 pixels; |
||
| 3130 | tU8* dptr; |
||
| 3131 | tU8* dptr2; |
||
| 3132 | tU8 pixel_1; |
||
| 3133 | tU8 pixel_2; |
||
| 3134 | int i; |
||
| 3135 | int j; |
||
| 3136 | int dst_row_skip; |
||
| 3137 | int src_row_skip; |
||
| 3138 | int width_over_2; |
||
| 3139 | LOG_TRACE("(%p, %p, %d, %d, %d, %d)", pDestn, pSource, pSource_width, pSource_height, pX_offset, pY_offset); |
||
| 3140 | |||
| 3141 | dst_row_skip = 2 * pDestn->row_bytes - 2 * pSource_width; |
||
| 3142 | src_row_skip = (pSource->row_bytes - pSource_width) / 2; |
||
| 3143 | sptr = (tU16*)((tU8*)pSource->pixels - 2 * src_row_skip + 2 * (pSource->row_bytes * pSource_height / 2)); |
||
| 3144 | dptr = (tU8*)pDestn->pixels + 2 * pSource_width + (2 * pSource_height + pY_offset) * pDestn->row_bytes - pDestn->row_bytes; |
||
| 3145 | dptr2 = dptr - pDestn->row_bytes; |
||
| 3146 | width_over_2 = pSource_width / 2; |
||
| 3147 | for (i = 0; i < pSource_height; i++) { |
||
| 3148 | for (j = 0; j < width_over_2; j++) { |
||
| 3149 | --sptr; |
||
| 3150 | pixels = *sptr; |
||
| 3151 | pixel_1 = pixels >> 8; |
||
| 3152 | pixel_2 = pixels >> 0; |
||
| 3153 | dptr[-1] = pixel_1; |
||
| 3154 | dptr2[-1] = pixel_1; |
||
| 3155 | dptr[-2] = pixel_1; |
||
| 3156 | dptr2[-2] = pixel_1; |
||
| 3157 | dptr[-3] = pixel_2; |
||
| 3158 | dptr2[-3] = pixel_2; |
||
| 3159 | dptr[-4] = pixel_2; |
||
| 3160 | dptr2[-4] = pixel_2; |
||
| 3161 | dptr -= 4; |
||
| 3162 | dptr2 -= 4; |
||
| 3163 | } |
||
| 3164 | dptr -= dst_row_skip; |
||
| 3165 | dptr2 -= dst_row_skip; |
||
| 3166 | sptr -= src_row_skip; |
||
| 3167 | } |
||
| 3168 | } |