DATA Spaces Visualization for Liquid Galaxy is an Android application developed as part of Google Summer of Code 2025 with the Liquid Galaxy project. Built with Flutter, a UI framework by Google for building natively compiled applications, this app is designed to visualize Data Spaces information on Liquid Galaxy systems. It serves as a bridge between FIWARE-based Data Spaces and Liquid Galaxy's immersive visualization capabilities, enabling users to explore and interact with spatial data from Data Spaces in an engaging way.
Flutter was chosen for this project because:
- Rich set of customizable widgets
- Excellent performance for real-time data visualization
- Strong support for Material Design
- Great community support and extensive package ecosystem
- Native compilation for optimal Android performance
Data Spaces visualization is crucial for:
- Understanding the interconnection of different data sources within Data Spaces
- Visualizing FIWARE context information in a geographical context
- Making data-driven decisions based on Data Spaces information
- Facilitating real-time monitoring of Data Spaces entities
- Improving the accessibility of Data Spaces information through immersive visualization
-
Data Spaces Integration:
- Connection to FIWARE Context Broker
- Real-time entity data visualization
- Support for multiple Data Spaces sources
- NGSI-v2 compatibility
- Agricultural data from pig farms (DWG and FCR metrics)
-
Spatial Data Visualization:
- Google Maps integration
- Entity location mapping
- Attribute visualization
- Real-time updates
-
Liquid Galaxy Connectivity:
- Secure SSH connection
- Synchronized visualization across displays
- Remote installation control
- KML generation for entity visualization
- Synchronized map view between app and Liquid Galaxy
- QR scanner for quick setup
-
Data Management:
- Configure refresh intervals
- Manage cached data
- Filter and sort information
-
User Interface:
- Material Design
- Entity filtering and search
- Customizable visualization options
- Intuitive controls for Liquid Galaxy interaction
- Colorblind mode support with optimized color schemes
- Accessibility features for color-vision deficient users
- Flutter: A UI framework by Google for building natively compiled applications
- Dart: Modern programming language optimized for client apps
- FIWARE: Context information management
- Google Maps Flutter: Official Flutter plugin for Google Maps
- dartssh2: SSH connection management for Flutter
- Provider: State management solution for Flutter
- Shared Preferences: Flutter plugin for persistent storage
- NGSI-v2: Data Spaces communication protocol
- Flutter SDK (^3.8.1)
- Android Studio
- Android SDK
- Git
- Access to a FIWARE Context Broker
- Liquid Galaxy system
-
Clone the repository:
git clone https://github.com/LiquidGalaxyLAB/DATA-Spaces-for-LG-Frontend.git
-
Navigate to the project directory:
cd DATA-Spaces-for-LG-Frontend
-
Install dependencies:
flutter pub get
-
Configure Google Maps:
- Rename
android/app/src/main/res/values/strings.xml.example
tostrings.xml
- Replace
YOUR_API_KEY
with your Google Maps API key in the renamed file
- Rename
-
Build and install the Android application:
flutter build apk
-
Initial Setup:
-
Configure Liquid Galaxy connection settings:
- Manual configuration through settings
- Quick setup using QR code scanner
- Connection validation system
-
Set up Data Spaces connection parameters
-
Configure visualization preferences
-
Enable colorblind mode if needed
-
-
Data Spaces Interaction:
- Browse available entities
- Filter entities by type or attributes
- View entity details and locations
-
Visualization Control:
- Select entities for visualization
- Control Liquid Galaxy camera
- Customize visualization styles
- Manage active visualizations
-
Data Management:
- Monitor entity updates
- View historical data
The application includes a comprehensive colorblind mode that:
- Uses carefully selected color combinations suitable for different types of color vision deficiencies
- Ensures high contrast for better readability
- Allows easy switching between normal and colorblind modes
- Maintains consistency in the user interface across both modes
This project is licensed under the Apache License 2.0 - see the LICENSE.md file for details.
Developer: Marc Bañeres Farrán
Liquid Galaxy: Website | GitHub Google Summer of Code 2025: Project Page