123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- /*
- ===========================================================================
- Doom 3 GPL Source Code
- Copyright (C) 1999-2011 id Software LLC, a ZeniMax Media company.
- This file is part of the Doom 3 GPL Source Code (?Doom 3 Source Code?).
- Doom 3 Source Code is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
- Doom 3 Source Code is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with Doom 3 Source Code. If not, see <http://www.gnu.org/licenses/>.
- In addition, the Doom 3 Source Code is also subject to certain additional terms. You should have received a copy of these additional terms immediately following the terms and conditions of the GNU General Public License which accompanied the Doom 3 Source Code. If not, please request a copy in writing from id Software at the address below.
- If you have questions concerning this license or the applicable additional terms, you may contact in writing id Software LLC, c/o ZeniMax Media Inc., Suite 120, Rockville, Maryland 20850 USA.
- ===========================================================================
- */
- #ifndef __SURFACE_PATCH_H__
- #define __SURFACE_PATCH_H__
- /*
- ===============================================================================
- Bezier patch surface.
- ===============================================================================
- */
- class idSurface_Patch : public idSurface {
- public:
- idSurface_Patch( void );
- idSurface_Patch( int maxPatchWidth, int maxPatchHeight );
- idSurface_Patch( const idSurface_Patch &patch );
- ~idSurface_Patch( void );
- void SetSize( int patchWidth, int patchHeight );
- int GetWidth( void ) const;
- int GetHeight( void ) const;
- // subdivide the patch mesh based on error
- void Subdivide( float maxHorizontalError, float maxVerticalError, float maxLength, bool genNormals = false );
- // subdivide the patch up to an explicit number of horizontal and vertical subdivisions
- void SubdivideExplicit( int horzSubdivisions, int vertSubdivisions, bool genNormals, bool removeLinear = false );
- protected:
- int width; // width of patch
- int height; // height of patch
- int maxWidth; // maximum width allocated for
- int maxHeight; // maximum height allocated for
- bool expanded; // true if vertices are spaced out
- private:
- // put the approximation points on the curve
- void PutOnCurve( void );
- // remove columns and rows with all points on one line
- void RemoveLinearColumnsRows( void );
- // resize verts buffer
- void ResizeExpanded( int height, int width );
- // space points out over maxWidth * maxHeight buffer
- void Expand( void );
- // move all points to the start of the verts buffer
- void Collapse( void );
- // project a point onto a vector to calculate maximum curve error
- void ProjectPointOntoVector( const idVec3 &point, const idVec3 &vStart, const idVec3 &vEnd, idVec3 &vProj );
- // generate normals
- void GenerateNormals( void );
- // generate triangle indexes
- void GenerateIndexes( void );
- // lerp point from two patch point
- void LerpVert( const idDrawVert &a, const idDrawVert &b, idDrawVert &out ) const;
- // sample a single 3x3 patch
- void SampleSinglePatchPoint( const idDrawVert ctrl[3][3], float u, float v, idDrawVert *out ) const;
- void SampleSinglePatch( const idDrawVert ctrl[3][3], int baseCol, int baseRow, int width, int horzSub, int vertSub, idDrawVert *outVerts ) const;
- };
- /*
- =================
- idSurface_Patch::idSurface_Patch
- =================
- */
- ID_INLINE idSurface_Patch::idSurface_Patch( void ) {
- height = width = maxHeight = maxWidth = 0;
- expanded = false;
- }
- /*
- =================
- idSurface_Patch::idSurface_Patch
- =================
- */
- ID_INLINE idSurface_Patch::idSurface_Patch( int maxPatchWidth, int maxPatchHeight ) {
- width = height = 0;
- maxWidth = maxPatchWidth;
- maxHeight = maxPatchHeight;
- verts.SetNum( maxWidth * maxHeight );
- expanded = false;
- }
- /*
- =================
- idSurface_Patch::idSurface_Patch
- =================
- */
- ID_INLINE idSurface_Patch::idSurface_Patch( const idSurface_Patch &patch ) {
- (*this) = patch;
- }
- /*
- =================
- idSurface_Patch::~idSurface_Patch
- =================
- */
- ID_INLINE idSurface_Patch::~idSurface_Patch() {
- }
- /*
- =================
- idSurface_Patch::GetWidth
- =================
- */
- ID_INLINE int idSurface_Patch::GetWidth( void ) const {
- return width;
- }
- /*
- =================
- idSurface_Patch::GetHeight
- =================
- */
- ID_INLINE int idSurface_Patch::GetHeight( void ) const {
- return height;
- }
- #endif /* !__SURFACE_PATCH_H__ */
|