Алгоритм вывода окружности

Для вывода контура круга можно использовать соотношение между координатами X и Y для точек окружности X2+Y2=R2 и построить алгоритм прямого вычисления координат. Однако в этом случае необходимо вычислять квадратный корень (как элемент бесконечной последовательности приближений).

Приведем запись инкрементного алгоритма Брезенхэма:

r2:=radius*radius;

dst:=4*r2;

dxt:=radius/1.414213562373;

t:=0;

s:=-4*r2*radius;

e:=(-s/2)-3*r2;

ca:=-6*r2;

cd:=-10*r2;

x:=0; y:=radius;

Закрасить пиксел (xc,yc+radius);

Закрасить пиксел (xc,yc-radius);

Закрасить пиксел (xc+radius,yc);

Закрасить пиксел (xc-radius,yc);

Для indx от 1 до dxt с шагом 1:

x:=x+1;

Если e>=0 то e:=e+t+ca иначе y:=y-1, e:=e+t-s+cd, s:=s+dst; t:=t-dst;

Закрасить пиксел (xc+x,yc+y);

Закрасить пиксел (xc+y,yc+x);

Закрасить пиксел (xc+y,yc-x);

Закрасить пиксел (xc+x,yc-y);

Закрасить пиксел (xc-x,yc-y);

Закрасить пиксел (xc-y,yc-x);

Закрасить пиксел (xc-y,yc+x);

Закрасить пиксел (xc-x,yc+y).

В этом алгоритме используется симметрия круга - в основном цикле вычисляются координаты точек окружности только для одного октанта и сразу рисуются восемь симметрично расположенных пикселов.

Алгоритм вывода эллипса

Инкрементный алгоритм для эллипса подобен алгоритму для круга, но несколько сложнее его:

 

a:=|enx-xc|; b:=|eny-yc|;

a2:=a*a; b2:=b*b;

dds:=4*a2; ddt:=4*b2; dxt:=a2/sqrt(a2+b2);

t:=0;

s:=-4*a2*b;

e:=(-s/2)-2*b2-a2;

ca:=-6*b2;

cd:=ca-4*a2;

x:=xc; y:=yc+b;

Закрасить пиксел (x, y);

Закрасить пиксел (x, 2*yc-y);

Закрасить пиксел (2*xc-x, 2*yc-y);

Закрасить пиксел (2*xc-x, y);

Для indx от 1 до dxt с шагом 1:

x:=x+1;

Если e>=0 то e:=e+t+ca иначе y:=y-1, e:=e+t-s+cd,

s:=s+dds; t:=t-ddt;

Закрасить пиксел (x, y);

Закрасить пиксел (x, 2*yc-y);

Закрасить пиксел (2*xc-x, 2*yc-y);

Закрасить пиксел (2*xc-x, y);

dxt:=|y-yc|;

e:=e-(t/2+s/2+b2+a2);

ca:=-6*a2;

cd:=ca-4*b2;

Для indx от 1 до dxt с шагом 1:

y:=y-1;

Если e<=0 то e:=e-s+ca иначе x:=x+1, e:=e-s+t+cd,

t:=t-ddt; s:=s+dds;

Закрасить пиксел (x, y);

Закрасить пиксел (x, 2*yc-y);

Закрасить пиксел (2*xc-x, 2*yc-y);

Закрасить пиксел (2*xc-x, y).

В этом алгоритме использована симметрия эллипса по квадрантам. Алгоритм состоит из двух циклов. Сначала для x от 0 до dxt, где а потом цикл до точки x=a, y=0.

Лекция 12

Алгоритмы закрашивания








Дата добавления: 2015-11-20; просмотров: 1793;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.008 сек.