/** * This file has no copyright assigned and is placed in the Public Domain. * This file is part of the mingw-w64 runtime package. * No warranty is given; refer to the file DISCLAIMER.PD within this package. */ #ifndef __glu_h__ #ifndef __GLU_H__ #define __glu_h__ #define __GLU_H__ #include #ifdef __cplusplus extern "C" { #endif #ifdef WINE_NO_UNICODE_MACROS #define gluErrorStringWIN gluErrorStringWIN_cant_be_used_in_this_context gluErrorStringWIN_cant_be_used_in_this_context #elif defined(UNICODE) #define gluErrorStringWIN(errCode) ((LPCSTR) gluErrorUnicodeStringEXT(errCode)) #else #define gluErrorStringWIN(errCode) ((LPCWSTR) gluErrorString(errCode)) #endif const GLubyte *APIENTRY gluErrorString(GLenum errCode); const WCHAR *APIENTRY gluErrorUnicodeStringEXT(GLenum errCode); const GLubyte *APIENTRY gluGetString(GLenum name); void APIENTRY gluOrtho2D(GLdouble left,GLdouble right,GLdouble bottom,GLdouble top); void APIENTRY gluPerspective(GLdouble fovy,GLdouble aspect,GLdouble zNear,GLdouble zFar); void APIENTRY gluPickMatrix(GLdouble x,GLdouble y,GLdouble width,GLdouble height,GLint viewport[4]); void APIENTRY gluLookAt(GLdouble eyex,GLdouble eyey,GLdouble eyez,GLdouble centerx,GLdouble centery,GLdouble centerz,GLdouble upx,GLdouble upy,GLdouble upz); int APIENTRY gluProject(GLdouble objx,GLdouble objy,GLdouble objz,const GLdouble modelMatrix[16],const GLdouble projMatrix[16],const GLint viewport[4],GLdouble *winx,GLdouble *winy,GLdouble *winz); int APIENTRY gluUnProject(GLdouble winx,GLdouble winy,GLdouble winz,const GLdouble modelMatrix[16],const GLdouble projMatrix[16],const GLint viewport[4],GLdouble *objx,GLdouble *objy,GLdouble *objz); int APIENTRY gluScaleImage(GLenum format,GLint widthin,GLint heightin,GLenum typein,const void *datain,GLint widthout,GLint heightout,GLenum typeout,void *dataout); int APIENTRY gluBuild1DMipmaps(GLenum target,GLint components,GLint width,GLenum format,GLenum type,const void *data); int APIENTRY gluBuild2DMipmaps(GLenum target,GLint components,GLint width,GLint height,GLenum format,GLenum type,const void *data); #ifdef __cplusplus class GLUnurbs; class GLUquadric; class GLUtesselator; typedef class GLUnurbs GLUnurbsObj; typedef class GLUquadric GLUquadricObj; typedef class GLUtesselator GLUtesselatorObj; typedef class GLUtesselator GLUtriangulatorObj; #else typedef struct GLUnurbs GLUnurbs; typedef struct GLUquadric GLUquadric; typedef struct GLUtesselator GLUtesselator; typedef struct GLUnurbs GLUnurbsObj; typedef struct GLUquadric GLUquadricObj; typedef struct GLUtesselator GLUtesselatorObj; typedef struct GLUtesselator GLUtriangulatorObj; #endif GLUquadric *APIENTRY gluNewQuadric(void); void APIENTRY gluDeleteQuadric(GLUquadric *state); void APIENTRY gluQuadricNormals(GLUquadric *quadObject,GLenum normals); void APIENTRY gluQuadricTexture(GLUquadric *quadObject,GLboolean textureCoords); void APIENTRY gluQuadricOrientation(GLUquadric *quadObject,GLenum orientation); void APIENTRY gluQuadricDrawStyle(GLUquadric *quadObject,GLenum drawStyle); void APIENTRY gluCylinder(GLUquadric *qobj,GLdouble baseRadius,GLdouble topRadius,GLdouble height,GLint slices,GLint stacks); void APIENTRY gluDisk(GLUquadric *qobj,GLdouble innerRadius,GLdouble outerRadius,GLint slices,GLint loops); void APIENTRY gluPartialDisk(GLUquadric *qobj,GLdouble innerRadius,GLdouble outerRadius,GLint slices,GLint loops,GLdouble startAngle,GLdouble sweepAngle); void APIENTRY gluSphere(GLUquadric *qobj,GLdouble radius,GLint slices,GLint stacks); GLUtesselator *APIENTRY gluNewTess(void); void APIENTRY gluDeleteTess(GLUtesselator *tess); void APIENTRY gluTessBeginPolygon(GLUtesselator *tess,void *polygon_data); void APIENTRY gluTessBeginContour(GLUtesselator *tess); void APIENTRY gluTessVertex(GLUtesselator *tess,GLdouble coords[3],void *data); void APIENTRY gluTessEndContour(GLUtesselator *tess); void APIENTRY gluTessEndPolygon(GLUtesselator *tess); void APIENTRY gluTessProperty(GLUtesselator *tess,GLenum which,GLdouble value); void APIENTRY gluTessNormal(GLUtesselator *tess,GLdouble x,GLdouble y,GLdouble z); void APIENTRY gluGetTessProperty(GLUtesselator *tess,GLenum which,GLdouble *value); GLUnurbs *APIENTRY gluNewNurbsRenderer(void); void APIENTRY gluDeleteNurbsRenderer(GLUnurbs *nobj); void APIENTRY gluBeginSurface(GLUnurbs *nobj); void APIENTRY gluBeginCurve(GLUnurbs *nobj); void APIENTRY gluEndCurve(GLUnurbs *nobj); void APIENTRY gluEndSurface(GLUnurbs *nobj); void APIENTRY gluBeginTrim(GLUnurbs *nobj); void APIENTRY gluEndTrim(GLUnurbs *nobj); void APIENTRY gluPwlCurve(GLUnurbs *nobj,GLint count,GLfloat *array,GLint stride,GLenum type); void APIENTRY gluNurbsCurve(GLUnurbs *nobj,GLint nknots,GLfloat *knot,GLint stride,GLfloat *ctlarray,GLint order,GLenum type); void APIENTRY gluNurbsSurface(GLUnurbs *nobj,GLint sknot_count,float *sknot,GLint tknot_count,GLfloat *tknot,GLint s_stride,GLint t_stride,GLfloat *ctlarray,GLint sorder,GLint torder,GLenum type); void APIENTRY gluLoadSamplingMatrices(GLUnurbs *nobj,const GLfloat modelMatrix[16],const GLfloat projMatrix[16],const GLint viewport[4]); void APIENTRY gluNurbsProperty(GLUnurbs *nobj,GLenum property,GLfloat value); void APIENTRY gluGetNurbsProperty(GLUnurbs *nobj,GLenum property,GLfloat *value); #ifdef WINE_STRICT_PROTOTYPES void APIENTRY gluQuadricCallback(GLUquadric *qobj,GLenum which,void (CALLBACK *fn)(void)); void APIENTRY gluTessCallback(GLUtesselator *tess,GLenum which,void (CALLBACK *fn)(void)); void APIENTRY gluNurbsCallback(GLUnurbs *nobj,GLenum which,void (CALLBACK *fn)(void)); #else void APIENTRY gluQuadricCallback(GLUquadric *qobj,GLenum which,void (CALLBACK *fn)()); void APIENTRY gluTessCallback(GLUtesselator *tess,GLenum which,void (CALLBACK *fn)()); void APIENTRY gluNurbsCallback(GLUnurbs *nobj,GLenum which,void (CALLBACK *fn)()); #endif typedef void (CALLBACK *GLUquadricErrorProc)(GLenum); typedef void (CALLBACK *GLUtessBeginProc)(GLenum); typedef void (CALLBACK *GLUtessEdgeFlagProc) (GLboolean); typedef void (CALLBACK *GLUtessVertexProc)(void *); typedef void (CALLBACK *GLUtessEndProc)(void); typedef void (CALLBACK *GLUtessErrorProc)(GLenum); typedef void (CALLBACK *GLUtessCombineProc)(GLdouble[3],void*[4],GLfloat[4],void**); typedef void (CALLBACK *GLUtessBeginDataProc)(GLenum,void *); typedef void (CALLBACK *GLUtessEdgeFlagDataProc) (GLboolean,void *); typedef void (CALLBACK *GLUtessVertexDataProc)(void *,void *); typedef void (CALLBACK *GLUtessEndDataProc)(void *); typedef void (CALLBACK *GLUtessErrorDataProc)(GLenum,void *); typedef void (CALLBACK *GLUtessCombineDataProc)(GLdouble[3],void*[4],GLfloat[4],void**,void*); typedef void (CALLBACK *GLUnurbsErrorProc)(GLenum); #define GLU_VERSION_1_1 1 #define GLU_VERSION_1_2 1 #define GLU_INVALID_ENUM 100900 #define GLU_INVALID_VALUE 100901 #define GLU_OUT_OF_MEMORY 100902 #define GLU_INCOMPATIBLE_GL_VERSION 100903 #define GLU_VERSION 100800 #define GLU_EXTENSIONS 100801 #define GLU_TRUE GL_TRUE #define GLU_FALSE GL_FALSE #define GLU_SMOOTH 100000 #define GLU_FLAT 100001 #define GLU_NONE 100002 #define GLU_POINT 100010 #define GLU_LINE 100011 #define GLU_FILL 100012 #define GLU_SILHOUETTE 100013 #define GLU_OUTSIDE 100020 #define GLU_INSIDE 100021 #define GLU_TESS_MAX_COORD 1.0e150 #define GLU_TESS_WINDING_RULE 100140 #define GLU_TESS_BOUNDARY_ONLY 100141 #define GLU_TESS_TOLERANCE 100142 #define GLU_TESS_WINDING_ODD 100130 #define GLU_TESS_WINDING_NONZERO 100131 #define GLU_TESS_WINDING_POSITIVE 100132 #define GLU_TESS_WINDING_NEGATIVE 100133 #define GLU_TESS_WINDING_ABS_GEQ_TWO 100134 #define GLU_TESS_BEGIN 100100 #define GLU_TESS_VERTEX 100101 #define GLU_TESS_END 100102 #define GLU_TESS_ERROR 100103 #define GLU_TESS_EDGE_FLAG 100104 #define GLU_TESS_COMBINE 100105 #define GLU_TESS_BEGIN_DATA 100106 #define GLU_TESS_VERTEX_DATA 100107 #define GLU_TESS_END_DATA 100108 #define GLU_TESS_ERROR_DATA 100109 #define GLU_TESS_EDGE_FLAG_DATA 100110 #define GLU_TESS_COMBINE_DATA 100111 #define GLU_TESS_ERROR1 100151 #define GLU_TESS_ERROR2 100152 #define GLU_TESS_ERROR3 100153 #define GLU_TESS_ERROR4 100154 #define GLU_TESS_ERROR5 100155 #define GLU_TESS_ERROR6 100156 #define GLU_TESS_ERROR7 100157 #define GLU_TESS_ERROR8 100158 #define GLU_TESS_MISSING_BEGIN_POLYGON GLU_TESS_ERROR1 #define GLU_TESS_MISSING_BEGIN_CONTOUR GLU_TESS_ERROR2 #define GLU_TESS_MISSING_END_POLYGON GLU_TESS_ERROR3 #define GLU_TESS_MISSING_END_CONTOUR GLU_TESS_ERROR4 #define GLU_TESS_COORD_TOO_LARGE GLU_TESS_ERROR5 #define GLU_TESS_NEED_COMBINE_CALLBACK GLU_TESS_ERROR6 #define GLU_AUTO_LOAD_MATRIX 100200 #define GLU_CULLING 100201 #define GLU_SAMPLING_TOLERANCE 100203 #define GLU_DISPLAY_MODE 100204 #define GLU_PARAMETRIC_TOLERANCE 100202 #define GLU_SAMPLING_METHOD 100205 #define GLU_U_STEP 100206 #define GLU_V_STEP 100207 #define GLU_PATH_LENGTH 100215 #define GLU_PARAMETRIC_ERROR 100216 #define GLU_DOMAIN_DISTANCE 100217 #define GLU_MAP1_TRIM_2 100210 #define GLU_MAP1_TRIM_3 100211 #define GLU_OUTLINE_POLYGON 100240 #define GLU_OUTLINE_PATCH 100241 #define GLU_NURBS_ERROR1 100251 #define GLU_NURBS_ERROR2 100252 #define GLU_NURBS_ERROR3 100253 #define GLU_NURBS_ERROR4 100254 #define GLU_NURBS_ERROR5 100255 #define GLU_NURBS_ERROR6 100256 #define GLU_NURBS_ERROR7 100257 #define GLU_NURBS_ERROR8 100258 #define GLU_NURBS_ERROR9 100259 #define GLU_NURBS_ERROR10 100260 #define GLU_NURBS_ERROR11 100261 #define GLU_NURBS_ERROR12 100262 #define GLU_NURBS_ERROR13 100263 #define GLU_NURBS_ERROR14 100264 #define GLU_NURBS_ERROR15 100265 #define GLU_NURBS_ERROR16 100266 #define GLU_NURBS_ERROR17 100267 #define GLU_NURBS_ERROR18 100268 #define GLU_NURBS_ERROR19 100269 #define GLU_NURBS_ERROR20 100270 #define GLU_NURBS_ERROR21 100271 #define GLU_NURBS_ERROR22 100272 #define GLU_NURBS_ERROR23 100273 #define GLU_NURBS_ERROR24 100274 #define GLU_NURBS_ERROR25 100275 #define GLU_NURBS_ERROR26 100276 #define GLU_NURBS_ERROR27 100277 #define GLU_NURBS_ERROR28 100278 #define GLU_NURBS_ERROR29 100279 #define GLU_NURBS_ERROR30 100280 #define GLU_NURBS_ERROR31 100281 #define GLU_NURBS_ERROR32 100282 #define GLU_NURBS_ERROR33 100283 #define GLU_NURBS_ERROR34 100284 #define GLU_NURBS_ERROR35 100285 #define GLU_NURBS_ERROR36 100286 #define GLU_NURBS_ERROR37 100287 void APIENTRY gluBeginPolygon(GLUtesselator *tess); void APIENTRY gluNextContour(GLUtesselator *tess,GLenum type); void APIENTRY gluEndPolygon(GLUtesselator *tess); #define GLU_CW 100120 #define GLU_CCW 100121 #define GLU_INTERIOR 100122 #define GLU_EXTERIOR 100123 #define GLU_UNKNOWN 100124 #define GLU_BEGIN GLU_TESS_BEGIN #define GLU_VERTEX GLU_TESS_VERTEX #define GLU_END GLU_TESS_END #define GLU_ERROR GLU_TESS_ERROR #define GLU_EDGE_FLAG GLU_TESS_EDGE_FLAG #ifdef __cplusplus } #endif #endif #endif