#pragma once #include "tarray.h" #include "vectors.h" #include "maptypes.h" struct Section; struct SectorGeometryPlane { TArray vertices; TArray texcoords; FVector3 normal{}; }; enum GeomFlags { NoEarcut = 1, NoLibtess = 2, FloorDone = 4, CeilingDone = 8, }; using SectionGeometryPlane = SectorGeometryPlane; struct sectortypelight { float ceilingxpan_; float ceilingypan_; float floorxpan_; float floorypan_; ESectorFlags ceilingstat; ESectorFlags floorstat; FTextureID ceilingtexture; FTextureID floortexture; int16_t ceilingheinum; int16_t floorheinum; void copy(sectortype* sec) { ceilingxpan_ = sec->ceilingxpan_; ceilingypan_ = sec->ceilingypan_; floorxpan_ = sec->floorxpan_; floorypan_ = sec->floorypan_; ceilingstat = sec->ceilingstat; floorstat = sec->floorstat; ceilingheinum = sec->ceilingheinum; floorheinum = sec->floorheinum; ceilingtexture = sec->ceilingtexture; floortexture = sec->floortexture; } }; struct SectionGeometryData { SectorGeometryPlane planes[2]; TArray meshVertices; // flat vertices. Stored separately so that plane changes won't require completely new triangulation. TArray meshIndices; sectortypelight compare[2] = {}; DVector2 poscompare[2] = {}; DVector2 poscompare2[2] = {}; FVector3 normal[2]; }; class SectionGeometry { TArray data; bool ValidateSection(Section* section, int plane); void MarkDirty(sectortype* sector); bool CreateMesh(Section* section); void CreatePlaneMesh(Section* section, int plane, const FVector2& offset); public: SectionGeometryPlane* get(Section* section, int plane, const FVector2& offset, TArray** pIndices); void SetSize(unsigned sectcount) { data.Clear(); // delete old content data.Resize(sectcount); } }; extern SectionGeometry sectionGeometry;