Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose: Defines the interface a given texture for the 3D renderer. Current
// implementations are for world textures (WADTexture.cpp) and sprite
// textures (Texture.cpp).
//
//=============================================================================
#ifndef IEDITORTEXTURE_H
#define IEDITORTEXTURE_H
#pragma once
#include <utlvector.h>
class CDC; class CPalette; class IMaterial;
//
// Set your texture ID to this in your implementation's constructor.
//
#define TEXTURE_ID_NONE -1
//
// Texture formats. hack: MUST correlate with radio buttons in IDD_OPTIONS_CONFIGS.
//
enum TEXTUREFORMAT { tfNone = -1, tfWAD = 0, tfWAL = 1, tfWAD3 = 2, tfWAD4 = 3, tfWAD5 = 4, tfVMT = 5, tfSprite = 6 // dvs: not sure if I want to do it this way
};
//
// Flags for DrawTexData_t.
//
#define drawCaption 0x01
#define drawResizeAlways 0x02
#define drawIcons 0x04
#define drawErrors 0x08
#define drawUsageCount 0x10
struct DrawTexData_t { int nFlags; int nUsageCount; };
class IEditorTexture { public:
virtual ~IEditorTexture(void) { }
//
// dvs: remove one of these
//
virtual int GetImageWidth( void ) const = 0; virtual int GetImageHeight( void ) const = 0;
virtual int GetWidth( void ) const = 0; virtual int GetHeight( void ) const = 0;
virtual float GetDecalScale( void ) const = 0;
//
// dvs: Try to remove as many of these as possible:
//
virtual const char *GetName( void ) const = 0; virtual int GetShortName( char *szShortName ) const = 0; virtual int GetKeywords( char *szKeywords ) const = 0; virtual void Draw(CDC *pDC, RECT &rect, int iFontHeight, int iIconHeight, DrawTexData_t &DrawTexData) = 0; virtual TEXTUREFORMAT GetTextureFormat( void ) const = 0; virtual int GetSurfaceAttributes( void ) const = 0; virtual int GetSurfaceContents(void ) const = 0; virtual int GetSurfaceValue( void ) const = 0; virtual CPalette *GetPalette( void ) const = 0; virtual bool HasData( void ) const = 0; virtual bool HasPalette( void ) const = 0; virtual bool Load( void ) = 0; // ensure that texture is loaded. could this be done internally?
virtual void Reload( bool bFullReload ) = 0; // The texture changed. If bFullReload is true, then the material system reloads it too.
virtual bool IsLoaded( void ) const = 0; virtual const char *GetFileName( void ) const = 0;
virtual bool IsWater( void ) const = 0;
//-----------------------------------------------------------------------------
// Purpose:
// Input : pData -
// Output :
//-----------------------------------------------------------------------------
virtual int GetImageDataRGB( void *pData = NULL ) = 0;
//-----------------------------------------------------------------------------
// Purpose:
// Input : pData -
// Output :
//-----------------------------------------------------------------------------
virtual int GetImageDataRGBA( void *pData = NULL ) = 0;
//-----------------------------------------------------------------------------
// Purpose: Returns true if this texture has an alpha component, false if not.
//-----------------------------------------------------------------------------
virtual bool HasAlpha( void ) const = 0;
//-----------------------------------------------------------------------------
// Purpose: Returns whether this texture is a dummy texture or not. Dummy textures
// serve as placeholders for textures that were found in the map, but
// not in the WAD (or the materials tree). The dummy texture enables us
// to bind the texture, find it by name, etc.
//-----------------------------------------------------------------------------
virtual bool IsDummy( void ) const = 0; // dvs: perhaps not the best name?
//-----------------------------------------------------------------------------
// Purpose: Returns the unique texture ID for this texture object. The texture ID
// identifies the texture object across all renderers, and is assigned
// by the first renderer that actually binds the texture thru BindTexture.
//
// Only the renderer ever needs to call SetTextureID.
//-----------------------------------------------------------------------------
virtual int GetTextureID( void ) const = 0;
//-----------------------------------------------------------------------------
// Purpose: Sets the unique texture ID for this texture object. The texture ID
// identifies the texture object across all renderers, and is assigned
// by the first renderer that actually binds the texture thru BindTexture.
//
// Only the renderer should ever call SetTextureID!
//-----------------------------------------------------------------------------
virtual void SetTextureID( int nTextureID ) = 0;
//-----------------------------------------------------------------------------
// Returns the material system material associated with a texture
//-----------------------------------------------------------------------------
virtual IMaterial* GetMaterial( bool bForceLoad=true ) { return 0; } };
typedef CUtlVector<IEditorTexture *> EditorTextureList_t;
#endif // IEDITORTEXTURE_H
|