![]() |
![]() ![]() ![]() ![]() ![]() |
![]() |
Кривая ГильбертаDelphi , Графика и Игры , Графика![]() unit gilbert_; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, ComCtrls; type TForml = class(TForm) procedure FormPaint(Sender: TObject); private { Private declarations } public { Public declarations } end; var Form1: TForm1; implementation {$R *.dfm} var p: integer = 5; // порядок кривой u: integer = 7; // длина штриха { Кривую Гильберта можно получить путем соединения элементов а,b,с и d. Каждый элемент строит соответствующая процедура. } procedure a(i: integer; canvas: TCanvas); forward; procedure b(i: integer; canvas: TCanvas); forward; procedure с(i: integer; canvas: TCanvas); forward; procedure d(i: integer; canvas: TCanvas); forward; // Элементы кривой procedure a(i: integer; canvas: TCanvas); begin if i > 0 then begin d(i - l, canvas); canvas.LineTo(canvas.PenPos.X + u, canvas.PenPos.Y); a(i - l, canvas); canvas.LineTo(canvas.PenPos.X, canvas.PenPos.Y + u); a(i - l, canvas); canvas.LineTo(canvas.PenPos.X - u, canvas.PenPos.Y); с(i - 1, canvas); end; end; procedure b(i: integer; canvas: TCanvas); begin if i > 0 then begin c(i - l, canvas); canvas.LineTo(canvas.PenPos.X - u, canvas.PenPos.Y); b(i - 1, canvas); canvas.LineTo(canvas.PenPos.X, canvas.PenPos.Y - u); b(i - l, canvas); canvas.LineTo(canvas.PenPos.X + u, canvas.PenPos.Y); d(i - l, canvas); end; end; procedure c(i: integer; canvas: TCanvas); begin if i > 0 then begin b(i - 1, canvas); canvas.LineTo(canvas.PenPos.X, canvas.PenPos.Y - u); с(i - 1, canvas); canvas.LineTo(canvas.PenPos.X - u, canvas.PenPos.Y); c(i - 1, canvas); canvas.LineTo(canvas.PenPos.X, canvas.PenPos.Y + u); a(i - 1, canvas); end; end; procedure d(i: integer; canvas: TCanvas); begin if i > 0 then begin a(i - 1, canvas); canvas.LineTo(canvas.PenPos.X, canvas.PenPos.Y + u); d(i - 1, canvas); canvas.LineTo(canvas.PenPos.X + u, canvas.PenPos.Y); d(i - 1, canvas); canvas.LineTo(canvas.PenPos.X, canvas.PenPos.Y - u); b(i - 1, canvas); end; end; procedure TForml.FormPaint(Sender: TObject); begin Form1.Canvas.MoveTo(u, u); a(5, Form1.Canvas); // вычертить кривую Гильберта end; end. Следует обратить внимание на следующую особенность реализации программы. Процедура, которая вычерчивает элемент а, помимо самой себя (для вычерчивания элемента а кривой более низкого порядка) вызывает процедуры d и ь, описание (текст) которых в тексте программы находится после процедуры а. Чтобы компилятор не вывел сообщение об ошибке, в текст программы помещено объявление процедуры с ключевым словом forward, означающим, что это только объявление, а описание (реализация) находится дальше. Таким образом, уже в процессе компиляции процедуры а, компилятор "знает", что имена ь и d означают процедуры. Программа на языке Паскаль, которая рисует кривую Гилберта с помощью Delphi. Программа состоит из нескольких процедур для рисования элементов кривой (a, b, c и d) и основной процедуры FormPaint для отрисовки формы с кривой. Кривая Гилберта рисуется рекурсивным вызовом этих процедур для создания шаблона. Каждая процедура перемещает позицию каранда на канвасе и затем вызывает себя или другие процедуры, чтобы продолжить рисование кривой. Вот краткое описание каждой процедуры:
Основная процедура FormPaint вызывает процедуру Обратите внимание, что это программы использует forward declaration для процедур Кривая Гильберта - геометрическая фигура, полученная соединением элементов a, b, с и d, каждый из которых строит соответствующую процедура. Комментарии и вопросыПолучайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.
|
||||
©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007 |