BOX.C 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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-1999 PARALLAX SOFTWARE CORPORATION. ALL RIGHTS RESERVED.
  12. */
  13. #include "mem.h"
  14. #include "gr.h"
  15. #include "grdef.h"
  16. void gr_ubox0(int left,int top,int right,int bot)
  17. {
  18. int i, d;
  19. unsigned char * ptr1;
  20. unsigned char * ptr2;
  21. ptr1 = DATA + ROWSIZE *top+left;
  22. ptr2 = ptr1;
  23. d = right - left;
  24. for (i=top; i<=bot; i++ )
  25. {
  26. ptr2[0] = COLOR;
  27. ptr2[d] = COLOR;
  28. ptr2 += ROWSIZE;
  29. }
  30. ptr2 = ptr1;
  31. d = (bot - top)*ROWSIZE;
  32. for (i=1; i<(right-left); i++ )
  33. {
  34. ptr2[i+0] = COLOR;
  35. ptr2[i+d] = COLOR;
  36. }
  37. }
  38. void gr_box0(int left,int top,int right,int bot)
  39. {
  40. if (top > MAXY ) return;
  41. if (bot < MINY ) return;
  42. if (left > MAXX ) return;
  43. if (right < MINX ) return;
  44. if (top < MINY) top = MINY;
  45. if (bot > MAXY ) bot = MAXY;
  46. if (left < MINX) left = MINX;
  47. if (right > MAXX ) right = MAXX;
  48. gr_ubox0(left,top,right,bot);
  49. }
  50. void gr_ubox12(int left,int top,int right,int bot)
  51. {
  52. int i;
  53. for (i=top; i<=bot; i++ )
  54. {
  55. gr_upixel( left, i );
  56. gr_upixel( right, i );
  57. }
  58. gr_uscanline( left, right, top );
  59. gr_uscanline( left, right, bot );
  60. }
  61. void gr_box12(int left,int top,int right,int bot)
  62. {
  63. if (top > MAXY ) return;
  64. if (bot < MINY ) return;
  65. if (left > MAXX ) return;
  66. if (right < MINX ) return;
  67. if (top < MINY) top = MINY;
  68. if (bot > MAXY ) bot = MAXY;
  69. if (left < MINX) left = MINX;
  70. if (right > MAXX ) right = MAXX;
  71. gr_ubox12(left, top, right, bot );
  72. }
  73. void gr_ubox(int left,int top,int right,int bot)
  74. {
  75. if (TYPE==BM_LINEAR)
  76. gr_ubox0( left, top, right, bot );
  77. else if ( TYPE == BM_MODEX )
  78. gr_ubox12( left, top, right, bot );
  79. else
  80. gr_ubox12( left, top, right, bot );
  81. }
  82. void gr_box(int left,int top,int right,int bot)
  83. {
  84. if (TYPE==BM_LINEAR)
  85. gr_box0( left, top, right, bot );
  86. else if ( TYPE == BM_MODEX )
  87. gr_box12( left, top, right, bot );
  88. else
  89. gr_ubox12( left, top, right, bot );
  90. }