Как рассчитать все параметры треугольника?
Для расчета основных параметров треугольника (таких как: периметр, площадь, длины сторон, углы, координаты, радиусы вписанной и описанной окружностей, а также координаты их центров) можно воспользоваться следующим классом TTriangle. Все формулы, используемые в коде, а также пример работы класса в практической реализации см. на странице "Расчет треугольника"
TTriangle = class private fx1, fy1 : Double; fx2, fy2 : Double; fx3, fy3 : Double; function GetDistAB: Double; function GetDistAC: Double; function GetDistBC: Double; function GetPerimeter: Double; function GetArea: Double; function GetAngleA: Double; function GetAngleB: Double; function GetAngleC: Double; function GetRadiusIn: Double; function GetRadiusOut: Double; function GetCenterOut: TFPoint; function GetCenterIn: TFPoint; function PointsInLine: Boolean; public // Задание треугольника координатами его вершин constructor Create( ax1,ay1, ax2,ay2, ax3,ay3: Double); overload; // Задание треугольника длинами его сторон constructor Create( a, b, c: Double); overload; //функция нахождения длины отрезка function Dist( ax1, ay1, ax2, ay2: Double): Double; published // координаты первой вершины A property X1: Double read fx1 write fx1; property Y1: Double read fy1 write fy1; // координаты второй вершины B property X2: Double read fx2 write fx2; property Y2: Double read fy2 write fy2; // координаты третьей вершины С property X3: Double read fx3 write fx3; property Y3: Double read fy3 write fy3; property DistAB: Double read GetDistAB; // Длина AB property DistBC: Double read GetDistBC; // Длина BC property DistAC: Double read GetDistAC; // Длина AC property Perimeter: Double read GetPerimeter; // Периметр property Area: Double read GetArea; // Площадь property AngleA: Double read GetAngleA; // Угол A property AngleB: Double read GetAngleB; // Угол B property AngleC: Double read GetAngleC; // Угол C // Радиус вписанной окружности property RadiusIn: Double read GetRadiusIn; // Радиус описанной окружности property RadiusOut: Double read GetRadiusOut; // Центр описанной окружности property CenterOut: TFPoint read GetCenterOut; // Центр вписанной окружности property CenterIn: TFPoint read GetCenterIn; end; { TTriangle } constructor TTriangle.Create(ax1, ay1, ax2, ay2, ax3, ay3: Double); begin fx1 := ax1; fy1 := ay1; fx2 := ax2; fy2 := ay2; fx3 := ax3; fy3 := ay3; end; constructor TTriangle.Create(a, b, c: Double); Var cosa: Double; begin fx1 := 0; fy1 := 0; fx2 := 0; fy2 := c; cosa := (b*b+c*c - a*a)/(2*b*c); fy3 := b * cosa; fx3 := b * sin(arccos(cosA)); end; function TTriangle.Dist(ax1, ay1, ax2, ay2: Double): Double; begin Result := sqrt((ax2-ax1)*(ax2-ax1)+(ay2-ay1)*(ay2-ay1)); end; function TTriangle.GetAngleA: Double; Var a, r: Double; begin a := (fx2-fx1)*(fx3-fx1)+(fy2-fy1)*(fy3-fy1); r := a/DistAB/DistAC; Result := arccos(r); end; function TTriangle.GetAngleB: Double; Var a, r: Double; begin a := (fx1-x2)*(fx3-fx2)+(fy1-fy2)*(fy3-fy2); r := a/DistAB/DistBC; Result := arccos(r); end; function TTriangle.GetAngleC: Double; Var a, r: Double; begin a := (fx2-x3)*(fx1-fx3)+(fy2-fy3)*(fy1-fy3); r := a/DistBC/DistAC; Result := arccos(r); end; function TTriangle.GetArea: Double; begin Result := sqrt((Perimeter/2*(Perimeter/2-DistAB)* (Perimeter/2-DistBC)*(Perimeter/2-DistAC))); end; function TTriangle.GetCenterIn: TFPoint; Var Lc, Lb, La : Double; cx, cy, bx, by, ax, ay : Double; K1, K2 : Double; begin Lb := DistBC/DistAB; Lc := DistBC/DistAC; cx := (fx2+Lc*fx1)/(Lc+1); cy := (fy2+Lc*fy1)/(Lc+1); bx := (fx3+Lb*fx1)/(Lb+1); by := (fy3+Lb*fy1)/(Lb+1); if cx <> fx3 then K1 := (cy-fy3)/(cx-fx3) else K1 := 1e+96; if bx <> fx2 then K2 := (by-fy2)/(bx-fx2) else K2 := 1e+96; Result.x := (K1*fx3-K2*fx2+(fy2-fy3))/(K1-K2); if Result.x <> fx3 then Result.y := K1*(Result.x-fx3)+fy3 else Result.y := K2*(Result.x-fx2)+fy2; end; function TTriangle.GetCenterOut: TFPoint; Var ma, mb : Double; // коэффициенты наклона линий begin if fx2 <> fx1 then ma := (fy2-fy1)/(fx2-fx1) else ma := 1e95; if fx3 <> fx2 then mb := (fy3-fy2)/(fx3-fx2) else mb := 1e95; Result.x := (ma*mb*(fy1-fy3) + mb*(fx1+fx2) - ma*(fx2+fx3))/(2*(mb-ma)); if ma <> 0 then Result.y := -1/ma*(Result.x - (fx1+fx2)/2) + (fy1+fy2)/2 else Result.y := -1/mb*(Result.x - (fx2+fx3)/2) + (fy2+fy3)/2; end; function TTriangle.GetDistAB: Double; begin Result := Dist ( fx1, fy1, fx2, fy2); end; function TTriangle.GetDistAC: Double; begin Result := Dist ( fx1, fy1, fx3, fy3); end; function TTriangle.GetDistBC: Double; begin Result := Dist ( fx2, fy2, fx3, fy3); end; function TTriangle.GetPerimeter: Double; begin Result := DistAB + DistBC + DistAC; end; function TTriangle.GetRadiusIn: Double; begin if not PointsInLine then Result := 2 * Area / Perimeter; end; function TTriangle.GetRadiusOut: Double; begin if not PointsInLine then Result := (DistAB*DistBC*DistAC)/(4*Area); end; function TTriangle.PointsInLine: Boolean; Var a : double; begin Result := false; a := fx1*fy2+fx2*fy3+fx3*fy1-fx3*fy2-fx2*fy1-fx1*fy3; if abs(a - 1e-20) < 1e-19 then Result := true; end;
Пример использования класса для задачи "Как найти площадь треугольника, заданного длинами сторон a=10, b=12, c=11?"
procedure TForm1.Button1Click(Sender: TObject); Var T: TTriangle; begin T := TTriangle.Create( 10, 12, 11); showmessage( FloatToStr( T.Area)); end;
Пример использования класса для задачи "Как найти периметр треугольника, заданного координатами вершин A(0,0), B(1,0), C(1,1)?"
procedure TForm1.Button1Click(Sender: TObject); Var T: TTriangle; begin T := TTriangle.Create( 0, 0, 1, 0, 1, 1); showmessage(FloatToStr( T.Perimeter)); end;
buy prescription drugs from india legal to buy prescription drugs without prescription
onlinepharmacyero.com buy anti biotics without prescription
buy prescription drugs online without pain medications without a prescription
onlinepharmacyero.com is it illegal to buy prescription drugs online
buy cialis vs viagra buy ed pills online how can i order viagra online
order cialis us https://edpillsphrm.com order viagra online us
cheapest generic cialis online https://edpillsphrm.com cialis sale manila
cialis cheap fast delivery online prescription for ed meds cialis buy europe
cheapest generic levitra online generic viagra cialis buy nz
order viagra by phone https://edpillsphrm.com phone number to order cialis
cheapest generic viagra https://edpillsphrm.com buy viagra cheap no prescription
buy viagra dominican republic buy ed pills online good place buy cialis
cialis pills dosage generic ed pills order viagra boots
buy levitra dapoxetine https://edpillsphrm.com cheap cialis pills online
cialis pills sale canada https://edpillsphrm.com generic viagra online
order levitra online https://edpillsphrm.com buy cialis new zealand
viagra online sale list of approved canadian pharmacies viagra sale amsterdam
safe buy generic viagra online https://edpillsphrm.com buy viagra in australia
viagra buy online usa https://edpillsphrm.com cialis cheap overnight
buy quality viagra online generic ed pills viagra pro order now
where can you buy viagra yahoo canada ed drugs online viagra prescription
viagra online australia cheap buy ed pills online viagra for sale za
buy levitra with prescription canada pharmacies online prescriptions viagra-cheap.org
what cialis pills look like https://edpillsphrm.com levitra sale canada
cheap cialis 40 mg https://edpillsphrm.com buying cialis online uk
cheap viagra cialis online generic ed pills buy viagra online from canada
otc viagra https://edpillsphrm.com viagra sale lloyds
buy viagra legally uk https://edpillsphrm.com buy viagra express delivery
order viagra by mail https://edpillsphrm.com cialis sale canada
where to buy viagra in vancouver generic viagra 100mg cheap herbal viagra uk
cialis forum where to buy canada ed drugs buy viagra soft tabs
buy cialis uk cheap list of approved canadian pharmacies can you buy viagra cvs
cialis break pills https://edpillsphrm.com viagra doses 200 mg
viagra sale karachi canadian pharmacy donde sale viagra
buy viagra online new zealand generic ed pills where to buy cialis in toronto canada
viagra women sale online list of approved canadian pharmacies buy levitra london
cheap levitra india https://edpillsphrm.com buy viagra mastercard
viagra sale bristol ed drugs online from canada cheapest levitra canada
cialis pills description canada pharmacies online prescriptions discount viagra
buy viagra uk only viagra without a doctor prescription usa order viagra online paypal
order cialis from canada https://edpillsphrm.com buy viagra professional online
discount viagra professional https://edpillsphrm.com buy cialis from india
cheapest generic viagra and cialis buy generic ed pills online where to buy viagra in la
viagrabuyonline.com canada ed drugs generic viagra cheap canada
cheap viagra real https://edpillsphrm.com buy levitra uk online
cialis viagra levitra sale generic viagra 100mg best buy levitra
generic levitra cheapest prices https://edpillsphrm.com where can i buy levitra
cialis 20mg cheap generic ed pills cvs viagra
how to buy cialis in japan generic ed pills buy viagra england
buy cialis online eu generic viagra 100mg where to buy viagra uk
buy authentic cialis https://edpillsphrm.com how to buy generic cialis
order cialis online canada online prescription for ed meds buy viagra houston