Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Gsoc2024 rebased autoplot #2547

Merged
merged 18 commits into from
Nov 22, 2024
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
18 commits
Select commit Hold shift + click to select a range
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions AUTHORS
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ in alphabetic order by first name
- Matthias Riße <[email protected]>
- May Bär <[email protected]>
- Nilupul Manodya <[email protected]>
- Preetam Sundar Das <[email protected]>
- Reimar Bauer <[email protected]>
- Rishabh Soni <[email protected]>
- Sakshi Chopkar <[email protected]>
Expand Down
97 changes: 97 additions & 0 deletions docs/autoplot_dock_widget.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
GUI FOR AUTOMATED PLOTTING
ReimarBauer marked this conversation as resolved.
Show resolved Hide resolved
==========================

Autoplot Docking Widget
-----------------------

**Autoplot Dockwidget Description:**
The Docking Widget offers users a Graphical User Interface (GUI) for downloading plots based on specified configurations. It provides a user-friendly approach, integrating seamlessly with other dock widgets. This widget can be accessed across all three views—Top View, Side View, and Linear View—ensuring flexibility and ease of use for different user preferences.

**Components:**

The autoplot docking widget contains the following parameters which can be configured:

- **Select configuration file button**: This button is used to select the JSON file for uploading the configurations to the dock widget. By default, it uses the `mssautoplot.json` file located in this path - `$HOME/.config/msui`.

- **Left Treewidget**: The following parameters can be configured or updated based on requirements:

- Flight
- Map Sections
- Vertical
- Filename
- Initial Time
- Valid Time

- **Right Treewidget**: The following parameters can be configured or updated:

- URL
- Layers
- Styles
- Level
- Start Time
- End Time
- Time Interval

- **ComboBoxes**: These allow configuring the start time, end time, and time interval. Ensure that the start time is always less than the end time. The plots are downloaded from the start time to the end time at the provided time intervals.

- **Download Plots Button**: This button is used to download plots based on the configurations. The configuration is saved in the `mssautoplot.json` file by default, located at `$HOME/.config/msui`.

- **Update/Create JSON file**: This button will create or update the JSON file. If not present, it will update the default `mssautoplot.json` file located at `$HOME/.config/msui`.

How to Use
----------

The `mssautoplot.json` file located in the `$HOME/.config/msui` directory contains the default configuration.

The **left treewidget** is used to configure the automated plotting flights list:

.. code-block:: json

"automated_plotting_flights":
[
["flight1", "section1", "vertical1", "filename1", "init_time1", "time1"],
["flight2", "section2", "vertical2", "filename2", "init_time2", "time2"]
]

- Flight, filename, and section parameters are configured in the **Top View**.
- The vertical parameter is configured in the **Side View**.

The **right treewidget** is used to configure the automated plotting flight sections, which are based on the view:

- For **Top View**, it is `"automated_plotting_hsecs": [["URL", "Layer", "Styles", "Level"]]`.
- For **Side View**, it is `"automated_plotting_vsecs": [["URL", "Layer", "Styles", "Level"]]`.
- For **Linear View**, it is `"automated_plotting_lsecs": [["URL", "Layer", "Styles"]]`.

Inserting, Updating, and Removing Configuration in the Treewidget
-----------------------------------------------------------------

There are three buttons— **Add**, **Update**, and **Remove**—under each treewidget:

- **Add Button**: Inserts a row based on the current configurations.

- For the left treewidget, the current values of flight, section, vertical, filename, init_time, and time are inserted.
- For the right treewidget, the current values of URL, Layers, Styles, Level, Start Time, End Time, and Time Interval are inserted.

- **Remove Button**: Removes the selected row.

- **Update Button**: Updates the selected row with the current values (only active after selecting a row).

Ensure that the **right tree widget** has at least one row before inserting into the left treewidget.

Downloading the Plots
---------------------

Plots can be downloaded in the following ways:

1. Upload the configuration JSON file by clicking the **Select configuration file** button, then click the **Download Plots** button to download the plots.
2. Upload the configuration JSON file by clicking the **Select configuration file** button, then make modifications as needed.
3. Download plots with or without flight track from start time to end time at specified time intervals. This ensures that a total of `M x N` plots are downloaded, where `M` is the number of rows in the left treewidget and `N` is the number of rows in the right treewidget.

Example
-------

An `mssautoplot.json` file generated after clicking the **Update/Create Configuration file Button** in the path, e.g. “$HOME/.config/msui” by default:

**/$HOME/.config/msui/mssautoplot.json**

.. literalinclude:: samples/config/msui/autoplot_dockwidget.json.sample
Loading
Loading