У нас: 141825 рефератів
Щойно додані Реферати Тор 100
Скористайтеся пошуком, наприклад Реферат        Грубий пошук Точний пошук
Вхід в абонемент


Національний Університет "Києво-Могилянська Академія"

Створення гри типу DOOM, Wolf 3D

План

Створення простого тривимірного зображення кадру гри. Основи. Метод визначення швидкості роботи гри. Додаткові можливості.

Система розробки: Pentium 150Mhz, 32M RAM, 1G HDD, S3 SVGA, Borland C++ 3.1

Мета: Створити гру, що зовнішньо схожа на Wolfenstein 3D

Методы: Гра створена за методом, що зветься Ray Casting (проведення променя) — процес зображення тривимірного світу за двовимірною інформацією. Ось основні принципи цього методу:

1. На основі двовимірної карти, що схожа на папір в клітинку, будується лабіринт, що складається з замальованих та чистих клітинок.

2. Мапа створена з квадратів фіксованого розміру (в нашому випадку — 64 ), що дозволяє кожному об’єкту (гравцю) пересуватися на 64 одиниці в будь-якому напрямі до переходу на інший квадрат. Весь лабіринт складається з таких квадратів, що утворюють двовимірний масив.

3. Гравець визначається як місце на цій мапі, що має три характеристики:

координату X

координату Y

кут зору

Так як ми знаємо, де знаходиться гравець та те, в який бік він дивиться, ми можемо взнати, що він бачить в цей момент. Для початку нам треба вирішити яке поле зору має гравець. Нехай це буде 60, для того щоб зображення було найбільш реалістичним. Це значить, що гравець буде бачити всі предмети та стіни на 30 ліворуч та на 30 праворуч.

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

5. Тепер ми отримали поле зору, що включає в себе стіни попереду гравця при данному куті зору.

6. Ось що має бачити гравець в цьому випадку.

7. Так як же все ж таки отримати таке тривимірне зображення з двовимірної мапи? Просто вираховуючи висоту стін як функцію від відстані. Маючи поточні координати гравця, координати стіни та, використовуючи тригонометрію, ми можемо визначити відстань між гравцем та стіною. Проблема в тому, щоб виконати всі ці розрахунки настільки швидко, щоб гра виглядала реалістично. Але цим ми займемося пізніше. Зараз нехай спрацює простий метод визначення відстані до стіни. При цьому потрібно пам’ятати, що ми проводимо промінь для кожного стовпчика пікселей екрану, що для режиму VGA 13h (320x200x256) дає нам 320 стовпчиків по 200 пікселів. Тобто, 320 променів буде проведено щоб намалювати 1 кадр.

8. Почнемо з заповнення початкових значень для гравця. Як ми вже сказали, кожний квадрат має розміри 64x64 одиниці. Нехай гравець стоїть в клітинці (1, 1) десь на ѕ клітинки згори та на ј клітинки зліва. Значить координати гравця десь приблизно (80, 112) (64 + 64 * ј, 64 + 64 * ѕ). Початковий кут зору буде 0. Так як ми будемо використовувати тригонометричні функції з бібліотеки <math.h> мови C, ми будемо використовувати координатну систему, де кут збільшується за годинниковою стрілкою.

9. Тому, як було сказано в пункті 4, ми починаємо проводити промені від 30 зліва від нашого кута зору (=0) (або з 330) до 30 справа від нашого кута зору (або до 30). Можна побачити правильний трикутник від того місця де стоїть гравець до точки з кутом 330.

; ; ;

10. Зараз ми можемо намалювати (вигадану) лінію від гравця до якої-небудь точки на куті 330. Але наскільки ж довгою має бути ця лінія? Настільки, щоб можна було визначити що ми натрапили на стіну або вийшли за межі нашого лабіринту. Нехай наш лабіринт має розміри 10x8 (x*y). Тоді у нас 80 квадратів. Тоді максимальна ширина (довжина) нашого лабіринту —64 * 10 = 640 на 64 * 8 = 512. Максимальна відстань, на яку нам потрібно пускати промінь — , , що дорівнює 819.5999 або 820 одиниць. Що ж, 820 це максимальна відстань, на яку ми можемо пустити промінь, переглядаючи по дорозі чи не натрапили ми на стіну або чи не вийшли ми за межі лабіринту. Ми звели проведення променя до малювання лінії. А для малювання лінії у нас є алгоритм Брезенхама. Нам треба тільки визначити координати кінцевих точок лінії. Якщо ми маємо початкові координати гравця (X, Y), тоді використаємо вирази для точок кола щоб взнати кінцеві координати.

Використавши числа з пунктів 8 та 10 отримуємо:

що дає: . Передавши параметри (80, 112, 790, -298) в процедуру проведення лінії, що перевіряє зіткнення з стінами. Для кожної точки вздовж лінії ми визнячаємо координати на нашій карті так:

Поглянувши знову на малюнок 1 ми бачимо що наше перше зіткнення з стіною відбувається у клітинці (2, 0). Тепер визначимо відстань до цієї стіни. Назвемо точку перетину з стіною W, щоб не сплутати її з точкою кінця відрізка. Відстань визначається так: , . З малюнку видно, що стіна знаходиться десь в (128, 128) в квадраті (2, 0) тому: , з чого виплаває, що відстань = 50.596 або приблизно 51 одиниці. Знаючи відстань ми, заглянувши в таблицю висот, можемо взнати висоту стіни і намалювати одну горизонтальну лінію на екрані визначеної висоти. Продовжуємо цей процес для всіх колонок на екрані (320), де кожна колонка відповідає віддалі до стіни, і заповнюємо весь екран. Як ви мабуть і здогадуєтесь, ми не будемо зменшувати наш кут по цілому градусу, а по що дорівнює 0,1875. 320 стовпчиків по 0,1875 дає нашого поля зору.

Таблиця висот будується так: для кожної з можливих


Сторінки: 1 2