SRB2/src/r_textures.h

110 lines
3 KiB
C
Raw Normal View History

2020-01-07 15:35:10 +00:00
// SONIC ROBO BLAST 2
//-----------------------------------------------------------------------------
// Copyright (C) 1993-1996 by id Software, Inc.
// Copyright (C) 1998-2000 by DooM Legacy Team.
2022-03-03 19:24:46 +00:00
// Copyright (C) 1999-2022 by Sonic Team Junior.
2020-01-07 15:35:10 +00:00
//
// This program is free software distributed under the
// terms of the GNU General Public License, version 2.
// See the 'LICENSE' file for more details.
//-----------------------------------------------------------------------------
/// \file r_textures.h
/// \brief Texture generation.
#ifndef __R_TEXTURES__
#define __R_TEXTURES__
#include "r_defs.h"
#include "r_state.h"
#include "p_setup.h" // levelflats
#include "r_data.h"
#ifdef __GNUG__
#pragma interface
#endif
// A single patch from a texture definition,
// basically a rectangular area within
// the texture rectangle.
typedef struct
{
// Block origin (always UL), which has already accounted for the internal origin of the patch.
INT16 originx, originy;
UINT16 wad, lump;
UINT8 flip; // 1 = flipx, 2 = flipy, 3 = both
UINT8 alpha; // Translucency value
enum patchalphastyle style;
} texpatch_t;
// texture type
enum
{
TEXTURETYPE_UNKNOWN,
TEXTURETYPE_SINGLEPATCH,
TEXTURETYPE_COMPOSITE,
#ifdef WALLFLATS
TEXTURETYPE_FLAT,
#endif
};
// A texture_t describes a rectangular texture,
// which is composed of one or more texpatch_t structures
2020-01-07 15:35:10 +00:00
// that arrange graphic patches.
typedef struct
{
// Keep name for switch changing, etc.
char name[8];
UINT32 hash;
2020-01-07 15:35:10 +00:00
UINT8 type; // TEXTURETYPE_
INT16 width, height;
boolean holes;
UINT8 flip; // 1 = flipx, 2 = flipy, 3 = both
void *flat; // The texture, as a flat.
2020-01-07 15:35:10 +00:00
// All the patches[patchcount] are drawn back to front into the cached texture.
INT16 patchcount;
texpatch_t patches[0];
} texture_t;
// all loaded and prepared textures from the start of the game
extern texture_t **textures;
extern INT32 *texturewidth;
extern fixed_t *textureheight; // needed for texture pegging
extern UINT32 **texturecolumnofs; // column offset lookup table for each texture
extern UINT8 **texturecache; // graphics data for each generated full-size texture
// Load TEXTURES definitions, create lookup tables
void R_LoadTextures(void);
void R_LoadTexturesPwad(UINT16 wadnum);
2020-01-07 15:35:10 +00:00
void R_FlushTextureCache(void);
2020-01-07 15:43:27 +00:00
// Texture generation
2020-01-07 15:35:10 +00:00
UINT8 *R_GenerateTexture(size_t texnum);
UINT8 *R_GenerateTextureAsFlat(size_t texnum);
2020-01-07 15:35:10 +00:00
INT32 R_GetTextureNum(INT32 texnum);
void R_CheckTextureCache(INT32 tex);
2020-01-07 15:43:27 +00:00
void R_ClearTextureNumCache(boolean btell);
2020-01-07 15:35:10 +00:00
2020-01-07 15:43:27 +00:00
// Retrieve texture data.
void *R_GetLevelFlat(levelflat_t *levelflat);
2020-01-07 15:35:10 +00:00
UINT8 *R_GetColumn(fixed_t tex, INT32 col);
2020-01-07 16:27:59 +00:00
void *R_GetFlat(lumpnum_t flatnum);
2020-01-07 15:35:10 +00:00
boolean R_CheckPowersOfTwo(void);
boolean R_CheckSolidColorFlat(void);
UINT16 R_GetFlatSize(size_t length);
UINT8 R_GetFlatBits(INT32 size);
void R_SetFlatVars(size_t length);
2020-01-07 15:43:27 +00:00
// Returns the texture number for the texture name.
2020-01-07 15:35:10 +00:00
INT32 R_TextureNumForName(const char *name);
INT32 R_CheckTextureNumForName(const char *name);
2020-01-07 15:43:27 +00:00
lumpnum_t R_GetFlatNumForName(const char *name);
2020-01-07 15:35:10 +00:00
extern INT32 numtextures;
#endif