Solitaire revisited

vorhergehende Artikel in: Revisited Rants
20.05.2016

Ich überlege schon lange daran, eins meiner ersten Programme, die ich je in der Sprache Java geschrieben habe, neu und besser (oder zumindest anders) zu implementieren.

Als ich mit diesen Überlegungen begann, wollte ich eigentlich eine neue Programmiersprache lernen. Im Lichte der neuesten Entwicklungen habe ich dies immer wieder verschoben (Es sollte eine Web-Anwendung mit Javascript und so werden).

Jetzt habe ich noch einmal darüber nachgedacht und bin mit mir übereingekommen, dass ich zunächst mal damit anfange, mir Gedanken über die Architektur einer solchen Anwendung zu machen. Danach könnte ich das Spiel nochmal in Java ordentlich implementieren und daran anschließend dann auch andere Programmiersprachen ausprobieren. Vielleicht ließe sich daraus dann auch ein interessanter Programmierkurs entwickeln?

Zunächst einige Festlegungen: Wir legen das Konzept einer Karte fest - Diese hat eine Farbe und eine Wertigkeit. Weitere Eigenschaften einer Karte sind vier visuelle Charakteristika: Die Vorder- und Rückseitenbilder: jeweils vollständig und teilverdeckt.

Ein weiteres Konzept ist das einer Ablage auf dem Tisch, Diese Ablage wird bestimmt durch folgende Eigenschaften: Oberste offene Karte (Sonderfall: Ablage leer) und welche Karte auf diese oberste Karte gelegt werden darf. Weiterhin wird festgelegt, ob eine Karte von dieser Ablage wegbewegt werden darf und falls ja, ob dies nur die oberste Karte sein darf oder eine der anderen offen liegenden oder sogar eine verdeckt liegende.

Wenn wir das gute alte Klondike benutzen, dann lassen sich diese Eigenschaften wie folgt definieren:

Stapel
Hier liegen die verdeckten Karten, die eine nach der anderen umgedreht als oberste auf die Reserve gelegt werden. Nur die oberste verdeckte Karte darf selektiert werden. Keine Karte darf auf den Stapel gelegt werden.
Reserve
Das ist der Platz, auf den die umgedrehten Karten des Stapels gelegt werden. Hier dürfen nur Karten abgelegt werden, die wenn selektiert verdeckt sind. Nur die oberste umgedrehte Karte darf selektiert werden.
Ziel
Diese vier Ablagen nehmen sie sortierten Karten auf. Keine Karte darf von hier entfernt werden. Hier dürfen nur umgedrehte Karten, die die obersten auf ihrer aktuellen Ablage sind, abgelegt werden. Die nur, wenn sie entweder ein Ass sind und die Ablage leer ist oder wenn sie dieselbe Farbe der bereits dort liegenden aufweisen und in der Wertigkeit genau eins über der obersten bereits dort liegenden Karte liegen.
Auslage
Die Auslage besteht insgesamt aus sieben Stapeln, die anfangs aus einer bis acht KArten bestehen, von denen jeweils die oberste initial umgedreht ist. Von dieser Ablage können Karten selektiert werden, die bereits umgedreht sind. Dies muss nicht unbedingt die oberste sein. Hier dürfen Karten, die bereits umgedreht sind angelegt werden. Die nur, wenn sie entweder ein Ass sind und die Ablage leer ist oder wenn sie dieselbe Farbe der bereits dort liegenden aufweisen und in der Wertigkeit genau eins über der obersten bereits dort liegenden Karte liegen.

Diese eher flüchtig hingeworfene Skizze einer allgemeinen Spielmechanik für Solitäire-ähnliche Games wird nun zunächst in Java implementiert, um herauszufinden, ob man mit diesen lokalen Regeln tatsächlich ein solches Spiel fertigen kann.

Anschließend wird dann versucht, eine andere Sprache zur Umsetzung zu nutzen und weitere Solitäire-Spiele umzusetzen.

Alle Artikel rss Wochenübersicht Monatsübersicht Github Repositories Gitlab Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Mandelbrot-Sets mittels Shadern berechnen

    17.05.2019

    Nachdem ich in den letzten verregneten Tagen auf Youtube in den Videos von Numberphile versunken bin, hat mich eines davon angestachelt, mich selbst mit dem Mandelbrotset zu beschäftigen. Als ich dann noch Code fand, der behauptete, das auf einer Graphikkarte mittels Shadern berechnen zu können, war es um mich geschehen...

    Weiterlesen...

Neueste Artikel

  • Erste Vor-Version eines Gis-Plugin für die sQLshell

    Wie bereits in einem früheren Artikel erwähnt plane ich, demnächst ein Plugin für die sQLshell anzubieten, das eine Visualisierung von Daten mit räumlichem Bezug im Stil eines Geoinformationssystems erlaubt.

    Weiterlesen...
  • bad-certificates Version 2.1.0

    Das bereits vorgestellte Projekt zur automatisierten Erzeugung von Zertifikaten mit allen möglichen Fehlern hat eine Erweiterung erfahren und verfügt über ein Partnerprojekt - beide sind nunmehr in der Version 2.1.0 freigegeben

    Weiterlesen...
  • SQLite als Geodatenbank

    Wie bereits in einem früheren Artikel beschrieben treibe ich derzeit Anstrengungen voran, die sQLshell attraktiver für Nutzer zu machen, die mit Geodatenbanken arbeiten.

    Weiterlesen...

Manche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.

Wer daran teilhaben und eventuell sogar davon profitieren möchte, muß damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.

Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...

PS: Meine öffentlichen GitHub-Repositories findet man hier - meine öffentlichen GitLab-Repositories finden sich dagegen hier.