home *** CD-ROM | disk | FTP | other *** search
/ Monster Disc 2: The Best of 1992 / MONSTER2.ISO / prog / djgpp / cbgrx102.a01 / CONTRIB / LIBGRX / SRC / FILLARC.C < prev    next >
Encoding:
C/C++ Source or Header  |  1992-08-12  |  1.8 KB  |  58 lines

  1. /**
  2.  ** FILLARC.C
  3.  **
  4.  **  Copyright (C) 1992, Csaba Biegl
  5.  **    820 Stirrup Dr, Nashville, TN, 37221
  6.  **    csaba@vuse.vanderbilt.edu
  7.  **
  8.  **  This file is distributed under the terms listed in the document
  9.  **  "copying.cb", available from the author at the address above.
  10.  **  A copy of "copying.cb" should accompany this file; if not, a copy
  11.  **  should be available from where this file was obtained.  This file
  12.  **  may not be distributed without a verbatim copy of "copying.cb".
  13.  **  You should also have received a copy of the GNU General Public
  14.  **  License along with this program (it is in the file "copying");
  15.  **  if not, write to the Free Software Foundation, Inc., 675 Mass Ave,
  16.  **  Cambridge, MA 02139, USA.
  17.  **
  18.  **  This program is distributed in the hope that it will be useful,
  19.  **  but WITHOUT ANY WARRANTY; without even the implied warranty of
  20.  **  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  21.  **  GNU General Public License for more details.
  22.  **/
  23.  
  24. #include "grx.h"
  25. #include "libgrx.h"
  26. #include "clipping.h"
  27.  
  28. void GrFilledEllipseArc(int xc,int yc,int xa,int ya,int start,int end,int c)
  29. {
  30.     int pt[MAX_ELLIPSE_PTS+1][2];
  31.     int x1,x2,y1,y2,nn;
  32.     MOUSE_FLAG;
  33.  
  34.     if(xa < 0) xa = (-xa);
  35.     if(ya < 0) ya = (-ya);
  36.     x1 = xc - xa; y1 = yc - ya;
  37.     x2 = xc + xa; y2 = yc + ya;
  38.     CLIPSORTEDBOX(CURC,x1,y1,x2,y2);
  39.     MOUSE_BLOCK(CURC,x1,y1,x2,y2);
  40.     nn = _GrGenerateEllipseArc(pt,xc,yc,xa,ya,start,end);
  41.     if(nn < 0)
  42.         GrFilledConvexPolygon((-nn),pt,c);
  43.     else if(nn == 1)
  44.         GrPlot(pt[0][0],pt[0][1],c);
  45.     else {
  46.         pt[nn][0] = xc;
  47.         pt[nn][1] = yc;
  48.         GrFilledPolygon(++nn,pt,c);
  49.     }
  50.     MOUSE_UNBLOCK();
  51. }
  52.  
  53. void GrFilledCircleArc(int xc,int yc,int r,int start,int end,int c)
  54. {
  55.     GrFilledEllipseArc(xc,yc,r,r,start,end,c);
  56. }
  57.  
  58.