GRASS Programmer's Manual  6.5.svn(2014)-r66266
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
gsd_surf.c File Reference

OGSF library - loading and manipulating surfaces. More...

#include <stdlib.h>
#include <grass/gis.h>
#include <grass/glocale.h>
#include <grass/gstypes.h>
#include "gsget.h"
#include "rowcol.h"
Include dependency graph for gsd_surf.c:

Go to the source code of this file.

Macros

#define DEBUG_ARROW   (0)
 
#define SET_SCOLOR(sf)
 MACROS for use in gsd_ortho_wall ONLY !!! More...
 

Functions

int gsd_surf (geosurf *surf)
 ADD. More...
 
int gsd_surf_map_old (geosurf *surf)
 ADD. More...
 
int gsd_surf_const (geosurf *surf, float k)
 Using tmesh - not confident with qstrips portability. More...
 
int gsd_surf_func (geosurf *gs, int(*user_func)())
 Define user function. More...
 
int gsd_triangulated_wall (int npts1, int npts2, geosurf *surf1, geosurf *surf2, Point3 *points1, Point3 *points2, float *norm)
 ADD. More...
 
void gsd_setfc (int mode)
 ADD. More...
 
int gsd_getfc (void)
 ADD. More...
 
int gsd_ortho_wall (int np, int ns, geosurf **gsurfs, Point3 **points, float *norm)
 ADD. More...
 
int gsd_wall (float *bgn, float *end, float *norm)
 ADD. More...
 
int gsd_norm_arrows (geosurf *surf)
 ADD. More...
 
int gsd_surf_map (geosurf *surf)
 Draw surface using triangle fan instead of strip. More...
 

Detailed Description

OGSF library - loading and manipulating surfaces.

GRASS OpenGL gsurf OGSF Library

(C) 1999-2008 by the GRASS Development Team

This program is free software under the GNU General Public License (>=v2). Read the file COPYING that comes with GRASS for details.

Author
Bill Brown USACERL (October 1993)
Doxygenized by Martin Landa <landa.martin gmail.com> (May 2008)

Definition in file gsd_surf.c.

Macro Definition Documentation

#define DEBUG_ARROW   (0)

Definition at line 41 of file gsd_surf.c.

Referenced by gsd_norm_arrows().

#define SET_SCOLOR (   sf)
Value:
if(check_color[sf]) \
{ \
tx = points[sf][i][X] - gsurfs[sf]->x_trans; \
ty = points[sf][i][Y] - gsurfs[sf]->y_trans; \
offset = XY2OFF(gsurfs[sf], tx, ty); \
colors[sf] = gs_mapcolor(cobuf[sf], coloratt[sf], offset); \
}
#define XY2OFF(gs, px, py)
Definition: rowcol.h:22
#define Y(x)
Definition: display/draw.c:246
#define X(y)
Definition: display/draw.c:248
int gs_mapcolor(typbuff *cobuff, gsurf_att *coloratt, int offset)
Call this one when you already know att_src is MAP_ATT.
Definition: gs.c:969

MACROS for use in gsd_ortho_wall ONLY !!!

Definition at line 46 of file gsd_surf.c.

Referenced by gsd_ortho_wall().

Function Documentation

int gsd_getfc ( void  )

ADD.

Returns

Definition at line 1220 of file gsd_surf.c.

Referenced by GS_get_fencecolor(), and GS_transp_is_set().

int gsd_norm_arrows ( geosurf *  surf)

ADD.

Need to do Zexag scale of normal for arrow direction, drawing routine unexags z for arrow

Parameters
surfsurface (geosurf)
Returns

Definition at line 1810 of file gsd_surf.c.

References BM_get(), buff, DEBUG_ARROW, FNORM, G_debug(), GET_MAPATT, GS_check_cancel(), gs_get_att_typbuff(), GS_get_scale(), GS_global_exag(), gs_mapcolor(), gs_update_curmask(), gsd_3darrow(), gsd_arrow(), gsd_colormode(), gsd_do_scale(), gsd_popmatrix(), gsd_pushmatrix(), gsd_translate(), if(), int, VCOLS, VROWS, X, Y, and ymax.

Referenced by gsd_surf().

int gsd_ortho_wall ( int  np,
int  ns,
geosurf **  gsurfs,
Point3 **  points,
float *  norm 
)
void gsd_setfc ( int  mode)

ADD.

Parameters
mode

Definition at line 1208 of file gsd_surf.c.

References tools::mode.

Referenced by GS_set_fencecolor().

int gsd_surf ( geosurf *  surf)

ADD.

Parameters
surfsurface (geosurf)
Returns
-1 on error

Definition at line 81 of file gsd_surf.c.

References G_debug(), gs_calc_normals(), gs_get_att_src(), gsd_norm_arrows(), gsd_surf_const(), gsd_surf_func(), and gsd_surf_map().

Referenced by GS_draw_surf().

int gsd_surf_const ( geosurf *  surf,
float  k 
)

Using tmesh - not confident with qstrips portability.

Todo:
FIX: do_diff won't work right - needs normals - maybe calculate on the fly
Parameters
surfsurface (geosurf)
k
Returns

Definition at line 729 of file gsd_surf.c.

References BM_get(), G_debug(), GS_check_cancel(), gs_get_att_typbuff(), GS_get_scale(), gs_mapcolor(), gs_update_curmask(), gsd_bgnpolygon(), gsd_bgntmesh(), gsd_blend(), gsd_checkpoint(), gsd_colormode(), gsd_do_scale(), gsd_endpolygon(), gsd_endtmesh(), gsd_getwindow(), gsd_litvert_func(), gsd_popmatrix(), gsd_pushmatrix(), gsd_translate(), gsd_zwritemask(), gsdiff_do_SD(), gsdiff_get_SDref(), int, n, NULL, VCOLS, VROWS, tools::window, X, Y, and ymax.

Referenced by gsd_coarse_surf_map(), gsd_surf(), gsd_surf_map(), and gsd_surf_map_old().

int gsd_surf_func ( geosurf *  gs,
int(*)()  user_func 
)

Define user function.

Not yet supported

Parameters
gssurface (geosurf)
user_funcuser function
Returns
1

Definition at line 1092 of file gsd_surf.c.

Referenced by gsd_surf().

int gsd_surf_map ( geosurf *  surf)

Draw surface using triangle fan instead of strip.

Optimized by getting rid of BM_get mask check - GET_MAPPATT does same and returns zero if masked

Only do in window check on Fan center(v0) to further optimize – this runs the risk of trimming points in view !!

Parameters
surfsurface (geosurf)
Returns

Definition at line 2062 of file gsd_surf.c.

References buff, FNORM, GET_MAPATT, GS_check_cancel(), gs_get_att_typbuff(), GS_get_scale(), GS_global_exag(), gs_mapcolor(), gs_update_curmask(), gsd_bgntfan(), gsd_blend(), gsd_checkpoint(), gsd_colormode(), gsd_do_scale(), gsd_endtfan(), gsd_getwindow(), gsd_litvert_func(), gsd_popmatrix(), gsd_pushmatrix(), gsd_set_material(), gsd_surf_const(), gsd_translate(), gsd_zwritemask(), int, SCALE_ATT, VCOLS, VROWS, tools::window, X, Y, and ymax.

Referenced by gsd_surf().

int gsd_triangulated_wall ( int  npts1,
int  npts2,
geosurf *  surf1,
geosurf *  surf2,
Point3 *  points1,
Point3 *  points2,
float *  norm 
)

ADD.

Parameters
npts1
npts2
surf1first surface (geosurf)
surf2second surface (geosurf)
points1
points2
norm
Returns
1

Definition at line 1111 of file gsd_surf.c.

References gs_get_att_typbuff(), gs_mapcolor(), gsd_bgntmesh(), gsd_colormode(), gsd_do_scale(), gsd_endtmesh(), gsd_litvert_func(), gsd_popmatrix(), gsd_pushmatrix(), int, X, XY2OFF, and Y.

int gsd_wall ( float *  bgn,
float *  end,
float *  norm 
)

ADD.

bgn,end should already be in world modeling coords, but have to be reverse-translated to apply to each surface

Parameters
bgn,end2d line for cutting plane
normindicates which way wall faces
Returns

Definition at line 1715 of file gsd_surf.c.

References err, G_free(), G_warning(), gs_getall_surfaces(), GS_v3eq(), gsd_ortho_wall(), gsdrape_get_allsegments(), n, X, and Y.

Referenced by gsd_draw_cplane_fence().