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