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.gazeta.pl!not-for-mail
    From: Dariusz Zolna <a...@u...com>
    Newsgroups: pl.comp.programming
    Subject: Re: Punkty przecięcia okręgu i odcinka
    Date: Fri, 04 Jun 2010 14:20:42 +0200
    Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
    Lines: 52
    Message-ID: <huar2p$qkv$1@inews.gazeta.pl>
    References: <6...@n...onet.pl>
    <6...@n...onet.pl>
    NNTP-Posting-Host: pradnikd.gemini.net.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: quoted-printable
    X-Trace: inews.gazeta.pl 1275654041 27295 193.25.0.21 (4 Jun 2010 12:20:41 GMT)
    X-Complaints-To: u...@a...pl
    NNTP-Posting-Date: Fri, 4 Jun 2010 12:20:41 +0000 (UTC)
    X-User: dejet
    X-Antivirus: avast! (VPS 100604-0, 2010-06-04), Outbound message
    In-Reply-To: <6...@n...onet.pl>
    X-Antivirus-Status: Clean
    User-Agent: Thunderbird 2.0.0.24 (Windows/20100228)
    Xref: news-archive.icm.edu.pl pl.comp.programming:185676
    [ ukryj 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;
    }

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: