ReactOS Fundraising Campaign 2012
 
€ 4,410 / € 30,000

Information | Donate

Home | Info | Community | Development | myReactOS | Contact Us

  1. Home
  2. Community
  3. Development
  4. myReactOS
  5. Fundraiser 2012

  1. Main Page
  2. Alphabetical List
  3. Data Structures
  4. Directories
  5. File List
  6. Data Fields
  7. Globals
  8. Related Pages

ReactOS Development > Doxygen

curvesub.cc
Go to the documentation of this file.
00001 /*
00002 ** License Applicability. Except to the extent portions of this file are
00003 ** made subject to an alternative license as permitted in the SGI Free
00004 ** Software License B, Version 1.1 (the "License"), the contents of this
00005 ** file are subject only to the provisions of the License. You may not use
00006 ** this file except in compliance with the License. You may obtain a copy
00007 ** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600
00008 ** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at:
00009 **
00010 ** http://oss.sgi.com/projects/FreeB
00011 **
00012 ** Note that, as provided in the License, the Software is distributed on an
00013 ** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS
00014 ** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND
00015 ** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A
00016 ** PARTICULAR PURPOSE, AND NON-INFRINGEMENT.
00017 **
00018 ** Original Code. The Original Code is: OpenGL Sample Implementation,
00019 ** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics,
00020 ** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.
00021 ** Copyright in any portions created by third parties is as indicated
00022 ** elsewhere herein. All Rights Reserved.
00023 **
00024 ** Additional Notice Provisions: The application programming interfaces
00025 ** established by SGI in conjunction with the Original Code are The
00026 ** OpenGL(R) Graphics System: A Specification (Version 1.2.1), released
00027 ** April 1, 1999; The OpenGL(R) Graphics System Utility Library (Version
00028 ** 1.3), released November 4, 1998; and OpenGL(R) Graphics with the X
00029 ** Window System(R) (Version 1.3), released October 19, 1998. This software
00030 ** was created using the OpenGL(R) version 1.2.1 Sample Implementation
00031 ** published by SGI, but has not been independently verified as being
00032 ** compliant with the OpenGL(R) version 1.2.1 Specification.
00033 */
00034 
00035 /*
00036  * curvesub.c++
00037  *
00038  * $Date: 2006-03-12 00:07:02 +0000 (Sun, 12 Mar 2006) $ $Revision: 1.1 $
00039  * $Header: /cygdrive/c/RCVS/CVS/ReactOS/reactos/lib/glu32/libnurbs/internals/curvesub.cc,v 1.1 2004/02/02 16:39:11 navaraf Exp $
00040  */
00041 
00042 #include "glimports.h"
00043 #include "myassert.h"
00044 #include "mystdio.h"
00045 #include "subdivider.h"
00046 #include "renderhints.h"
00047 #include "backend.h"
00048 #include "quilt.h"
00049 #include "curvelist.h"
00050 #include "curve.h"
00051 #include "nurbsconsts.h"
00052 
00053 /*--------------------------------------------------------------------------
00054  * drawCurves - main curve rendering entry point
00055  *--------------------------------------------------------------------------
00056  */
00057 
00058 void
00059 Subdivider::drawCurves( void )
00060 {
00061     REAL    from[1], to[1];
00062     Flist   bpts;
00063     qlist->getRange( from, to, bpts );
00064 
00065     renderhints.init( );
00066 
00067     backend.bgncurv();
00068     for( int i=bpts.start; i<bpts.end-1; i++ ) {
00069         REAL pta, ptb;
00070     pta = bpts.pts[i];
00071     ptb = bpts.pts[i+1];
00072 
00073     qlist->downloadAll( &pta, &ptb, backend );
00074 
00075     Curvelist curvelist( qlist, pta, ptb );
00076     samplingSplit( curvelist, renderhints.maxsubdivisions );
00077     }
00078     backend.endcurv();
00079 }
00080 
00081 
00082 /*--------------------------------------------------------------------------
00083  * samplingSplit - recursively subdivide patch, cull check each subpatch  
00084  *--------------------------------------------------------------------------
00085  */
00086 
00087 void
00088 Subdivider::samplingSplit( Curvelist& curvelist, int subdivisions )
00089 {
00090     if( curvelist.cullCheck() == CULL_TRIVIAL_REJECT )  return;
00091 
00092     curvelist.getstepsize();
00093 
00094     if( curvelist.needsSamplingSubdivision() && (subdivisions > 0) ) {
00095     REAL mid = ( curvelist.range[0] + curvelist.range[1] ) * 0.5;
00096     Curvelist lowerlist( curvelist, mid );
00097     samplingSplit( lowerlist, subdivisions-1 ); // lower
00098     samplingSplit( curvelist, subdivisions-1 ); // upper
00099     } else {
00100     long nu = 1 + ((long) (curvelist.range[2] / curvelist.stepsize));
00101     backend.curvgrid( curvelist.range[0], curvelist.range[1], nu );
00102     backend.curvmesh( 0, nu );
00103     }
00104 }
00105 

Generated on Sat May 26 2012 04:22:16 for ReactOS by doxygen 1.7.6.1

ReactOS is a registered trademark or a trademark of ReactOS Foundation in the United States and other countries.