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

trimregion.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  * trimregion.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/trimregion.cc,v 1.1 2004/02/02 16:39:13 navaraf Exp $
00040  */
00041 
00042 #include "glimports.h"
00043 #include "myassert.h"
00044 #include "mystdio.h"
00045 #include "trimregion.h"
00046 #include "backend.h"
00047 
00048 TrimRegion::TrimRegion( void )
00049 {
00050 }
00051 
00052 void
00053 TrimRegion::setDu( REAL du )
00054 {
00055     oneOverDu = 1.0/du;
00056 }
00057 
00058 void
00059 TrimRegion::init( long npts, Arc_ptr extrema )
00060 {
00061     left.init( npts, extrema, extrema->pwlArc->npts - 1 ); 
00062     left.getNextPt();
00063 
00064     right.init( npts, extrema, 0 ); 
00065     right.getPrevPt();
00066 }
00067 
00068 void
00069 TrimRegion::getPts( Arc_ptr extrema )
00070 {
00071     left.getNextPts( extrema );
00072     right.getPrevPts( extrema );
00073 }
00074 
00075 void
00076 TrimRegion::getPts( Backend &backend )
00077 {
00078     left.getNextPts( bot.vval, backend );
00079     right.getPrevPts( bot.vval, backend );
00080 }
00081 
00082 void 
00083 TrimRegion::getGridExtent( void )
00084 {
00085     getGridExtent( left.last(), right.last() );
00086 }
00087 
00088 void
00089 TrimRegion::getGridExtent( TrimVertex *l, TrimVertex *r )
00090 {
00091     bot.ustart = (long) ((l->param[0] - uarray.uarray[0])*oneOverDu);
00092     if( l->param[0] >= uarray.uarray[bot.ustart] ) bot.ustart++;
00093 //  if( l->param[0] > uarray.uarray[bot.ustart] ) bot.ustart++;
00094     assert( l->param[0] <= uarray.uarray[bot.ustart] );
00095     assert( l->param[0] >= uarray.uarray[bot.ustart-1] );
00096 
00097     bot.uend = (long) ((r->param[0] - uarray.uarray[0])*oneOverDu);
00098     if( uarray.uarray[bot.uend] >= r->param[0] ) bot.uend--;
00099 //  if( uarray.uarray[bot.uend] > r->param[0] ) bot.uend--;
00100     assert( r->param[0] >= uarray.uarray[bot.uend] );
00101     assert( r->param[0] <= uarray.uarray[bot.uend+1] );
00102 }
00103 
00104 int
00105 TrimRegion::canTile( void )
00106 {
00107     TrimVertex *lf = left.first();
00108     TrimVertex *ll = left.last();
00109     TrimVertex *l = ( ll->param[0] > lf->param[0] ) ? ll : lf; 
00110 
00111     TrimVertex *rf = right.first();
00112     TrimVertex *rl = right.last();
00113     TrimVertex *r = ( rl->param[0] < rf->param[0] ) ? rl : rf;
00114     return (l->param[0] <= r->param[0]) ? 1 : 0;
00115 }
00116 

Generated on Sun May 27 2012 04:23:48 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.