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.
69 lines
3.0 KiB
69 lines
3.0 KiB
//========= Copyright Valve Corporation, All rights reserved. ============// |
|
// |
|
// Purpose: A set of utilities to render standard shapes |
|
// |
|
//===========================================================================// |
|
|
|
#ifndef RENDERUTILS_H |
|
#define RENDERUTILS_H |
|
|
|
#ifdef _WIN32 |
|
#pragma once |
|
#endif |
|
|
|
#include "tier2/tier2.h" |
|
#include "Color.h" |
|
|
|
//----------------------------------------------------------------------------- |
|
// Forward declarations |
|
//----------------------------------------------------------------------------- |
|
class Vector; |
|
class QAngle; |
|
class IMaterial; |
|
struct matrix3x4_t; |
|
|
|
|
|
// Renders a wireframe sphere |
|
void RenderWireframeSphere( const Vector &vCenter, float flRadius, int nTheta, int nPhi, Color c, bool bZBuffer ); |
|
|
|
// Renders a sphere |
|
void RenderSphere( const Vector &vCenter, float flRadius, int nTheta, int nPhi, Color c, bool bZBuffer ); |
|
void RenderSphere( const Vector &vCenter, float flRadius, int nTheta, int nPhi, Color c, IMaterial *pMaterial ); |
|
|
|
// Renders a wireframe box relative to an origin |
|
void RenderWireframeBox( const Vector &vOrigin, const QAngle& angles, const Vector &vMins, const Vector &vMaxs, Color c, bool bZBuffer ); |
|
|
|
// Renders a swept wireframe box |
|
void RenderWireframeSweptBox( const Vector &vStart, const Vector &vEnd, const QAngle &angles, const Vector &vMins, const Vector &vMaxs, Color c, bool bZBuffer ); |
|
|
|
// Renders a solid box |
|
void RenderBox( const Vector& origin, const QAngle& angles, const Vector& mins, const Vector& maxs, Color c, bool bZBuffer, bool bInsideOut = false ); |
|
void RenderBox( const Vector& origin, const QAngle& angles, const Vector& mins, const Vector& maxs, Color c, IMaterial *pMaterial, bool bInsideOut = false ); |
|
|
|
// Renders axes, red->x, green->y, blue->z (axis aligned) |
|
void RenderAxes( const Vector &vOrigin, float flScale, bool bZBuffer ); |
|
void RenderAxes( const matrix3x4_t &transform, float flScale, bool bZBuffer ); |
|
|
|
// Render a line |
|
void RenderLine( const Vector& v1, const Vector& v2, Color c, bool bZBuffer ); |
|
|
|
// Draws a triangle |
|
void RenderTriangle( const Vector& p1, const Vector& p2, const Vector& p3, Color c, bool bZBuffer ); |
|
void RenderTriangle( const Vector& p1, const Vector& p2, const Vector& p3, Color c, IMaterial *pMaterial ); |
|
|
|
// Draws a axis-aligned quad |
|
void RenderQuad( IMaterial *pMaterial, float x, float y, float w, float h, float z, float s0, float t0, float s1, float t1, const Color& clr ); |
|
|
|
// Renders a screen space quad |
|
void DrawScreenSpaceRectangle( IMaterial *pMaterial, |
|
int nDestX, int nDestY, int nWidth, int nHeight, // Rect to draw into in screen space |
|
float flSrcTextureX0, float flSrcTextureY0, // which texel you want to appear at destx/y |
|
float flSrcTextureX1, float flSrcTextureY1, // which texel you want to appear at destx+width-1, desty+height-1 |
|
int nSrcTextureWidth, int nSrcTextureHeight, // needed for fixup |
|
void *pClientRenderable = NULL, // Used to pass to the bind proxies |
|
int nXDice = 1, |
|
int nYDice = 1, |
|
float fDepth = 0.0 ); // what Z value to put in the verts |
|
|
|
#endif // RENDERUTILS_H |
|
|
|
|