Компьютерная графика - Краткое руководство
Компьютерная графика - это искусство рисования картинок на экранах компьютеров с помощью программирования. Он включает в себя вычисления, создание и обработку данных. Другими словами, мы можем сказать, что компьютерная графика - это инструмент визуализации для создания и обработки изображений.
Электронно-лучевая трубка
Основным устройством вывода в графической системе является видеомонитор. Основным элементом видеомонитора являетсяCathode Ray Tube (CRT), показано на следующем рисунке.
Работа ЭЛТ очень проста -
Электронная пушка испускает пучок электронов (катодные лучи).
Электронный луч проходит через фокусирующие и отклоняющие системы, которые направляют его в определенные места на покрытом люминофором экране.
Когда луч попадает на экран, люминофор излучает небольшое пятно света в каждой точке, с которой контактирует электронный луч.
Он перерисовывает изображение, быстро направляя электронный луч обратно на те же точки экрана.
Есть два способа (случайное сканирование и растровое сканирование), с помощью которых мы можем отобразить объект на экране.
Растровое сканирование
В системе растрового сканирования электронный луч перемещается по экрану по одной строке сверху вниз. По мере того, как электронный луч перемещается через каждый ряд, интенсивность луча включается и выключается, чтобы создать узор из освещенных пятен.
Определение изображения хранится в области памяти, называемой Refresh Buffer или же Frame Buffer. Эта область памяти содержит набор значений интенсивности для всех точек экрана. Сохраненные значения интенсивности затем извлекаются из буфера обновления и «рисуются» на экране по одной строке (строке сканирования) за раз, как показано на следующем рисунке.
Каждая точка на экране называется pixel (picture element) или же pel. В конце каждой строки развертки электронный луч возвращается в левую часть экрана, чтобы начать отображение следующей строки развертки.
Случайное сканирование (векторное сканирование)
В этом методе электронный луч направляется только в ту часть экрана, где должно быть нарисовано изображение, а не сканирование слева направо и сверху вниз, как при растровом сканировании. Его еще называютvector display, stroke-writing display, или же calligraphic display.
Определение изображения хранится как набор команд рисования линий в области памяти, называемой refresh display file. Чтобы отобразить указанное изображение, система циклически перебирает набор команд в файле отображения, по очереди рисуя каждую линию компонента. После обработки всех команд рисования линий система возвращается к первой линейной команде в списке.
Дисплеи с произвольной разверткой предназначены для рисования всех составляющих линий изображения от 30 до 60 раз в секунду.
Применение компьютерной графики
Компьютерная графика имеет множество приложений, некоторые из которых перечислены ниже -
Computer graphics user interfaces (GUIs) - Графическая, ориентированная на мышь парадигма, которая позволяет пользователю взаимодействовать с компьютером.
Business presentation graphics - «Картинка стоит тысячи слов».
Cartography - Составление карт.
Weather Maps - Отображение в реальном времени, символьные представления.
Satellite Imaging - Геодезические изображения.
Photo Enhancement - Повышение резкости смазанных фотографий.
Medical imaging - МРТ, компьютерная томография и т. Д. - Неинвазивное внутреннее обследование.
Engineering drawings - механические, электрические, гражданские и др. - Замена по чертежам прошлых лет.
Typography - Использование изображений персонажей в издательстве - замена жесткого типа прошлого.
Architecture - Планы строительства, эскизы экстерьера - замена чертежей и чертежей прошлых лет.
Art - Компьютеры предоставляют художникам новую среду.
Training - Летные тренажеры, компьютерное обучение и др.
Entertainment - Фильмы и игры.
Simulation and modeling - Замена физического моделирования и постановок
Линия соединяет две точки. Это базовый элемент графики. Чтобы провести линию, вам понадобятся две точки, между которыми можно провести линию. В следующих трех алгоритмах мы называем одну точку линии$X_{0}, Y_{0}$ а вторая точка линии как $X_{1}, Y_{1}$.
Алгоритм DDA
Алгоритм цифрового дифференциального анализатора (DDA) - это простой алгоритм генерации линий, который объясняется здесь шаг за шагом.
Step 1 - Получите ввод двух конечных точек $(X_{0}, Y_{0})$ и $(X_{1}, Y_{1})$.
Step 2 - Рассчитайте разницу между двумя конечными точками.
dx = X1 - X0
dy = Y1 - Y0
Step 3- Основываясь на вычисленной разнице на шаге 2, вам необходимо определить количество шагов, на которые нужно поставить пиксель. Если dx> dy, вам нужно больше шагов по координате x; в противном случае по координате y.
if (absolute(dx) > absolute(dy))
Steps = absolute(dx);
else
Steps = absolute(dy);
Step 4 - Вычислить приращение по координате x и координате y.
Xincrement = dx / (float) steps;
Yincrement = dy / (float) steps;
Step 5 - Поместите пиксель, успешно увеличив координаты x и y соответственно, и завершите рисование линии.
for(int v=0; v < Steps; v++)
{
x = x + Xincrement;
y = y + Yincrement;
putpixel(Round(x), Round(y));
}
Генерация линии Брезенхема
Алгоритм Брезенхема - это еще один алгоритм преобразования инкрементного сканирования. Большим преимуществом этого алгоритма является то, что он использует только целочисленные вычисления. Перемещение по оси x с единичными интервалами и на каждом шаге выбор между двумя разными координатами y.
Например, как показано на следующем рисунке, из позиции (2, 3) вам нужно выбрать между (3, 3) и (3, 4). Вам нужна точка, которая находится ближе к исходной линии.
В позиции образца $X_{k}+1,$ вертикальные расстояния от математической линии обозначены как $d_{upper}$ и $d_{lower}$.
На приведенной выше иллюстрации координата y на математической линии в точке $x_{k}+1$ это -
Y = m ($X_{k}$+1) + b
Так, $d_{upper}$ и $d_{lower}$ даны следующим образом -
$$d_{lower} = y-y_{k}$$
$$= m(X_{k} + 1) + b - Y_{k}$$
и
$$d_{upper} = (y_{k} + 1) - y$$
$= Y_{k} + 1 - m (X_{k} + 1) - b$
Вы можете использовать их, чтобы принять простое решение о том, какой пиксель ближе к математической линии. Это простое решение основано на разнице между двумя позициями пикселей.
$$d_{lower} - d_{upper} = 2m(x_{k} + 1) - 2y_{k} + 2b - 1$$
Заменим m на dy / dx, где dx и dy - разности между конечными точками.
$$dx (d_{lower} - d_{upper}) =dx(2\frac{\mathrm{d} y}{\mathrm{d} x}(x_{k} + 1) - 2y_{k} + 2b - 1)$$
$$ = 2dy.x_{k} - 2dx.y_{k} + 2dy + 2dx(2b-1)$$
$$ = 2dy.x_{k} - 2dx.y_{k} + C$$
Итак, параметр решения $P_{k}$для k- го шага по линии задается -
$$p_{k} = dx(d_{lower} - d_{upper})$$
$$ = 2dy.x_{k} - 2dx.y_{k} + C$$
Знак параметра решения $P_{k}$ такой же, как у $d_{lower} - d_{upper}$.
Если $p_{k}$ отрицательно, затем выберите нижний пиксель, в противном случае выберите верхний пиксель.
Помните, что изменения координат происходят по оси x с шагом в единицу, поэтому вы можете делать все с помощью целочисленных вычислений. На шаге k + 1 параметр решения задается как -
$$p_{k +1} = 2dy.x_{k + 1} - 2dx.y_{k + 1} + C$$
Вычитание $p_{k}$ из этого получаем -
$$p_{k + 1} - p_{k} = 2dy(x_{k + 1} - x_{k}) - 2dx(y_{k + 1} - y_{k})$$
Но, $x_{k+1}$ такой же как $x_{k+1}$. Итак -
$$p_{k+1} = p_{k} + 2dy - 2dx(y_{k+1} - y_{k})$$
Где, $Y_{k+1} – Y_{k}$ равно 0 или 1 в зависимости от знака $P_{k}$.
Первый параметр решения $p_{0}$ оценивается в $(x_{0}, y_{0})$ дается как -
$$p_{0} = 2dy - dx$$
Теперь, принимая во внимание все вышеупомянутые моменты и вычисления, вот алгоритм Брезенхема для наклона m <1 -
Step 1 - Введите две конечные точки линии, сохраняя левую конечную точку в $(x_{0}, y_{0})$.
Step 2 - Постройте точку $(x_{0}, y_{0})$.
Step 3 - Вычислите константы dx, dy, 2dy и (2dy - 2dx) и получите первое значение для параметра решения как -
$$p_{0} = 2dy - dx$$
Step 4 - На каждом $X_{k}$ вдоль линии, начиная с k = 0, выполните следующий тест -
Если $p_{k}$ <0, следующая точка для построения - $(x_{k}+1, y_{k})$ и
$$p_{k+1} = p_{k} + 2dy$$ Иначе,
$$(x_{k}, y_{k}+1)$$
$$p_{k+1} = p_{k} + 2dy - 2dx$$
Step 5 - Повторите шаг 4 (dx - 1) раз.
Для m> 1 выясните, нужно ли вам увеличивать x, увеличивая каждый раз y.
После решения уравнение для параметра решения $P_{k}$ будет очень похоже, только x и y в уравнении меняются местами.
Алгоритм средней точки
Алгоритм средней точки принадлежит Брезенхэму, который был модифицирован Питтуэем и Ван Акеном. Предположим, что вы уже поместили точку P в координату (x, y), а наклон линии равен 0 ≤ k ≤ 1, как показано на следующем рисунке.
Теперь вам нужно решить, ставить ли следующую точку в E или N. Это можно выбрать, указав точку пересечения Q, ближайшую к точке N или E. Если точка пересечения Q находится ближе всего к точке N, то N рассматривается как следующий пункт; в противном случае E.
Чтобы определить это, сначала вычислите среднюю точку M (x + 1, y + ½). Если точка пересечения Q прямой с вертикальной линией, соединяющей E и N, находится ниже M, тогда возьмите E в качестве следующей точки; в противном случае возьмите N в качестве следующей точки.
Чтобы проверить это, нам нужно рассмотреть неявное уравнение -
F (x, y) = mx + b - y
Для положительного m при любом данном X,
- Если y находится на линии, то F (x, y) = 0
- Если y находится выше линии, то F (x, y) <0
- Если y ниже линии, то F (x, y)> 0
Нарисовать круг на экране немного сложнее, чем нарисовать линию. Есть два популярных алгоритма создания круга:Bresenham’s Algorithm и Midpoint Circle Algorithm. Эти алгоритмы основаны на идее определения последующих точек, необходимых для рисования круга. Давайте подробно обсудим алгоритмы -
Уравнение круга $X^{2} + Y^{2} = r^{2},$ где r радиус.
Алгоритм Брезенхема
Мы не можем отобразить непрерывную дугу на растровом дисплее. Вместо этого мы должны выбрать положение ближайшего пикселя, чтобы завершить дугу.
На следующей иллюстрации видно, что мы поместили пиксель в положение (X, Y), и теперь нужно решить, где разместить следующий пиксель - в N (X + 1, Y) или в S (X + 1, Y-1).
Это можно решить с помощью параметра решения d.
- Если d <= 0, то следующим пикселем следует выбрать N (X + 1, Y).
- Если d> 0, то следующим пикселем следует выбрать S (X + 1, Y-1).
Алгоритм
Step 1- Получите координаты центра круга и радиуса и сохраните их в x, y и R соответственно. Установите P = 0 и Q = R.
Step 2 - Установить параметр решения D = 3 - 2R.
Step 3 - Повторите шаг 8, пока P ≤ Q.
Step 4 - Вызов Draw Circle (X, Y, P, Q).
Step 5 - Увеличьте значение P.
Step 6 - Если D <0, то D = D + 4P + 6.
Step 7 - Иначе установите R = R - 1, D = D + 4 (PQ) + 10.
Step 8 - Вызов Draw Circle (X, Y, P, Q).
Draw Circle Method(X, Y, P, Q).
Call Putpixel (X + P, Y + Q).
Call Putpixel (X - P, Y + Q).
Call Putpixel (X + P, Y - Q).
Call Putpixel (X - P, Y - Q).
Call Putpixel (X + Q, Y + P).
Call Putpixel (X - Q, Y + P).
Call Putpixel (X + Q, Y - P).
Call Putpixel (X - Q, Y - P).
Алгоритм средней точки
Step 1 - Входной радиус r и центр круга $(x_{c,} y_{c})$ и получить первую точку на окружности круга с центром в начале координат как
(x0, y0) = (0, r)
Step 2 - Рассчитайте начальное значение параметра решения как
$P_{0}$ = 5/4 - r (См. Следующее описание для упрощения этого уравнения.)
f(x, y) = x2 + y2 - r2 = 0
f(xi - 1/2 + e, yi + 1)
= (xi - 1/2 + e)2 + (yi + 1)2 - r2
= (xi- 1/2)2 + (yi + 1)2 - r2 + 2(xi - 1/2)e + e2
= f(xi - 1/2, yi + 1) + 2(xi - 1/2)e + e2 = 0
Let di = f(xi - 1/2, yi + 1) = -2(xi - 1/2)e - e2
Thus,
If e < 0 then di > 0 so choose point S = (xi - 1, yi + 1).
di+1 = f(xi - 1 - 1/2, yi + 1 + 1) = ((xi - 1/2) - 1)2 + ((yi + 1) + 1)2 - r2
= di - 2(xi - 1) + 2(yi + 1) + 1
= di + 2(yi + 1 - xi + 1) + 1
If e >= 0 then di <= 0 so choose point T = (xi, yi + 1)
di+1 = f(xi - 1/2, yi + 1 + 1)
= di + 2yi+1 + 1
The initial value of di is
d0 = f(r - 1/2, 0 + 1) = (r - 1/2)2 + 12 - r2
= 5/4 - r {1-r can be used if r is an integer}
When point S = (xi - 1, yi + 1) is chosen then
di+1 = di + -2xi+1 + 2yi+1 + 1
When point T = (xi, yi + 1) is chosen then
di+1 = di + 2yi+1 + 1
Step 3 - На каждом $X_{K}$ положение, начиная с K = 0, выполните следующий тест -
If PK < 0 then next point on circle (0,0) is (XK+1,YK) and
PK+1 = PK + 2XK+1 + 1
Else
PK+1 = PK + 2XK+1 + 1 – 2YK+1
Where, 2XK+1 = 2XK+2 and 2YK+1 = 2YK-2.
Step 4 - Определите точки симметрии в других семи октантах.
Step 5 - Переместите каждую позицию вычисляемого пикселя (X, Y) по круговой траектории с центром на $(X_{C,} Y_{C})$ и нанесите на график значения координат.
X = X + XC, Y = Y + YC
Step 6 - Повторяйте шаги с 3 по 5, пока X> = Y.
Многоугольник - это упорядоченный список вершин, как показано на следующем рисунке. Для заливки полигонов определенными цветами вам необходимо определить пиксели, попадающие на границу многоугольника, и те, которые попадают внутрь многоугольника. В этой главе мы увидим, как можно заливать многоугольники разными способами.
Алгоритм сканирования линии
Этот алгоритм работает, пересекая линию сканирования с краями многоугольника и заполняя многоугольник между парами пересечений. Следующие шаги показывают, как работает этот алгоритм.
Step 1 - Найдите Ymin и Ymax из данного многоугольника.
Step 2- ScanLine пересекает каждый край многоугольника от Ymin до Ymax. Назовите каждую точку пересечения многоугольника. Как показано на рисунке выше, они называются p0, p1, p2, p3.
Step 3 - Отсортируйте точки пересечения в порядке возрастания координаты X, то есть (p0, p1), (p1, p2) и (p2, p3).
Step 4 - Заполните все те пары координат, которые находятся внутри многоугольников, и игнорируйте альтернативные пары.
Алгоритм заполнения наводнения
Иногда мы сталкиваемся с объектом, где хотим залить область и ее границу разными цветами. Мы можем раскрасить такие объекты заданным внутренним цветом вместо поиска определенного цвета границы, как в алгоритме заполнения границ.
Вместо того, чтобы полагаться на границу объекта, он полагается на цвет заливки. Другими словами, он заменяет внутренний цвет объекта цветом заливки. Когда больше нет пикселей исходного внутреннего цвета, алгоритм завершается.
И снова этот алгоритм основан на методе заполнения пикселей с четырьмя или восемью соединениями. Но вместо того, чтобы искать цвет границы, он ищет все смежные пиксели, которые являются частью интерьера.
Алгоритм граничного заполнения
Алгоритм заливки границ работает как его название. Этот алгоритм выбирает точку внутри объекта и начинает заливку, пока не достигнет границы объекта. Для работы этого алгоритма цвет границы и цвет, который мы заполняем, должны отличаться.
В этом алгоритме мы предполагаем, что цвет границы одинаков для всего объекта. Алгоритм заливки границ может быть реализован с помощью 4-связанных пикселей или 8-связанных пикселей.
4-соединенный многоугольник
В этой технике используются 4-соединенные пиксели, как показано на рисунке. Мы помещаем пиксели выше, ниже, справа и слева от текущих пикселей, и этот процесс будет продолжаться, пока мы не найдем границу с другим цветом.
Алгоритм
Step 1 - Инициализировать значение начальной точки (seedx, seedy), fcolor и dcol.
Step 2 - Определите граничные значения многоугольника.
Step 3 - Убедитесь, что текущая исходная точка имеет цвет по умолчанию, затем повторяйте шаги 4 и 5 до достижения граничных пикселей.
If getpixel(x, y) = dcol then repeat step 4 and 5
Step 4 - Измените цвет по умолчанию на цвет заливки в начальной точке.
setPixel(seedx, seedy, fcol)
Step 5 - Рекурсивно выполните процедуру с четырьмя точками соседства.
FloodFill (seedx – 1, seedy, fcol, dcol)
FloodFill (seedx + 1, seedy, fcol, dcol)
FloodFill (seedx, seedy - 1, fcol, dcol)
FloodFill (seedx – 1, seedy + 1, fcol, dcol)
Step 6 - Выход
Есть проблема с этой техникой. Рассмотрим случай, показанный ниже, где мы пытались заполнить всю область. Здесь изображение заполнено лишь частично. В таких случаях нельзя использовать технику 4-связанных пикселей.
8-соединенный многоугольник
В этой технике используются 8-соединенные пиксели, как показано на рисунке. Мы помещаем пиксели выше, ниже, справа и слева от текущих пикселей, как мы делали в 4-связной технике.
В дополнение к этому мы также помещаем пиксели по диагоналям, чтобы покрыть всю область текущего пикселя. Этот процесс будет продолжаться до тех пор, пока мы не найдем границу другого цвета.
Алгоритм
Step 1 - Инициализировать значение начальной точки (seedx, seedy), fcolor и dcol.
Step 2 - Определите граничные значения многоугольника.
Step 3 - Убедитесь, что текущая исходная точка имеет цвет по умолчанию, затем повторяйте шаги 4 и 5, пока не будут достигнуты граничные пиксели.
If getpixel(x,y) = dcol then repeat step 4 and 5
Step 4 - Измените цвет по умолчанию на цвет заливки в начальной точке.
setPixel(seedx, seedy, fcol)
Step 5 - Рекурсивно выполните процедуру с четырьмя точками соседства
FloodFill (seedx – 1, seedy, fcol, dcol)
FloodFill (seedx + 1, seedy, fcol, dcol)
FloodFill (seedx, seedy - 1, fcol, dcol)
FloodFill (seedx, seedy + 1, fcol, dcol)
FloodFill (seedx – 1, seedy + 1, fcol, dcol)
FloodFill (seedx + 1, seedy + 1, fcol, dcol)
FloodFill (seedx + 1, seedy - 1, fcol, dcol)
FloodFill (seedx – 1, seedy - 1, fcol, dcol)
Step 6 - Выход
Техника 4-соединенных пикселей не смогла заполнить область, как отмечено на следующем рисунке, чего не произойдет с техникой 8-связной.
Тест изнутри-снаружи
Этот метод также известен как counting number method. При заливке объекта нам часто нужно определить, находится ли конкретная точка внутри объекта или за его пределами. Есть два метода, с помощью которых мы можем определить, находится ли конкретная точка внутри объекта или снаружи.
- Правило четного и нечетного
- Правило ненулевого числа витков
Правило четного и нечетного
В этом методе мы считаем пересечение ребер вдоль линии от любой точки (x, y) до бесконечности. Если количество взаимодействий нечетное, то точка (x, y) является внутренней точкой. Если количество взаимодействий четное, то точка (x, y) является внешней точкой. Вот пример, чтобы дать вам четкое представление -
Из рисунка выше видно, что из точки (x, y) количество точек взаимодействия слева равно 5, а справа - 3. Таким образом, общее количество точек взаимодействия равно 8, что нечетно. . Следовательно, точка считается внутри объекта.
Правило ненулевого числа обмоток
Этот метод также используется с простыми многоугольниками, чтобы проверить, является ли данная точка внутренней или нет. Это просто можно понять с помощью булавки и резинки. Закрепите булавку на одном из краев многоугольника и привяжите к нему резиновую ленту, а затем протяните резиновую ленту по краям многоугольника.
Когда все края многоугольника будут покрыты резинкой, проверьте штифт, который был закреплен в проверяемой точке. Если мы находим хотя бы один ветер в точке, считайте его внутри многоугольника, иначе мы можем сказать, что точка не находится внутри многоугольника.
В другом альтернативном методе задайте направление всем краям многоугольника. Проведите линию сканирования от тестируемой точки к левому краю оси X.
Присвойте значение 1 всем ребрам, которые будут направлены вверх, и всем остальным -1 в качестве значений направления.
Проверьте значения направления кромок, от которых проходит линия сканирования, и просуммируйте их.
Если общая сумма значения этого направления не равна нулю, то проверяемая точка является interior point, в противном случае это exterior point.
На приведенном выше рисунке мы суммируем значения направлений, из которых проходит линия сканирования, тогда сумма составляет 1 - 1 + 1 = 1; который не равен нулю. Итак, точка называется внутренней точкой.
Основное использование обрезки в компьютерной графике - удаление объектов, линий или сегментов линий, находящихся за пределами области просмотра. Преобразование просмотра нечувствительно к положению точек относительно объема просмотра - особенно точек позади зрителя - и перед созданием вида необходимо удалить эти точки.
Отсечение точки
Вырезать точку из заданного окна очень просто. Рассмотрим следующий рисунок, где прямоугольник обозначает окно. Отсечение точки сообщает нам, находится ли данная точка (X, Y) в данном окне или нет; и решает, будем ли мы использовать минимальные и максимальные координаты окна.
Координата X данной точки находится внутри окна, если X лежит между Wx1 ≤ X ≤ Wx2. Таким же образом, координата Y данной точки находится внутри окна, если Y лежит между Wy1 ≤ Y ≤ Wy2.
Обрезка линии
Принцип отсечения линии такой же, как и отсечения точки. При обрезке линии мы вырезаем часть линии, которая находится за пределами окна, и оставляем только ту часть, которая находится внутри окна.
Вырезки линии Коэна-Сазерленда
Этот алгоритм использует окно отсечения, как показано на следующем рисунке. Минимальная координата области отсечения равна$(XW_{min,} YW_{min})$ а максимальная координата для области отсечения равна $(XW_{max,} YW_{max})$.
Мы будем использовать 4 бита, чтобы разделить всю область. Эти 4 бита представляют верхнюю, нижнюю, правую и левую часть области, как показано на следующем рисунке. ЗдесьTOP и LEFT бит установлен в 1, потому что это TOP-LEFT угол.
Есть 3 возможности для линии -
Строка может полностью находиться внутри окна (эту строку следует принять).
Линия может полностью выходить за пределы окна (эта линия будет полностью удалена из области).
Линия может частично находиться внутри окна (мы найдем точку пересечения и проведем только ту часть линии, которая находится внутри области).
Алгоритм
Step 1 - Назначьте код региона для каждой конечной точки.
Step 2 - Если у обеих конечных точек есть код региона 0000 затем примите эту строку.
Step 3 - Иначе выполните логическое ANDоперация для обоих кодов регионов.
Step 3.1 - Если результата нет 0000, затем отклоните линию.
Step 3.2 - Еще нужна вырезка.
Step 3.2.1 - Выберите конечную точку линии, которая находится за окном.
Step 3.2.2 - Найдите точку пересечения на границе окна (на основе кода региона).
Step 3.2.3 - Замените конечную точку точкой пересечения и обновите код региона.
Step 3.2.4 - Повторяйте шаг 2 до тех пор, пока мы не найдем обрезанную строку, которая либо принимается, либо тривиально отклоняется.
Step 4 - Повторите шаг 1 для других строк.
Алгоритм отсечения линии Сайруса-Бека
Этот алгоритм более эффективен, чем алгоритм Коэна-Сазерленда. Он использует параметрическое линейное представление и простые точечные произведения.
Параметрическое уравнение линии -
P0P1:P(t) = P0 + t(P1-P0)
Пусть N i - внешнее нормальное ребро E i . Теперь выберите любую произвольную точку P Ei на ребре E i, тогда скалярное произведение N i ∙ [P (t) - P Ei ] определяет, находится ли точка P (t) «внутри края клипа» или «вне» края клипа или «На» краю зажима.
Точка P (t) находится внутри, если N i . [P (t) - P Ei ] <0
Точка P (t) находится снаружи, если N i . [P (t) - P Ei ]> 0
Точка P (t) находится на ребре, если N i . [P (t) - P Ei ] = 0 (точка пересечения)
N i . [P (t) - P Ei ] = 0
N i . [P 0 + t (P 1 -P 0 ) - P Ei ] = 0 (замена P (t) на P 0 + t (P 1 -P 0 ))
N i . [P 0 - P Ei ] + N i .t [P 1 -P 0 ] = 0
N i . [P 0 - P Ei ] + N i ∙ tD = 0 (заменяя D на [P 1 -P 0 ])
N i . [P 0 - P Ei ] = - N i ∙ tD
Уравнение для t становится,
$$t = \tfrac{N_{i}.[P_{o} - P_{Ei}]}{{- N_{i}.D}}$$
Это действительно для следующих условий -
- N i ≠ 0 (ошибки не может быть)
- D ≠ 0 (P 1 ≠ P 0 )
- N i ∙ D ≠ 0 (P 0 P 1 не параллельно E i )
Отсечение многоугольника (алгоритм Сазерленда-Ходжмана)
Многоугольник также можно обрезать, указав окно обрезки. Алгоритм отсечения полигонов Сазерленда Ходжмана используется для отсечения полигонов. В этом алгоритме все вершины многоугольника отсекаются по каждому краю окна отсечения.
Сначала многоугольник обрезается по левому краю окна многоугольника, чтобы получить новые вершины многоугольника. Эти новые вершины используются для обрезки многоугольника по правому краю, верхнему краю, нижнему краю окна отсечения, как показано на следующем рисунке.
При обработке края многоугольника с окном отсечения точка пересечения обнаруживается, если край не полностью находится внутри окна отсечения, а частичный край от точки пересечения до внешнего края обрезается. На следующих рисунках показаны обрезки левого, правого, верхнего и нижнего края -
Обрезка текста
Для вырезания текста в компьютерной графике используются различные методы. Это зависит от методов, используемых для создания символов, и требований конкретного приложения. Есть три метода обрезки текста, которые перечислены ниже:
- Обрезка всех строк или ничего
- Обрезка всех или ни одного символа
- Обрезка текста
На следующем рисунке показаны все или никакие обрезки строк -
В методе обрезки всей строки или отсутствия строки мы либо сохраняем всю строку, либо отклоняем всю строку на основе окна обрезки. Как показано на рисунке выше, STRING2 полностью находится внутри окна отсечения, поэтому мы оставляем его, а STRING1, находясь только частично внутри окна, мы отклоняем.
На следующем рисунке показано вырезание всех или ни одного символа -
Этот метод отсечения основан на символах, а не на всей строке. В этом методе, если строка полностью находится внутри окна отсечения, мы сохраняем ее. Если он частично находится за окном, то -
Вы отклоняете только ту часть строки, которая находится вне
Если символ находится на границе окна отсечения, мы отбрасываем этот символ целиком и оставляем остальную строку.
На следующем рисунке показано вырезание текста -
Этот метод отсечения основан на символах, а не на всей строке. В этом методе, если строка полностью находится внутри окна отсечения, мы сохраняем ее. Если он частично находится за окном, то
Вы отклоняете только ту часть строки, которая находится снаружи.
Если символ находится на границе окна отсечения, мы отбрасываем только ту часть символа, которая находится за пределами окна отсечения.
Растровая графика
Растровое изображение - это набор пикселей, описывающий изображение. Это тип компьютерной графики, которую компьютер использует для хранения и отображения изображений. В этом типе графики изображения хранятся побитно, поэтому он называется растровой графикой. Для лучшего понимания давайте рассмотрим следующий пример, в котором мы рисуем смайлик, используя растровую графику.
Теперь посмотрим, как этот смайлик по крупицам сохраняется в компьютерной графике.
Присмотревшись к исходному смайлику, мы можем увидеть две синие линии, которые на рисунке выше представлены как B1, B2 и E1, E2.
Таким же образом смайлик представлен с использованием битов комбинации A4, B5, C6, D6, E5 и F4 соответственно.
Основными недостатками растровой графики являются -
Мы не можем изменить размер растрового изображения. Если вы попытаетесь изменить размер, пиксели станут размытыми.
Цветные растровые изображения могут быть очень большими.
Преобразование означает преобразование одной графики в другую с применением правил. У нас могут быть различные типы преобразований, такие как перемещение, масштабирование вверх или вниз, вращение, сдвиг и т. Д. Когда преобразование происходит на 2D-плоскости, это называется 2D-преобразованием.
Преобразования играют важную роль в компьютерной графике для изменения положения графики на экране и изменения их размера или ориентации.
Однородные координаты
Чтобы выполнить последовательность преобразования, такую как перевод с последующим вращением и масштабированием, нам нужно выполнить последовательный процесс -
- Перевести координаты,
- Поверните переведенные координаты, а затем
- Масштабируйте повернутые координаты, чтобы завершить составное преобразование.
Чтобы сократить этот процесс, мы должны использовать матрицу преобразования 3 × 3 вместо матрицы преобразования 2 × 2. Чтобы преобразовать матрицу 2 × 2 в матрицу 3 × 3, мы должны добавить дополнительную фиктивную координату W.
Таким образом, мы можем представить точку тремя числами вместо двух, что называется Homogenous Coordinateсистема. В этой системе мы можем представить все уравнения преобразования в матричном умножении. Любая декартова точка P (X, Y) может быть преобразована в однородные координаты с помощью P '(X h , Y h , h).
Перевод
Перевод перемещает объект в другое место на экране. Вы можете перевести точку в 2D, добавив координату переноса (t x , t y ) к исходной координате (X, Y), чтобы получить новую координату (X ', Y').
Из рисунка выше вы можете написать, что -
X’ = X + tx
Y’ = Y + ty
Пара (t x , t y ) называется вектором трансляции или вектором сдвига. Вышеупомянутые уравнения также могут быть представлены с помощью векторов-столбцов.
$P = \frac{[X]}{[Y]}$ p '= $\frac{[X']}{[Y']}$Т = $\frac{[t_{x}]}{[t_{y}]}$
Мы можем записать это как -
P’ = P + T
Вращение
Во время вращения мы поворачиваем объект на определенный угол θ (тета) от его начала. Из следующего рисунка видно, что точка P (X, Y) расположена под углом φ от горизонтальной координаты X на расстоянии r от начала координат.
Предположим, вы хотите повернуть его на угол θ. После поворота на новое место вы получите новую точку P '(X', Y ').
Используя стандартную тригонометрию, исходная координата точки P (X, Y) может быть представлена как -
$X = r \, cos \, \phi ...... (1)$
$Y = r \, sin \, \phi ...... (2)$
Точно так же мы можем представить точку P '(X', Y ') как -
${x}'= r \: cos \: \left ( \phi \: + \: \theta \right ) = r\: cos \: \phi \: cos \: \theta \: − \: r \: sin \: \phi \: sin \: \theta ....... (3)$
${y}'= r \: sin \: \left ( \phi \: + \: \theta \right ) = r\: cos \: \phi \: sin \: \theta \: + \: r \: sin \: \phi \: cos \: \theta ....... (4)$
Подставляя уравнения (1) и (2) в (3) и (4) соответственно, мы получим
${x}'= x \: cos \: \theta − \: y \: sin \: \theta $
${y}'= x \: sin \: \theta + \: y \: cos \: \theta $
Представляя вышеуказанное уравнение в матричной форме,
$$[X' Y'] = [X Y] \begin{bmatrix} cos\theta & sin\theta \\ −sin\theta & cos\theta \end{bmatrix}OR $$
P '= P ∙ R
Где R - матрица вращения
$$R = \begin{bmatrix} cos\theta & sin\theta \\ −sin\theta & cos\theta \end{bmatrix}$$
Угол поворота может быть положительным и отрицательным.
Для положительного угла поворота мы можем использовать указанную выше матрицу поворота. Однако для поворота на отрицательный угол матрица изменится, как показано ниже -
$$R = \begin{bmatrix} cos(−\theta) & sin(−\theta) \\ -sin(−\theta) & cos(−\theta) \end{bmatrix}$$
$$=\begin{bmatrix} cos\theta & −sin\theta \\ sin\theta & cos\theta \end{bmatrix} \left (\because cos(−\theta ) = cos \theta \; and\; sin(−\theta ) = −sin \theta \right )$$
Масштабирование
Для изменения размера объекта используется преобразование масштабирования. В процессе масштабирования вы либо увеличиваете, либо сжимаете размеры объекта. Масштабирование может быть достигнуто путем умножения исходных координат объекта на коэффициент масштабирования, чтобы получить желаемый результат.
Предположим, что исходные координаты - (X, Y), коэффициенты масштабирования - (S X , S Y ), а полученные координаты - (X ', Y'). Математически это можно представить, как показано ниже -
X' = X . SX and Y' = Y . SY
Коэффициент масштабирования S X , S Y масштабирует объект по осям X и Y соответственно. Вышеупомянутые уравнения также могут быть представлены в матричной форме, как показано ниже -
$$\binom{X'}{Y'} = \binom{X}{Y} \begin{bmatrix} S_{x} & 0\\ 0 & S_{y} \end{bmatrix}$$
ИЛИ ЖЕ
P’ = P . S
Где S - матрица масштабирования. Процесс масштабирования показан на следующем рисунке.
Если мы предоставим значения меньше 1 для коэффициента масштабирования S, то мы можем уменьшить размер объекта. Если мы предоставим значения больше 1, то мы можем увеличить размер объекта.
Отражение
Отражение - это зеркальное отображение исходного объекта. Другими словами, мы можем сказать, что это операция вращения на 180 °. При преобразовании отражения размер объекта не меняется.
На следующих рисунках показаны отражения относительно осей X и Y и относительно начала координат соответственно.
Сдвиг
Преобразование, изменяющее форму объекта, называется преобразованием сдвига. Есть два сдвиговых преобразованияX-Shear и Y-Shear. Один сдвигает значения координат X, а другой сдвигает значения координат Y. Тем не мение; в обоих случаях только одна координата меняет свои координаты, а другая сохраняет свои значения. Стрижка также называетсяSkewing.
X-Shear
X-Shear сохраняет координату Y, и в координаты X вносятся изменения, в результате чего вертикальные линии наклоняются вправо или влево, как показано на рисунке ниже.
Матрица преобразования для X-Shear может быть представлена как -
$$X_{sh} = \begin{bmatrix} 1& shx& 0\\ 0& 1& 0\\ 0& 0& 1 \end{bmatrix}$$
Y '= Y + Sh y . Икс
X '= X
Y-ножницы
Y-Shear сохраняет координаты X и изменяет координаты Y, в результате чего горизонтальные линии трансформируются в линии с уклоном вверх или вниз, как показано на следующем рисунке.
Y-сдвиг может быть представлен в матрице как -
$$Y_{sh} \begin{bmatrix} 1& 0& 0\\ shy& 1& 0\\ 0& 0& 1 \end{bmatrix}$$
Х '= Х + Ш х . Y
Y '= Y
Составное преобразование
Если за преобразованием плоскости T1 следует преобразование второй плоскости T2, то сам результат может быть представлен одним преобразованием T, которое является композицией T1 и T2, взятых в этом порядке. Это записывается как T = T1 ∙ T2.
Составное преобразование может быть достигнуто путем объединения матриц преобразования для получения комбинированной матрицы преобразования.
Комбинированная матрица -
[T][X] = [X] [T1] [T2] [T3] [T4] …. [Tn]
Где [Ti] - любая комбинация
- Translation
- Scaling
- Shearing
- Rotation
- Reflection
Изменение порядка преобразования приведет к другим результатам, поскольку в общем случае умножение матриц не является накопительным, то есть [A]. [B] ≠ [B]. [A] и порядок умножения. Основная цель составления преобразований - повысить эффективность за счет применения одного составного преобразования к точке, а не применения серии преобразований одно за другим.
Например, чтобы повернуть объект вокруг произвольной точки (X p , Y p ), мы должны выполнить три шага:
- Переведите точку (X p , Y p ) в начало координат.
- Поверните его относительно начала координат.
- Наконец, переместите центр вращения обратно на место.
В 2D-системе мы используем только две координаты X и Y, но в 3D добавляется дополнительная координата Z. Методы трехмерной графики и их применение имеют фундаментальное значение для индустрии развлечений, игр и компьютерного дизайна. Это постоянная область исследований в области научной визуализации.
Кроме того, компоненты трехмерной графики теперь являются частью почти каждого персонального компьютера и, хотя традиционно предназначены для программного обеспечения с интенсивным использованием графики, такого как игры, они все чаще используются другими приложениями.
Параллельная проекция
При параллельной проекции координата z отбрасывается, а параллельные линии от каждой вершины объекта растягиваются до пересечения с плоскостью обзора. В параллельной проекции мы указываем направление проекции вместо центра проекции.
При параллельной проекции расстояние от центра проекции до плоскости проекции бесконечно. В этом типе проекции мы соединяем спроецированные вершины отрезками линии, которые соответствуют соединениям на исходном объекте.
Параллельные проекции менее реалистичны, но они хороши для точных измерений. В проекциях этого типа параллельные линии остаются параллельными, а углы не сохраняются. Различные типы параллельных проекций показаны в следующей иерархии.
Ортографическая проекция
В ортогональной проекции направление проекции перпендикулярно проекции плоскости. Есть три типа орфографических проекций -
- Передняя проекция
- Верхняя проекция
- Боковая проекция
Косая проекция
В наклонной проекции направление проекции не перпендикулярно проекции плоскости. В наклонной проекции мы можем видеть объект лучше, чем в ортогональной проекции.
Есть два типа наклонных проекций - Cavalier и Cabinet. Проекция Cavalier составляет 45 ° к плоскости проекции. Проекция линии, перпендикулярной плоскости обзора, имеет ту же длину, что и сама линия в проекции Кавальер. В кавалерской проекции коэффициенты ракурса для всех трех основных направлений равны.
Выступ шкафа составляет 63,4 ° к плоскости проекции. В проекции кабинета линии, перпендикулярные поверхности просмотра, проецируются на 1/2 своей фактической длины. Обе проекции показаны на следующем рисунке -
Изометрические проекции
Ортографические проекции, которые показывают более одной стороны объекта, называются axonometric orthographic projections. Наиболее распространенная аксонометрическая проекция - этоisometric projectionгде плоскость проекции пересекает каждую координатную ось в системе координат модели на равном расстоянии. В этой проекции сохраняется параллельность линий, но не углы. На следующем рисунке показана изометрическая проекция -
Перспективная проекция
В перспективной проекции расстояние от центра проекции до проекционной плоскости конечно, а размер объекта изменяется обратно пропорционально расстоянию, что выглядит более реалистично.
Расстояние и углы не сохраняются, а параллельные линии не остаются параллельными. Вместо этого все они сходятся в одной точке, называемойcenter of projection или же projection reference point. Существует 3 типа перспективных проекций, которые показаны на следующей диаграмме.
One point перспективную проекцию нарисовать просто.
Two point перспективная проекция дает лучшее впечатление глубины.
Three point перспективную проекцию нарисовать сложнее всего.
На следующем рисунке показаны все три типа перспективной проекции -
Перевод
В 3D-трансляции мы передаем координату Z вместе с координатами X и Y. Процесс перевода в 3D похож на 2D-перевод. Перевод перемещает объект в другое положение на экране.
На следующем рисунке показан эффект перевода -
Точку можно перевести в 3D, добавив координату перевода $(t_{x,} t_{y,} t_{z})$ к исходной координате (X, Y, Z), чтобы получить новую координату (X ', Y', Z ').
$T = \begin{bmatrix} 1& 0& 0& 0\\ 0& 1& 0& 0\\ 0& 0& 1& 0\\ t_{x}& t_{y}& t_{z}& 1\\ \end{bmatrix}$
P '= P ∙ T
$[X′ \:\: Y′ \:\: Z′ \:\: 1] \: = \: [X \:\: Y \:\: Z \:\: 1] \: \begin{bmatrix} 1& 0& 0& 0\\ 0& 1& 0& 0\\ 0& 0& 1& 0\\ t_{x}& t_{y}& t_{z}& 1\\ \end{bmatrix}$
$= [X + t_{x} \:\:\: Y + t_{y} \:\:\: Z + t_{z} \:\:\: 1]$
Вращение
Трехмерное вращение отличается от двухмерного вращения. В трехмерном вращении мы должны указать угол поворота вместе с осью вращения. Мы можем выполнять трехмерное вращение вокруг осей X, Y и Z. Они представлены в матричной форме, как показано ниже -
$$R_{x}(\theta) = \begin{bmatrix} 1& 0& 0& 0\\ 0& cos\theta & −sin\theta& 0\\ 0& sin\theta & cos\theta& 0\\ 0& 0& 0& 1\\ \end{bmatrix} R_{y}(\theta) = \begin{bmatrix} cos\theta& 0& sin\theta& 0\\ 0& 1& 0& 0\\ −sin\theta& 0& cos\theta& 0\\ 0& 0& 0& 1\\ \end{bmatrix} R_{z}(\theta) =\begin{bmatrix} cos\theta & −sin\theta & 0& 0\\ sin\theta & cos\theta & 0& 0\\ 0& 0& 1& 0\\ 0& 0& 0& 1 \end{bmatrix}$$
Следующий рисунок объясняет вращение вокруг различных осей -
Масштабирование
Вы можете изменить размер объекта, используя преобразование масштабирования. В процессе масштабирования вы либо увеличиваете, либо сжимаете размеры объекта. Масштабирование может быть достигнуто путем умножения исходных координат объекта на коэффициент масштабирования, чтобы получить желаемый результат. На следующем рисунке показан эффект 3D-масштабирования -
В операции трехмерного масштабирования используются три координаты. Предположим, что исходные координаты (X, Y, Z), коэффициенты масштабирования равны$(S_{X,} S_{Y,} S_{z})$соответственно, а полученные координаты - (X ', Y', Z '). Математически это можно представить, как показано ниже -
$S = \begin{bmatrix} S_{x}& 0& 0& 0\\ 0& S_{y}& 0& 0\\ 0& 0& S_{z}& 0\\ 0& 0& 0& 1 \end{bmatrix}$
P '= P ∙ S
$[{X}' \:\:\: {Y}' \:\:\: {Z}' \:\:\: 1] = [X \:\:\:Y \:\:\: Z \:\:\: 1] \:\: \begin{bmatrix} S_{x}& 0& 0& 0\\ 0& S_{y}& 0& 0\\ 0& 0& S_{z}& 0\\ 0& 0& 0& 1 \end{bmatrix}$
$ = [X.S_{x} \:\:\: Y.S_{y} \:\:\: Z.S_{z} \:\:\: 1]$
Сдвиг
Преобразование, изменяющее форму объекта, называется shear transformation. Как и в случае 2D-сдвига, мы можем разрезать объект по оси X, Y или Z в 3D.
Как показано на приведенном выше рисунке, есть координата P. Вы можете сдвинуть ее, чтобы получить новую координату P ', которая может быть представлена в виде трехмерной матрицы, как показано ниже -
$Sh = \begin{bmatrix} 1 & sh_{x}^{y} & sh_{x}^{z} & 0 \\ sh_{y}^{x} & 1 & sh_{y}^{z} & 0 \\ sh_{z}^{x} & sh_{z}^{y} & 1 & 0 \\ 0 & 0 & 0 & 1 \end{bmatrix}$
P '= P ∙ Sh
$X’ = X + Sh_{x}^{y} Y + Sh_{x}^{z} Z$
$Y' = Sh_{y}^{x}X + Y +sh_{y}^{z}Z$
$Z' = Sh_{z}^{x}X + Sh_{z}^{y}Y + Z$
Матрицы преобразования
Матрица трансформации - это основной инструмент трансформации. Матрица размером nxm умножается на координату объектов. Обычно для преобразования используются матрицы 3 x 3 или 4 x 4. Например, рассмотрим следующую матрицу для различных операций.
$T = \begin{bmatrix} 1& 0& 0& 0\\ 0& 1& 0& 0\\ 0& 0& 1& 0\\ t_{x}& t_{y}& t_{z}& 1\\ \end{bmatrix}$ | $S = \begin{bmatrix} S_{x}& 0& 0& 0\\ 0& S_{y}& 0& 0\\ 0& 0& S_{z}& 0\\ 0& 0& 0& 1 \end{bmatrix}$ | $Sh = \begin{bmatrix} 1& sh_{x}^{y}& sh_{x}^{z}& 0\\ sh_{y}^{x}& 1 & sh_{y}^{z}& 0\\ sh_{z}^{x}& sh_{z}^{y}& 1& 0\\ 0& 0& 0& 1 \end{bmatrix}$ |
Translation Matrix | Scaling Matrix | Shear Matrix |
$R_{x}(\theta) = \begin{bmatrix} 1& 0& 0& 0\\ 0& cos\theta & -sin\theta& 0\\ 0& sin\theta & cos\theta& 0\\ 0& 0& 0& 1\\ \end{bmatrix}$ | $R_{y}(\theta) = \begin{bmatrix} cos\theta& 0& sin\theta& 0\\ 0& 1& 0& 0\\ -sin\theta& 0& cos\theta& 0\\ 0& 0& 0& 1\\ \end{bmatrix}$ | $R_{z}(\theta) = \begin{bmatrix} cos\theta & -sin\theta & 0& 0\\ sin\theta & cos\theta & 0& 0\\ 0& 0& 1& 0\\ 0& 0& 0& 1 \end{bmatrix}$ |
Rotation Matrix |
В компьютерной графике нам часто нужно рисовать на экране разные типы объектов. Объекты не всегда бывают плоскими, и нам нужно много раз рисовать кривые, чтобы нарисовать объект.
Типы кривых
Кривая - это бесконечно большой набор точек. У каждой точки есть два соседа, кроме конечных точек. Кривые можно в целом разделить на три категории:explicit, implicit, и parametric curves.
Неявные кривые
Неявные представления кривой определяют набор точек на кривой, используя процедуру, которая может проверить, находится ли точка на кривой. Обычно неявная кривая определяется неявной функцией формы -
f (x, y) = 0
Он может представлять многозначные кривые (несколько значений y для значения x). Типичным примером является круг, неявное представление которого
x2 + y2 - R2 = 0
Явные кривые
Математическая функция y = f (x) может быть изображена в виде кривой. Такая функция является явным представлением кривой. Явное представление не является общим, поскольку оно не может представлять вертикальные линии и также является однозначным. Для каждого значения x функция обычно вычисляет только одно значение y.
Параметрические кривые
Кривые, имеющие параметрическую форму, называются параметрическими кривыми. Явные и неявные представления кривой могут использоваться только в том случае, если функция известна. На практике используются параметрические кривые. Двумерная параметрическая кривая имеет следующий вид -
P (t) = f (t), g (t) или P (t) = x (t), y (t)
Функции f и g становятся координатами (x, y) любой точки на кривой, и точки получаются, когда параметр t изменяется в определенном интервале [a, b], обычно [0, 1].
Кривые Безье
Кривая Безье открыта французским инженером Pierre Bézier. Эти кривые могут быть созданы под контролем других точек. Приблизительные касательные с использованием контрольных точек используются для построения кривой. Кривая Безье может быть представлена математически как -
$$\sum_{k=0}^{n} P_{i}{B_{i}^{n}}(t)$$
где $p_{i}$ - множество точек и ${B_{i}^{n}}(t)$ представляет собой полиномы Бернштейна, которые задаются -
$${B_{i}^{n}}(t) = \binom{n}{i} (1 - t)^{n-i}t^{i}$$
где n - степень полинома, i это индекс, а t это переменная.
Простейшая кривая Безье - это прямая линия от точки $P_{0}$ к $P_{1}$. Квадратичная кривая Безье определяется тремя контрольными точками. Кубическая кривая Безье определяется четырьмя контрольными точками.
Свойства кривых Безье
Кривые Безье обладают следующими свойствами -
Обычно они повторяют форму контрольного многоугольника, который состоит из сегментов, соединяющих контрольные точки.
Они всегда проходят через первую и последнюю контрольные точки.
Они содержатся в выпуклой оболочке своих определяющих контрольных точек.
Степень полинома, определяющего сегмент кривой, на единицу меньше количества определяющих точек многоугольника. Следовательно, для 4 контрольных точек степень полинома равна 3, т.е. кубический полином.
Кривая Безье обычно повторяет форму определяющего многоугольника.
Направление касательного вектора в конечных точках такое же, как у вектора, определенного первым и последним отрезками.
Свойство выпуклой оболочки для кривой Безье гарантирует, что многочлен плавно следует за контрольными точками.
Никакая прямая линия не пересекает кривую Безье больше раз, чем ее контрольный многоугольник.
Они инвариантны относительно аффинного преобразования.
Кривые Безье демонстрируют глобальный контроль, что означает, что перемещение контрольной точки изменяет форму всей кривой.
Данная кривая Безье может быть подразделена в точке t = t0 на два сегмента Безье, которые соединяются вместе в точке, соответствующей значению параметра t = t0.
B-сплайновые кривые
Кривая Безье, полученная с помощью базисной функции Бернштейна, имеет ограниченную гибкость.
Во-первых, количество указанных вершин многоугольника фиксирует порядок полученного многочлена, который определяет кривую.
Вторая ограничивающая характеристика заключается в том, что значение функции смешения отлично от нуля для всех значений параметров по всей кривой.
Базис B-сплайнов содержит базис Бернштейна как частный случай. Базис B-сплайнов неглобальный.
Кривая B-сплайна определяется как линейная комбинация контрольных точек Pi и базовой функции B-сплайна. $N_{i,}$ k (t) определяется как
$C(t) = \sum_{i=0}^{n}P_{i}N_{i,k}(t),$ $n\geq k-1,$ $t\: \epsilon \: [ tk-1,tn+1 ]$
Где,
{$p_{i}$: i = 0, 1, 2… .n} - контрольные точки
k - порядок полиномиальных сегментов B-сплайновой кривой. Порядок k означает, что кривая составлена из кусочно-полиномиальных отрезков степени k - 1,
в $N_{i,k}(t)$являются «нормализованными функциями смешивания B-сплайнов». Они описываются порядком k и неубывающей последовательностью действительных чисел, обычно называемой «последовательностью узлов».
$${t_{i}:i = 0, ... n + K}$$
Функции N i , k описываются следующим образом:
$$N_{i,1}(t) = \left\{\begin{matrix} 1,& if \:u \: \epsilon \: [t_{i,}t_{i+1}) \\ 0,& Otherwise \end{matrix}\right.$$
и если k> 1,
$$N_{i,k}(t) = \frac{t-t_{i}}{t_{i+k-1}} N_{i,k-1}(t) + \frac{t_{i+k}-t}{t_{i+k} - t_{i+1}} N_{i+1,k-1}(t)$$
и
$$t \: \epsilon \: [t_{k-1},t_{n+1})$$
Свойства кривой B-сплайна
Кривые B-сплайна обладают следующими свойствами:
Сумма базисных функций B-сплайна для любого значения параметра равна 1.
Каждая базисная функция положительна или равна нулю для всех значений параметров.
Каждая базисная функция имеет ровно одно максимальное значение, за исключением k = 1.
Максимальный порядок кривой равен количеству вершин определяющего многоугольника.
Степень полинома B-сплайна не зависит от количества вершин определяющего многоугольника.
B-сплайн позволяет локально управлять поверхностью кривой, потому что каждая вершина влияет на форму кривой только в диапазоне значений параметров, в котором связанная с ней базовая функция отлична от нуля.
Кривая демонстрирует свойство уменьшения вариации.
Кривая обычно повторяет форму определяющего многоугольника.
Любое аффинное преобразование можно применить к кривой, применив ее к вершинам определяющего многоугольника.
Линия кривой внутри выпуклой оболочки определяющего многоугольника.
Многоугольные поверхности
Объекты представлены в виде набора поверхностей. Представление 3D-объекта делится на две категории.
Boundary Representations (B-reps) - Он описывает 3D-объект как набор поверхностей, которые отделяют интерьер объекта от окружающей среды.
Space–partitioning representations - Он используется для описания внутренних свойств путем разделения пространственной области, содержащей объект, на набор небольших неперекрывающихся смежных твердых тел (обычно кубиков).
Наиболее часто используемым представлением границы для объекта 3D-графики является набор полигонов поверхности, которые окружают внутреннюю часть объекта. Многие графические системы используют этот метод. Набор полигонов сохраняется для описания объекта. Это упрощает и ускоряет визуализацию поверхности и отображение объекта, поскольку все поверхности можно описать линейными уравнениями.
Полигональные поверхности широко используются в приложениях для проектирования и твердотельного моделирования, поскольку их wireframe displayможно сделать быстро, чтобы дать общее представление о структуре поверхности. Затем создаются реалистичные сцены путем интерполяции шаблонов затенения по поверхности многоугольника для освещения.
Таблицы многоугольников
В этом методе поверхность определяется набором координат вершин и связанных атрибутов. Как показано на следующем рисунке, имеется пять вершин от v 1 до v 5 .
Каждая вершина хранит информацию о координатах x, y и z, которая представлена в таблице как v 1 : x 1 , y 1 , z 1 .
Таблица Edge используется для хранения информации о краях многоугольника. На следующем рисунке ребро E 1 находится между вершинами v 1 и v 2, которые представлены в таблице как E 1 : v 1 , v 2 .
Таблица поверхностей многоугольника хранит количество поверхностей, присутствующих в многоугольнике. На следующем рисунке поверхность S 1 покрыта ребрами E 1 , E 2 и E 3, которые могут быть представлены в таблице поверхностей многоугольника как S 1 : E 1 , E 2 и E 3 .
Плоские уравнения
Уравнение для плоской поверхности может быть выражено как -
Ах + By + Cz + D = 0
Где (x, y, z) - любая точка на плоскости, а коэффициенты A, B, C и D - константы, описывающие пространственные свойства плоскости. Мы можем получить значения A, B, C и D, решив набор трех плоских уравнений, используя значения координат для трех неколлинеарных точек на плоскости. Предположим, что три вершины плоскости - это (x 1 , y 1 , z 1 ), (x 2 , y 2 , z 2 ) и (x 3 , y 3 , z 3 ).
Решим следующие одновременные уравнения для отношений A / D, B / D и C / D. Вы получаете значения A, B, C и D.
(A / D) x 1 + (B / D) y 1 + (C / D) z 1 = -1
(A / D) х 2 + (B / D) y 2 + (C / D) z 2 = -1
(A / D) x 3 + (B / D) y 3 + (C / D) z 3 = -1
Чтобы получить вышеуказанные уравнения в детерминантной форме, примените правило Крамера к вышеуказанным уравнениям.
$A = \begin{bmatrix} 1& y_{1}& z_{1}\\ 1& y_{2}& z_{2}\\ 1& y_{3}& z_{3} \end{bmatrix} B = \begin{bmatrix} x_{1}& 1& z_{1}\\ x_{2}& 1& z_{2}\\ x_{3}& 1& z_{3} \end{bmatrix} C = \begin{bmatrix} x_{1}& y_{1}& 1\\ x_{2}& y_{2}& 1\\ x_{3}& y_{3}& 1 \end{bmatrix} D = - \begin{bmatrix} x_{1}& y_{1}& z_{1}\\ x_{2}& y_{2}& z_{2}\\ x_{3}& y_{3}& z_{3} \end{bmatrix}$
Для любой точки (x, y, z) с параметрами A, B, C и D мы можем сказать, что -
Ax + By + Cz + D ≠ 0 означает, что точка не находится на плоскости.
Ax + By + Cz + D <0 означает, что точка находится внутри поверхности.
Ax + By + Cz + D> 0 означает, что точка находится вне поверхности.
Многоугольные сетки
3D-поверхности и твердые тела могут быть аппроксимированы набором многоугольных и линейных элементов. Такие поверхности называютсяpolygonal meshes. В полигональной сетке каждое ребро используется не более чем двумя полигонами. Набор полигонов или граней вместе формирует «кожу» объекта.
Этот метод можно использовать для представления в графике широкого класса твердых тел / поверхностей. Полигональную сетку можно визуализировать с помощью алгоритмов удаления скрытых поверхностей. Полигональную сетку можно представить тремя способами:
- Явное представление
- Указатели на список вершин
- Указатели на список краев
Преимущества
- Его можно использовать для моделирования практически любого объекта.
- Их легко представить в виде набора вершин.
- Их легко трансформировать.
- Их легко нарисовать на экране компьютера.
Недостатки
- Кривые поверхности можно описать только приблизительно.
- Сложно смоделировать некоторые типы объектов, например волосы или жидкость.
Когда мы смотрим на изображение, содержащее непрозрачные объекты и поверхности, мы не можем видеть те объекты, которые находятся позади от объектов, находящихся ближе к глазу. Мы должны удалить эти скрытые поверхности, чтобы получить реалистичное изображение на экране. Выявление и удаление этих поверхностей называетсяHidden-surface problem.
Есть два подхода к удалению скрытых поверхностных проблем: Object-Space method и Image-space method. Метод пространства объектов реализован в физической системе координат, а метод пространства изображений реализован в системе координат экрана.
Когда мы хотим отобразить 3D-объект на 2D-экране, нам необходимо идентифицировать те части экрана, которые видны с выбранной позиции просмотра.
Метод с буфером глубины (Z-буфер)
Этот метод разработан Катмулл. Это подход, основанный на пространстве изображений. Основная идея состоит в том, чтобы проверить глубину Z каждой поверхности, чтобы определить ближайшую (видимую) поверхность.
В этом методе каждая поверхность обрабатывается отдельно по одному пикселю за раз по всей поверхности. Значения глубины для пикселя сравниваются, и ближайшая (наименьшая z) поверхность определяет цвет, который будет отображаться в буфере кадра.
Очень эффективно наносится на поверхности многоугольника. Поверхности можно обрабатывать в любом порядке. Чтобы переопределить более близкие полигоны от дальних, два буфера с именемframe buffer и depth buffer, используются.
Depth buffer используется для хранения значений глубины для позиции (x, y) по мере обработки поверхностей (0 ≤ глубина ≤ 1).
В frame buffer используется для хранения значения интенсивности значения цвета в каждой позиции (x, y).
Z-координаты обычно нормируются в диапазоне [0, 1]. Значение 0 для координаты z указывает заднюю панель отсечения, а значение 1 для координаты z указывает переднюю панель отсечения.
Алгоритм
Step-1 - Установите значения буфера -
Буфер глубины (x, y) = 0
Framebuffer (x, y) = цвет фона
Step-2 - Обработка каждого полигона (по одному)
Для каждого проецируемого (x, y) пикселя многоугольника вычислите глубину z.
Если Z> depthbuffer (x, y)
Вычислить цвет поверхности,
установить depthbuffer (x, y) = z,
framebuffer (x, y) = цвет поверхности (x, y)
Преимущества
- Легко реализовать.
- Это снижает проблему скорости, если реализовано аппаратно.
- Он обрабатывает один объект за раз.
Недостатки
- Требуется большая память.
- Это трудоемкий процесс.
Метод сканирования линии
Это метод определения видимой поверхности в пространстве изображений. Этот метод имеет информацию о глубине только для одной строки сканирования. Чтобы потребовать одну строку сканирования значений глубины, мы должны сгруппировать и обработать все полигоны, пересекающие данную строку сканирования одновременно, перед обработкой следующей строки сканирования. Две важные таблицы,edge table и polygon table, поддерживаются для этого.
The Edge Table - Он содержит координаты конечных точек каждой линии в сцене, обратный наклон каждой линии и указатели в таблице многоугольников для соединения ребер с поверхностями.
The Polygon Table - Он содержит коэффициенты плоскости, свойства материала поверхности, другие данные поверхности и может быть указателем на таблицу краев.
Для облегчения поиска поверхностей, пересекающих заданную строку сканирования, формируется активный список ребер. В активном списке хранятся только те ребра, которые пересекают линию сканирования в порядке увеличения x. Также для каждой поверхности устанавливается флаг, указывающий, находится ли позиция вдоль линии сканирования внутри или снаружи поверхности.
Позиции пикселей по каждой строке сканирования обрабатываются слева направо. На левом пересечении с поверхностью флаг поверхности включен, а на правом - выключен. Вам нужно выполнять вычисления глубины только в том случае, если флажки нескольких поверхностей включены в определенной позиции строки сканирования.
Метод территориального деления
Преимущество метода разделения по областям достигается за счет обнаружения тех областей обзора, которые представляют собой часть одной поверхности. Разделите общую область просмотра на все меньшие и меньшие прямоугольники, пока каждая небольшая область не будет проекцией части единственной видимой поверхности или не будет никакой поверхности вообще.
Продолжайте этот процесс до тех пор, пока подразделения не будут легко проанализированы как принадлежащие одной поверхности или пока они не уменьшатся до размера одного пикселя. Самый простой способ сделать это - на каждом этапе последовательно разделить область на четыре равные части. Есть четыре возможных отношения, которые поверхность может иметь с определенной границей области.
Surrounding surface - Тот, который полностью закрывает территорию.
Overlapping surface - Тот, который частично находится внутри и частично за пределами области.
Inside surface - Тот, который полностью находится внутри области.
Outside surface - Тот, который полностью находится за пределами области.
Тесты для определения видимости поверхности в пределах области могут быть сформулированы в терминах этих четырех классификаций. Никаких дальнейших подразделений указанной области не требуется, если выполняется одно из следующих условий:
- Все поверхности являются внешними по отношению к площади.
- Только одна внутренняя, перекрывающая или окружающая поверхность находится в области.
- Окружающая поверхность закрывает все остальные поверхности в границах области.
Обнаружение обратного лица
Быстрый и простой метод объектно-пространственного определения обратных граней многогранника основан на тестах «внутри-снаружи». Точка (x, y, z) находится «внутри» поверхности многоугольника с параметрами плоскости A, B, C и D, если когда внутренняя точка находится на линии обзора поверхности, многоугольник должен быть задней гранью ( мы находимся внутри этого лица и не можем видеть его спереди с нашей позиции наблюдения).
Мы можем упростить этот тест, рассмотрев вектор нормали N к поверхности многоугольника, которая имеет декартовы компоненты (A, B, C).
В общем, если V - вектор в направлении взгляда от положения глаза (или «камеры»), то этот многоугольник является задней гранью, если
V.N > 0
Кроме того, если описания объектов преобразованы в координаты проекции и ваше направление обзора параллельно оси z просмотра, тогда -
V = (0, 0, V z ) и V.N = V Z C
Так что нам нужно только рассматривать знак C как компонент вектора нормали N.
В системе обзора для правшей с направлением обзора вдоль отрицательного $Z_{V}$По оси многоугольник является задней гранью, если C <0. Кроме того, мы не можем видеть грань, у нормали которой z компонент C = 0, поскольку ваше направление взгляда направлено на этот многоугольник. Таким образом, в общем, мы можем пометить любой многоугольник как заднюю грань, если его вектор нормали имеет значение компонента z -
C <= 0
Подобные методы могут использоваться в пакетах, в которых используется система просмотра для левшей. В этих пакетах параметры плоскости A, B, C и D могут быть вычислены из координат вершин многоугольника, заданных по часовой стрелке (в отличие от направления против часовой стрелки, используемого в правой системе).
Кроме того, обратные грани имеют векторы нормали, которые указывают в сторону от позиции просмотра и идентифицируются как C> = 0, когда направление взгляда - положительное. $Z_{v}$ось. Изучая параметр C для различных плоскостей, определяющих объект, мы можем сразу идентифицировать все задние грани.
Метод А-буфера
Метод A-буфера - это расширение метода буфера глубины. Метод A-буфера - это метод определения видимости, разработанный в Lucas Film Studios для системы рендеринга «Рендеринг всего, что вы когда-либо видели» (REYES).
A-буфер расширяет метод буфера глубины, чтобы обеспечить прозрачность. Ключевой структурой данных в A-буфере является буфер накопления.
Каждая позиция в A-буфере имеет два поля -
Depth field - Хранит положительное или отрицательное действительное число
Intensity field - Он хранит информацию об интенсивности поверхности или значение указателя
Если глубина> = 0, число, сохраненное в этой позиции, представляет собой глубину одной поверхности, перекрывающей соответствующую область пикселей. В поле интенсивности затем сохраняются компоненты RGB цвета поверхности в этой точке и процент покрытия пикселей.
Если глубина <0, это указывает на вклад нескольких поверхностей в интенсивность пикселя. В поле интенсивности затем сохраняется указатель на связанный список данных поверхности. Поверхностный буфер в A-буфере включает:
- Компоненты интенсивности RGB
- Параметр непрозрачности
- Depth
- Процент покрытия площади
- Идентификатор поверхности
Алгоритм работает так же, как алгоритм буфера глубины. Значения глубины и непрозрачности используются для определения окончательного цвета пикселя.
Метод сортировки по глубине
Метод сортировки по глубине использует как пространство изображения, так и операции с пространством объектов. Метод сортировки по глубине выполняет две основные функции:
Сначала поверхности сортируются в порядке уменьшения глубины.
Во-вторых, поверхности преобразуются по порядку, начиная с поверхности наибольшей глубины.
Преобразование сканирования полигональных поверхностей выполняется в пространстве изображения. Этот метод решения проблемы скрытой поверхности часто называютpainter's algorithm. На следующем рисунке показан эффект сортировки по глубине -
Алгоритм начинается с сортировки по глубине. Например, начальная оценка «глубины» многоугольника может быть принята как ближайшее значение z любой вершины многоугольника.
Возьмем многоугольник P в конце списка. Рассмотрим все многоугольники Q, z-экстенты которых перекрывают P. Перед тем, как нарисовать P, мы делаем следующие тесты. Если какой-либо из следующих тестов положителен, мы можем предположить, что P можно нарисовать до Q.
- Не перекрываются ли x-экстенты?
- Не перекрываются ли y-экстенты?
- Находится ли P на противоположной стороне плоскости Q с точки зрения?
- Находится ли Q полностью на той же стороне плоскости P, что и точка обзора?
- Не перекрываются ли проекции полигонов?
Если все тесты терпят неудачу, мы разделяем либо P, либо Q, используя плоскость другого. Новые полигоны разреза вставляются в порядке глубины, и процесс продолжается. Теоретически такое разбиение может генерировать O (n 2 ) отдельных полигонов, но на практике количество полигонов намного меньше.
Деревья двоичного разбиения пространства (BSP)
Разделение двоичного пространства используется для расчета видимости. Чтобы построить BSP-деревья, нужно начать с полигонов и пометить все края. Работая только с одним ребром за раз, расширяйте каждое ребро так, чтобы оно разделило плоскость надвое. Поместите первое ребро дерева как корень. Добавьте последующие края в зависимости от того, находятся ли они внутри или снаружи. Ребра, которые охватывают продолжение ребра, которое уже находится в дереве, разделяются на две части, и обе добавляются к дереву.
Из рисунка выше сначала возьмите A как корень.
Составьте список всех узлов на рисунке (а).
Ставим все узлы перед корнем A слева от узла A и поместите все те узлы, которые находятся за корнем A с правой стороны, как показано на рисунке (b).
Сначала обработайте все передние узлы, а затем узлы сзади.
Как показано на рисунке (c), мы сначала обработаем узел B. Так как перед узлом ничего нетB, мы поставили NIL. Однако у нас есть узелC в задней части узла B, поэтому узел C перейдет в правую часть узла B.
Повторите тот же процесс для узла D.
Французско-американский математик доктор Бенуа Мандельброт открыл фракталы. Слово фрактал произошло от латинского слова фрактус, что означает сломанный.
Что такое фракталы?
Фракталы - это очень сложные изображения, генерируемые компьютером по одной формуле. Они созданы с использованием итераций. Это означает, что одна формула повторяется снова и снова с немного разными значениями с учетом результатов предыдущей итерации.
Фракталы используются во многих областях, таких как -
Astronomy - Для анализа галактик, колец Сатурна и др.
Biology/Chemistry - Для изображения культур бактерий, химических реакций, анатомии человека, молекул, растений,
Others - Для изображения облаков, береговой линии и границ, сжатия данных, распространения, экономики, фрактального искусства, фрактальной музыки, пейзажей, специальных эффектов и т. Д.
Генерация фракталов
Фракталы можно создавать, повторяя одну и ту же форму снова и снова, как показано на следующем рисунке. На рисунке (а) изображен равносторонний треугольник. На рисунке (b) мы можем видеть, что треугольник повторяется, чтобы создать звездообразную форму. На рисунке (c) мы можем видеть, что форма звезды на рисунке (b) повторяется снова и снова, чтобы создать новую форму.
Мы можем сделать неограниченное количество итераций, чтобы создать желаемую форму. С точки зрения программирования, для создания таких фигур используется рекурсия.
Геометрические фракталы
Геометрические фракталы имеют дело с формами, встречающимися в природе, которые не имеют целочисленных или фрактальных размеров. Чтобы геометрически построить детерминированный (неслучайный) самоподобный фрактал, мы начинаем с заданной геометрической формы, называемойinitiator. Затем части инициатора заменяются шаблоном, называемымgenerator.
Например, если мы используем инициатор и генератор, показанные на рисунке выше, мы можем построить хороший шаблон, повторив его. Каждый отрезок прямой в инициаторе заменяется на каждом шаге четырьмя отрезками равной длины. Коэффициент масштабирования равен 1/3, поэтому фрактальная размерность D = ln 4 / ln 3 ≈ 1,2619.
Кроме того, длина каждого сегмента линии в инициаторе увеличивается в 4/3 раза на каждом шаге, так что длина фрактальной кривой стремится к бесконечности по мере того, как к кривой добавляется больше деталей, как показано на следующем рисунке -
Анимация означает оживление любого объекта компьютерной графики. Он обладает способностью вводить энергию и эмоции в самые, казалось бы, неодушевленные предметы. Компьютерная анимация и компьютерная анимация - это две категории компьютерной анимации. Он может быть представлен в виде фильма или видео.
Основная идея анимации состоит в том, чтобы воспроизводить записанные изображения с достаточно высокой скоростью, чтобы обмануть человеческий глаз и заставить их интерпретировать их как непрерывное движение. Анимация может оживить серию мертвых изображений. Анимация может использоваться во многих областях, таких как развлечения, компьютерное проектирование, научная визуализация, обучение, образование, электронная коммерция и компьютерное искусство.
Техники анимации
Аниматоры изобрели и использовали множество различных техник анимации. В основном есть шесть техник анимации, которые мы обсудим по очереди в этом разделе.
Традиционная анимация (кадр за кадром)
Традиционно большая часть анимации делалась вручную. Все кадры в анимации нужно было рисовать вручную. Поскольку для каждой секунды анимации требуется 24 кадра (фильма), количество усилий, необходимых для создания даже самого короткого фильма, может быть огромным.
Ключевые кадры
В этой технике создается раскадровка, а затем художники рисуют основные кадры анимации. Основные фреймы - это те, в которых происходят заметные изменения. Это ключевые моменты анимации. Создание ключевых кадров требует, чтобы аниматор указывал критические или ключевые положения для объектов. Затем компьютер автоматически заполняет недостающие кадры, плавно интерполируя эти позиции.
Процедурный
В процедурной анимации объекты анимируются процедурой - набором правил - а не ключевыми кадрами. Аниматор задает правила и начальные условия и запускает моделирование. Правила часто основаны на физических правилах реального мира, выраженных математическими уравнениями.
Поведенческий
В поведенческой анимации автономный персонаж определяет свои собственные действия, по крайней мере, до определенной степени. Это дает персонажу возможность импровизировать и освобождает аниматора от необходимости указывать каждую деталь движения каждого персонажа.
На основе производительности (захват движения)
Другой метод - это захват движения, при котором магнитные или визуальные датчики регистрируют действия человека или животного в трех измерениях. Затем компьютер использует эти данные для анимации объекта.
Эта технология позволила ряду известных спортсменов создать действия для персонажей спортивных видеоигр. Захват движения довольно популярен среди аниматоров, главным образом потому, что некоторые из обычных человеческих действий можно легко запечатлеть. Однако могут быть серьезные расхождения между формой или размерами предмета и графическим характером, и это может привести к проблемам с точным исполнением.
Физически обоснованный (динамика)
В отличие от ключевого кадрирования и движущегося изображения, имитация использует законы физики для создания движущихся изображений и других объектов. Моделирование можно легко использовать для создания немного отличающихся последовательностей при сохранении физического реализма. Во-вторых, моделирование в реальном времени обеспечивает более высокую степень интерактивности, когда реальный человек может маневрировать действиями моделируемого персонажа.
Напротив, приложения, основанные на ключевых кадрах и движении, выбирают и изменяют движения, образуют предварительно вычисленную библиотеку движений. Одним из недостатков, которым страдает моделирование, является опыт и время, необходимые для ручной сборки соответствующих систем управления.
Ключевые кадры
Ключевой кадр - это кадр, в котором мы определяем изменения в анимации. Каждый кадр является ключевым при создании покадровой анимации. Когда кто-то создает 3D-анимацию на компьютере, они обычно не указывают точное положение какого-либо объекта в каждом кадре. Они создают ключевые кадры.
Ключевые кадры - это важные кадры, во время которых объект меняет свой размер, направление, форму или другие свойства. Затем компьютер определяет все промежутки между кадрами и экономит аниматору очень много времени. На следующих иллюстрациях изображены кадры, нарисованные пользователем, и кадры, созданные компьютером.
Морфинг
Преобразование формы объекта из одной формы в другую называется морфингом. Это одно из самых сложных преобразований.
Морф выглядит так, как будто два изображения плавно сливаются друг с другом. С технической точки зрения, два изображения искажены, и между ними происходит затухание.