Опубликован: 08.07.2007 | Доступ: свободный | Студентов: 1431 / 183 | Оценка: 4.43 / 4.02 | Длительность: 13:47:00
Специальности: Программист
Лекция 1:

Основы машинной графики

Математические основы компьютерной графики

Для того чтобы отображать графические объекты на дисплее нужно иметь некий инструмент, позволяющий легко и просто описывать эти объекты на языке математики. Положение точек на плоскости очень удобно описывать с помощью декартовой системы координат. Чтобы создать декартову систему координат нужно провести две прямые неколлинеарные линии, которые называют осями. Пусть они пересекаются в точке O, которую называют началом координат. Выберем на построенных осях единицу измерения. Тогда положение любой точки плоскости можно описать через координаты этой точки, которые представляют собой расстояния от начала координат до проекций точки на соответствующие оси координат. Проекцией точки на координатную ось называется точка пересечения прямой, проходящей через заданную точку и параллельной другой оси координат. Вообще введенные оси координат могут располагаться под произвольным углом (рис. 1.1).


Рис. 1.1.

Однако, на практике удобно пользоваться системой координат со взаимно перпендикулярными осями. Такая система координат называется ортогональной. Оси координат имеют названия; горизонтальная ось называется осью абсцисс ( Ox ), вертикальная – осью ординат ( Oy ). Таким образом, точка на плоскости представляется двумя своими координатами, что записывается в виде двумерного вектора P=(x,y).

Математический аппарат описания точек на плоскости с помощью декартовой системы координат идеально подходит для выполнения различных аффинных преобразований над точками (сдвиг, масштабирование, вращение).

Точку P(x,y), заданную на плоскости можно перенести (сдвинуть) в новую позицию путем добавления к координатам этой точки констант переноса. Для произвольной точки P=(x,y), которая перемещается в новую точку P'=(x',y'), сдвигаясь на Tx единиц параллельно оси абсцисс и на Ty единиц параллельно оси ординат, можно записать следующие выражения: x'=x+Tx, y'=y+Ty. Так, например, точка с координатами P(1,2) смещаясь на расстояние (5,7) преобразуется в точку P'(6,9). Определяя точку и перенос как вектор-строки P=(x,y), P'=(x',y') и T=(Tx,Ty) можно записать преобразование переноса (сдвига) в векторной форме: (x',y')=(x,y)+(Tx,Ty) или P'=P+T. Преобразованию можно подвергнуть не только одни точки. Геометрический объект можно переместить, применив к каждой его точке преобразование переноса. Так, если в описании объекта имеются отрезки прямой, то достаточно применить преобразование к концам отрезка и затем провести прямую линию между двумя преобразованными точками. Это правило справедливо и для операций масштабирования и поворота. На рис. 1.2 представлен результат действия на треугольник операции переноса на расстояние (2,-1).


Рис. 1.2.

Точки можно подвергнуть операции масштабирования (растяжения или сжатия) в Sx раз вдоль оси абсцисс и в Sy раз вдоль оси ординат. Полученные в результате новые точки будут выражаться как: x'=x*Sx ; y'=y*Sy. Определив S как

\left( \begin{array}{ccc} S_{x} & 0 \\ 0 & S_{y} \\ \end{array} \right),
данные выражения можно записать в матричной форме:
(x',y')=(x,y) \left( \begin{array}{ccc} S_{x} & 0 \\ 0 & S_{y} \\ \end{array} \right)
или P'=P*S. На рис. 1.3 показан треугольник, промасштабированный с коэффициентами 0,5 по оси абсцисс и коэффициентом 2 вдоль оси ординат.


Рис. 1.3.

Следует отметить, что операция масштабирования производится относительно начала координат. В результате преобразования объект может стать меньше/больше в размерах и ближе/дальше от начала координат. Пропорции объекта также могут измениться при масштабировании с различными коэффициентами: Sx\ne Sy. Для сохранения пропорций необходимо, чтобы масштабные коэффициенты были равны: Sx=Sy.

Точка плоскости P=(x,y) может быть повернута на произвольный угол \phi относительно начала координат и перейдет в новую точку P'=(x',y') (рис. 1.4)


Рис. 1.4.

Выведем формулы для пересчета точки (x,y) в точку (x',y'). Обозначим расстояние от начала координат до точки P(x,y) через \rho. Очевидно, что расстояние от начала координат до точки P'(x',y') также будет \rho. Пусть Q и Q' - проекции точек P и P' соответственно на ось абсцисс. Тогда из прямоугольного треугольника OP'Q' и тригонометрических определений синуса и косинуса имеем:

\left\{\begin{array}{ccc} cos(\phi+\theta)= \frac{x'}{\rho}//\mbox{отношение прилежащего катета }OQ' \mbox{ к гипотенузе }OP' \\ 
sin(\phi+\theta)= \frac{y'}{\rho}//\mbox{отношение противолежащего катета }Q'P' \mbox{ к гипотенузе }OP'
\end{array}\right

Домножим правую и левую части уравнений на \rho.

\left\{\begin{array}{ccc} 
x'=\rho cos(\phi+\theta)=\rho cos\phi cos\theta-\rho sin\phi sin\theta \\ 
y'=\rho sin(\phi+\theta)=\rho sin\phi cos\theta-\rho cos\phi sin\theta
\end{array}\right

Используя простейшие тригонометрические свойства прямоугольного треугольника OPQ, следует заметить, что \rho \cos \theta =x, а \rho \sin \theta =y. Таким образом, формула "перевода" точки P(x,y) в точку P'(x',y') поворотом на угол \phi относительно начала координат будет:

\left\{\begin{array}{ccc} x'=x cos\phi-y sin\phi \\ y'=x sin\phi+y cos\phi \end{array}\right

В матричном виде преобразование вращения будет выглядеть так:

(x' y') =(x y) \left( \begin{array}{ccc} cos\phi & sin\phi \\
 -sin\phi & cos\phi \\ \end{array} \right)

Так треугольник с координатами вершин (20,0),(60,0),(40,100) после поворота на угол 45 градусов по часовой стрелке относительно начала координат (\varphi =-45) градусов будет иметь новые значения координат вершин: (10\sqrt{2},-10\sqrt{2}),(30\sqrt{2},-30\sqrt{2}),(70\sqrt{2},30\sqrt{2}).

Точка плоскости P(x,y) может быть легко отражена относительно прямых y=0, x=0, y=x следующим образом. Отражение относительно прямой y=0 (ось абсцисс) может быть получено с использованием матрицы \mathbf{M} = \left( \begin{array}{ccc} 1 & 0 \\ 0 & -1 \\ \end{array} \right). Так, например, точка P=(2,3) при таком отражении преобразуется в точку P_{1}=(2,-3) (рис. 1.5).

Подобным образом матрица отражения относительно прямой x=0 (ось ординат) будет иметь вид \mathbf{M} = \left( \begin{array}{ccc} -1 & 0 \\ 0 & 1 \\ \end{array} \right). Точка P=(2,3) при отражении относительно оси ординат преобразуется в точку P_{2}=(-2,3) (рис. 1.5).

Отражение относительно прямой y=x осуществляется с помощью матрицы \mathbf{M} = \left( \begin{array}{ccc} 0 & 1 \\ 1 & 0 \\ \end{array} \right). Точка P=(2,3) в результате такого отражения преобразуется в точку P_{3}=(3,2) (рис. 1.5).


Рис. 1.5.

Рассмотренные выше аффинные преобразования переноса, масштабирования, вращения и отражения можно записать в матричной форме следующим образом: P'=P+T, P'=P*S, P'=P*R, P'=P*M, где P' - координаты преобразованной точки, P - координаты исходной точки, T - вектор сдвига ( translate ), S - матрица масштабирования ( scale ), R - матрица вращения ( rotate ), M - матрица отражения ( mirror ). К сожалению, операция переноса (сдвига) реализуется отдельно (с помощью сложения) от масштабирования, поворота и отражения (с помощью умножения). Тем не менее, существует возможность, чтобы все эти элементарные преобразования (перенос, масштабирование, вращение, отражение) можно было реализовать с помощью только операций умножения матриц. Данная возможность реализуется с помощью так называемых однородных координат точки.