
- •1. Цели и задачи компьютерной графики
- •2. Растровая и векторная визуализация изображений. Основные характеристики растровых изображений
- •3. Аддитивная цветовая модель rgb. Кодирование цвета. Палитра
- •4. Графические форматы. Работа с растровыми изображениями (форматы ddb, dib, bmp-файлы)
- •5. Понятие об инкрементных алгоритмах растеризации. Растровое представление отрезка. Вывод и реализация алгоритма
- •6. Понятие об инкрементных алгоритмах растеризации. Построение окружности методом средней точки. Вывод и реализация алгоритма
- •7. Стиль линии (перо). Алгоритм вывода линии
- •8. Стиль заполнения, кисть, текстура
- •9. Геометрические основы компьютерной графики. Системы координат (декартова, полярная, сферическая) и векторы. Скалярное и векторное произведение векторов
- •11. Построение кривых. Интерполяционный полином Лагранжа. Достоинства и недостатки. Реализация
- •12. Построение кривых. Интерполяционный кубический сплайн. Реализация
- •13. Построение кривых. Геометрические сплайны. Кривая Безье. Геометрический алгоритм построения кривой Безье. Реализация
- •14. Мировые и экранные координаты. Алгоритм пересчёта мировых 2d-координат в оконные. Вывод и реализация
- •15. Физическая и логическая системы координат. Режимы отображения (без настройки параметров). Алгоритм преобразования координат в gdi и его связь с алгоритмом пересчёта мировых координат в оконные
- •16. Режимы отображения и настройка их параметров (функции класса cdc mfc). Функция SetMyMode, назначение, параметры и реализация
- •17. Аффинные преобразования на плоскости. Преобразование системы координат: смещение, растяжение-сжатие, поворот
- •18. Аффинные преобразования на плоскости. Преобразование объектов: смещение, растяжение-сжатие, поворот
- •19. Аффинные преобразования в пространстве. Преобразование системы координат: смещение, растяжение-сжатие, повороты вокруг осей координат
- •20. Аффинные преобразования в пространстве. Преобразования объектов: смещение, растяжение-сжатие, повороты вокруг осей координат
- •21. Основные типы проекций. Видовая система координат (вывод матрицы преобразования)
- •22. Перспективные преобразования (вывод матрицы преобразования). Схема пересчёта координат при переходе от мировых 3d-координат к экранным
- •23. Модели описания поверхностей
- •24. Каркасная визуализация трёхмерных изображений. Принцип удаления невидимых граней для выпуклого многогранника. Реализация
- •30. Графическая библиотека OpenGl. Структура glut-приложения. Пример
- •31. Графическая библиотека OpenGl. Рисование графических примитивов. Дисплейные списки. Удаление нелицевых граней. Вывод текста. Примеры
- •Вершины и примитивы
- •Положение вершины в пространстве
- •Цвет вершины
- •Нормаль
- •Операторные скобки glBegin / glEnd
- •Дисплейные списки
- •Массивы вершин
- •32. Графическая библиотека OpenGl. Системы координат. Модельно-видовые преобразования. Примеры
- •Матрицы
- •Модельно-видовые преобразования
- •33. Графическая библиотека OpenGl. Проекции. Область вывода. Создание анимации. Примеры
- •Область вывода
- •Создание анимации в OpenGl
- •34. Графическая библиотека OpenGl. Материалы и освещение. Примеры
- •Модель освещения
- •Описание источников света
- •35. Графическая библиотека OpenGl. Структура приложения с использованием библиотеки mfc
Модельно-видовые преобразования
К модельно-видовым преобразованиям будем относить перенос, поворот и изменение масштаба вдоль координатных осей. Для проведения этих операций достаточно умножить на соответствующую матрицу каждую вершину объекта и получить измененные координаты этой вершины:
где M – матрица модельно-видового преобразования. Перспективное преобразование и проектирование производится аналогично. Сама матрица может быть создана с помощью следующих команд:
void glTranslate[f d] (GLtype x, GLtype y, GLtype z),
void glRotate[f d] (GLtype angle, GLtype x, GLtype y, GLtype z) ,
void glScale[f d] (GLtype x, GLtype y, GLtype z).
Где
glTranlsate*() – производит перенос объекта, прибавляя к координатам его вершин значения своих параметров.
glRotate*() – производит поворот объекта против часовой стрелки на угол angle (измеряется в градусах) вокруг вектора (x, y, z).
glScale*() – производит масштабирование объекта (сжатие или растяжение) вдоль вектора (x, y ,z), умножая соответствующие координаты его вершин на значения своих параметров.
Все эти преобразования изменяют текущую матрицу, а поэтому применяются к примитивам, которые определяются позже. В случае, если надо, например, повернуть один объект сцены, а другой оставить неподвижным, удобно сначала сохранить текущую видовую матрицу в стеке командой glPushMatrix(), затем вызвать glRotate() с нужными параметрами, описать примитивы, из которых состоит этот объект, а затем восстановить текущую матрицу командой glPopMatrix().
Кроме изменения положения самого объекта, часто бывает необходимо изменить положение наблюдателя, что также приводит к изменению модельно-видовой матрицы. Это можно сделать с помощью команды
void gluLookAt (GLdouble ex, GLdouble ey, GLdouble ez,
GLdouble center_x, GLdouble center_y, GLdouble center_z,
GLdouble up_x, GLdouble up_y, GLdouble up_z)
где точка (ex, ey, ez) определяет точку наблюдения в МСК,
точка (center_x, center_y, center_z) задает центр сцены, который будет проектироваться в центр области вывода, а вектор (up_x, up_y, up_z) задает направление вектора, вдоль которого в видовом порте (см. ниже) ориентируется ось Y, определяя поворот камеры. Причем вектор (up_x, up_y, up_z) не должен быть параллелен линии, проведенной от точки наблюдения (ex, ey, ez) до наблюдаемой точки (center_x, center_y, center_z) .
Если, например, камеру не надо поворачивать, то задается значение (0,1,0), а со значением (0,-1,0) сцена будет перевернута.
Строго говоря, эта команда совершает перенос и поворот объектов сцены, но в таком виде задавать параметры бывает удобнее. Следует отметить, что вызывать команду gluLookAt() имеет смысл перед определением преобразований объектов, когда модельно-видовая матрица равна единичной.
Замечание . В общем случае матричные преобразования в OpenGL нужно записывать в обратном порядке. Например, необходимо сначала повернуть объект, а затем передвинуть его, то сначала надо вызвать команду glTranslate(), а только потом – glRotate(). После этого можно определить сам объект.