22 Temmuz 2009, ÇARŞAMBA
Nasıl eğer poligon noktaları listesi saat yönünde sırayla olup olmadığını belirlemek için?
Puan listesi olan ne varsa saat yönünde sırayla onlar bulabilirim?
Örneğin:
point[0] = (5,0)
point[1] = (6,4)
point[2] = (4,5)
point[3] = (1,5)
point[4] = (1,0)
ki anti-saat yönünde olduğunu söylüyorlar (saat yönünün tersine bazı insanlar için).
CEVAP
22 Temmuz 2009, ÇARŞAMBA
Önerilen yöntemlerden bazıları olmayan konveks çokgen, bir hilal gibi durumda başarısız olur. Burada olmayan dışbükey çokgenler (hatta kendisiyle kesişen bir şekil-sekiz, ister inan poligon gibi . bir işe yarayacak bu çok basit. ben^>çoğunluklasaat yönünde).
Kenarlar, (x2-x1) () y2 y1 üzerinde topla. Eğer sonuç eğri saat yönünde olumlu ise, eğer negatif çıkarsa eğriyi saat yönünün tersine. (Sonucu kapalı alan, / - Kongre ile iki katı.)
point[0] = (5,0) edge[0]: (6-5)(4 0) = 4
point[1] = (6,4) edge[1]: (4-6)(5 4) = -18
point[2] = (4,5) edge[2]: (1-4)(5 5) = -30
point[3] = (1,5) edge[3]: (1-1)(0 5) = 0
point[4] = (1,0) edge[4]: (5-1)(0 0) = 0
---
-44 counter-clockwise
Bunu Paylaş:
Nasıl değişken olup olmadığını belirle...
Nasıl pi benim hesaplama doğru olup ol...
Nasıl belirli bir Linux 32 bit veya 64...
Hızlı eğer bir tam sayı iki tamsayı (d...
Nasıl bir web sayfası doğrudan tarayıc...