Опубликован: 20.10.2007 | Уровень: специалист | Доступ: свободно
Лекция 4:

Представление геометрической информации

< Лекция 3 || Лекция 4: 123 || Лекция 5 >

Поверхности свободных форм (функциональные модели)

Характерной особенностью предлагаемого способа задания поверхностей является то, что основным примитивом здесь является поверхность второго порядка - квадрик. Он определяется с помощью вещественной непрерывной функции трех переменных (x,y,z) в виде неравенства

F(x,y,z)\ge 0.
Таким образом, квадрик есть замкнутое подмножество евклидова пространства, все точки которого удовлетворяют указанному неравенству. Уравнение
F(x,y,z)=0
описывает границу этого множества. Множество точек, удовлетворяющих неравенству
F(x,y,z)<0,
образует внешнюю область квадрика.

Свободная форма - это произвольная поверхность, обладающая свойствами гладкости, непрерывности и неразрывности. На базе квадриков строятся свободные формы, которые описывают функциональные модели. Свободная форма, построенная на этих принципах, имеет ряд достоинств, к которым, в первую очередь, надо отнести следующие:

  • Легкая процедура расчета координат каждой точки.
  • Небольшой объем информации для описания достаточно сложных форм.
  • Возможность строить поверхности на основе скалярных данных без предварительной триангуляции.

Этот подход будет более подробно изложен в следующих главах.

В нашем курсе предполагается рассмотреть растровые алгоритмы для изображения таких геометрических примитивов, как отрезки, многоугольники, окружности и эллипсы. Но сначала мы займемся тем геометрическим аппаратом, который позволит адекватно описывать объекты в пространстве, работать с ними и формировать изображение.

Системы координат: мировая, объектная, наблюдателя и экранная

Одной из распространенных задач компьютерной графики является изображение двумерных графиков в некоторой системе координат. Эти графики предназначены для отображения зависимости между переменными, заданной с помощью функции. Например, во второй главе настоящего курса приведен ряд графиков, характеризующих восприятие света глазом человека. Чтобы получить такой график, прикладная программа должна описать различные выходные примитивы (точки, линии, цепочки символов), указав их местоположение и размеры в прямоугольной системе координат. Единицы измерения, в которых задаются эти объекты, зависят от их природы: изменение температуры, например, можно отображать в градусах за час, перемещение тела в пространстве - в километрах в секунду, и т. д. Эти прикладные (или ориентированные на пользователя) координаты позволяют задавать объекты в двумерном или трехмерном мире пользователя, и их принято называть мировыми координатами.

Изображение трехмерных объектов сопряжено с целым рядом задач. Прежде всего надо помнить, что изображение является плоским, поэтому надо добиться адекватной передачи визуальных свойств предметов, дать достаточно наглядное представление о глубине. В дальнейшем группы трехмерных объектов, предназначенных для изображения, будем называть пространственной сценой, а ее двумерное изображение - образом.

Объектная система координат и система координат наблюдателя

Рис. 4.3. Объектная система координат и система координат наблюдателя

Как и в случае с двумерными объектами, первым шагом построения является ввод информации об объектах. Сцена занимает какое-то определенное место в пространстве, а ее описание привязывается к трехмерной декартовой системе координат, связанной с нею, - объектной координатной системе. Координаты объектов, составляющих сцену, определяются на основе их реальных размеров и взаимного расположения. В зависимости от точки, из которой рассматривается сцена, можно получить множество различных ее образов. Если построено достаточно много таких образов, то по ним можно восстановить объемную структуру предмета. Выбор точки и направления зрения тоже можно описать математически, введя декартову систему координат наблюдателя, начало которой находится в точке обзора, а одна из осей совпадает с направлением зрения (рис. 4.3). Переход от объектных координат к координатам наблюдателя математически реализуется так, как это было описано в третьей главе. На этом этапе преобразований сохраняются реальные размеры объектов.

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

Картинная плоскость и экран

Рис. 4.4. Картинная плоскость и экран

Поскольку нашей конечной целью является получение изображения на экране, то перенесение образа сопровождается изменением масштаба в соответствии с размерами экрана. Обычно началом координат в системе координат образа считается левый нижний угол листа с изображением. На экране дисплея начало координат традиционно находится в левом верхнем углу. Отображение рисунка с картинной плоскости на экран должно производиться с минимальным искажением пропорций, что само по себе вносит ограничение на область экрана, занимаемую рисунком. Изменение масштаба должно осуществляться с сохранением пропорций области (рис. 4.4).

Объекты в системе координат картинной плоскости задаются в каких- либо единицах измерения, причем масштаб одинаков по обеим осям координат. На экране единицей измерения является пиксель, который следует рассматривать как прямоугольный, поэтому масштабы по горизонтальной и вертикальной осям могут быть различны, что необходимо учитывать при задании коэффициентов масштабирования.

Рассмотрим ситуацию, когда изображение занимает на картинной плоскости прямоугольную область x_1\le x\lex_2, \; y_1\le y\le y_2. При отображении рисунка на экран каждая точка исходного прямоугольника с координатами (x,y) перейдет в некоторую точку с целочисленными координатами (i,j). Введем обозначения:

\begin{gathered}
\Delta x=x_2-x_1, \quad \Delta y=y_2-y_1, \quad \Delta i=i_2-i_1, \quad \Delta j=j_2-j_1, \\
S_x=\frac{\Delta i}{\Delta x}, \quad S_y=\frac{\Delta j}{\Delta y}
\end{gathered}
(предполагается, что изображение займет на экране прямоугольник i_1\le i\le i_2, \; j_1\lej\le j_2 ). Определим преобразование координат образа (x,y) в экранные координаты (i,j) формулами
i=i_1+S_x(x-x_1), \quad j=j_2-S_y(y-y_1).
Ясно, что при таком отображении прямоугольная область образа в точности перейдет в соответствующий экранный прямоугольник, как показано на рисунке. Теперь надо определить сам экранный прямоугольник так, чтобы его пропорции соответствовали прямоугольнику образа, т.е.
\frac{\Delta x}{\Delta y}=\frac{\Delta i\cdot l_x}{\Delta j\cdot l_y}\equiv\kappa\frac{\Delta i}{\Delta j},
где l_x, l_y - горизонтальный и вертикальный размер одного пикселя. Эти параметры легко установить, зная размеры экрана и разрешение. Отсюда получаем
\Delta j=\kappa\cdot S_x\cdot\Delta y, \quad S_y=\kappa\cdot S_x
Теперь достаточно задать на экране начало отсчета и горизонтальный размер окна, а остальные параметры легко вычисляются.

< Лекция 3 || Лекция 4: 123 || Лекция 5 >
Сабина Бахриддинова
Сабина Бахриддинова
Дмитрий Трефилов
Дмитрий Трефилов