Skip to content

Commit

Permalink
output: read vertex buffer size from level
Browse files Browse the repository at this point in the history
This replaces the fixed vertex buffer size of 1500 with a maximum value
read from the level - so the "biggest" room, object or static mesh
determines the array size.

Resolves LostArtefacts#1398.
  • Loading branch information
lahm86 committed Jul 2, 2024
1 parent f44cbcf commit 0c71da7
Show file tree
Hide file tree
Showing 6 changed files with 47 additions and 1 deletion.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
- fixed lightning rendering z-buffer issues (#1385, regression from 1.4)
- fixed possible game crashes if more than 16 savegame slots are set (#1374)
- fixed savegame slots higher than 64 not working (#1395)
- fixed a crash in custom levels if a room had more than 1500 vertices (#1398)

## [4.1.2](https://github.com/LostArtefacts/TR1X/compare/4.1.1...4.1.2) - 2024-04-28
- fixed pictures display time (#1349, regression from 4.1)
Expand Down
1 change: 1 addition & 0 deletions src/game/gamebuf.c
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ static const char *GameBuf_GetBufferName(GAME_BUFFER buffer)
case GBUF_SAMPLES: return "Samples";
case GBUF_TRAP_DATA: return "Trap data";
case GBUF_CREATURE_DATA: return "Creature data";
case GBUF_VERTEX_BUFFER: return "Vertex buffer";
}
// clang-format on
return "Unknown";
Expand Down
1 change: 1 addition & 0 deletions src/game/gamebuf.h
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ typedef enum GAME_BUFFER {
GBUF_SAMPLES,
GBUF_TRAP_DATA,
GBUF_CREATURE_DATA,
GBUF_VERTEX_BUFFER,
} GAME_BUFFER;

void GameBuf_Init(void);
Expand Down
36 changes: 36 additions & 0 deletions src/game/level.c
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ static bool Level_LoadTexturePages(MYFILE *fp);
static bool Level_LoadFromFile(
const char *filename, int32_t level_num, bool is_demo);
static void Level_CompleteSetup(int32_t level_num);
static void Level_CalculateMaxVertices(void);

static bool Level_LoadFromFile(
const char *filename, int32_t level_num, bool is_demo)
Expand Down Expand Up @@ -890,6 +891,8 @@ static void Level_CompleteSetup(int32_t level_num)
// Configure enemies who carry and drop items
Carrier_InitialiseLevel(level_num);

Level_CalculateMaxVertices();

// Move the prepared texture pages into g_TexturePagePtrs.
uint8_t *base = GameBuf_Alloc(
m_LevelInfo.texture_page_count * PAGE_SIZE, GBUF_TEXTURE_PAGES);
Expand Down Expand Up @@ -925,6 +928,39 @@ static void Level_CompleteSetup(int32_t level_num)
Memory_FreePointer(&sample_sizes);
}

static void Level_CalculateMaxVertices(void)
{
size_t max_vertices = 0;
for (int32_t i = 0; i < O_NUMBER_OF; i++) {
OBJECT_INFO *object_info = &g_Objects[i];
if (!object_info->loaded) {
continue;
}

for (int32_t j = 0; j < object_info->nmeshes; j++) {
max_vertices =
MAX(max_vertices, *(g_Meshes[object_info->mesh_index + j] + 5));
}
}

for (int32_t i = 0; i < STATIC_NUMBER_OF; i++) {
STATIC_INFO *static_info = &g_StaticObjects[i];
if (!static_info->loaded || static_info->nmeshes < 0) {
continue;
}

max_vertices =
MAX(max_vertices, *(g_Meshes[static_info->mesh_number] + 5));
}

for (int32_t i = 0; i < g_RoomCount; i++) {
max_vertices = MAX(max_vertices, *g_RoomInfo[i].data);
}

LOG_INFO("Maximum vertices: %d", max_vertices);
Output_ReserveVertexBuffer(max_vertices);
}

bool Level_Load(int level_num)
{
LOG_INFO("%d (%s)", level_num, g_GameFlow.levels[level_num].level_file);
Expand Down
8 changes: 7 additions & 1 deletion src/game/output.c
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
#include "config.h"
#include "game/clock.h"
#include "game/console.h"
#include "game/gamebuf.h"
#include "game/overlay.h"
#include "game/phase/phase.h"
#include "game/picture.h"
Expand Down Expand Up @@ -48,7 +49,7 @@ static int32_t m_WibbleTable[WIBBLE_SIZE] = { 0 };
static int32_t m_ShadeTable[WIBBLE_SIZE] = { 0 };
static int32_t m_RandTable[WIBBLE_SIZE] = { 0 };

static PHD_VBUF m_VBuf[1500] = { 0 };
static PHD_VBUF *m_VBuf = NULL;
static int32_t m_DrawDistFade = 0;
static int32_t m_DrawDistMax = 0;
static RGB_F m_WaterColor = { 0 };
Expand Down Expand Up @@ -77,6 +78,11 @@ static const int16_t *Output_CalcRoomVertices(const int16_t *obj_ptr);
static int32_t Output_CalcFogShade(int32_t depth);
static void Output_CalcWibbleTable(void);

void Output_ReserveVertexBuffer(const size_t size)
{
m_VBuf = GameBuf_Alloc(size * sizeof(PHD_VBUF), GBUF_VERTEX_BUFFER);
}

static const int16_t *Output_DrawObjectG3(
const int16_t *obj_ptr, int32_t number)
{
Expand Down
1 change: 1 addition & 0 deletions src/game/output.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ void Output_DownloadTextures(int page_count);
RGBA_8888 Output_RGB2RGBA(const RGB_888 color);
void Output_SetPalette(RGB_888 palette[256]);
RGB_888 Output_GetPaletteColor(uint8_t idx);
void Output_ReserveVertexBuffer(const size_t size);

int32_t Output_GetNearZ(void);
int32_t Output_GetFarZ(void);
Expand Down

0 comments on commit 0c71da7

Please sign in to comment.