首頁 後端開發 C++ 如何判斷兩個矩形是否重疊?

如何判斷兩個矩形是否重疊?

Dec 23, 2024 am 04:08 AM

How Do You Determine if Two Rectangles Overlap?

確定矩形之間的重疊:

確定矩形之間重疊的初始方法似乎基於與中鏈接的算法不同的算法的問題。提供的演算法使用了更直接的直角座標比較,如下所示:

if (RectA.Left < RectB.Right && RectA.Right > RectB.Left &&
    RectA.Top > RectB.Bottom && RectA.Bottom < RectB.Top) 

 // Assuming Left, Right, Top and Bottom are the coordinates of the rectangles along the X and Y axis
登入後複製

在笛卡爾座標中,這個條件可以表示為:

if (RectA.X1 < RectB.X2 && RectA.X2 > RectB.X1 &&
    RectA.Y1 > RectB.Y2 && RectA.Y2 < RectB.Y1)
登入後複製

證明矛盾:

這個條件是基於反證法原理。如果滿足以下任何條件,則矩形不能重疊:

  • 矩形A 的左邊緣位於矩形B 右邊緣的右側(矩形A 完全位於矩形B 的右側)
  • RectA 的右邊緣位於RectB 左邊緣的左側(RectA 完全位於RectB 的左側)矩形B)
  • 矩形 A的上緣位於矩形B 的下緣下方(矩形A 完全位於矩形B 下方)
  • 矩形A 的下緣位於矩形B 的上緣上方(矩形A 完全位於矩形B 上方)

因此,重疊的條件與這些相反條件:

  • 矩形框A 的左邊緣位於矩形框 B右邊緣的左邊
  • 長方形框A 的右邊緣位於長方形框B 左邊緣的右側
  • 長方形框A 的上緣在上方長方形B的底邊
  • 矩形A的底邊在下面RectB的頂邊

附加說明:

  • 此演算法假設矩形平行於 X 軸和 Y 軸。
  • 要允許一個像素重疊,請變更 在相關邊界上使用 = 運算子。
  • 演算法可以輕鬆調整以適應不同的座標系(例如,如果 Y 從上到下增加)。

以上是如何判斷兩個矩形是否重疊?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

c語言函數格式字母大小寫轉換步驟 c語言函數格式字母大小寫轉換步驟 Mar 03, 2025 pm 05:53 PM

c語言函數格式字母大小寫轉換步驟

c語言函數返回值的類型有哪些?返回值是由什麼決定的? c語言函數返回值的類型有哪些?返回值是由什麼決定的? Mar 03, 2025 pm 05:52 PM

c語言函數返回值的類型有哪些?返回值是由什麼決定的?

Gulc:從頭開始建造的C庫 Gulc:從頭開始建造的C庫 Mar 03, 2025 pm 05:46 PM

Gulc:從頭開始建造的C庫

c語言函數的定義和調用規則是什麼 c語言函數的定義和調用規則是什麼 Mar 03, 2025 pm 05:53 PM

c語言函數的定義和調用規則是什麼

C標準模板庫(STL)如何工作? C標準模板庫(STL)如何工作? Mar 12, 2025 pm 04:50 PM

C標準模板庫(STL)如何工作?

distinct用法和短語分享 distinct用法和短語分享 Mar 03, 2025 pm 05:51 PM

distinct用法和短語分享

c語言函數返回值在內存保存在哪裡? c語言函數返回值在內存保存在哪裡? Mar 03, 2025 pm 05:51 PM

c語言函數返回值在內存保存在哪裡?

如何有效地使用STL(排序,查找,轉換等)的算法? 如何有效地使用STL(排序,查找,轉換等)的算法? Mar 12, 2025 pm 04:52 PM

如何有效地使用STL(排序,查找,轉換等)的算法?

See all articles