-
Data: 2010-06-04 12:20:42
Temat: Re: Punkty przecięcia okręgu i odcinka
Od: Dariusz Zolna <a...@u...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]
ślamazar pisze:
> acha - zapomniałem o inpucie - trzeba dodac jakis imput albo
> dane wejsciowe podac w kodzie - druga uwaga ten kod z tej stronki zakłada
> ze srodek okregu jest w (0, 0 ) jak nie to trzeba konce odcinka (i centrum
> okregu niejako niejawnie) przed przeliczeniem przesunac o roznice np
Dzięki, niestety nie działa. Przykładowe dane dla funkcji:
x = 87, y = -33, r = 20
x1 = 51, y1 = -77
x2 = 115, y2 = -4
Dla tych danych odcinek przecina okrąg w 2 miejscach. Jest to
(teoretycznie) wykrywane przez algorytm, ale współrzędne punktów
przecięcia wychodzą nieprawidłowe (x_1 = 137492, y_1 = 9015003).
Czegoś w tych wzorach brakuje...
Pozdrawiam,
Dariusz Żołna
int CircleLineIntersectPts(
double x, double y, double r, double x1, double y1, double x2, double
y2) //, int *xo1, int *yo1, int *xo2, int *yo2)
{
x1 -= x;
y1 -= y;
x2 -= x;
y2 -= y;
double dx = x2-x1;
double dy = y2-y1;
double dr = sqrt(dx*dx+dy*dy);
double D = x1*y2-x2*y1;
double delta = r*r*dr*dr-D*D;
if(delta<0) return 0;
if(delta==0) return 1;
if(delta>0)
{
double x_1 =((D*dy+sgn(dy)*dx*sqrt(r*r*dr*dr-D*D))/dr*dr) + x;
double x_2 =((D*dy-sgn(dy)*dx*sqrt(r*r*dr*dr-D*D))/dr*dr) + x;
double y_1 =((-D*dy+abs(dy)*dx*sqrt(r*r*dr*dr-D*D))/dr*dr) + y;
double y_2 =((-D*dy-abs(dy)*dx*sqrt(r*r*dr*dr-D*D))/dr*dr) + y;
}
return 2;
}
Następne wpisy z tego wątku
- 04.06.10 12:38 Dariusz Zolna
- 04.06.10 14:59 Tomasz Sowa
- 04.06.10 19:22 Dariusz Zolna
Najnowsze wątki z tej grupy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
Najnowsze wątki
- 2025-02-21 Warszawa => Key Account Manager IT <=
- 2025-02-21 Warszawa => Data Engineer (Tech Lead) <=
- 2025-02-21 Aliexpress zaczął oszukiwać na bezczelnego.
- 2025-02-21 Warszawa => System Architect (Java background) <=
- 2025-02-21 Kula w łeb
- 2025-02-21 Warszawa => System Architect (background deweloperski w Java) <=
- 2025-02-21 Warszawa => Solution Architect (Java background) <=
- 2025-02-21 Lublin => JavaScript / Node / Fullstack Developer <=
- 2025-02-21 Pawel S
- 2025-02-21 Warszawa => Key Account Manager (Usługi HR) <=
- 2025-02-21 Katowice => Senior Field Sales (system ERP) <=
- 2025-02-21 Chrzanów => Programista NodeJS <=
- 2025-02-21 Wrocław => Konsultant wdrożeniowy Comarch XL/Optima (Księgowość i
- 2025-02-21 Warszawa => Administrator Systemów Windows IT <=
- 2025-02-21 Wrocław => Specjalista ds. Sprzedaży (transport drogowy) <=