Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология Образование Политология Производство Психология Стандартизация Технологии |
ANGLE(x, y); readln; CloseGraph end.
Вид функции " ugol_0" определяет базовую форму узора. В приведенном варианте " ugol_0" равномерно изменяется от 0 до 2*PI и базовой линией является окружность (многоугольник). Слагаемое i*sin(k*ugol) определяет отклонение от базовой формы узора - циклические пульсации угла и заставляет узор " завиваться" вокруг базовой линии. Коэффициент " k" определяет количество " лепестков" узора, от параметров " i" и " dl" зависит их форма и размер. Параметр " s" определяет количество " стежков" в узоре и следовательно общий размер узора. Меняя форму базовой линии, функцию пульсации угла, а также размер стежка " dl" в зависимости от номера шага " n", можно получать самые разнообразные узоры. Например, если убрать оператор ugol_0: = ugol;, то базовой линией узора будет прямая, наклоненная к оси " Х" под углом ugil_0. Варьированием i, k, s можно менять периодичность, форму и размер деталей узора.
Практическое задание N. 1. 61
1. С использованием процедуры ANGLE построить 14-лепестковый узор без самопересечений с разным цветом для каждого лепестка узора. Построить эллиптический узор, задав вместо dl два различных значения dlx и dly. 2. Построить " кружевную ленту" с базовой линией узора в форме синусоиды: вместо оператора ugol_0: = ugol; подставить ugol_0: = Pi/4*sin(ugol);. 3. Построить " кружевную рамку", задавая поворот базовой линии через определенное число циклических изменений угла: ugol_0: = ugol_0 + pi/2;.
Создание узоров построением зеркальных отображений фигуры. Большинство людей впервые знакомятся с некоторыми принципами построения узоров, изучая детский зеркальный калейдоскоп. В калейдоскопе система из трех зеркал создает эффект нескольких шестикратных отражений набора цветных кристаллов. Математически такой принцип построения узора можно описать следующим образом. Имеется " N" выходящих из одной точки лучей - осей симметрии. Угол между лучами равен 2*PI/N. Строится первая (исходная) фигура в секторе между первым и вторым лучами. Затем строится вторая фигура как зеркальное отображение первой фигуры относительно второго луча, третья фигура, как зеркальное отображение второй фигуры относительно третьего луча и так далее. Если N - четно, то исходная фигура будет также зеркальным отражением N-й фигуры и получившийся узор будет симметричным (правильный калейдоскоп). Если нет необходимости моделировать реальные отражения, то исходную фигуру можно строить с пересечением осей симметрии и по любому количеству секторов.
Ниже приведен пример программы создания узора построением отражений " m" точек относительно " n" осей отражения (зеркал). Исходная фигура - замкнутая ломаная, состоящая из разноцветных отрезков прямых. Для каждой узловой точки линии определяется расстояние до центра узора (радиус r). Угол (ugol), под которым расположена узловая точка относительно горизонтальной линии, вычисляется как арктангенс отношения ординаты " x" к абсциссе " y" (в системе координат центра узора). Угол, под которым расположена отраженная точка, увеличивается на величину, равную удвоенной разности между углом наклона оси отражения и углом расположения отражаемой точки. { ---------- ------------ " Калейдоскоп": ------------------------ Строится фигура в виде ломаной линии, состоящей из " m-1" отрезков прямых и " n" зеркальных отражений этой ломаной относительно осей симметрии, проходящих через центр узора. ------------------------------------- ------------ } Uses Graph, Crt; type mas = array[1..40, 1..20] of integer; Var Gd, Gm, n, m, i, j, Rz, { длина зеркала } xc, yc, { координаты центра узора } xr, yr: integer; { координаты концов зеркал } alf: real; { угол между зеркалом и осью X } x, y: mas; { координаты узлов фигуры } {---------------------------------------------------------------- } { процедура построения фигуры в виде ломаной линии с " m" узлами } Procedure UZOR(m, n: integer; x, y: mas); Var i, j: integer; ugol: real; Begin for j: = 1 to n do begin moveto(x[m, j], y[m, j]); { установка курсора в m-ную точку ломаной } for i: = 1 to m do begin { цикл рисования j-ой ломаной по m точкам } setcolor(i mod 7+9); lineto(x[i, j], y[i, j]) End end end;
{-----------------------------------------------------------------} { процедура расчета координат отражений точки (x, y) относительно центра узора} Procedure MIRROR(n, m: integer; var x, y: mas); var i, j: integer; r, ugol: real; { координаты точки в полярной системе координат } Begin for i: = 1 to m do begin if x[i, 1]< > 0 then ugol: =arctan(y[i, 1]/x[i, 1]) else ugol: =Pi/2; r: = sqrt(1.*x[i, 1]*x[i, 1]+y[i, 1]*y[i, 1]); for j: = 1 to n do begin ugol: = 4*Pi*j/n - ugol; x[i, j]: =round(r*cos(ugol)); y[i, j]: =round(r*sin(ugol)) end End end; { ---------------------------------------------------------------- } BEGIN Gd: = Detect; InitGraph(Gd, Gm, 'C: \tp7\bgi'); SetWriteMode(1); xc: = GetmaxX div 2; yc: = GetmaxY div 2; { координаты центра узора } n: = 12; { число зеркал } m: = 10; { число узловых точек ломаной } Rz: = 150; { длина линии зеркала } for i: = 1 to n do begin alf: = 2. *PI*i/n; xr: = xc + round(Rz*cos(alf)); yr: = yc - round(Rz*sin(alf)); setcolor(7); line(xr, yr, xc, yc) { построение линий зеркал } end; Randomize; Repeat for i: = 1 to m do begin {расчет координат точек исходной фигуры } x[i, 1]: = Random(200)+1; y[i, 1]: = Random(100) end; MIRROR(n, m, x, y); { расчет координат отраженных точек в системе координат узора } for i: = 1 to m do { расчет координат точек узора} for j: = 1 to n do begin { в системе координат экрана } x[i, j]: = x[i, j] + xc; y[i, j]: = y[i, j] + yc end; UZOR(m, n, x, y); delay(1000); UZOR(m, n, x, y) { рисование узора } |
Последнее изменение этой страницы: 2017-03-17; Просмотров: 344; Нарушение авторского права страницы