DSVGO
Um unsere Webseite für Sie optimal zu gestalten und fortlaufend verbessern zu können, verwenden wir Cookies. Durch die weitere Nutzung der Webseite stimmen Sie der Verwendung von Cookies zu.
Server Wartungsarbeiten
Die Grundidee war die Entwicklung eines 2D Plattformers im Stil der alten Metroid-Spiele. So sollen die Level nicht in sich abgeschlossen sein, sondern eher so, dass der Spieler zu einem späteren Zeitpunkt zurückkehren muss, um neue Wege zu erkunden. Dies soll den Spieler motivieren, die einzelnen Levelabschnitte genauer zu erkunden.
Eine weitere Motivation ist das Lösen von Rätseln, um voran zu kommen. Der Spieler findet dazu ein Schwerkraftgerät, mit dessen Hilfe er um sich herum eine Art Blase erschaffen kann, in die er schwerelos ist. So kann der Spieler auch Orte erreichen, die normalerweise unerreichbar für ihn wären. Auch Objekte werden angezogen, sobald sie sich in dieser Blase befinden. Somit kann der Spieler ebenfalls Objekte erreichen, die sonst unerreichbar wären.
Die Hauptmotivation liegt darin, ein bestimmtes Ziel zu erreichen. In diesem Fall bedeutet das, dass der Hauptcharakter eine geliebte Person sucht, die sich auf einem verlassenen Raumschiff befinden soll.
Das verlassene Raumschiff ist dabei der Hauptschauplatz des gesamten Spiels und beinhaltet die verschiedenen Levelebenen, die der Spieler erkunden kann.
Pattform: PC
Genre: 2D Plattformer
Zielgruppe: Gewohnheitsspieler
Spielwelt: Science-Fiction- Weltraum
Gameplay / Motivation: Schwerkraft ein- und ausschalten, Rätsel lösen, Sammeln
Bedienung: Hauptfokus liegt zunächst auf Controller
Engine: Unity
Beim Leveldesign standen wir von Anfang an vor der Frage, ob wir einen eher freien, oder einen eher realistischen Anspruch bei der Gestaltung der Level verfolgen sollten. Durch einen sehr freien Ansatz bei der Levelgestaltung könnte man die Spielmechanik der Schwerkraftaufhebung deutlich stärker einsetzen (wie wir schon in unserem ersten Testlevel sehen konnten). Gleichzeitig hatten wir jedoch auch einen narrativen Anspruch an unser Spiel, der sich auch im Leveldesign widerspiegeln sollte, Somit entschieden wir uns für einen eher realistischen Ansatz, so dass die Level auf dem Raumschiff so aussehen sollten wie auf einem "echten" Raumschiff. Als Vorbilder dienten dabei etliche Science-Fiction Filme wie etwa Alien, oder Spiele, wie etwa Metroid, Dead Space, oder auch System Shock. Die Aufteilung der Level wurde so Konzipiert, dass sie Unabhängig von denen Ebenen des Raumschiffs sein sollte. Das heißt, dass es zwar drei Level und drei Raumschiffsebenen geben sollte, diese aber nicht deckungsgleich sein sollten. Der erste Level war noch so entworfen, dass der Spieler dort (beinahe) die komplette unterste Ebene erforscht, mit dem zweiten Level sollte sich das aber ändern und der dritte Level sollte letztendlich auf allen drei Ebenen spielen.
Der erste Level sollte im unteren Bereich des Schiffes spielen, einen eher mechanischen Look haben, den Spieler einen Einblick in die Geschehnisse an Bord geben und zudem als Tutorial fungieren. Der Spieler solle hier zum ersten mal seine neuen Fähigkeiten ausprobieren können. Zudem sollte er aber auch schon ein paar einfache Rätsel lösen, die mit der Schwerkraftmechanik einhergehen. Diese ersten Rätsel sollen dabei noch recht einfach sein: schwebe an Stellen, zu denen man bei normaler Schwerkraft nicht hinkommt, Sammle eine Schlüselkarte ein, oder bringe 3 Gegenstände (Reperaturkits) zu einem speziellen Punkt (Energiegenerator). Dabei sollte er durch die Spielumgebung lernen was alles mit der Schwerkraftmechanik möglich ist (etwa Gegenstände bewegen bzw. ziehen), ohne es hier schon Anwenden zu müssen. Dies sollte auf entsprechende Rätsel vorbereiten, die in einem späteren Spielabschnitt vorkommen sollten. Auch über die Geschichte sollte der Spieler informiert werden. So sollten erste Textnachrichten einen Einblick in die Geschichte und in einige der letzten Momente der Besatzungsmitgleider an Bord gewähren, bevor sie das Schiff verließen. Ansonsten ist der Aufbau recht linear. Der Spieler bewegt sich mehr oder weniger ausschließlich von links nach rechts, überwindet Hindernisse und repariert letztendlich den Hauptreaktor. Dies ermöglicht ihm zum Hauptaufzug zurückzukehren und auf die zweite Ebene zu wechseln.
Der zeite Level beginnt auf der zweiten Ebene. Anders als beim ersten Level wird jedoch in etwa nur die Hälfte dieser Ebene erforscht. Der Spieler wird damit konfrontiert, dass er einen Sicherheitscode braucht um mit dem Aufzug auf die Kommandoebene gelangen zu können. Schon früh entschieden wir uns dafür, dass sich auf der zweiten Ebene ein Labortrakt befinden sollte. Wir sprachen wohl auch über einen Wohntrakt, jedoch sollten Labore das prägende Element sein. Zudem sollte diese Ebene zwar über Räume und Gänge mit einer geringeren Deckenhöhe verfügen, als auf der Ebene davor. Allerdings sollte diese Ebene über mehrere Stockwerke verfügen, die der Spieler über Treppen, Leitern und über Löcher im Boden erreichen sollte. Der Aufbau sollte somit in gewisser Weise unserem ersten Testlevel entsprechen, in dem wir zunächst nur unsere Spielmechanik getestet hatten. Ebenfalls früh hatten wir uns dafür entschieden, dass der Spieler später in den Labortrakt zurückkehren sollte, um dort einen Gegenstand o.ä. zu holen. Somit war klar, dass nicht die komplette Ebene im zweiten Level betretbar sein sollte. Beim späteren Entwurf des Levels ergab sich, dass das Labor zu diesem Zeitpunkt für den Spieler komplett unerreichbar sein sollte. Stattdessen sollte nur die Wohnsektion begehbar sein. Aufgrund von Beschädigungen und verschlossenen Türen, sollte dieser Level eher einem kleinen Labyrith ähneln, durch dass sich der Spieler bewegen muss. Nachrichten in den Wohnungen der besatzung erzählen die Geschichte fort und geben Hinweise darauf, wie man weitere Teile des Levels für den Spieler öffnet (etwa durch die Preisgabe von Codes). Letztendlich findet der Spieler den Sicherheitscode um auf die Kommandoebene zu gelangen.
Der Übergang zwischen dem zweiten und dritten Level ist fließend. Nach dem Betreten der Kommandoebene gelangt man zur Bürcke des Schiffes, doch diese ist verschlossen. Wenn man versucht die Brücke zu betreten meldet sich der Captain, der sich auf der Brücke befindet und den Spieler dazu zwingt in den Labortrakt zu gehen um dort etwas für ihn zu holen und es dann zur Fähre im Hangar des Schiffes zu bringen (die unterste Ebene). Im Gegenzug will der Captain dem Spieler verraten, wo sich die Person befindet, die der Spieler sucht - seine Zwillingsschwester. Der Spieler muss sich also wieder zur zweiten Ebene bewegen, kann dort aber nun den zuvor geschlossenen Labortrakt betreten. Ähnlich wie zurvor bewegt er sich über mehrere Stockwerke durch einem zum Teil stark zerstörtes Labor. Über Enviormental Storytelling erhält der Spieler einblick über die Experimente die hier wohl stattgefunden haben müssen. Größere Teile der Laborausrüstung wurde Zerstört, in mindestes einem Labor gab es eine Explosion und an einigen Wänden breitet sich eine schwarze, flüßig-moosige Lebensform aus. Hier sollen die schwierigsten Rätsel auf den Spieler warten. So muss er etwa lose Kabel mit den passenden Steckdosen mithilfe seiner Gravitationsfähigkeit wieder verbinden, oder Gegenstände, die sich in Lüftungsschächten o.ä. befinden, an die er normalerweise nicht herankommt "herausziehen". Weiterhin sollen der labyrithartige Aufbau wie auch das Managment von verschlossenen Türen, die mithilfe von Zahlencodes und Schlüsselkarten geöffnet werden müssen, den Spieler vor Hindernisse stellen. Letztendlich findet der Spieler dass, was er dem Captain bringen soll und begibt sich wieder auf die erste Ebene. Dort übergibt er es ihm und erwährt nun, dass der Captain die Zwillingsschwester des spielers in seiner persönlichen Suite auf der Kommandoebene befindet. Der Spieler erhält einen entsprechenden Zahlencode und begibt sich nun dorthin zurück. In der suite angekommen findet er letztendlich nur eine Textnachricht, die aussagt, dass die Zwillingsschwester des Spielers vom Captain bei vor Evakuierung des schiffes eingesperrt wurde. Ihr gelang es jedoch letztendlich die persönliche Fluchtkapsel des Captains zu hacken und flh zum nächstgelegenen Planeten. Nach dem Lesen der Nachricht aktiviert sich die Slbstzerstörung des Raumschiffes und der Spieler muss unter Zeitdruck zum Anfang des Spieles zurückkehren.
Hier ein Playthrough des ersten Levelabschnittes.
Ein Großteil der Arbeit war die Programmierung. Darunter fallen die Mechaniken wie z.B. das Schwerkraft-Feature sowie kleinere Funktionen (Steuerung, öffnen von Türen, betätigen der Hebel, reparieren des Reaktors, einsammeln von Gegenständen usw.) Auch das Ein- und Ausblenden von UI Elementen (Pause Menü, Batterieanzeige, Benutzen-Taste usw.) musste programmiert werden. Es gibt um die 25 Scripte in dem Projekt.
Da dieses Projekt im Rahmen eines zukünftigen Projekts weiterentwickelt werden soll, war es auch wichtig, die Scripte/den Code möglichst so zu erstellen, dass diese in Zukunft einfacher wiederverwendet bzw. erweitert werden können. Dies hat dann auch den Zeitaufwand der Programmierung erhöht.
Das Hauptfeature war die Schwerkraftmechanik. Dafür wurden zwei Scripts erstellt. Einmal das Script für das Schwerkraftgerät selbst. Dieses ist dafür verantwortlich, dass sich das Gerät ein- und ausschaltet und je nachdem den Stand der Batterie überprüft. Bei dem zweiten Script handelt es sich um den Bereich, der um den Spieler erschaffen wird. Dieser hat die Aufgabe, Gegenstände anzuziehen, die sich in dem Bereich befinden.
Ein weiteres Feature ist das Tür-System. Diese lassen sich über die verschiedenen Terminals bedienen. Für die einzelnen Türen gibt es ein Script, welches diese einfach öffnen und schließen lässt. Die Logik, unter welchen Bedingungen eine Tür geöffnet werden kann, steckt in den sogenannten Terminals. Während bei einem normalen Terminal ein einfacher Druck auf die Benutzen-Taste ausreicht, überprüft das KeyCardTerminal, ob der Spieler die benötigte Schlüsselkarte bei sich hat. Das LeverTerminal stellt die Hebel dar, welche immer eine Tür öffnen und gleichzeitig eine andere schließen. Das KeyPadTerminal erwartet einen Code vom Spieler, den dieser eingeben muss. Erst bei Eingabe des richtigen Codes öffnet sich die Tür. Ist der Code einmal korrekt eingegeben, kann die Tür jederzeit ohne erneute Eingabe geschlossen und wieder geöffnet werden.
Mithilfe des Dialog-Systems ist es möglich, dem Spieler Texte über einen Computer anzuzeigen. Somit erfährt er nach und nach, was auf dem Schiff vorgefallen ist. Mit der Benutzen-Taste kann der Spieler den “Dialog” schließen bzw. den nächsten Satz einblenden lassen.
Im Rahmen des Projekts konnten wir die Erfahrung machen, wie viel Arbeit in einem “einfachen” 2D Platformer stecken kann. Allein die Anzahl der Scripts für die Mechaniken wuchs immer weiter an. Auch merkten wir, dass uns trotz eines umfangreichen Tilesets aus dem Asset Store noch viele Grafiken und Animationen fehlten, sodass nach weiteren Grafiken recherchiert werden musste. Dadurch lernten wir, dass ein Grafiker im Team einen großen Vorteil bietet, da so alle Grafiken für das Spiel individuell erstellt werden können.
Deshalb haben wir den Fokus erstmal auf die Mechaniken, die Soundeffekte und dem Storytelling gelegt.
Im Folgenden noch ein paar Beispiele, auf die wir während des Projektes gestoßen sind:
Die Map mit dem normalen Tilemap-Collider (links) und mit dem Composite-Collider (rechts)
Der Composite-Collider mit hinzugefügtem Physics Material 2D
Der normale Tilemap-Collider führte in der Anfangsphase dazu, dass der Spieler zwischen den einzelnen Tiles hängen bleiben konnte. Dies trat sehr zufällig auf. Nach einer Recherche wurde klar, dass die Behebung des Problems sehr einfach ist. Bei dem Tilemap-Collider muss einfach der Haken bei Used By Composite gesetzt werden. Anschließend kann der Composite-Collider als Komponente hinzugefügt werden. Anschließend wird automatisch ein Rigidbody 2D hinzugefügt, bei dem der Body Type auf Kinematic gestellt werden muss, da die Tilemap sonst eine Schwerkraft hat und nach unten fällt. Dieser sorgt dafür, dass nicht mehr jedes einzelne Tile einen Collider hat, sondern die gesamte Tilemap als Collider zusammengefasst wird. So kann der Spieler nicht mehr zwischen den einzelnen Tiles hängen bleiben.
Ein weiteres Problem bestand aber weiterhin: Sobald der Spieler gegen eine Wand gesprungen ist, blieb er dort hängen, solange man sich in Richtung der Wand bewegte. Aber auch dafür war die Lösung letztendlich einfach. Man benötigte nur ein Physics Material 2D, welches in Unity sehr einfach erstellt werden kann. Bei diesen setzt man einfach die Friction und Bounciness auf 0 und fügt dieses dem Composite-Collider hinzu.
Treppen mit normalen Tilemap-Collider (links) und mit Composite-Collider (rechts)
Collider für die einzelnen Treppen einfügen
Einfügen eines Physic2D Materials für den Stair-Collider, damit Spieler nicht zu schnell die Treppe hoch sprintet.
Im späteren Spielverlauf sollen auch noch Treppen eingefügt werden, die ebenfalls im grundlegenden Tileset enthalten sind. Bei den Treppen gab es allerdings das Problem, dass sowohl der Tilemap-Collider als auch der Composite-Collider verhindern, dass der Spieler die Treppe betreten kann, ohne zu springen. Er würde vor jeder Stufe hängen bleiben. Die einfachste Lösung war es, für die beiden Treppenarten (steile und flache Treppen) für jede Richtung einen Edge-Collider zu erstellen und manuell einzufügen. So haben die Treppen eine eigene Tilemap, jedoch ohne eigenen Tilemap-Collider.
Ein weiteres Problem war dann, dass der Spieler die Treppen zu schnell hochgekommen ist, sodass er am Ende der Treppe hoch "gesprungen" ist. Um dieses Problem zu lösen, wurde für den Edge-Collider ein Physics Material 2D mit dem Namen Stairs_Friction erstellt. Der Spieler verliert dadurch je nach eingestelltem Friction Wert die Geschwindigkeit auf der Treppe. Mit einem Wert von 2 konnte zunächst das beste Ergebnis erzielt werden, um das Problem zu lösen.
Während der Recherche nach ersten Soundplatzhaltern wurde schnell deutlich, dass die meisten vorgefertigten Sounds nicht unseren Erwartungen entsprachen. Viele der Klänge waren zwar für sich genommen eine gute Bereicherung, trugen jedoch dazu bei, dass keine einheitliche Atmosphäre geschaffen werden konnte. Außerdem waren einige der Anforderungen so speziell, dass es schlichtweg kein vergleichbares bereitgestelltes Soundset gab. Aufgrund dessen wurden viele der Sounds nicht eins zu eins übernommen, sondern nach eigenen Vorstellungen nachgebaut und verändert. Die neugewonnene Erfahrung mit diesem Prozess lässt spätere Probleme deutlich einfacher beheben, sorgte in diesem Projekt jedoch für einen hohen Zeitaufwand.
Im Folgendem eine Übersicht der aufgewendeten Stunden.
Person | Bereich | Stunden gesamt |
T. Lamping | Organisation
| 35
|
Grafik und Design
| 15
| |
Programmierung
| 130
| |
Person | Bereich | Stunden gesamt |
M. Laudon | Organisation
| 38
|
Grafik und Design
| 10
| |
Sound
| 125
| |
Q & A
| 8
|
Person | Bereich | Stunden gesamt |
S. Morlok | Organisation
| 50
|
Leveldesign
| 75
| |
Unity
| 30
| |
Texte
| 15
| |
Q & A
| 10
|