186 lines
5.3 KiB
C++
186 lines
5.3 KiB
C++
//========= Copyright Valve Corporation, All rights reserved. ============//
|
|
//
|
|
// Purpose: Implementation of IEditorTexture interface for placeholder textures.
|
|
// Placeholder textures are used for textures that are referenced in
|
|
// the map file but not found in storage.
|
|
//
|
|
//=============================================================================//
|
|
|
|
#include "stdafx.h"
|
|
#include <process.h>
|
|
#include <afxtempl.h>
|
|
#include <io.h>
|
|
#include <sys\stat.h>
|
|
#include <fcntl.h>
|
|
#include "DummyTexture.h"
|
|
|
|
// memdbgon must be the last include file in a .cpp file!!!
|
|
#include <tier0/memdbgon.h>
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Constructor.
|
|
//-----------------------------------------------------------------------------
|
|
CDummyTexture::CDummyTexture(const char *pszName, TEXTUREFORMAT eFormat)
|
|
{
|
|
if (pszName != NULL)
|
|
{
|
|
strcpy(m_szName, pszName);
|
|
}
|
|
else
|
|
{
|
|
strcpy(m_szName, "Missing texture");
|
|
}
|
|
|
|
m_eTextureFormat = eFormat;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Destructor.
|
|
//-----------------------------------------------------------------------------
|
|
CDummyTexture::~CDummyTexture()
|
|
{
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Returns an empty string, since we have no source file.
|
|
//-----------------------------------------------------------------------------
|
|
const char *CDummyTexture::GetFileName() const
|
|
{
|
|
static char *pszEmpty = "";
|
|
return(pszEmpty);
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Returns a string of comma delimited keywords associated with this
|
|
// material.
|
|
// Input : pszKeywords - Buffer to receive keywords, NULL to query string length.
|
|
// Output : Returns the number of characters in the keyword string.
|
|
//-----------------------------------------------------------------------------
|
|
int CDummyTexture::GetKeywords(char *pszKeywords) const
|
|
{
|
|
if (pszKeywords != NULL)
|
|
{
|
|
*pszKeywords = '\0';
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose:
|
|
// Input : *pszName -
|
|
// Output :
|
|
//-----------------------------------------------------------------------------
|
|
// dvs: move into a common place for CWADTexture & CDummyTexture
|
|
int CDummyTexture::GetShortName(char *pszName) const
|
|
{
|
|
char szBuf[MAX_PATH];
|
|
|
|
if (pszName == NULL)
|
|
{
|
|
pszName = szBuf;
|
|
}
|
|
|
|
if (m_eTextureFormat == tfWAL)
|
|
{
|
|
const char *psz = strstr(m_szName, "textures");
|
|
if (psz == NULL)
|
|
{
|
|
psz = m_szName;
|
|
}
|
|
else
|
|
{
|
|
psz += strlen("textures\\");
|
|
}
|
|
|
|
strcpy(pszName, psz);
|
|
|
|
// remove extension
|
|
char *pszExtension = strstr(pszName, ".wal");
|
|
if (pszExtension)
|
|
{
|
|
*pszExtension = 0;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
strcpy(pszName, m_szName);
|
|
}
|
|
|
|
return(strlen(pszName));
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: If the buffer pointer passed in is not NULL, copies the image data
|
|
// in RGB format to the buffer
|
|
// Input : pImageRGB - Pointer to buffer that receives the image data. If the
|
|
// pointer is NULL, no data is copied, only the data size is returned.
|
|
// Output : Returns a the size of the RGB image in bytes.
|
|
//-----------------------------------------------------------------------------
|
|
int CDummyTexture::GetImageDataRGB( void *pImageRGB )
|
|
{
|
|
return(0);
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: If the buffer pointer passed in is not NULL, copies the image data
|
|
// in RGBA format to the buffer
|
|
// Input : pImageRGBA - Pointer to buffer that receives the image data. If the
|
|
// pointer is NULL, no data is copied, only the data size is returned.
|
|
// Output : Returns a the size of the RGBA image in bytes.
|
|
//-----------------------------------------------------------------------------
|
|
int CDummyTexture::GetImageDataRGBA( void *pImageRGBA )
|
|
{
|
|
return(0);
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose:
|
|
// Input : size -
|
|
//-----------------------------------------------------------------------------
|
|
void CDummyTexture::GetSize( SIZE &size ) const
|
|
{
|
|
size.cx = 0;
|
|
size.cy = 0;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Renders "No Image" into a device context as a placeholder for the
|
|
// missing texture.
|
|
// Input : pDC -
|
|
// rect -
|
|
// iFontHeight -
|
|
// dwFlags -
|
|
//-----------------------------------------------------------------------------
|
|
void CDummyTexture::Draw(CDC *pDC, RECT &rect, int iFontHeight, int iIconHeight, DrawTexData_t &DrawTexData)
|
|
{
|
|
CFont *pOldFont = (CFont *)pDC->SelectStockObject(ANSI_VAR_FONT);
|
|
COLORREF crText = pDC->SetTextColor(RGB(0xff, 0xff, 0xff));
|
|
COLORREF crBack = pDC->SetBkColor(RGB(0, 0, 0));
|
|
|
|
pDC->FillRect(&rect, CBrush::FromHandle(HBRUSH(GetStockObject(BLACK_BRUSH))));
|
|
pDC->TextOut(rect.left + 2, rect.top + 2, "No Image", 8);
|
|
|
|
pDC->SelectObject(pOldFont);
|
|
pDC->SetTextColor(crText);
|
|
pDC->SetBkColor(crBack);
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Loads this texture from disk if it is not already loaded.
|
|
// Output : Returns true on success, false on failure.
|
|
//-----------------------------------------------------------------------------
|
|
bool CDummyTexture::Load( void )
|
|
{
|
|
return(true);
|
|
}
|