Refactoring and minor changes
This commit is contained in:
parent
d739d909b5
commit
7c63b3c2e9
39
daten.pl
39
daten.pl
@ -15,8 +15,8 @@ einheit(tank, 5, 5, 3, 3).
|
||||
% Startpositionen der Spieler mit jeweils -1 auf die coords
|
||||
% Damit ist die init_player universell
|
||||
% playerStart(Player, X, Y)
|
||||
playerStart(1, -1, -1).
|
||||
playerStart(2, 3, 3).
|
||||
player(1).
|
||||
player(2).
|
||||
|
||||
% Die Anzahl an tokens die pro Runde an die Spieler verteilt wird
|
||||
player_tokens(10).
|
||||
@ -64,29 +64,34 @@ reset_game :-
|
||||
|
||||
|
||||
% Initialisiert die Einheiten für die jeweiligen Spieler
|
||||
init_player(Player, Type1, Type2, Type3) :-
|
||||
% der shabang ist hier damit die einheiten jeweils in den
|
||||
% richtigen ecken spawnen
|
||||
playerStart(Player, X, Y),
|
||||
Xp1 is X + 1,
|
||||
Xp2 is X + 2,
|
||||
|
||||
Yp1 is Y + 1,
|
||||
Yp2 is Y + 2,
|
||||
|
||||
init_player1(Player, Type1, Type2, Type3) :-
|
||||
% Berechnet die zustehenden Tokens pro Runde für den Spieler
|
||||
einheit(Type1, _, Defense_Points1, _, Cost1),
|
||||
einheit(Type2, _, Defense_Points2, _, Cost2),
|
||||
einheit(Type3, _, Defense_Points3, _, Cost3),
|
||||
|
||||
player_tokens(Tokens),
|
||||
Cost is Tokens - (Cost1 + Cost2 + Cost3),
|
||||
|
||||
assert( player_tokens(Player, Cost) ),
|
||||
|
||||
% Definiert die aktiven einheiten der Spieler
|
||||
% einheit_active(Player, Einheit Type, feldX, feldY)
|
||||
assert( einheit_active(Player,Type1,Xp1,Yp1,Defense_Points1) ),
|
||||
assert( einheit_active(Player,Type2,Xp2,Yp1,Defense_Points2) ),
|
||||
assert( einheit_active(Player,Type3,Xp1,Yp2,Defense_Points3) ).
|
||||
assert( einheit_active(Player,Type1,0,0,Defense_Points1) ),
|
||||
assert( einheit_active(Player,Type2,0,1,Defense_Points2) ),
|
||||
assert( einheit_active(Player,Type3,1,0,Defense_Points3) ).
|
||||
|
||||
|
||||
init_player2(Player, Type1, Type2, Type3) :-
|
||||
% Berechnet die zustehenden Tokens pro Runde für den Spieler
|
||||
einheit(Type1, _, Defense_Points1, _, Cost1),
|
||||
einheit(Type2, _, Defense_Points2, _, Cost2),
|
||||
einheit(Type3, _, Defense_Points3, _, Cost3),
|
||||
|
||||
player_tokens(Tokens),
|
||||
Cost is Tokens - (Cost1 + Cost2 + Cost3),
|
||||
assert( player_tokens(Player, Cost) ),
|
||||
|
||||
% Definiert die aktiven einheiten der Spieler
|
||||
% einheit_active(Player, Einheit Type, feldX, feldY)
|
||||
assert( einheit_active(Player,Type1,4,4,Defense_Points1) ),
|
||||
assert( einheit_active(Player,Type2,4,3,Defense_Points2) ),
|
||||
assert( einheit_active(Player,Type3,3,4,Defense_Points3) ).
|
31
logik.pl
31
logik.pl
@ -13,8 +13,8 @@ change_player_to(Player) :-
|
||||
% je nach dem ob dieser gerade am Zug ist oder nicht
|
||||
inactive_player(Player) :-
|
||||
current_player(Player1),
|
||||
playerStart(Player1,_,_),
|
||||
playerStart(Player,_,_),
|
||||
player(Player1),
|
||||
player(Player),
|
||||
Player1 \= Player.
|
||||
|
||||
% Das hier muss an jedem Rundenende ausgeführt werden um den
|
||||
@ -41,6 +41,18 @@ player_turn(Player) :-
|
||||
save_action_points(Player).
|
||||
|
||||
|
||||
% Gibt den Betrag der Zahl zurück
|
||||
betrag(Num1, Num2) :-
|
||||
(
|
||||
Num1 >= 0,
|
||||
Num2 is Num1
|
||||
), !
|
||||
;
|
||||
(
|
||||
Num2 is -Num1
|
||||
).
|
||||
|
||||
|
||||
% Bewegt die Einheit des aktuellen Spielers an position Xold, Yold
|
||||
% auf position Xnew, Ynew
|
||||
einheit_move(Xold, Yold, Xnew, Ynew) :-
|
||||
@ -55,8 +67,13 @@ einheit_move(Xold, Yold, Xnew, Ynew) :-
|
||||
|
||||
% Errechnen der verbleibenden Tokens
|
||||
retract( player_tokens(Player, Tokens) ),
|
||||
% die berechnung muss noch mal angeschaut werden
|
||||
TokensNew is Tokens - (Xold - Xnew) - (Xold - Ynew),
|
||||
|
||||
betrag(Xold - Xnew, Xmove),
|
||||
betrag(Yold - Ynew, Ymove),
|
||||
|
||||
TokensNew is Tokens - Xmove - Ymove,
|
||||
TokensNew >= 0,
|
||||
|
||||
assert( player_tokens(Player, TokensNew) ).
|
||||
|
||||
|
||||
@ -67,10 +84,12 @@ einheit_attack(Xattack, Yattack, Xdefend, Ydefend) :-
|
||||
current_player(Player),
|
||||
einheit_active(Player, TypeAttack, Xattack, Yattack, _),
|
||||
einheit_active(PlayerDefend, TypeDefend, Xdefend, Ydefend, HP),
|
||||
einheit(TypeAttack, AP, _,_,_),
|
||||
einheit(TypeAttack, AP, _, _, _),
|
||||
einheit(TypeDefend, _, _, Mult, _),
|
||||
HPwithMult is HP * Mult,
|
||||
(
|
||||
(% Entweder die Einheit überlebt
|
||||
einheit_alive(AP, HP, HPnew),
|
||||
einheit_alive(AP, HPwithMult, HPnew),
|
||||
retract( einheit_active(PlayerDefend, TypeDefend,
|
||||
Xdefend, Ydefend, HP) ),
|
||||
assert( einheit_active(PlayerDefend, TypeDefend,
|
||||
|
Loading…
x
Reference in New Issue
Block a user