CIRCLE.C 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. /*
  2. THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
  3. SOFTWARE CORPORATION ("PARALLAX"). PARALLAX, IN DISTRIBUTING THE CODE TO
  4. END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
  5. ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
  6. IN USING, DISPLAYING, AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
  7. SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
  8. FREE PURPOSES. IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
  9. CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES. THE END-USER UNDERSTANDS
  10. AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
  11. COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION. ALL RIGHTS RESERVED.
  12. */
  13. /*
  14. * $Source: f:/miner/source/2d/rcs/circle.c $
  15. * $Revision: 1.3 $
  16. * $Author: john $
  17. * $Date: 1994/11/18 22:51:01 $
  18. *
  19. * .
  20. *
  21. * $Log: circle.c $
  22. * Revision 1.3 1994/11/18 22:51:01 john
  23. * Changed a bunch of shorts to ints in calls.
  24. *
  25. * Revision 1.2 1994/05/12 17:33:18 john
  26. * Added circle code.
  27. *
  28. * Revision 1.1 1994/05/12 17:21:49 john
  29. * Initial revision
  30. *
  31. *
  32. */
  33. #pragma off (unreferenced)
  34. static char rcsid[] = "$Id: circle.c 1.3 1994/11/18 22:51:01 john Exp $";
  35. #pragma on (unreferenced)
  36. #include "mem.h"
  37. #include "gr.h"
  38. #include "grdef.h"
  39. int gr_circle(fix xc1,fix yc1,fix r1)
  40. {
  41. int p,x, y, xc, yc, r;
  42. r = f2i(r1);
  43. xc = f2i(xc1);
  44. yc = f2i(yc1);
  45. p=3-(r*2);
  46. x=0;
  47. y=r;
  48. // Big clip
  49. if ( (xc+r) < 0 ) return 1;
  50. if ( (xc-r) > WIDTH ) return 1;
  51. if ( (yc+r) < 0 ) return 1;
  52. if ( (yc-r) > HEIGHT ) return 1;
  53. while(x<y)
  54. {
  55. // Draw the first octant
  56. gr_pixel( xc-y, yc-x );
  57. gr_pixel( xc+y, yc-x );
  58. gr_pixel( xc-y, yc+x );
  59. gr_pixel( xc+y, yc+x );
  60. if (p<0)
  61. p=p+(x<<2)+6;
  62. else {
  63. // Draw the second octant
  64. gr_pixel( xc-x, yc-y );
  65. gr_pixel( xc+x, yc-y );
  66. gr_pixel( xc-x, yc+y );
  67. gr_pixel( xc+x, yc+y );
  68. p=p+((x-y)<<2)+10;
  69. y--;
  70. }
  71. x++;
  72. }
  73. if(x==y) {
  74. gr_pixel( xc-x, yc-y );
  75. gr_pixel( xc+x, yc-y );
  76. gr_pixel( xc-x, yc+y );
  77. gr_pixel( xc+x, yc+y );
  78. }
  79. return 0;
  80. }
  81. int gr_ucircle(fix xc1,fix yc1,fix r1)
  82. {
  83. int p,x, y, xc, yc, r;
  84. r = f2i(r1);
  85. xc = f2i(xc1);
  86. yc = f2i(yc1);
  87. p=3-(r*2);
  88. x=0;
  89. y=r;
  90. while(x<y)
  91. {
  92. // Draw the first octant
  93. gr_upixel( xc-y, yc-x );
  94. gr_upixel( xc+y, yc-x );
  95. gr_upixel( xc-y, yc+x );
  96. gr_upixel( xc+y, yc+x );
  97. if (p<0)
  98. p=p+(x<<2)+6;
  99. else {
  100. // Draw the second octant
  101. gr_upixel( xc-x, yc-y );
  102. gr_upixel( xc+x, yc-y );
  103. gr_upixel( xc-x, yc+y );
  104. gr_upixel( xc+x, yc+y );
  105. p=p+((x-y)<<2)+10;
  106. y--;
  107. }
  108. x++;
  109. }
  110. if(x==y) {
  111. gr_upixel( xc-x, yc-y );
  112. gr_upixel( xc+x, yc-y );
  113. gr_upixel( xc-x, yc+y );
  114. gr_upixel( xc+x, yc+y );
  115. }
  116. return 0;
  117. }
  118.