亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > 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++程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美不卡视频一区发布| 亚洲视屏在线播放| 亚洲激情视频在线| 91免费看片网站| 97福利一区二区| 欧美电影在线播放| 国产精品福利小视频| 自拍偷拍亚洲精品| 国产激情视频一区| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲精品中文字幕有码专区| 久久久久久国产| 91精品国产综合久久久久久蜜臀| 成人久久精品视频| 久久影视电视剧凤归四时歌| 亚洲欧美日韩在线高清直播| 日韩欧美在线免费| 伊人亚洲福利一区二区三区| 黑人巨大精品欧美一区二区| 亚洲伊人一本大道中文字幕| 欧美极品少妇全裸体| 欧洲亚洲女同hd| 伊人久久五月天| 欧美一级在线亚洲天堂| 岛国视频午夜一区免费在线观看| 欧美极度另类性三渗透| 国产精品老女人视频| 亚洲精品成人网| 亚洲国产欧美一区二区三区久久| 国产福利精品在线| 久久精品免费播放| 欧美性xxxxxxx| 2019国产精品自在线拍国产不卡| 日韩电影在线观看永久视频免费网站| 在线看日韩欧美| 亚洲免费视频一区二区| 2020久久国产精品| 亚洲毛片在线看| 国产自产女人91一区在线观看| 国产精品色婷婷视频| 日韩一区二区精品视频| 九九精品在线视频| 欧美精品在线网站| 45www国产精品网站| 久久精品国产亚洲精品2020| 45www国产精品网站| 26uuu国产精品视频| 欧美专区在线视频| 国产性猛交xxxx免费看久久| 亚洲视频在线观看视频| 一区二区三区日韩在线| 欧美激情一区二区三区久久久| 国产美女直播视频一区| 亚洲人午夜精品免费| 美女撒尿一区二区三区| 亚洲天堂男人天堂女人天堂| 国产精品扒开腿做爽爽爽男男| 色噜噜久久综合伊人一本| 国产97人人超碰caoprom| 69久久夜色精品国产69乱青草| 日韩电影大片中文字幕| 亚洲欧美日韩成人| 日本精品中文字幕| 欧美巨乳美女视频| 欧美富婆性猛交| 国产精品久久久精品| 久久精视频免费在线久久完整在线看| 久久免费高清视频| 欧美夫妻性生活xx| 亚洲精品资源美女情侣酒店| 欧美寡妇偷汉性猛交| 欧美又大粗又爽又黄大片视频| 热门国产精品亚洲第一区在线| 国产精品亚洲第一区| 亚洲xxxx在线| 亚洲女人天堂色在线7777| 在线观看欧美日韩国产| 欧美激情高清视频| 色偷偷噜噜噜亚洲男人| 黄网动漫久久久| 欧美多人爱爱视频网站| 亚洲美女自拍视频| 亚洲精品中文字| 在线观看久久av| 欧美激情久久久| 精品国产网站地址| 精品久久久久久国产91| 国产精品久久99久久| 91精品在线观看视频| 亚洲国产日韩欧美在线99| 另类专区欧美制服同性| 色在人av网站天堂精品| 狠狠色噜噜狠狠狠狠97| 久久av在线播放| 久久久久久午夜| 欧洲精品毛片网站| 伊人久久男人天堂| 日韩av在线网址| 欧美国产日本在线| 97视频国产在线| 九九九久久国产免费| 亚洲精品在线不卡| 欧美亚洲视频一区二区| 97香蕉超级碰碰久久免费的优势| 亚洲色图国产精品| 日韩欧美精品中文字幕| 亚洲第一天堂av| 日韩成人中文字幕在线观看| 国产在线观看精品一区二区三区| 中文字幕亚洲综合| 久久久久久久久久久成人| 欧美精品在线观看| 亚洲少妇激情视频| 欧美成人精品激情在线观看| 欧美性猛交99久久久久99按摩| 日韩一区二区av| 久久久综合免费视频| 久久免费成人精品视频| 国产精品丝袜久久久久久高清| 午夜精品久久久久久久久久久久| 国产精品美女www爽爽爽视频| 国产婷婷色综合av蜜臀av| 国产999精品视频| 高跟丝袜欧美一区| 这里精品视频免费| 中文欧美日本在线资源| 九九久久精品一区| 91久久久久久久久| 亚洲自拍另类欧美丝袜| 欧美国产激情18| 亚洲日韩第一页| 色偷偷偷亚洲综合网另类| 亚洲欧美制服中文字幕| 国产精品久久久久久久天堂| 久久国产精品首页| 成人国产精品色哟哟| 亚洲一区二区自拍| 国产小视频国产精品| 亚洲区免费影片| 欧美日韩国产丝袜另类| 成人国产精品久久久久久亚洲| 国产日韩综合一区二区性色av| 久久精品视频va| 亚洲最大av在线| 久久久噜噜噜久久中文字免| 亚洲a在线观看| 亚洲999一在线观看www| 国产男人精品视频| 午夜精品久久久久久久男人的天堂| 国产精品第8页| 日韩电影免费在线观看中文字幕| 亚洲丝袜在线视频| 精品高清一区二区三区| 高清亚洲成在人网站天堂| 国产精品自拍视频| 久久久精品国产网站| 国产精品久久久久久久久影视| 久久成人在线视频| 亚洲人成在线播放| 欧美午夜www高清视频| 色综合色综合久久综合频道88| 国产一区二区三区直播精品电影| 日韩欧美一区二区三区久久| 国产精选久久久久久|