Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.12.05;
Скачать: CL | DM;

Вниз

дальность хода   Найти похожие ветки 

 
MANGOL   (2004-07-31 16:32) [0]

Привет!
У меня такая проблема:
в пошаговой стратегии при выделении юнита нужно рассчитать координаты всех точек(клеток), в которые он может добраться за этот ход. у юнита есть moves, местность нескольких типов - с разной проходимостью.
бился над этой фигнёй целый день. моя прога вроде считает, но не точно (приблизительно :) ).. урезает всё время пару клеток.

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


 
Timedrops ©   (2004-07-31 17:16) [1]

Поищи метод волновой трассировки - наиболее простой метод
всегда практически работает, обходит препятствия.
Получи сначало весь путь в масив. Каждый элемент
массива представь например в виде
record
x,y : integer;
land: integer; //это будет указывать сколько ходов потеряет юнит
end;

всё. подсчитывай последовательно куда же он по этому пути дотопает.

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


 
MANGOL   (2004-07-31 19:25) [2]

THANX!
волновая трассировка - это чюдо..
правда, как оказалось, я именно её и использовал. Просто в одном месте вместо "<" поставил ">"  :)



Страницы: 1 вся ветка

Текущий архив: 2004.12.05;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.029 c
1-1100865130
Zilog
2004-11-19 14:52
2004.12.05
исключение "недопустимый дескриптор окна"!?


1-1100980074
noob
2004-11-20 22:47
2004.12.05
Массив


14-1100755165
X9
2004-11-18 08:19
2004.12.05
16-битная графика в Sims 2


6-1096615076
AlexA
2004-10-01 11:17
2004.12.05
TIdSMTP в теле письма "заменяются" русские буквы


3-1099464032
SergP
2004-11-03 09:40
2004.12.05
Получить номер строки DbGrid в событии DrawColumnCell