КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Общий вид аффинного преобразования
Отражение Как говорилось в примечании к преобразованию сжатия/растяжения, отражения получаются следующим образом: [ -1 0 0 ] [ 0 1 0 ] [ 0 0 1 ] [ 1 0 0 ] [ 0 -1 0 ] [ 0 0 1 ] Матрица 3x3, последний столбец которой равен (0 0 1)T, задает аффинное преобразование плоскости: [ * * 0 ] [ * * 0 ] [ * * 1 ] По одному из свойств, аффинное преобразование можно записать в виде: f(x) = x * R + t, где R – обратимая матрица 2x2, а t – произвольный вектор. В однородных координатах это запишется следующим образом: [ R1,1 R1,2 0 ] [ R2,1 R2,2 0 ] [ tx ty 1 ] Если умножить вектор-строку на эту матрицу получаем результат преобразования: [ x y 1 ] * [ R1,1 R1,2 0 ] [ R2,1 R2,2 0 ] [ tx ty 1 ] = [ x’ y’ 1 ] + [ tx ty 1 ] При этом [ x’ y’ ] = R * [ x y ] Прим. Любопытный читатель уже задал себе вопрос: в чем смысл определителя матрицы R? При аффинном преобразовании площади всех фигур изменяются в |R|. (Можно строго доказать это с точки зрения математики, но здесь этот факт приводится без доказательства.) Т.о. аффинное преобразование представляется в виде композиции некоторого преобразования, задаваемого матрицей R, и параллельного переноса. Разберем более подробно природу этой матрицы и возможности, которые она нам дает. Матрица R определяет новый базис плоскости. Т.е. вектор (1, 0) переходит в (R1,1, R1,2), вектор (0, 1) переходит в (R2,1, R2,2). Новый базис это строки матрицы R. Пример. При отражении относительно оси y, базисный вектор по оси ординат сохраняется, а по оси абсцисс переходит в (-1, 0). Т.о. матрица R будет выглядеть следующим образом: [ -1 0 ] [ 0 1 ] Выше приведены базовые сведения о таком мощном инструменте, как аффинное преобразование. Остается много вопросов: какой подкласс аффинных преобразований сохраняет углы между прямыми? Как можно представить аффинное преобразование в виде композиции нескольких подклассов? Как задавать более сложные преобразования, например, осевая симметрия относительно произвольной прямой? Ответы на эти вопросы и более детальное рассмотрение аффинного преобразования будут приведены отдельно, в качестве раздела курса теоретической геометрии. Остановимся на практической реализации аффинного преобразования в виде демонстрационной программы. К возможностям приложения, демонстрирующего поворот плоскости мышью, добавляются функции параллельного переноса при нажатой клавише CTRL. Т.к. эта статья является завершающей в данном разделе, код демонстрационного приложения должен быть соответствующим. Давайте попробуем разобраться, какие блоки нужны в графическом приложении, параллельно рассматривая, как они реализованы в данной программе: · блок, в котором происходит создание окна и обрабатываются сообщения операционной системы, реализован в файлe main.cpp · графический движок, выполняющий отрисовку изображения, класс Engine · прослойка, необходимая для преобразования логических координат в оконные и обратно, класс Viewport · объект, отвечающий за реакцию на действия пользователя, класс Action В приведенном примере реализованы эти функциональные блоки, с подробными комментариями.
Дата добавления: 2014-01-15; Просмотров: 571; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |