Skip to content

🌌 A virtual universe which lets you explore, analyze and present huge planetary datasets and large simulation data in real-time.

License

Notifications You must be signed in to change notification settings

JonasGilg/cosmoscout-vr

 
 

Repository files navigation

CosmoScout VR is a modular virtual universe developed at the German Aerospace Center (DLR). It lets you explore, analyze and present huge planetary data sets and large simulation data in real-time.

Build Status Coverage Status documentation license source loc plugin loc comments DOI

The software can be build on Linux (gcc or clang) and Windows (msvc). Nearly all dependencies are included as git submodules, please refer to the documentation in order to get started.

Features

Below is a rough sketch of the possibilities you have with CosmoScout VR. While this list is far from complete it provides a good overview of the current feature set. You can also read the changelog to learn what's new in the current version. There is also an interesting article in the DLR magazine which provides some insight into the ideas behind CosmoScout VR.

  • Solar System Simulation
    • Positioning of celestial bodies and space crafts based on SPICE
    • Rendering of highly detailed level-of-detail planets based on WebMapServices (with csp-lod-bodies)
    • Rendering of configurable atmospheres (Mie- and Rayleigh-scattering) around planets (with csp-atmospheres)
    • Physically based rendering of 3D satellites (with csp-satellites)
    • Rendering of Tycho, Tycho2 and Hipparcos star catalogues (with csp-stars)
    • Rendering of orbits and trajectories based on SPICE (with csp-trajectories)
    • Rendering of shadows
    • HDR-Rendering
  • Flexible User Interface
    • Completely written in JavaScript with help of the Chromium Embedded Framework
    • Main UI can be drawn in the screen- or world-space
    • Web pages can be placed on planetary surfaces
    • Interaction works both in VR and on the Desktop
    • Clear API between C++ and JavaScript
  • Cross-Platform
    • Runs on Linux
    • Runs on Windows
    • Runs on MacOS
  • System Architecture
    • Plugin-based - most functionality is loaded at run-time
    • Network synchronization of multiple instances
  • Hardware device support - CosmoScout VR basically supports everything which is supported by ViSTA and VRPN. The devices below are actively supported (or planned to be supported).
    • Mouse
    • Keyboard
    • HTC-Vive
    • ART-Tracking systems
    • 3D-Connexion Space Navigator
    • Multi-screen systems like tiled displays or CAVE's
    • Multi-screen systems on distributed rendering clusters
    • Side-by-side stereo systems
    • Quad-buffer stereo systems
    • Anaglyph stereo systems
    • Game Pads like the X-Box controller

Getting Started

⚠️ Warning: CosmoScout VR is research software which is still under heavy development and changes on a daily basis. Many features are badly documented, it will crash without warning and may do other unexpected things. We are working hard on improving the user experience - please report all issues and suggestions you have!

For each release, binary packages are automatically created via Github Actions.

When started for the very first time, some example datasets will be downloaded from the internet. This will take some time! The progress of this operation is shown on the loading screen.

If the binary releases do not work for you or you want to test the latest features, you have to compile CosmoScout VR yourself. This is actually quite easy as there are several guides in the docs directory to get you started!

Plugins for CosmoScout VR

CosmoScout VR can be extended via plugins. In fact, without any plugins, CosmoScout VR is just a black and empty universe. Here is a list of available plugins.

Official Plugins Description Screenshot
csp-anchor-labels Draws a click-able label at each celestial anchor. When activated, the user automatically travels to the selected body. The size and overlapping-behavior of the labels can be adjusted. screenshot
csp-atmospheres Draws atmospheres around celestial bodies. It calculates single Mie- and Rayleigh scattering via raycasting in real-time. screenshot
csp-custom-web-ui Allows adding custom HTML-based user interface elements as sidebar-tabs, as floating windows or into free space. screenshot
csp-fly-to-locations Adds several quick travel targets to the sidebar. It supports shortcuts to celestial bodies and to specific geographic locations on those bodies. screenshot
csp-lod-bodies Draws level-of-detail planets and moons. This plugin supports the visualization of entire planets in a 1:1 scale. The data is streamed via Web-Map-Services (WMS) over the internet. A dedicated MapServer is required to use this plugin. screenshot
csp-measurement-tools Provides several tools for terrain measurements. Like measurement of distances, height profiles, volumes or areas. screenshot
csp-minimap Displays a configurable 2D-Minimap in the user interface. screenshot
csp-recorder A CosmoScout VR plugin which allows basic capturing of high-quality videos. Requires that csp-web-api is enabled. screenshot
csp-rings Draws simple rings around celestial bodies. The rings can be configured with an inner and an outer radius and a texture. screenshot
csp-satellites Draws GTLF models at positions based on SPICE data. It uses physically based rendering for surface shading. screenshot
csp-sharad Renders radar datasets acquired by the Mars Reconnaissance Orbiter. The SHARAD profiles are rendered inside of Mars, the Martian surface is made translucent in front of the profiles. screenshot
csp-simple-bodies Renders simple spherical celestial bodies. The bodies are drawn as an ellipsoid with an equirectangular texture. screenshot
csp-stars Draws 3D-stars loaded from catalogues. For now Tycho, Tycho2 and the Hipparcos catalogue are supported. screenshot
csp-trajectories Draws trajectories of celestial bodies and spacecrafts based on SPICE. The color, length, number of samples and the reference frame can be configured. screenshot
csp-web-api Allows to control CosmoScout VR via an HTTP protocol. It also allows capturing screenshots over HTTP. screenshot

License

Copyright (c) 2019 German Aerospace Center (DLR)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Credits

Some badges in this README.md are from shields.io. The documentation of CosmoScout VR also uses icons from simpleicons.org.

About

🌌 A virtual universe which lets you explore, analyze and present huge planetary datasets and large simulation data in real-time.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 80.3%
  • JavaScript 5.4%
  • HTML 4.6%
  • CMake 3.5%
  • CSS 2.5%
  • GLSL 1.4%
  • Other 2.3%