(Beispielpflanzen mit Code) |
(→Status) |
||
Zeile 126: | Zeile 126: | ||
== Status == | == Status == | ||
Implementiert: | '''Implementiert:''' | ||
* Testprogram mit simpler Graphik, siehe oben. | * Testprogram mit simpler Graphik, siehe oben. | ||
* Regelanwendung fürs Wachstum | * Regelanwendung fürs Wachstum | ||
Zeile 133: | Zeile 134: | ||
* Pflanzenwachstumssprache definieren und einen Parser schreiben | * Pflanzenwachstumssprache definieren und einen Parser schreiben | ||
* Fortpflanzung | * Fortpflanzung | ||
* Web-Interface | |||
:* Pflanzen eingeben, bearbeiten, als „aktiv“ markieren | |||
:* Syntaxcheck | |||
TODO: | '''TODO''' (patches accepted!): | ||
* Spielsteuerung (Rundendauer, Punkteverwaltung) | * Spielsteuerung (Rundendauer, Punkteverwaltung) | ||
* Schöne Graphik | * Schöne Graphik | ||
* Syntax dokumentieren | * Syntax dokumentieren | ||
* Web-Interface | |||
:* Pflanzen-Vorschau (renderAsPNG-Binary gibts schon) | |||
[[Kategorie:GPN8]] | [[Kategorie:GPN8]] |
Version vom 25. Juni 2009, 23:51 Uhr
Ein lustiges Pflanzenwachsprogrammiervisualisierungsspiel.
Idee
Der Spieler erstellt eine Pflanzenwachstumsbeschreibung in einer für L-seed entworfenen kleinen, regelbasierten Sprache, und läd sie, etwa über ein Web-Interface, auf den Server hoch. Dieser lässt dann die Pflanzen der Spieler in einem gemeinsamen Beet wachsen und um Licht konkurrieren. Die Pflanzen, die am effektivsten wachsen, können sich auch schneller vermehren und das Beet überwuchern. Das ganze soll natürlich per Beamer schön visualisiert werden.
Der Spieler kann auf das Pflanzenwachstum keinen Einfluss mehr nehmen, die Pflanze arbeitet ihren Code, also ihr Genom, stur ab. Allerdings kann für die nächste Generation, wenn die erste Pflanzen Samen hat wachsen lassen, der Code verbessert werden.
Insgesamt soll das Spiel einen chilligen Touch erhalten und auch schön zuzuschauen sein, wenn man nicht am Code feilt.
Eine ausführlichere Einführung ist auf Joachims Blog zu lesen.
Code
Der aktuellen Haskell-Code kann unter http://git.nomeata.de/?p=L-seed.git;a=summary bezogen werden. Die einzigen Abhängigkeiten sind parsec und gtk2hs. Unter Debian/Ubuntu sind das die Pakete libghc6-cairo-dev, libghc6-gtk-dev und libghc6-parsec-dev.
Die Haddock-Dokumentation ist auf http://entropia.de/~nomeata/L-seed-doc/
Beispiele
Hier ein paar Code-Beispiele, und wie sie nach jeweils der gleichen Zeit aussehen. Den Code für diese und weitere Pflanzen findet man auch unter http://git.nomeata.de/?p=L-seed.git;a=tree;f=examples
Status
Implementiert:
- Testprogram mit simpler Graphik, siehe oben.
- Regelanwendung fürs Wachstum
- Schattenberechnung
- Wachstumsgeschwindigkeit abhängig von eingefangener Lichtmenge und Pflanzengröße
- Pflanzenwachstumssprache definieren und einen Parser schreiben
- Fortpflanzung
- Web-Interface
- Pflanzen eingeben, bearbeiten, als „aktiv“ markieren
- Syntaxcheck
TODO (patches accepted!):
- Spielsteuerung (Rundendauer, Punkteverwaltung)
- Schöne Graphik
- Syntax dokumentieren
- Web-Interface
- Pflanzen-Vorschau (renderAsPNG-Binary gibts schon)