-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #430 from pro3d-space/features/gisView-trajectories
GIS View
- Loading branch information
Showing
167 changed files
with
112,893 additions
and
114,098 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
# The MIT License | ||
|
||
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. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,20 @@ | ||
## 4.25.0-prerelease10 | ||
- optimized kd tree loading from caches | ||
|
||
## 4.25.0-prerelease6 | ||
- #413 (without footprints part), #330, #414, #397 | ||
|
||
## 4.25.0-prerelease5 | ||
- trafo updates merged with develop | ||
|
||
## 4.25.0-prerelease4 | ||
- fixed refsystem normalization | ||
|
||
## 4.25.0-prerelease2 | ||
- option for switching euler angle order | ||
|
||
## 4.25.0-prerelease1 | ||
- testrelease | ||
- fixed pivot transformation | ||
|
||
## 4.24.0-prerelease1 | ||
- testrelease |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,141 @@ | ||
|
||
## PRo3D.GIS | ||
|
||
Summary: This feature allows to interpret celestial bodies and surfaces from within pro3d and serves as a basis for GIS functionality in PRo3D. | ||
General concept: A new UI tab allows to assign coordiante frames and celestial body information to surfaces and GIS entities. By setting observeration time and by choosing an observer body, views or fly-by scenarious can be modelled. | ||
|
||
|
||
## SPICE | ||
|
||
### Pre-requisistes | ||
As mentioned in [SPICE docs](./spice.md) pro3d allows to load custom spice kernels. In this documentation we use the [HERA spice kernels](https://s2e2.cosmos.esa.int/bitbucket/projects/spice_kernels/repos/hera/browse), which are also used in the [solar-system demo](https://github.com/pro3d-space/PRo3D.SPICE) | ||
|
||
To follow the demo download or clone the [repository](https://s2e2.cosmos.esa.int/bitbucket/projects/spice_kernels/repos/hera/browse). | ||
|
||
|
||
### Loading the kernel | ||
|
||
There are two options to load SPICE kernels. | ||
|
||
#### The command line | ||
- by using the command-line argument `--defaultSpiceKernel path`, e.g. the path to the tm file: `"../hera/kernels/mk/hera_crema_2_0_LPC_ECP_PDP.tm"`, the SPICE kernel to be loaded at application startup can be specified. | ||
|
||
#### The UI | ||
|
||
1. Initially PRo3D with GIS view enabled looks like this: | ||
|
||
data:image/s3,"s3://crabby-images/cd336/cd33680ac9ccb8b643cb69a13f143c675ed53f80" alt="alt text" | ||
|
||
2. Load the kernel via: | ||
|
||
data:image/s3,"s3://crabby-images/f3c3d/f3c3d4204a6722c085a8f855ec70a0f406788966" alt="alt text" | ||
|
||
3. Then the Gis View should print the path to the kernel (scroll down, and look at the settings pane within the GIS view): | ||
|
||
data:image/s3,"s3://crabby-images/3b1ef/3b1ef4e638393aabdfd46f567d9a3ea8408314c9" alt="" | ||
|
||
A green check mark appears below the path if loading the kernel was successful. If there is a red exclamation mark beneath the path loading was not successful. PRo3D's text output will give more detailed information why, it might be that the path to the kernel is not correct. | ||
|
||
## PRO3D GIS View Tab | ||
|
||
### Current Observation Settings | ||
|
||
At the top of the GIS tab there is a section entitled "Current Observation Settings". This is used to define an observer, a target, a point in time, and a reference frame. | ||
|
||
data:image/s3,"s3://crabby-images/ab19a/ab19a45928ebf2af21fbde4bd60156ed87b066f6" alt="" | ||
|
||
* Observer: The entity from which we want to observe a specific target. The camera will be placed at the location of the observer. | ||
* Target: The entity we want to look at. The camera will look in the direction of the target. | ||
* Time: The point of time at which we want to observe. The loaded spice kernel needs to have data for observer and target at the selected point in time! | ||
* Reference Frame: The reference frame into which all other frames will be converted. Which frame is selected here should not change the visual result. | ||
|
||
### Surfaces | ||
|
||
To use a surface with PRo3D's GIS functionality, it has to be associated with a reference frame, and can be associated with an entity. This reference frame in which the surface is defined is needed to transform the surface to the global reference system used by PRo3D. | ||
Assigning a reference frame and entity to a loaded surfaces is done in the "Surfaces" tab. | ||
|
||
data:image/s3,"s3://crabby-images/bca0b/bca0bf611f8214878dafa1b57d44571c55f71b02" alt="" | ||
|
||
Select the correct reference frame (and optionally entity) from the dropdown menu. If the entity or reference frame needed is not in the dropdown menu, it can be created in the "Entities"/"Reference Frames" tab. | ||
|
||
### Entities | ||
|
||
Entities can be celestial bodies or spacecraft. To work with PRO3D's GIS functionality the Spice Name of the entity needs to be defined in the loaded spice kernel. | ||
|
||
The entity tab lists all entities. There are some default entities already present in PRo3D. | ||
|
||
data:image/s3,"s3://crabby-images/54d5c/54d5c95ad08165ed0d14985f5df15a6ef6af1cd2" alt="" | ||
|
||
An entity can be edited by clicking on the right hand icon in the "Actions" column. The icon used to edit the HERA entity is circled in red in the screenshot below. | ||
|
||
data:image/s3,"s3://crabby-images/128c6/128c613aa6538378854abfd0b6af98bbeaf27239" alt="" | ||
|
||
The red cross to the left of the edit icon deletes the corresponding entity. | ||
|
||
Each entity can be assigned a reference frame in the column "Reference Frame". For each entity, a sphere can be drawn in the scene. Whether a sphere is drawn is determined by the checkbox in the "Draw" column. | ||
|
||
A new entity can be created by clicking on the green plus icon at the bottom right hand side of the Entities tab. The spice name can only be set when creating an entity, it cannot be changed once the entity is created. To change a spice name you need to deleted the old entity and create a new one with the new spice name and the settings of the old entity. Spice names are unique, so you cannot create two entities with the same spice name. | ||
|
||
Clicking on the edit icon of an entity (see above), opens a section for the entity: | ||
|
||
data:image/s3,"s3://crabby-images/920fb/920fbd1cd7964f6655f045bc75c9d8bd8134eefe" alt="" | ||
|
||
The reference frame and whether to draw an entity can be selected in this view as well as the following settings: | ||
|
||
- **Geometry Path** (not yet implemented) path to a geometry that is displayed at the location of this entity instead of a simple sphere | ||
- **Texture Path** The path to an image (for example a jpeg file) that is rendered onto the entity. | ||
- **Radius** The radius of the sphere that is drawn in the location of the entity in meters. | ||
|
||
The green save icon at the bottom right hand corner closes the edit view. | ||
|
||
Below an example of the entity Moon with a radius of 1736000 meters and a texture path. | ||
|
||
data:image/s3,"s3://crabby-images/b7c1f/b7c1f60bf3c61ede5b871914a497c0fd2fad2c12" alt="" | ||
|
||
## Reference Frames | ||
|
||
Reference frames can be deleted (red cross icon) and created (green plus icon in the bottom right corner) in this view. They can also be assigned an entity which is associated with them. | ||
|
||
data:image/s3,"s3://crabby-images/b70c3/b70c3f6c2c13265c534736e4113822f7153504cd" alt="" | ||
|
||
A new reference frame can be created by clicking on the green plus icon at the bottom right hand side of the Reference Frames tab. The spice name can only be set when creating a reference frame, it cannot be changed once the reference frame is created. To change a spice name you need to deleted the old reference frame and create a new one with the new spice name and the settings of the old reference frame. Spice names are unique, so you cannot create two reference frame with the same spice name. | ||
|
||
## Observing mars | ||
|
||
Let us now observe mars from, say phobos. | ||
1. Set the observation settings (including a time which is in available in the kernel) | ||
data:image/s3,"s3://crabby-images/4b636/4b636f13f277e8a94a94bbb236c14879d6dd6d8a" alt="" | ||
|
||
2. Next, make sure the proxy visualization for mars is enabled: | ||
data:image/s3,"s3://crabby-images/8836d/8836dd0d68c13a24f63efcc936bc970b4f97cfa0" alt="" | ||
and | ||
|
||
data:image/s3,"s3://crabby-images/bb0b6/bb0b689d00c84f13b89cd2207205a682774343a2" alt="" | ||
|
||
Also make sure to have the far plane set far away for viewing mars from phobos. Ajust the near *and* far planes accordingly: | ||
data:image/s3,"s3://crabby-images/09db3/09db3eddd137455b32eaab492c8bbaf38e0d540d" alt="" | ||
|
||
Now mars should be visible from the observation point of view. | ||
|
||
By using the visualization properties in the entity list the element can be textured as well. | ||
|
||
data:image/s3,"s3://crabby-images/4ead6/4ead69920e5ec72997745d4a2e3380e63a30aa9d" alt="" | ||
|
||
Next let us load the mola dataset. | ||
In the Surfaces pane witin the Gis View, now specifiy reference frame and celestial body for the surface (if it does not appear change the observation settings, e.g. by setting the time): | ||
data:image/s3,"s3://crabby-images/9e95b/9e95bc3f51fcd96f13a6e0cf73514f2d5dd91395" alt="" | ||
|
||
Since we have a full surface for mars now, we can switch of the proxy geometry: | ||
data:image/s3,"s3://crabby-images/887d7/887d78895de6e03d9e46d7914019ab81aaa48b18" alt="" | ||
|
||
## Extended features | ||
|
||
It is possible to add new celestial bodies, new reference frames. | ||
|
||
## Extended concept | ||
|
||
For story telling, PRo3D also supports to create GIS bookmarks. Similarly to stories on surfaces this can be used to create movies and interactive presentations for science. | ||
|
||
## Caveats | ||
|
||
Currently the GIS settings are not stored to scene files. |
File renamed without changes.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# Layered OPCs | ||
|
||
Goal: [Countour lines](../Contour-Lines.md) can be mapped onto secondary textures of [multilayer opcs](../Feature-Multitexture.md). Contour distance can be specified, the lines should appear as anti-aliased lines given a line width. | ||
|
||
Dependent tests: [layers](./layers.md) | ||
|
||
Approach: | ||
- import of OPC data | ||
- changing visualization properties to use secondary texture | ||
- apply contour line onto secondary texture | ||
- save/load of scenes and check whether all properties are restored properly | ||
|
||
Out-of-scope: | ||
- Multitextured OBJs | ||
|
||
Data needed: OPC with layers, e.g. Dimorphos, HeraV3. | ||
|
||
Steps: | ||
- [ ] run the [layers](./layers.md) test | ||
- [ ] Check whether counturs tab in the surface window appears | ||
data:image/s3,"s3://crabby-images/bfbab/bfbab66104a95568543308c4d991bbec38076102" alt="" | ||
- [ ] For eleveation as layer, choose distance/width/border accordingly: | ||
data:image/s3,"s3://crabby-images/8a0b5/8a0b529b49b8f090648053fcf8106f2760daeaca" alt="" | ||
Note: Lines should be crisp and anti-aliased. In the current screenshot above those are not. When we get higher-resolution layer this image will be updated. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
# Cutout geometry | ||
|
||
Goal: Perform annotations on a [multilayer](../Feature-Multitexture.md) opc and export cut-out geometry described by the annotation. | ||
|
||
Dependent tests: [layers](./layers.md) | ||
|
||
Approach: | ||
- import of OPC data | ||
- perform an annotation | ||
- use vscode nodebook to run a demo [notebook](../../notebooks/CutoutDemo.ipynb) to create an obj of the cutout geometry | ||
|
||
Prerequisited: | ||
- vscode with: ionide & polyglot notebook extension | ||
|
||
Out-of-scope: | ||
- Multitextured OBJs | ||
|
||
Data needed: OPC with layers, e.g. Dimorphos, HeraV3. | ||
|
||
Steps: | ||
- [ ] start PRo3D with the the pro3d api enabled using the command line flag (`--remoteApi `) or the predefined launch profile | ||
data:image/s3,"s3://crabby-images/726b1/726b1adcbd804b960b01a9c62ff6e41126bfed33" alt="" | ||
- [ ] run the [layers](./layers.md) test | ||
- [ ] open vscode in PRo3D root/notebooks and open the [cutout notebook](../../notebooks/CutoutDemo.ipynb). | ||
data:image/s3,"s3://crabby-images/e614e/e614e864c340c4d8749f607567de8d8686d9dc8d" alt="" | ||
- [ ] run the first cell and check the result (should be a green tickbox) | ||
data:image/s3,"s3://crabby-images/6dbc1/6dbc1ade511b11bf2369446229a5154c57816443" alt="" | ||
- [ ] create a annotation which forms a convex polygon | ||
data:image/s3,"s3://crabby-images/47e72/47e7290a03c9de0abbe130c99c4dcca71b79e18c" alt="" | ||
data:image/s3,"s3://crabby-images/6d2c1/6d2c12cf68335bcecedf6f2808057d10f3379d05" alt="" | ||
- [ ] run the next cell in the notebook. First it should print the ID of the annotation created: | ||
data:image/s3,"s3://crabby-images/3740a/3740a13a4e922afa85dcc7733d773b33b7e76102" alt="" | ||
- [ ] next it should print filtered vertices. Next check the result.obj - does it contain geometry representing the cotout, colored with elevation values: | ||
data:image/s3,"s3://crabby-images/614d4/614d41059cc350bfd190abd8c2b7ec25b6fd39ac" alt="" | ||
data:image/s3,"s3://crabby-images/aae18/aae18a41980968b4a4191f58fcd8df08fef805ce" alt="" |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.