Books c его натуралистичным перелистыванием страниц. Все остальные фишки как то не особо впечатляли, но это. По сравнению с обычными графическими интерфейсами, использующими стандартные элементы GUI, интерфейсы с использованием анимации Open. GL это новый шаг в развитии пользовательских интерфейсов. Историческое отступление первыми стали использовать элементы анимации в GUI рабочие станции Indy компании Silicon Graphics, которая и является основоположником языка Open. GL. На десктопах этих компьютеров были трехмерные кнопки меню, которые при нажатии переворачивались в 3. D, открывая списки подменю из таких же кнопок. Это было здорово, и это было действительно красиво. Жаль, что Silicon Graphics ушла в небытие из за неправильного менеджмента, эта компания была действительно первой во многом Open. GL, STL, журналируемые файловые системы. Поэтому не буду петь дифирамбы Apple, они лишь внедрили хорошо забытое старое. Но справедливости ради стоит отметить, что и это было прорывом, ведь они задали тенденцию и унылые статические интерфейсы, надеюсь, скоро останутся в прошлом. Итак, Open. GL анимация и GUI. По роду деятельности мне уже приходилось разрабатывать проекты с использованием Open. GL, поэтому когда я столкнулся с необходимостью создать анимацию, эмулирующую перелистывание бумажных страниц, передо мной встали две основные задачи. В качестве алгоритма деформации используется уравнение конуса. Кряк Для Компас V14 тут. Этот алгоритм был разработан в исследовательских лабораториях Xerox PARC еще в 2. Изгиб бумажного листа определяется поверхностью некоего конуса, изменяя параметры которого можно добиться требуемого эффекта анимации. Я не буду вдаваться в подробности описания самого алгоритма и тригонометрии. Скажу лишь что он пересчитывает любую 2. D точку Px,y плоскости листа в 3. D точку Tx,y,z, используя изменяемые параметры А и. Для тех, кто желает подробностей, есть исходники тестового проекта для i. OS и Open. GL ES. Интеграция Open. GL и пользовательского интерфейса. Методы анимации, используемые в пользовательских интерфейсах, обычно выполнены по следующей схеме первоначальное состояние фреймы анимации конечное состояние. То есть берутся некие начальное и конечное состояния анимированного объекта интерфейса, сам объект на время анимации обычно либо прячется, либо перекрывается объектом, который рендерит фреймы перехода, по окончании рендерер прячется и показывается объект в конечном состоянии. В применении к перелистываемым страницам первоначальное и конечное состояния соответствуют двум последовательным разворотам страниц книги. То есть алгоритм анимации должен быть следующим взять текстуры текущего разворота страниц выполнить прокрутку страниц offscreen взять текстуры следующего разворота страниц из offscreen buffer перекрыть разворот страниц Open. GL рендерером запустить анимацию по завершении спрятать Open. GL рендерер и показать следующий разворот, который находится в offscreen. В качестве рендререра Open. GL я использовал класс NSOpen. GLView, обладающий собственным Open. GL контекстом и несколькими удобными методами для управления этим контекстом. В зависимости от направления перелистывания, рендерер инициализируется четырьмя текстурами страниц, две статические текстуры и две динамические, деформируемые с помощью вышеприведенного алгоритма. Рассмотрим перелистывание страницы справа налево Текущий разворот левая страница статическая, правая страница динамическая. Следующий разворот левая страница динамическая, правая статическая. Ниже приведен код контроллера, управляющего анимацией перелистывания. Код упрощен и управляет переворотом страницы только в одну сторону. Вызывает update. Time со значением относительного времени анимации в промежутке 0. Flip. Animation NSAnimation. Так достигается эффект перетаскивания страницы, достаточно посылать рендереру сообщения update. Time из обработчика событий. Код рендерера Open. GL я приводить не буду, так как он банален. Маппинг текстур выполнен страйпами треугольников, добавлена подсветка сцены анимации. Ну и в заключение вот как это выглядит в работе извиняюсь за качество.