![]() |
|
#2
|
|||
|
|||
![]() Для начала вынести randomize куда нибудь в FormCreate;
И если задать внятные имена переменных и переписать вот так Код:
procedure TForm1.FormCreate(Sender: TObject); begin randomize; // вот так end; procedure TForm1.Button1Click(Sender: TObject); var x1,y1,r1,d1:integer; // координаты центра, радиус и диаметр первого круга x2,y2,r2,d2:integer;// координаты центра , радиус и диаметр второго круга xo,yo:integer;// координаты точки пересечения begin r1:=strtoint(edit1.Text); d1:=round(r1*2); r2:=strtoint(edit2.Text); d2:=round(r2*2); with chart1.Canvas do begin pen.Width:=3; pen.color:=clgreen; x1:=random((450)+110); // здесь вычисляем не верхний левый угол y1:=random((150)+110); // а центр круга Brush.Style:=bsClear; ellipse(x1-r1,y1-r1,x1+r1,y1+r1);// рисуем эллипс с учетом радиуса x2:=random((450)+110); y2:=random((150)+110); pen.Width:=2; pen.color:=clred; ellipse(x2-r2,y2-r2,x2+r2,y2+r2); end; yo:=round((sqr(r2)-sqr(r1)-x1-r1+sqr(x2)-sqr(r2)+sqr(r1)+sqr(x1)-sqr(x2)+sqr(y1)-sqr(y2)) / 2*(y1-y2)); // координата по y1 xo:=round((sqr(r2)-sqr(r1)-sqr(x1)+sqr(x2)-sqr(y1)+sqr(y2)+sqr(r2)-sqr(r1)-x1+sqr(x2) // координата x1 -sqr(r2)+sqr(r1)+sqr(x1)-sqr(x2)+sqr(y1)-sqr(y2)) /-2*(x1-x2)); (* p:= round(sqrt(sqr(x2+r2-x1-r1)+sqr(y1+r1+y2+2))); // расстояние между центрами окружностей*) p:= round(sqrt(sqr(x2-x1)+sqr(y1-y2))); // расстояние между центрами окружностей*) begin if p>r1+r2 then // проверяем, что окружности находятся слишком далеко begin memo1.text:='Окружности не пересекаются ' ; end else if p< Abs(r1-r2) then// проверяем, что одна окружность находятся целиком внутри другой begin memo1.text:='Окружности не пересекаются ' ; end else begin memo1.text:='Окружности пересекаются в точке y='+floattostr(yo)+'x='+floattostr(xo) ; end; end; то сразу станет очевидна ошибка в формуле, вычисляющей p формулы для xo и yo не проверял, но цыфры получаются какие-то огромные |