% hier kommt der ganze logik bums hin % Der aktuelle Spieler wird hiermit gesetzt damit das später % nicht bei jedem Aufruf angegeben werden muss :- assert( current_player(1) ). % das muss so weil sonst err % Damit vorherige action points (=0) auch in der ersten Runde exisiteren, sonst err :- assert( turn_action_points(1, 0) ), assert( turn_action_points(2, 0) ). % Verändern der Player Tokens hierüber change_player_tokens(TokensNew) :- TokensNew >= 0, current_player(Player), player_tokens(Player, Tokens), retract( player_tokens(Player, Tokens) ), assert( player_tokens(Player, TokensNew) ). change_player_tokens_decrement :- current_player(Player), player_tokens(Player, Tokens), TokensDecrement is Tokens - 1, change_player_tokens(TokensDecrement). % 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) :- % Den aktuellen Spieler abfragen current_player(Player), % Errechnen der verbleibenden Tokens betrag(Xold - Xnew, Xmove), betrag(Yold - Ynew, Ymove), player_tokens(Player, Tokens), TokensNew is Tokens - Xmove - Ymove, TokensNew >= 0, % Die vorhandenen Tokens des Spielers aktualisieren % Falls der Spieler nicht genug Tokens hat wird das hier false change_player_tokens(TokensNew), % Es darf keine Einheit auf dem Zielfeld bereits vorhanden sein \+ einheit_active(_, _, Xnew, Ynew, _), % Die Einheitv on der alten Position nehmen retract( einheit_active(Player, Type, Xold, Yold, Defense) ), % Die Einheit an die neue Position setzen assert( einheit_active(Player, Type, Xnew, Ynew, Defense) ), !. % Lässt zwei Einheiten gegeneinander Kämpfen % Die Einheit des aktuellen Spielers auf Xattack, Yattack % greift die Einheit des anderen auf Xdefend, Ydefend an einheit_attack(Xattack, Yattack, Xdefend, Ydefend) :- % Player token abziehen für den angriff-move % Falls nix übrig wird der angriff abgebrochen da false change_player_tokens_decrement, % Info für kämpfende Einheiten abrufen current_player(Player), einheit_active(Player, TypeAttack, Xattack, Yattack, _), einheit_active(PlayerDefend, TypeDefend, Xdefend, Ydefend, HP), % Info für Einheiten-Typen abrufen einheit(TypeAttack, AP, _, _, _), einheit(TypeDefend, _, _, MultDef, _), % Den Kampf durchführen ( (% Entweder die Einheit überlebt einheit_alive(AP, HP, HPnew, MultDef), retract( einheit_active(PlayerDefend, TypeDefend, Xdefend, Ydefend, HP) ), assert( einheit_active(PlayerDefend, TypeDefend, Xdefend, Ydefend, HPnew) ) ), ! ; (% Oder halt nicht einheit_delete(Xdefend, Ydefend) ) ), !. einheit_alive(AP, HP, HPnew, HPmult) :- % berechnen der differenz nach anwenden des multplikators HPwm is HP * HPmult, PwmDiff is HPwm - AP, % berechnen des Reduktionsverhältnis von HP Pratio is PwmDiff / HPwm, % berechnen der neuen HP und prüfen ob einheit alive HPnew is HP * Pratio, HPnew > 0. % Entfernt eine Einheit vom Spielfeld an Position X, Y einheit_delete(X, Y) :- retract( einheit_active(_, _, X, Y, _) ). get_color_of_fieldType(FieldTypeInt, Color) :- feldType(_, FieldTypeInt, Color). % Aktualisieren des aktuellen Spielers geht hiermit change_player_to(Player) :- retract( current_player(_X) ), assert( current_player(Player) ). % Ein Spieler ist entweder current_player oder inactive_player % je nach dem ob dieser gerade am Zug ist oder nicht inactive_player(Player) :- current_player(Player1), player(Player1), player(Player), Player1 \= Player. % Das hier muss an jedem Rundenende ausgeführt werden um den % aktuellen Spieler zu wechseln change_player :- inactive_player(Player), change_player_to(Player), !. % Falls das Spiel vorbei ist, mach nix end_turn :- game_over, write("Game Over!"), nl, inactive_player(Winner), write("Player "), write(Winner), write(" wins!"). % Beendet den Aktuellen Zug des Spielers end_turn :- % Die verbleibenden Tokens als Turn Speichern current_player(Player), player_tokens(Player, Tokens), last_turn(LastTurn), NewTurn is LastTurn + 1, assert( player_turn(Player, NewTurn, Tokens) ), % Die neue Anzahl an Tokens berechnen und setzen calc_tokens(Tcalc), change_player_tokens(Tcalc), % Den Spieler wechseln change_player. % Gibt aus der wie vielte Turn der höchste gespeicherte ist % für den aktuellen Spieler last_turn(Turn) :- current_player(Player), findall(X, player_turn(Player,_,X), Turns), max_member(Turn, Turns). % der shizz hier ist nicht getestet, sollte aber funzen % Berechnet die Summe aus Tokens des aktuellen und vergangenen Zuges calc_tokens(Tokens) :- % Aktuellen Spieler herausfinden current_player(Player), % Tokens die Pro Runde dazukommen hinzufügen player_tokens(Player, Tcurrent), player_tokens_per_turn(Player,Tturn), Tadd is Tcurrent + Tturn, % Tokens aus der vorletzten Runde entfernen last_turn(LastTurn), PreLastTurn is LastTurn - 1, player_turn(Player, PreLastTurn, Tprelast), % Neue Anzahl der Tokens ausgeben Tokens is Tadd - Tprelast. % game_over ist true wenn das game over ist - surprise surprise game_over :- current_player(Player), \+ einheit_active(Player,_,_,_,_).