Eine interaktive Karte für umweltbewusste Fahrradfahrer*innen, die ein Elektroauto besitzen und Nachhaltigkeit und Komfort kombinieren möchten.
Die Karte zeigt Ihnen die besten Orte zum Parken und Aufladen Ihres Elektrofahrzeugs, während Sie mit dem Fahrrad durch die Stadt fahren. Sie können auch auf die Karte sehen, wo Sie in der Nähe ein Fahrrad ausleihen können. Außerdem können Sie nach Radwegen suchen, um Ihre Fahrt so angenehm und effizient wie möglich zu gestalten.
Das Projekt umfasst die Entwicklung einer interaktiven Visualisierungslösung, die verschiedene Komponenten umfasst. Diese Komponenten arbeiten zusammen, um Daten aus einer PostGIS-Datenbank, Geoserver und weitere Quellen abzurufen und über eine webbasierte Benutzeroberfläche darzustellen.
Folgende Schritte sind erforderlich, um das Projekt lokal auszuführen:
- Stelle sicher, dass Docker, Docker Compose und Maven auf deinem System installiert sind.
- Klone das Projekt-Repository von GitHub:
git clone https://github.com/liRahimpour/intervisuell.git
- Gehe in das Projektverzeichnis:
cd intervisuell/iv-dev-dockercompose
- Führe das BashScript
build.sh
aus
Das Backend wurde mit Java Spring Boot, Hibernate und Maven entwickelt. Es stellt zwei Endpunkte bereit, die Daten aus der PostGIS-Datenbank abrufen und als JSON an das Frontend weitergeben. Die Endpunkte sind wie folgt erreichbar:
Module: intervisuell
Die Daten sind als CSV-dateien unter intervisuell/iv-dev-postgres/initdb
vorhanden (ladestationen_.csv und leihstationen.csv). Sie müssen die daten beispielweise über PgAdmin in der jeweiligen Tabelle importieren.
Module: iv-dev-postgres
Die Datenbank basiert auf PostgreSQL und verwendet die PostGIS-Erweiterung. Sie enthält zwei Tabellen: "Bike_rental" und "Charging_station". Die Datenbank ist über den Port 5432 erreichbar.
- Host: localhost
- POSTGRES_USER=
admin
- POSTGRES_PASSWORD=
admin
- POSTGRES_DB=
db
- Port:
5432
Module: iv-geoserver
Der Geoserver beinhaltet drei Overlays, die in der Visualisierung verwendet werden. Er ist über den Port 8084 erreichbar.
- Overlay:
const fahrradverleih = L.tileLayer.wms('http://localhost:8084/geoserver/wms', {
layers: 'mainz:fahrradverleih',
format: 'image/png',
minZoom: 1,
maxZoom: 20,
transparent: true,
icon: myIcon,
attribution: '... </a>'
});
const fahrradwege = L.tileLayer.wms('http://localhost:8084/geoserver/wms', {
layers: 'mainz:Radwege',
format: 'image/png',
minZoom: 1,
maxZoom: 20,
transparent: true,
attribution: '... </a>'
}).addTo(map);
const supermarkt = L.tileLayer.wms('http://localhost:8084/geoserver/wms', {
layers: 'mainz:Supermarkt',
format: 'image/png',
minZoom: 1,
maxZoom: 20,
transparent: true,
attribution: '... </a>'
});
- Zugriff über: http://localhost:8084/geoserver/web/
Module: wird über dockercompose Datei deployt unter services -> intervisuell-pgadmin
Das Datenbankadministrationstool pgAdmin wird verwendet, um die PostgreSQL-Datenbank zu initialisieren und zu verwalten. Es kann über den Port 8082 erreicht werden.
- Zugriff über: http://localhost:8082
- Username:
[email protected]
- Password:
admin
Module: iv-portal
Das Portal ist ein Nginx-Webserver, der die HTML-, CSS- und JavaScript-Dateien für die Benutzeroberfläche enthält. Es ist über den Port 8081 erreichbar.
- Zugriff über: http://localhost:8081
Module: iv-dev-dockercompose
Docker Compose ist ein Werkzeug (Container-Orchestrierung), mit dem man mehrere Docker-Container zu einer Anwendung zusammenfassen können. Mit einer einzigen Konfigurationsdatei, die als "docker-compose.yml" bezeichnet wird, kann man die Container, ihre Konfiguration und ihre Abhängigkeiten definieren.
Die Konfigurationsdatei ermöglicht es Ihnen, Container mit verschiedenen Images, Umgebungsvariablen, Netzwerkeinstellungen, Volumes etc. zu erstellen. Man kann auch die Kommunikation und Abhängigkeiten zwischen den Containern festlegen.
Pfad: Abgabe-Ordner
Dieses Projekt ist lizenziert unter einer Creative Commons Namensnennung 4.0 International Lizenz.
Das Projekt wurde im Rahmen des Fachs "Interaktive Visualisierung und Internet" an der Hochschule Mainz entwickelt.