-
Notifications
You must be signed in to change notification settings - Fork 0
Developer Guidelines How it Works
Der zentrale Baustein des Programms ist der DataManager. Hier werden zunächst nach Aufrufen der Funktion init() über den DataLoader alle Daten der Trips, User etc., welche in JSON Files gespeichert sind, geladen, in entsprechende DataFields der Klassen Trip, User etc. umgewandelt und dann in Arrays gespeichert. Außerdem hält sich der DataManager eine Instanz der RiskManager Klasse. Über diese erhält er Zugriff auf die Risiken der verschiedenen Daten, auf ihre jeweiligen Sichtbarkeiten und zu den passenden Erklärungs-Strings. Im DataPackage befindet sich jeweils der passende Trip und das passende Vehicle zu den aktuell abgefragten Daten. Mit diesen lassen sich auch die anderen Informationen finden.
Der RiskManager verwaltet alles, was mit den verschiedenen Risikostufen und Erklärungstexten zu den verschiedenen Daten zu tun hat. Dazu beinhaltet er ein Array mit allen möglichen Instanzen der Klasse Risk. In jeder Instanz von Risk ist ein DataType und eine Role enthalten. Außerdem befindet sich dort die zum DataType gehörende RiskExplanation, die Sichtbarkeit betrachtet von der enthaltenen Rolle, und das passende RiskLevel. Die RiskExplanation-Klasse stellt einen String mit der Erklärung zu dem Datum bereit, von diesem gibt es je zwei Versionen, eine, falls das Datum sichtbar ist, und eine, falls nicht.
Es gibt fünf verschieden Kategorien von DataFields: User, Payment, Trip, Vehicle und Company. Jedes DataField kann über eine id identifiziert werden. Dabei kennt jeweils der Trip die ids des zu ihm gehörgien User, Payment und Vehicle. Von den Klassen Payment und Vehicle existieren jeweils Unterklassen. So kann zwischen verschiedenen Zahlungsarten und Fahrzeugen differenziert werden.
Visualisierung vertraulicher Daten in Mobilitätssystemen (SS 2022) | Confidentiality Visualizer