Hausaufgabe
Einleitung
Zu Beginn des Softwarepraktikums soll sich jeder Teilnehmer mit C#, XNA und den dazugehörigen Werkzeugen vertraut machen. Ein guter Startpunkt dafür ist die Tutorial-Seite. Außerdem soll der erste Anstoß zum selbständigen Recherchieren der benötigten Quellen für das Softwarepraktikum gegeben werden. Aus diesem Grund müssen von jedem Teilnehmer in der ersten Woche (siehe Roadmap) verbindliche Hausaufgaben gemacht werden. Diese bestehen aus 5 Aufgaben.
- Lesen Sie den Text jeder Aufgabe vollständig durch, bevor Sie mit der Bearbeitung beginnen.
- Bearbeiten Sie die Aufgaben der Reihe nach.
- Beginnen Sie erst, wenn die Gruppeneinteilung online ist.
Aufgabe 1: Setup
Setzen Sie eine Arbeitsumgebung auf und testen Sie die Zugänge zu den verschiedenen Diensten.
- .NET 4.5
- Visual Studio 2010 (Visual Studio 2012 und XNA kann Probleme verursachen, daher empfehlen wir ausdrücklich VS 2010.)
- Resharper 8
- XNA Framework 4.0 Refresh
- Ein SVN-Client ihrer Wahl
Um auf die Dienste zugreifen zu können, brauchen Sie einen gültigen Poolaccount. Außerdem müssen Sie für die Dienste ein sog. WWW-Passwort einrichten.
Die folgenden Dienste sollten Sie getestet haben:
- Zugang zu ihrem SVN-Repository
- Zugang zum Trac ihrer Gruppe
- Die Gruppenmailingliste
Die Adressen dieser Dienste finden sich auf der Gruppeneinteilungsseite.
Aufgabe 2: Trac
Erstellen Sie für die Bearbeitung der Aufgabe 3 Tasks im Trac Ihrer Gruppe. Gehen Sie dazu wie folgt vor.
Product und Sprint Backlog für "Hausaufgabe" anlegen
Prüfen Sie, ob in Ihrem Trac bereits ein Backlog "Product Backlog" und ein Backlog "Sprint Backlog" angelegt wurde. Falls nein, legen Sie diese folgendermaßen an:
- Klicken Sie in der oberen Navigationsleiste auf "Admin".
- Klicken Sie in der linken Leiste auf "Backlogs".
- Geben Sie auf der rechten Seite den Namen "Product Backlog" ein und klicken Sie auf "Add and edit".
- Wählen Sie auf der nächsten Seite den Scope "global" und "Include Planned Tickets", sowie die Ticket Types "Requirement" und "User Story" aus und speichern Sie die aktuellen Einstellungen.
- Rufen Sie das Product Backlog erneut auf, indem Sie auf den Namen klicken. Stellen Sie unter "Column Preferences" folgende Eigenschaften ein (siehe auch Abbildung 1):
- "Business Value", Order=0
- "Importance", Order=2
- "Story Points", Order=3
- Geben Sie bei der Eigenschaft "Story Points" zusätzlich die Alternative "Total Story Points" an.
- Legen Sie ein neues Sprint Backlog, "Sprint Backlog", an, genauso, wie Sie das Product Backlog angelegt haben. Wählen Sie als Scope "sprint" aus und setzen Sie den Haken bei "Include Planned Tickets". Wählen Sie alle Ticket Types aus. Speichern Sie das Backlog.
- Rufen Sie das eben angelegte Sprint Backlog erneut auf und stellen Sie unter "Column Preferences" folgende Eigenschaften ein:
- "Owner", Order=1
- "Remaining Time", Order=0
- "Resources", Order=2
- Geben Sie außerdem bei "Remaining Time" als Alternative "Total Remaining Time" an.
Milestone für Hausaufgabe anlegen
Prüfen Sie, ob in Ihrem Trac bereits ein Milestone für die Hausaufgabe angelegt ist:
- Klicken Sie in der oberen Navigationsleiste auf "Admin".
- Klicken Sie in der linken Leiste auf "Milestones".
- Falls noch kein Milestone für die Hausaufgabe angelegt ist, legen Sie diesen an. Verwenden Sie das Datum der Abgabe (siehe Roadmap, Datumsformat beachten!).
Sprint für Hausaufgabe anlegen
Prüfen Sie, ob in Ihrem Trac bereits ein Sprint für die Hausaufgabe angelegt wurde (Admin -> Sprints). Falls nein, legen Sie diesen folgendermaßen an:
- Klicken Sie in der oberen Navigationsleiste auf "Admin".
- Klicken Sie in der linken Leiste auf "Sprints".
- Fügen Sie einen neuen Sprint mit Namen "Sprint Hausaufgabe", Milestone "Hausaufgabe", Start Date <heute> und End Date <Abgabezeitpunkt> hinzu. Beachten Sie dabei das Datumsformat.
- Beachten Sie, dass Trac anzeigt, dass der Sprint am folgenden Montag endet, falls Sie einen Tag an einem Wochenende als Endzeitpunkt angegeben haben. Das liegt daran, dass in Arbeitstagen (Montag-Freitag) gerechnet wird. Der verbindliche Abgabezeitpunkt der Hausaufgabe ist in der Roadmap angegeben.
Requirement für die Hausaufgabe anlegen
Prüfen Sie, ob in Ihrem Trac bereits das Requirement "Hausaufgaben machen" im Product Backlog angelegt ist. Falls nein, legen Sie dieses an.
- Klicken Sie am linken Rand auf "Product Backlog" und überprüfen Sie eventuell vorhandene Requirements.
- Klicken Sie auf der linken Seite unter Actions auf "New Requirement".
- Nennen Sie das neue Requirement "Hausaufgaben machen", weisen Sie dem Requirement den Milestone "Hausaufgabe" zu und speichern Sie es ab.
User Story anlegen
Legen Sie eine neue User Story für das Requirement "Hausaufgabe machen" an.
- Klicken Sie am linken Rand auf das Product Backlog.
- Wählen Sie das Requirement "Hausaufgabe machen" aus, indem Sie auf seine ID klicken.
- Klicken Sie auf der nächsten Seite unter dem Reiter "Edit" auf "Create a new referenced 'User Story'".
- Nennen Sie die User Story "Student <username> soll das Trac bedienen können, damit er in Zukunft produktiver arbeitet".
- Geben Sie den Sprint "Sprint Hausaufgabe" an und legen Sie die Importance auf "Mandatory" fest. Geben Sie außerdem Ihren Benutzernamen im Feld "Owner" an und erstellen Sie dann die neue User Story.
- Fügen Sie außerdem noch die beiden User Stories "Student <username> soll die Texte verstehen, damit er besser Spiele entwickeln kann" und "Student <username> soll ein XNA Programm schreiben, damit er früh merkt, ob irgendetwas nicht funktioniert" auf dieselbe Art zum Requirement "Hausaufgabe machen" hinzu.
Tasks für Aufgabe 3 erstellen
Legen Sie nun einen Task in der User Story "Student <username> soll das Trac bedienen können, damit er in Zukunft produktiver arbeitet" an, der bearbeitet werden soll.
- Klicken Sie am linken Rand auf das Product Backlog.
- Klicken Sie auf die ID der User Story.
- Klicken Sie im oberen Bereich auf "Edit".
- Klicken Sie in der Kategorie "References" auf "Create a new referenced 'Task'".
- Geben Sie den Tasknamen "Scrum verstehen" an.
- Geben sie im Feld "Remaining Time" die Zeit in Stunden an, die sie Ihrer Einschätzung nach für die Fertigstellung des Tasks benötigen.
- Speichern Sie den Task ab.
- Legen Sie außerdem den Task "Trac verstehen" für dieselbe User Story auf dieselbe Weise an.
Tasks für Aufgabe 4 erstellen
Erstellen Sie die Tasks für Aufgabe 4 unter User Story "Student <username> soll die Texte verstehen, damit er besser Spiele entwickeln kann" auf dieselbe Weise wie für Aufgabe 3:
- "'Clean Code Development' Artikel lesen"
- "'Dokumentation' Artikel lesen"
- "'Usability-Prinzipien beim Spieldesign' Artikel lesen"
- "'Trac und SVN' Artikel lesen"
Tasks für Aufgabe 5 erstellen
Erstellen Sie einen Task für Aufgabe 5, z.B. "Programm schreiben", auf dieselbe Weise wie für Aufgaben 3 und 4 für User Story "Student <username> soll ein XNA Programm schreiben, damit er früh merkt, ob irgendetwas nicht funktioniert".
Überprüfen der Tasks und Custom Query erstellen
Überprüfen Sie, ob Ihre Tasks richtig erstellt wurden, indem Sie sich das Product Backlog und das Sprint Backlog ansehen. Legen Sie außerdem ein neues Custom Query an. Ein Custom Query ist eine von Ihnen konfigurierte Ansicht, die Tickets und Tasks mit ihren Attributen filtert. Um eine geeignete Ansicht für Ihre Tickets oder Tasks zu erstellen, gehen Sie wie folgt vor:
- Klicken Sie in der oberen Navigationsleiste auf "View Tickets".
- Klicken Sie in der folgenden Ansicht oben rechts auf den Link "Custom Query".
- Konfigurieren Sie sich eine geeignete Ansicht, z.B. so wie in Abbildung 10 dargestellt.
- Klicken Sie auf "Update" um festzustellen, ob das Query richtig funktioniert.
- Klicken Sie auf "Save query" um das Query unter einem geeigneten Namen abzuspeichern. Sie können sie später jederzeit wieder löschen.
- Das neu erstellte Custom Query ist nun außerdem am linken Rand in der Kategorie "Tickets" zu finden.
Es gibt noch viele andere Arten, Ihre Ticketabfragen zu personalisieren. Für weiterführende Informationen können Sie die Trac-Dokumentationsseiten TracReports und TracQuery besuchen.
Tasks akzeptieren
Bevor Sie mit den Aufgaben beginnen, sollten Sie Ihren entsprechenden Tasks akzeptieren.
- Wählen Sie auf der linken Seite den Sprint "Sprint Hausaufgabe" aus und klicken Sie auf "View".
- Öffnen Sie die Tasks Ihrer User Stories, indem Sie auf die entsprechenden IDs klicken.
- Wählen Sie im Reiter "Edit" in der Kategorie "Action" die Auswahlmöglichkeit "accept Next status will be 'accepted'" aus und klicken Sie auf "Submit changes".
Aussehen
Wenn Sie alle Schritte durchgeführt haben, sollte das Sprint Backlog für den Sprint "Sprint Hausaufgabe" in etwa so aussehen, wie in Abbildung 13.
Aufgabe 3: Scrum und Trac verstehen
- Recherchieren Sie, was Scrum ist und wie Scrum funktioniert.
- Lesen Sie außerdem den Wikipedia-Artikel zu User Stories.
- Machen Sie sich mit den anderen Funktionen des Tracs vertraut
- Schauen Sie sich die verschiedenen Bereiche des Admin-Interfaces an und lesen Sie ggf. die Dokumentation (Links zur Dokumentation befinden sich auf jeder Trac-Seite).
- Schauen Sie außerdem die verschiedenen Ansichten, die Sie über die Navigationsleiste am oberen Rand erreichen (Home, Timeline, Roadmap, ...) an.
- Hinweis: Sie können nichts kaputt machen, außer wenn Sie Ihren Teamkollegen oder sich selbst unter "Administration->Permissions" die Rechte entziehen. Machen Sie das also nicht.
- Beschreiben Sie in der User Story "Student <username> soll das Trac bedienen können, damit er in Zukunft produktiver arbeitet" kurz, wie Scrum mit unserem Trac zusammenhängt. Verwenden Sie dazu einen Kommentar.
Aufgabe 4: Texte lesen
Lesen Sie sich die folgenden Artikel durch:
Sollten Sie Fragen zu diesen Artikeln haben, wenden Sie sich an Ihren Tutor.
Tasks bearbeiten
Aktualisieren Sie die Ihrer Einschätzung nach noch verbleibende Zeit und die bereits benötigte Zeit für einen Task, während Sie daran arbeiten. Besonders bei Programmieraufgaben ist dies sinnvoll, da so eine Historie der Bearbeitung und der verbrauchten Zeit erstellt wird. Dies hilft nicht nur Ihnen bei der Planung weiterer Aufgaben und Abschätzung der dafür benötigten Zeit, sondern dient auch als Nachweis für Ihre kontinuierliche Mitarbeit (siehe Richtlinien).
Achtung: Geben Sie im Feld "Spent Time" jeweils immer die Gesamtsumme der verbrauchten Stunden an. Das heißt, keine Differenzen zu bereits früher eingetragenen Zeiten. Das bedeutet, die verbrauchte Zeit für ein Task kann pro Bearbeitungsiteration immer nur größer werden oder gleich groß bleiben, kann aber nie kleiner werden.
Tasks schließen
Wenn Sie mit einer Aufgabe fertig sind, sollten Sie Ihren entsprechenden Task schließen. Gehen Sie ähnlich wie beim Akzeptieren eines Tasks vor, aber wählen Sie jetzt im Block "Action" (siehe Abbildung 12) die Option "resolve as fixed" und klicken Sie dann auf "Submit changes".
Alternativ können Sie auch die "Remaining Time" auf 0 setzen. In diesem Fall wird der Task ebenfalls geschlossen.
Geben Sie außerdem die Gesamtzeit, die Sie für die Bearbeitung des Tasks gebraucht haben, im Feld "Spent Time" an.
Achtung: Geben Sie im Feld "Spent Time" jeweils immer die Gesamtsumme der verbrauchten Stunden an. Das heißt, keine Differenzen zu bereits früher eingetragenen Zeiten.
Aufgabe 5: Programm schreiben
Bevor Sie mit dieser Aufgabe beginnen, sollten Sie Ihren entsprechenden Task akzeptieren.
Erstellen Sie ein XNA-Programm, welches die folgenden Eigenschaften erfüllt:
Funktionale Anforderungen
- Das Programm zeichnet eine Hintergrundgrafik in einem XNA-Fenster.
- Vor dieser Hintergrundgrafik rotiert ein Uni-Logo um den Bildschirmmittelpunkt.
- Das Logo muss transparent sein, d.h. es dürfen keine weißen Ränder der verwendeten Grafik sichtbar sein.
- Das Logo muss korrekt skaliert sein, damit es vollständig in den sichtbaren Bereich hinein passt.
- Das Logo darf während der Bewegung nicht über die Ränder des sichtbaren Bereiches hinausragen. (Größenveränderung des Fensters ist zu vernachlässigen. Es gilt als Richtwert die Größe des Fensters bei Programmaufruf.)
- Das Logo muss teilweise durchsichtig (transparent) sein.
- Innerhalb des XNA-Fensters wird ein Maus-Cursor angezeigt.
- Wenn der Benutzer mit der Maus innerhalb des Fensters klickt, soll ein Sound abhängig von der Position des Cursors abgespielt werden:
- Liegt der Cursor über dem Logo, soll ein Ton A erklingen.
- Liegt der Cursor nicht über dem Logo, soll ein Ton B erklingen.
- Ton A und Ton B müssen verschieden sein.
Randbedingungen
Die Randbedingungen müssen erfüllt werden. Insbesondere muss Ihre Abgabe frei von Resharper-Fehlern und Warnungen sein.
Ressourcen
Damit das Erstellen von Grafiken ignoriert werden kann, gibt es hier die beiden Beispieldateien aus der Einführungsveranstaltung:
Als Audiodateien können beliebige, kurze, Dateien verwendet werden. Die beiden aus der Einführungsveranstaltung bekannten Waves gibt es hier:
Abgabe
Bitte verwenden Sie zur finalen Abgabe der Hausaufgabe das SVN-Repository ihrer Gruppe: Abgabe/Hausaufgabe Verwenden Sie außerdem in Ihrer Commit-Message einen Befehl, um die von Ihnen angelegten Tickets zu schließen. Die Syntax dafür finden Sie im Artikel Trac und SVN.
Hinweise
- Falls Sie Probleme beim Starten der Anwendung haben, schauen Sie zuerst in die FAQ. Ein oft auftretendes Problem ist z.B. die Fehlermeldung "No suitable graphics card found".