eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingPunkty przecięcia okręgu i odcinkaRe: Punkty przecięcia okręgu i odcinka
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.onet.pl!newsgate.onet.pl!niusy.one
    t.pl
    From: "ŚLAMAZAR" <p...@p...onet.pl>
    Newsgroups: pl.comp.programming
    Subject: Re: Punkty przecięcia okręgu i odcinka
    Date: Fri, 04 Jun 2010 12:59:57 +0200
    Organization: Onet.pl
    Lines: 55
    Sender: n...@n...onet.pl
    Message-ID: <6...@n...onet.pl>
    References: <huaili$db$1@inews.gazeta.pl>
    NNTP-Posting-Host: newsgate.onet.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset="iso-8859-2"
    Content-Transfer-Encoding: 8bit
    X-Trace: newsgate.onet.pl 1275649198 5630 213.180.130.18 (4 Jun 2010 10:59:58 GMT)
    X-Complaints-To: n...@o...pl
    NNTP-Posting-Date: Fri, 4 Jun 2010 10:59:58 +0000 (UTC)
    Content-Disposition: inline
    X-Mailer: http://niusy.onet.pl
    X-Forwarded-For: 83.6.145.68, 10.174.28.52
    X-User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows 98; FDM)
    Xref: news-archive.icm.edu.pl pl.comp.programming:185671
    [ ukryj nagłówki ]

    > Witam wszystkich,
    >
    > Dawno mnie tu nie było, ale nie mogę sobie poradzić z problemem z tematu
    > i uznałem, że to dobre miejsce żeby zapytać :)
    > Problem jest taki:
    > W układzie kartezjańskim mam dany odcinek opisany współrzędnymi początku
    > i końca (xp, yp, xk, yk) oraz okrąg opisany współrzędnymi środka i
    > promieniem (x, y, r). Potrzebuję odnaleźć punkty przecięcia odcinka i
    > okręgu. Możliwe są 3 przypadki:
    > - brak punktów przecięcia
    > - 1 punkt przecięcia (1 koniec odcinka znajduje się wewnątrz okręgu, to
    > akurat jest proste do wykrycia)
    > - 2 punkty przecięcia
    > - przypadek odcinka stycznego do okręgu można pominąć
    >
    > Ktoś pomoże? Kawałek kodu w C byłby niezmiernie przydatny :)
    >
    > Pozdrawiam,
    > Dariusz Żołna

    jest wzorek - tu np znalazłem

    http://mathworld.wolfram.com/Circle-LineIntersection
    .html

    chyba żywcem można przepisac na c to co tutaj jest

    double dx = x2-x1;
    double dy = y2-y1;
    double dr = sqrt(dx*dx+dy*dy)
    double D = x1*y2-x2*y1;

    double x_1 =D*dy+sgn(dy)*dx*sqrt(r*r*dr*dr-D*D);
    double x_2 =D*dy-sgn(dy)*dx*sqrt(r*r*dr*dr-D*D);


    double sgn(double x)
    {
    if(x<0) return -1.0;
    else return 1.0;
    }

    itp. - trzebaby sprawdzić czy to dobrze działa itp i dac ify
    od tych przypadków po delcie tam niżej - chyba powinieneś sobie
    poradzić - bo ja jakos nie mam chęci tego tu całego klepac i
    nie mam kompilatora pod reką by sprawdzić,

    pzdr ŚLAMAZAR






    --
    Wysłano z serwisu OnetNiusy: http://niusy.onet.pl

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: