source: trunk/src/opengl/glu/nurbs/internals/reader.cpp

Last change on this file was 2689, checked in by jeroen, 26 years ago

* empty log message *

File size: 4.7 KB
Line 
1/* $Id: reader.cpp,v 1.1 2000-02-09 08:50:28 jeroen Exp $ */
2/*
3** License Applicability. Except to the extent portions of this file are
4** made subject to an alternative license as permitted in the SGI Free
5** Software License B, Version 1.0 (the "License"), the contents of this
6** file are subject only to the provisions of the License. You may not use
7** this file except in compliance with the License. You may obtain a copy
8** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600
9** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at:
10**
11** http://oss.sgi.com/projects/FreeB
12**
13** Note that, as provided in the License, the Software is distributed on an
14** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS
15** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND
16** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A
17** PARTICULAR PURPOSE, AND NON-INFRINGEMENT.
18**
19** Original Code. The Original Code is: OpenGL Sample Implementation,
20** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics,
21** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.
22** Copyright in any portions created by third parties is as indicated
23** elsewhere herein. All Rights Reserved.
24**
25** Additional Notice Provisions: The application programming interfaces
26** established by SGI in conjunction with the Original Code are The
27** OpenGL(R) Graphics System: A Specification (Version 1.2.1), released
28** April 1, 1999; The OpenGL(R) Graphics System Utility Library (Version
29** 1.3), released November 4, 1998; and OpenGL(R) Graphics with the X
30** Window System(R) (Version 1.3), released October 19, 1998. This software
31** was created using the OpenGL(R) version 1.2.1 Sample Implementation
32** published by SGI, but has not been independently verified as being
33** compliant with the OpenGL(R) version 1.2.1 Specification.
34*/
35
36/*
37 * reader.c++
38 *
39 * $Date: 2000-02-09 08:50:28 $ $Revision: 1.1 $
40 * $Header: /home/ktk/tmp/odin/2007/netlabs.cvs/odin32/src/opengl/glu/nurbs/internals/reader.cpp,v 1.1 2000-02-09 08:50:28 jeroen Exp $
41 */
42
43#include <stdio.h>
44#include "glimports.h"
45#include "nurbsconsts.h"
46#include "reader.h"
47#include "trimvertex.h"
48#include "simplemath.h"
49
50//when read a pwlCurve, if two consecutive points are the same, then
51//eliminate one of them. This makes the tessellator more robust. The spec
52//assumes the application makes sure there are no redundant points.
53//but in Inspector, the trim curves seem to have redundant points a lot.
54//I guess other similar users may have the same problem.
55
56#define ELIMINATE_REDUNDANT_POINTS
57
58#ifdef ELIMINATE_REDUNDANT_POINTS
59#define equal(x,y) ( abs(x-y) <= 0.00001)
60#endif
61
62#ifdef ELIMINATE_REDUNDANT_POINTS
63O_pwlcurve::O_pwlcurve( long _type, long count, INREAL *array, long byte_stride, TrimVertex *trimpts )
64{
65 next = 0;
66 used = 0;
67 owner = 0;
68 pts = trimpts;
69 npts = (int) count;
70 int i;
71
72 /* copy user data into internal trimming data structures */
73 switch( _type ) {
74 case N_P2D: {
75 TrimVertex *v = pts;
76 TrimVertex *prev = NULL;
77 int num = 0;
78 int doit;
79 for(i=0; i<count; i++) {
80 doit = 1;
81 if(prev != NULL)
82 {
83 if(equal(prev->param[0], array[0]) && equal(prev->param[1], array[1]))
84 {
85 doit = 0;
86 }
87 }
88
89 if(doit)
90 {
91 v->param[0] = (REAL) array[0];
92 v->param[1] = (REAL) array[1];
93 prev = v;
94 v++;
95 num++;
96 }
97 array = (INREAL *) (((char *) array) + byte_stride);
98 }
99 npts = num;
100 break;
101 }
102 case N_P2DR: {
103 TrimVertex *v = pts;
104 for( TrimVertex *lastv = v + count; v != lastv; v++ ) {
105 v->param[0] = (REAL) array[0] / (REAL) array[2];
106 v->param[1] = (REAL) array[1] / (REAL) array[2];
107 array = (INREAL *) (((char *) array) + byte_stride);
108 }
109 break;
110 }
111 }
112}
113#else
114O_pwlcurve::O_pwlcurve( long _type, long count, INREAL *array, long byte_stride, TrimVertex *trimpts )
115{
116 next = 0;
117 used = 0;
118 owner = 0;
119 pts = trimpts;
120 npts = (int) count;
121
122 /* copy user data into internal trimming data structures */
123 switch( _type ) {
124 case N_P2D: {
125 TrimVertex *v = pts;
126 for( TrimVertex *lastv = v + count; v != lastv; v++ ) {
127 v->param[0] = (REAL) array[0];
128 v->param[1] = (REAL) array[1];
129 array = (INREAL *) (((char *) array) + byte_stride);
130 }
131 break;
132 }
133 case N_P2DR: {
134 TrimVertex *v = pts;
135 for( TrimVertex *lastv = v + count; v != lastv; v++ ) {
136 v->param[0] = (REAL) array[0] / (REAL) array[2];
137 v->param[1] = (REAL) array[1] / (REAL) array[2];
138 array = (INREAL *) (((char *) array) + byte_stride);
139 }
140 break;
141 }
142 }
143}
144#endif
145
146
147
148
149
Note: See TracBrowser for help on using the repository browser.