Поддержка / Donate
 

WebMoney

Яндекс.Деньги

SMS.Копилка
Деньги@Mail.ru
Rupay
E-gold
PayPal

 

Благодарю за поддержку!

Лента RSS - Новости сайта Новости сайта
Лента RSS - Новости форума Новости форума
Добавить в закладки и поделиться Bookmark and Share

 

Архив исходников

 


Automatic translation

 
English German French
Italian Spanish Portuguese
Greece Japan Chinese
  Korean  

  

 

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Google  
 

Отрисовка стрелки с заданными параметрами

Автор: Александр
WEB-сайт: http://delphibase.endimus.com

{ **** UBPFD *********** by delphibase.endimus.com ****
>> Отрисовка стрелки с заданными параметрами

// рисует стрелку с заданными параметрами
// X_Line, Y_Line - координаты "неподвижного" конца линии стрелки;
// Length_Line, Length_Arrow - длина линии и бокового ребра стрелки;
// Angle_Line, Angle_Arrow - углы между линией стрелки и горизонтальной
// осью и между линией стрелки и боковым ребром стрелки;
// IsAllTriangle - если True, то "подвижные" концы боковых рёбер стрелки
// соединяются отрезком прямой(и не рисуется высота равнобедренного треугольника стрелки);
// DrawSurface - поверхность на которой будет рисоваться стрелка

Зависимости: ничего неожиданного
Автор:       Александр
Copyright:   default
Дата:        14 февраля 2004 г.
***************************************************** }

procedure DrawArrow(X_Line, Y_Line, Length_Line, Length_Arrow: Integer;
  Angle_Line, Angle_Arrow: Extended;
  IsAllTriangle: Boolean; DrawSurface: TCanvas);
var
  XB, YB, XE, YE, XM, YM: Integer;
begin

  XB := Round(X_Line + Cos(Angle_Line) * Length_Line);
  YB := Round(Y_Line - Sin(Angle_Line) * Length_Line);
  XM := Round(XB - Cos(Angle_Arrow - Angle_Line) * Length_Arrow);
  YM := Round(YB - Sin(Angle_Arrow - Angle_Line) * Length_Arrow);
  XE := Round(XB + Sin(Angle_Arrow + Angle_Line - Pi / 2) * Length_Arrow);
  YE := Round(YB + Cos(Angle_Arrow + Angle_Line - Pi / 2) * Length_Arrow);
  DrawSurface.MoveTo(X_Line, Y_Line);
  if IsAllTriangle then
  begin
    DrawSurface.LineTo(Round((XM + XE) / 2), Round((YM + YE) / 2));
    DrawSurface.MoveTo(XB, YB);
  end
  else
    DrawSurface.LineTo(XB, YB);
  DrawSurface.LineTo(XM, YM);
  if IsAllTriangle then
    DrawSurface.LineTo(XE, YE)
  else
    DrawSurface.MoveTo(XE, YE);
  DrawSurface.LineTo(XB, YB)

end;



Источник - Проект "Delphi World" © Выпуск 2002 - 2004
Автор проекта: Акулов Николай



   Rambler's Top100             Яндекс цитирования