国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++判斷矩形相交的方法

2020-05-23 14:18:31
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了C++判斷矩形相交的方法,涉及C++針對平面坐標數學運算的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了C++判斷矩形相交的方法。分享給大家供大家參考。具體如下:

已知2矩形原點和寬高,判斷2矩形相交,相交矩形

相交判斷原理:

假定矩形是用一對點表達的(minx, miny) (maxx, maxy),那么兩個矩形

rect1{(minx1, miny1)(maxx1, maxy1)}

rect2{(minx2, miny2)(maxx2, maxy2)}

相交的結果一定是個矩形,構成這個相交矩形rect{(minx, miny) (maxx, maxy)}的點對坐標是:

minx = max(minx1, minx2)

miny = max(miny1, miny2)

maxx = min(maxx1, maxx2)

maxy = min(maxy1, maxy2)

如果兩個矩形不相交,那么計算得到的點對坐標必然滿足:

( minx > maxx ) 或者 ( miny > maxy )

判定是否相交,以及相交矩形是什么都可以用這個方法一體計算完成

設計3個類:

1. 點類:x,y

2. 矩形類:點,寬,高

3. 判斷相交類

程序實現:

 

 
  1. CPoint.h  
  2. #import <Foundation/Foundation.h> 
  3. @interface CPoint : NSObject  
  4. int x; //點坐標 
  5. int y; 
  6. -(void) print; 
  7. -(void) setX: (int) vx; 
  8. -(void) setY: (int) vy; 
  9. -(void) setXY:(int) vx :(int) vy; 
  10. -(int) x; 
  11. -(int) y; 
  12. @end  
  13. CPoint.m 
  14. #import "CPoint.h" 
  15. @implementation CPoint 
  16. -(void) print 
  17. NSLog(@"the point is (%i, %i)",x,y); 
  18. -(void) setX: (int) vx 
  19. x = vx; 
  20. -(void) setY: (int) vy 
  21. y = vy; 
  22. -(void) setXY:(int)vx :(int)vy 
  23. x = vx; 
  24. y = vy; 
  25. -(int) x 
  26. return x; 
  27. -(int) y 
  28. return y; 
  29. @end 
  30. CRect.h 
  31. #import <Foundation/Foundation.h> 
  32. #import "CPoint.h" 
  33. @interface CRect : NSObject 
  34. int w; //矩形長 
  35. int h; //矩形高 
  36. -(void) print; 
  37. -(int) w; 
  38. -(int) h; 
  39. -(void) setW: (int) vw; 
  40. -(void) setH: (int) vh; 
  41. -(void) setWH: (int) vw :(int) vh; 
  42. -(CPoint *) origin; 
  43. -(void) setOrigin: (CPoint *) pt; 
  44. @end 
  45. CRect.m 
  46. #import "CRect.h" 
  47. @implementation CRect 
  48. CPoint *origin; //點 
  49. -(void) print 
  50. NSLog(@"the rect:(x:%i, y:%i, w:%i,h:%i)",origin.x, origin.y, w, h); 
  51. -(int) w 
  52. return w; 
  53. -(int) h 
  54. return h; 
  55. -(void) setW:(int)vw 
  56. w = vw; 
  57. -(void) setH:(int)vh 
  58. h = vh; 
  59. -(void) setWH:(int)vw :(int)vh 
  60. w = vw; 
  61. h = vh; 
  62. -(CPoint *) origin 
  63. return origin; 
  64. -(void) setOrigin:(CPoint *)pt 
  65. origin = pt; 
  66. @end 
  67. DoCRect.h 
  68. #import <Foundation/Foundation.h> 
  69. #import "CRect.h" 
  70. @interface DoCRect : NSObject 
  71. -(BOOL) isIntersect:(CRect *) rect1 :(CRect *) rect2; //矩形相交否 
  72. -(CRect *) intersectRect: (CRect *) rect1 :(CRect *) rect2; //相交矩形 
  73. @end 
  74. DoCRect.m 
  75. #import "DoCRect.h" 
  76. @implementation DoCRect 
  77. //矩形是否相交 
  78. -(BOOL) isIntersect:(CRect *)rect1 :(CRect *)rect2 
  79. int minx = MAX(rect1.origin.x, rect2.origin.x); 
  80. int miny = MAX(rect1.origin.y, rect2.origin.y); 
  81. int maxx = MIN(rect1.origin.x+rect1.w, rect2.origin.x+rect2.w); 
  82. int maxy = MIN(rect1.origin.y+rect1.h, rect2.origin.y+rect2.h); 
  83. if (minx>maxx || miny>maxy) 
  84. return NO; 
  85. return YES; 
  86. -(CRect *) intersectRect:(CRect *)rect1 :(CRect *)rect2 
  87. int minx = MAX(rect1.origin.x, rect2.origin.x); 
  88. int miny = MAX(rect1.origin.y, rect2.origin.y); 
  89. int maxx = MIN(rect1.origin.x+rect1.w, rect2.origin.x+rect2.w); 
  90. int maxy = MIN(rect1.origin.y+rect1.h, rect2.origin.y+rect2.h);  
  91. CRect * rect = [[CRect alloc] init]; 
  92. CPoint *p = [[CPoint alloc] init]; 
  93. if (NO == [self isIntersect:rect1 :rect2])//no isIntersect 
  94. [p setXY:minx :miny]; 
  95. [rect setOrigin:p]; 
  96. rect.w = 0; 
  97. rect.h = 0; 
  98. return rect; 
  99. [p setXY:minx :miny]; 
  100. [rect setOrigin:p]; 
  101. rect.w = ABS(maxx-minx); 
  102. rect.h = ABS(maxy - miny); 
  103. return rect;  
  104. @end 
  105. main.m 測試 
  106. #import <Foundation/Foundation.h> 
  107. #import "DoCRect.h" 
  108. int main(int argc, const char * argv[]) 
  109. @autoreleasepool 
  110. NSLog(@"Hello,判斷矩形相交,返回矩形的原點和長高"); 
  111. //初始化對象 
  112. CRect *myrect1 = [[CRect alloc] init]; 
  113. CRect *myrect2 = [[CRect alloc] init]; 
  114. CPoint *p1 = [[CPoint alloc] init]; 
  115. CPoint *p2 = [[CPoint alloc] init]; 
  116. DoCRect *dorect = [[DoCRect alloc] init]; 
  117. //原點變量 
  118. [p1 setXY:200 :420]; 
  119. [p2 setXY:400 :300]; 
  120. //設置矩形原點 
  121. [myrect1 setOrigin:p1]; 
  122. [myrect1 setWH:250 :75]; 
  123. [myrect1 print]; 
  124. [myrect2 setOrigin:p2]; 
  125. [myrect2 setWH:100 :180]; 
  126. [myrect2 print]; 
  127. //判斷2矩形是否相交 
  128. BOOL insersect = [dorect isIntersect:myrect1 :myrect1]; 
  129. NSLog(@" two rect is :%@",insersect?@"YES":@"NO"); 
  130. //返回相交矩形 
  131. //CRect *inserectRect = [[CRect alloc] init]; 
  132. CRect *inserectRect = [dorect intersectRect:myrect1 :myrect2]; 
  133. [inserectRect print]; 
  134. return 0; 

希望本文所述對大家的C++程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 渭南市| 兴山县| 麻江县| 绵阳市| 耒阳市| 张家界市| 敦化市| 岱山县| 曲麻莱县| 梓潼县| 文昌市| 德昌县| 贡嘎县| 文山县| 宁武县| 琼中| 阿克陶县| 庆阳市| 濮阳县| 佛坪县| 山丹县| 淮阳县| 库车县| 上饶县| 鹤山市| 高陵县| 绥阳县| 碌曲县| 拜城县| 保靖县| 闽清县| 安达市| 星座| 泸水县| 焦作市| 大荔县| 聂拉木县| 聂拉木县| 达州市| 政和县| 漳州市|