Научная статья на тему 'Программная реализация трехмерных сцен'

Программная реализация трехмерных сцен Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
1171
208
i Надоели баннеры? Вы всегда можете отключить рекламу.
i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Текст научной работы на тему «Программная реализация трехмерных сцен»

Известия ТРТУ

Тематический выпуск

УДК 681.3.01

Д.Ю. Вишнякова, Н.А. Надолинский ПРОГРАММНАЯ РЕАЛИЗАЦИЯ ТРЕХМЕРНЫХ СЦЕН

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

В понятие трехмерной сцены входят:

♦ Изображение местности (ландшафт, небо).

♦ Статические (неподвижные) объекты.

♦ Динамические (подвижные) объекты.

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

К изображению местности можно отнести, во-первых, ландшафт. Ландшафт генерируется при помощи фракталов. Как известно, фрактальное изображение создается применением некоторой геометрической операции к геометрической фигуре и последующим многократным применением той же операции к полученному результату. Чтобы сгенерировать фрактальный ландшафт, достаточно присвоить случайные высоты трем вершинам равностороннего треугольника, а затем изогнуть каждое ребро, поднимая или опуская его середину на случайную высоту. Соединив линиями середины трех сторон, мы получим четыре треугольника. Если теперь применить операции изгиба и деления к каждому из получившихся тре, ,

.

сводится к примитивному алгоритму “изогнуть, разделить, рекурсивно повторить”, ибо существует достаточно проблем, связанных с хранением, делением, а также

.

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

производительность всей системы (под производительностью понимается количество кадров в секунду при выводе изображения), т.к. зачастую мы обозреваем не всю сцену сразу, а лишь отдельную ее часть, включающую в себя несколько сотен или тысяч полигонов. В данном случае наиболее целесообразно использовать метод двоичного разбиения пространства (Binary Space Partitioning Tree), т.е. построить BSP-дерево для всего статического мира. Вся суть метода состоит в разбиении

( ). -, ( ). -курсивно повторяя описанный процесс для каждого из полученных кластеров, по-

Материалы Международной конференции “Интеллектуальные САПР”

, ,

, .

Одним из основных преимуществ предложенного метода является полная независимость дерева от параметров проектирования (положения центра проектирования, направление проектирования и др.), что делает его весьма удобным для построения серий изображений одной и той же сцены из разных точек наблюдения. Это обстоятельство привело к тому, что BSP-деревья стали широко использоваться в ряде систем виртуальной реальности, в частности, широко известны в играх типа Doom, Quake, Quake II, Quake III.

Для динамических объектов также можно построить свое BSP-дерево, которое при проецировании будет вклеиваться в общее BSP-дерево.

, , следовало бы отметить способ изображения всей картины на экране.

При написании программ для операционной системы Windows нецелесообразно было бы использовать стандартный интерфейс GDI (Graphic Device Interface) для вывода на поверхность окна, т.к. GDI является простым и достаточно медленным интерфейсом, что не приемлимо при работе с 3D^^^^HKott. Наиболее эффективно было бы использовать уже ставшие стандартом в области графики библиотеки OpenGL (SGI) и Direct3D (Microsoft). Также сюда можно было бы отнести и библиотеку Glide (3dfx), но она поддерживает только чипсеты одной фирмы - 3dfx, что делает ее непопулярной. Direct3D при программировании является исключи, OpenGL, ( -

) -

( ). OpenGL - -

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

Предлагаемая программа создания сцен написана на языке Delphi 5.0, с ис-OpenGL .

программы осуществляется генерация ландшафта, как следствие построение BSP,

использованием текстурирования, освещенности, тумана и прозрачности.

Программа разработана в рамках работ по мультимедийным системам, проводимых международной лабораторией ELDIC.

УДК 007.681.518.2

..

НОВЫЙ ПОДХОД К ЭКСПЕРТНОЙ СИСТЕМЕ В ТЕХНОЛОГИИ

ОБУЧЕНИЯ

В настоящее время большое внимание уделяется разработке обучающих программ для нужд образования. Создано множество систем, сделано много попыток создать «электронного учителя». Можно уже смело говорить, что опыт в этом направлении достаточно накоплен и не стоит тратить много времени на перечисление всех достоинств этих программ, остановимся на некоторых немаловажных .

i Надоели баннеры? Вы всегда можете отключить рекламу.