Структура файла levels.mrg

Материал из Gravity Defied Wiki
(перенаправлено с «Levels.mrg»)
Перейти к: навигация, поиск

Для начала для тех, кто в танке, уясню:
int = 4 байта
short = 2 байта
byte = 1 байт

Итак. Грубо говоря, файл можно разделить на 2 части: заголовок и сам файл.

1. Заголовок

Заголовок, в свою очередь, можно поделить на 3 части: заголовок легкого, заголовок среднего, заголовок сложного уровней.
Структура заголовка (схематично):

[int кoл-во уровней на easy] { 
 [int номер_байта][название уровня][byte нулевой байт] 
 ... 
} 
[int кол-во уровней на medium] { 
 [int номер_байта][название уровня][byte нулевой байт] 
 ...
} 
[int кол-во уровней на hard] { 
 [int номер_байта][название уровня][byte нулевой байт] 
 ... 
}

Это и есть "3 части" заголовка. Рассмотрим их поподробнее.
Сначала идет int - количество уровней (на опр. уровне сложности). Потом идет запись:

{ int - номер байта (номер байта в файле, считая с нуля, где записан сам уровень.), название уровня, byte - закрывающий нулевой байт }

Эта запись повторяется столько раз, сколько уровней на данном уровне сложности - адрес начала для каждого трека. Потом аналогично для medium и для hard.

2. Сами треки

Эту часть файла тоже можно условно разделить на 2 части: информация о треке и сам трек.
Как раз начало этой, адрес, где эта запись начинается в файле (номер байта) мы читаем в заголовке файла. То есть если в mrg файле 30 уровней (10/10/10), то таких "записей уровня"
будет 30 - они просто идут друг за другом, ничем не разделяются.
"Информация" в файле записана следующим образом:

[byte - 0x33 - с этого байта начинаются все треки]
[int* - положение старта по оси X][int* - положение старта по оси Y (положение не флажка, а мотыка)]
[int* - положение финиша по оси X][int* - положение финиша по оси Y (в принципе ни от чего не зависит, постоянно 0)]
[short - количество точек][int - первая точка по оси X][int - первая точка по оси Y] 

Сам трек записывается как последовательность байтов:

 [byte - точка по оси X][byte точка по оси Y]
 [byte - точка по оси X][byte точка по оси Y]
 ...
 [byte - точка по оси X][byte точка по оси Y]

2 байта - X и Y = 1 точка. (количество точек, как я уже сказал, записано в "заголовке", "информации" уровня).
Оба байта - со знаком. Их значение - это смещение относительно предыдущей точки.
Если byte x равен -1, то byte y не читается, а читаются 2 int-а:

signed int x 
signed int y

Если значение signed int y больше 127, оно игнорируется и принимается за ноль.
Далее - без изменений, как раньше, byte x и byte y. Порядок байт - от старшего к младшему (big-endian).
int-ы, помеченные звездочками, записаны по-особому. Их нужно читать так:

(i >> 16) << 3

Автор: z-kzn-z