diff options
author | Brian Paul <brian.paul@tungstengraphics.com> | 2000-12-08 00:20:15 +0000 |
---|---|---|
committer | Brian Paul <brian.paul@tungstengraphics.com> | 2000-12-08 00:20:15 +0000 |
commit | 06d05afdd687fcd1d59d46c6a86c2e5707e1859b (patch) | |
tree | 420757bc9e8fbf482ef12cdca2d578b379165a32 /src/mesa/swrast | |
parent | fb7899bfec447e5840c2c1ea96619084093be424 (diff) |
Initial work on GL_MESA_sprite_point extension.
Still need to resolve clipping issues, finalize the spec.
Diffstat (limited to 'src/mesa/swrast')
-rw-r--r-- | src/mesa/swrast/s_points.c | 113 |
1 files changed, 111 insertions, 2 deletions
diff --git a/src/mesa/swrast/s_points.c b/src/mesa/swrast/s_points.c index 6e7e7010b2..58cf8e9946 100644 --- a/src/mesa/swrast/s_points.c +++ b/src/mesa/swrast/s_points.c @@ -1,4 +1,4 @@ -/* $Id: s_points.c,v 1.8 2000/12/08 00:18:39 brianp Exp $ */ +/* $Id: s_points.c,v 1.9 2000/12/08 00:20:15 brianp Exp $ */ /* * Mesa 3-D graphics library @@ -838,6 +838,60 @@ dist_atten_antialiased_rgba_point( GLcontext *ctx, const SWvertex *vert ) } +/* + * Sprite (textured point) + */ +static void +sprite_point( GLcontext *ctx, const SWvertex *vert ) +{ + SWcontext *swctx = SWRAST_CONTEXT(ctx); + const GLfloat radius = vert->pointSize; /* XXX threshold, alpha */ + SWvertex v0, v1, v2, v3; + GLuint unit; + + /* lower left corner */ + v0 = *vert; + v0.win[0] -= radius; + v0.win[1] -= radius; + + /* lower right corner */ + v1 = *vert; + v1.win[0] += radius; + v1.win[1] -= radius; + + /* upper right corner */ + v2 = *vert; + v2.win[0] += radius; + v2.win[1] += radius; + + /* upper left corner */ + v3 = *vert; + v3.win[0] -= radius; + v3.win[1] += radius; + + for (unit = 0; unit < ctx->Const.MaxTextureUnits; unit++) { + if (ctx->Texture.Unit[unit]._ReallyEnabled) { + v0.texcoord[unit][0] = 0.0; + v0.texcoord[unit][1] = 0.0; + v1.texcoord[unit][0] = 1.0; + v1.texcoord[unit][1] = 0.0; + v2.texcoord[unit][0] = 1.0; + v2.texcoord[unit][1] = 1.0; + v3.texcoord[unit][0] = 0.0; + v3.texcoord[unit][1] = 1.0; + } + } + + /* XXX if radius < threshold, attenuate alpha? */ + /* XXX what about clipping? */ + + /* render */ + swctx->Triangle(ctx, &v0, &v1, &v2); + swctx->Triangle(ctx, &v0, &v2, &v3); +} + + + #ifdef DEBUG extern void @@ -889,7 +943,11 @@ _swrast_choose_point( GLcontext *ctx ) GLboolean rgbmode = ctx->Visual.RGBAflag; if (ctx->RenderMode==GL_RENDER) { - if (!ctx->Point._Attenuated) { + if (ctx->Point.SpriteMode) { + /* XXX this is hacked in! */ + swrast->Point = sprite_point; + } + else if (!ctx->Point._Attenuated) { if (ctx->Point.SmoothFlag && rgbmode) { swrast->Point = antialiased_rgba_point; } @@ -943,3 +1001,54 @@ _swrast_choose_point( GLcontext *ctx ) /*_mesa_print_points_function(ctx);*/ } + + +#if 000 /* prototype of new point code */ + +#define RGBA 0x1 +#define SMOOTH 0x2 +#define LARGE 0x4 +#define TEXTURE 0x8 +#define ATTENUATE 0x10 +#define SPRITE 0x20 + +#define FLAGS (RGBA | SMOOTH | LARGE) +#define NAME rgba_smooth_large +#include "s_pointtemp.h" + +#define FLAGS (RGBA | TEXTURE | ATTENUATE) +#define NAME rgba_texture_smooth_attenuate +#include "s_pointtemp.h" + +#define FLAGS (INDEX | LARGE | ATTENUATE) +#define NAME index_large_attenuate +#include "s_pointtemp.h" + + +static void* point_tab[0x20]; + +void +_swrast_choose_point( GLcontext *ctx ) +{ + GLuint index = 0; + + if (ctx->RenderMode==GL_RENDER) { + if (ctx->Visual.RGBAflag) + index |= RGBA; + if (ctx->Point.SmoothFlag) + index |= SMOOTH; + if (ctx->Point._Attenuated || ctx->Point.Size > 1.0) + index |= SIZED; + if (ctx->Texture.ReallyEnabled) + index |= TEXTURE; + swrast->Point = point_tab[index]; + } + else if (ctx->RenderMode==GL_FEEDBACK) { + swrast->Point = gl_feedback_point; + } + else { + /* GL_SELECT mode */ + swrast->Point = gl_select_point; + } +} +#endif |