Точки пересечения прямой и дуги

Точки пересечения прямой и дуги - student2.ru

Чтобы выяснить взаимное положение дуги и отрезка прямой, следует (рис.124):

- из центра дуги опустить перпендикуляр на прямую;

- определить точку(XP,YP) пересечения перпендикуляра с прямой;

- измерить текущий угол перпендикуляра U;

- повернуть прямую вокруг

центра дуги на угол ( -U );

Координата Х точки А будет

Рис. 124 равна расстоянию от центра дуги до прямой, а координата Y будет найдена как катет прямоугольного треугольника при известных гипотенузе, равной радиусу дуги, и другому катету.

- вернуть точки в исходное положение.

Программное описание оператора:

begin

TekUgol( X1,Y1,X2,Y2,U0 );

DwaOtr(X1,Y1,U0,X,Y,90+U0,XP,YP,P);

DlinaO(XС,YС,XР,YР,L);

DlinaO(XС,YС,XN,YN,R);

if L > R then P:=0; {не пересекаются}

else if (L - R) < 0.05 then begin

P:=1; XA:=R; XB:=R; YA:=0; YB:=0;

{прямая касается дуги в точке(XP,YP)}

end

else begin

TekUgol( XC,YC,XP,YP,U );

XA = L; XB= -L ; {координаты Х точек А и В после

поворота на угол ( - U )}

Точки пересечения прямой и дуги - student2.ru ;YB = - YA ; {координаты Y точек

А и В после поворота на угол (- U)}

end;

XTS:=XT; YTS:=YT; UgS:=Ugol;

Ugol:=U; XT:=XC; YT:=YC;

PX[1]:=XA; PY[1]:=YA; PX[2]:=XB; PY[2]:=YB;

Preobr( 2 );

XA:=PX[1]; YA:=PY[1]; XB:=PX[2]; YB:=PY[2];

{координаты точек А и В после возврата в

исходное положение}

XT:=XTS; YT:=YTS; Ugol:=UgS; {координаты точек пересечения возвращены в исходную систему координат чертежа}

end;

Оператор: OtrDug(X1,Y1,Ug,XC,YC,R,XP1,YP1,XP2,YP2,P).

Остается выяснить принадлежность точек А и В исходным отрезку прямой и дуге, используя известные операторы:

PikOtr(XA,YA,X1,Y1,X2,Y2,P) ® P=1

PikOtr(XB,YB,X1,Y1,X2,Y2,P) ® P=0

PikDug(XA,YA,XC,YC,XN,YN, XK,YK,напр.,P)® P=1

PikDug(XB,YB,XC,YC,XN,YN, XK,YK,напр.,P)® P=1.

Отсюда следует, что точка А является точкой пересечения отрезка и дуги, точка В - нет, т.к. она не принадлежит отрезку ( Р=0).

Пересечение дуг

Для определения точек А и В пересечения двух окружностей с центрами (XC1,YC1), (XC2,YC2) и радиусами R1, R2 следует (рис. 125):

Точки пересечения прямой и дуги - student2.ru - определить расстояние L между центрами окружностей;

- определить текущий угол U прямой, соединяющей центры;

- повернуть вторую окружность вокруг центра первой окружности на угол ( - U );

После поворота координаты точек пересечения определяются системой уравнений

Точки пересечения прямой и дуги - student2.ru Точки пересечения прямой и дуги - student2.ru Точки пересечения прямой и дуги - student2.ru

Точки пересечения прямой и дуги - student2.ru .

- вернуть точки пересечения

окружностей в исходное положение.

Рис. 125

Программное описание оператора:

begin

DlinaO(XС1,YС1,XC2,YC2,L);

TekUgol( XC1,YC1,XC2,YC2,U );

if (R1+R2<L) or (L+R1<R2) or (L+R2<R1) or (L<0,001) then

begin

P:=0; {нет пересечения}

end

else begin

Точки пересечения прямой и дуги - student2.ru ; Точки пересечения прямой и дуги - student2.ru ;

Точки пересечения прямой и дуги - student2.ru ; Точки пересечения прямой и дуги - student2.ru ; {решена система уравнений

при условии, что угол U = 0}

XTS:=XT; YTS:=YT; UgS:=Ugol;

Ugol:= U; XT:=XC1; YT:=YC1; {введены угол возврата

точек пересечения и текущая база}

PX[1]:=XAP; PY[1]:=YAP; PX[2]:=XBP; PY[2]:=YBP;

{заполнен массив точек}

Preobr( 2 ); {выполнен возврат точек в исходное положение}

XA:=PX[1]; YA:=PY[1]; XB:=PX[2]; YB:=PY[2]; {выполне-

ны присвоения значений координат точек А и В}

XT:=XTS; YT:=YTS; Ugol:=UgS; {координаты точек пересечения возвращены в исходную систему координат чертежа}

end;

end;

Оператор: DugDug(XC1,YC1,R1,XC2,YC2,R2,X1,Y1,X2.Y2,P).

Остается определить принадлежность точек дугам:

PikDug(XA,YA,XC1,YC1,XN1,YN1, XK1,YK1,напр.,P)® P=1

PikDug(XB,YB,XC1,YC1,XN1,YN1, XK1,YK1,напр.,P)® P=1.

PikDug(XA,YA,XC2,YC2,XN2,YN2, XK2,YK2,напр.,P)® P=1

PikDug(XB,YB,XC2,YC2,XN2,YN2, XK2,YK2,напр.,P)® P=1.

Направление дуги

Оператор предназначен для автоматического распознавания направления выполняемой дуги по начальной и конечной точкам и центру (рис. 126).

Procedure Naprawl(Xc,Yc,Xn,Yn,Xk,Yk: Float;напр.: byte);

var U1,U2,UU: Float;

Точки пересечения прямой и дуги - student2.ru begin

TekUgol( Xc,Yc,Xn,Yn,U1 );

TekUgol( Xc,Yc,Xk,Yk,U2 );

{текущие углы начальной

и конечной точек дуги}

UU:=abs(U1-U2);

if (U1<U2) and (UU<180)

then напр:=1

else if (U1<U2) and (UU>180)

then напр:=2

else if (U1>U2) and (UU<180)

then напр:=2

else напр:=1;

Рис. 126 end;

Оператор: Naprawl(Xc,Yc,Xn,Yn,Xk,Yk,напр);

Взаимное положение линий

Procedure

Tch_NiK(XCg,YCg,Xg1,Yg1,Xg2,Yg2,Xs,Ys,XTn,YTn,LDk);

­ ¯

параметры ввода вывода

Точки пересечения прямой и дуги - student2.ru

Дуга NOKO в точке S пересекается с прямой NеKе и дугой NвKв (рис. 127). Направление обхода принимают совпадающим с направлением от начальной точки к конечной начального элемента NOKO. По отношению к начальному элементу определяется положение текущих элементов NеKе и NвKв.

Цель – определить траекторию движения по контуру NOS - SNе

Рис. 127 NеS - SKв - KвS - SKO и т.д. в бесконечном цикле если не будет назначен конечный элемент. Одновременно можно определить, что элементы SNе и SKв расположены внутри дуги NOKO.

С центром в точке пересечения S начального элемента с текущим выполнена дуга измерения радиусом LS (текущая точность измерения). Если рассматривается внутренняя область, то направление измерений (ход) противоположно направлению обхода. Ближайшая к NO точка Tn – начальная, Tk – конечная.

Максимальная длина дуги LDk от Tn до Тk. Если длины дуг от Tn до Te и от Tn до Tb меньше максимальной, то точки Те и Tb расположены внутри дуги NOKO, равно как и отрезки SNe, Skb. Если двигаться по дуге NOKO в направлении ‘обхода’, то первым встретим отрезок SNe, затем - дугу SKb. Те же отрезки прямой и дуги находятся внутри области, ограниченной дугой NOKO.

begin

if Obhod=1 then Hod:=2 else Hod:=1; {определено направление

измерений ‘Hod’ для внутренней области}

Элемент, по отношению к которому определяется положение других линий, отрезок прямой:

if El=1 then begin

Определим точки пересечения отрезка прямой и окружности:

TekUgol(Xg1, Yg1, Xg2, Yg2,Ug);

OtrDug(Xg1,Yg1,Ug,Xs,Ys,Ri,XP1,YP1,XP2,YP2,P);

{Ri - радиус окружности измерения дуги}

Найдем точки начала(XTn,YTn) и конца(XTk,YTk) измерений:

DlinaL(Xg1,Yg1,XP1,YP1,L1);

DlinaL(Xg1,Yg1,XP2,YP2,L2);

if L1<L2 then begin

XTn:=XP1; YTn:=YP1; XTk:=XP2; YTk:=YP2;

end

else begin

XTn:=XP2; YTn:=YP2; XTk:=XP1; YTk:=YP1;

end;

Выясним принадлежность точки Tk отрезку прямой:

PikOtr(XTk,YTk,Xg1,Yg1,Xg2,Yg2,P);

Определим LDk:

if P=1 then LDk:=180 else LDk:=360;

{Ldk - max угол, при LD<=LDk точка находится внутри области.

Если S совпадает с концом отрезка прямой, LDk=360. В другом

случае LDk=180}

end

Элемент, по отношению к которому определяется положение других линий, дуга:

else begin

Определим точки пересечения дуги и окружности:

DugDug(XCg,YCg,R,Xs,Ys,Ri,XP1,YP1,XP2,YP2,P);

Определим длины дуг от начальной точки дуги (Xg1,Yg1) до точек пересечения (XP1,YP1), (XP2,YP2):

DlinaD(XСg,YCg,Xg1,Yg1,XP1,YP1,Nag,LD1);

DlinaD(XCg,YCg,Xg1,Yg1,XP2,YP2,Nag,LD2);

Найдем точки начала(XTn,YTn) и конца(XTk,YTk) измерений:

if LD1<LD2 then begin

XTn:=XP1; YTn:=YP1; XTk:=XP2; YTk:=YP2;

end

else begin

XTn:=XP2; YTn:=YP2; XTk:=XP1; YTk:=YP1;

end;

Определим LDk:

DlinaD(Xs,Ys,XTn,YTn,XTk,YTk,Hod,LDk);

end;

end;

3.3.11.Операторы работы с файлами

- открыть временный файл, записать строку параметров линии и

прорисовать ее:

RisLineBox( Bx, El, Napr, X1, Y1, X2, Y2, XC, YC ), где:

Bx - номер временного файла или имя файла в зависимости от типа

переменной Bx;

El - определитель типа линии ( 1 - прямая, 2 - дуга);

Napr - направление дуги (1- против часовой стрелки, 2 - по часовой);

X1, Y1 - координаты начальной точки;

X2, Y2 - координаты конечной точки;

XC, YС - координаты центра дуги;

- прочитать файл линий, начиная с 1-й строки по Nк(последняя строка)

и заполнить строку переменных:

Наши рекомендации