{"name":"napari-time-series-plotter","display_name":"TSP","visibility":"public","icon":"","categories":[],"schema_version":"0.1.0","on_activate":null,"on_deactivate":null,"contributions":{"commands":[{"id":"napari-time-series-plotter.Explorer","title":"Dock TSPExplorer widget","python_name":"napari_time_series_plotter.dock_widgets:TSPExplorer","short_title":null,"category":null,"icon":null,"enablement":null},{"id":"napari-time-series-plotter.Inspector","title":"Dock TSPInspector widget","python_name":"napari_time_series_plotter.dock_widgets:TSPInspector","short_title":null,"category":null,"icon":null,"enablement":null}],"readers":null,"writers":null,"widgets":[{"command":"napari-time-series-plotter.Explorer","display_name":"Explorer","autogenerate":false},{"command":"napari-time-series-plotter.Inspector","display_name":"Inspector","autogenerate":false}],"sample_data":null,"themes":null,"menus":{},"submenus":null,"keybindings":null,"configuration":[]},"package_metadata":{"metadata_version":"2.1","name":"napari-time-series-plotter","version":"0.0.6","dynamic":null,"platform":null,"supported_platform":null,"summary":"A Plugin for napari to visualize pixel values over the first dimension (time -> t+3D, t+2D) as graphs.","description":"# napari-time_series_plotter\n\n[![License](https://img.shields.io/pypi/l/napari-time_series_plotter.svg?color=green)](https://github.com/ch-n/napari-time_series_plotter/raw/main/LICENSE)\n[![Python Version](https://img.shields.io/pypi/pyversions/napari-time_series_plotter.svg?color=green)](https://python.org)\n[![PyPI](https://img.shields.io/pypi/v/napari-time_series_plotter.svg?color=blue)](https://pypi.org/project/napari-time_series_plotter)\n[![Anaconda-Server Badge](https://anaconda.org/conda-forge/napari-time-series-plotter/badges/version.svg)](https://anaconda.org/conda-forge/napari-time-series-plotter)\n[![napari hub](https://img.shields.io/endpoint?url=https://api.napari-hub.org/shields/napari-time-series-plotter)](https://napari-hub.org/plugins/napari-time-series-plotter)\n[![tests](https://github.com/ch-n/napari-time_series_plotter/workflows/tests/badge.svg)](https://github.com/ch-n/napari-time_series_plotter/actions)\n[![codecov](https://codecov.io/gh/ch-n/napari-time_series_plotter/branch/main/graph/badge.svg)](https://codecov.io/gh/ch-n/napari-time_series_plotter)\n\n\n## Description\nNapari-time_series_plotter (TSP) is a plugin for the `napari` ndimensional image viewer. \n\n**TSP** adds live plotting of time-resolved images to napari. You can select and visualize pixel/voxel or ROI mean values from one or multiple image layers as intensity-over-time line plots (The first image dimension is handled as time) and save the figures or the underlying time series data as CSV file. TSP supports 3D to nD images (3D: t+2D, nD: t+nD).\n\n**Plotting** is handeled by the `Explorer` widget, it offers three different plotting modes: Voxel, Shapes, Points\n
--> Voxel mode offers live plotting while moving the cursor over an image layer\n
--> Shapes mode offers shape-based ROI plotting the ROI combination method can be one of [Mean, Median, STD, Sum, Min, Max]; multiple ROIs can be plotted simultaneously\n
--> Points mode offers simultaneous, point-based plotting of multiple voxels\n
You can modify and save the plots through the canvas toolbar.\n
Plotting powered by `napari-matplotlib`.\n\n**Viewing** the time series as a table is handled by the `Inspector` widget. You can load the data you've plotted and inspect the single time point values of each selection. The columns are named like the plots in the `Explorer`. You can copy the whole tabe or a selection to the clipboard or directly expot it to a CSV file to save the time series.\n\n----------------------------------\n\n## Installation\nYou can either install the latest version via pip or conda.\n\n**pip:**\n\n pip install napari-time-series-plotter\n\nor download the packaged `tar.gz` file from the release assets and install it with \n \n pip install /path/to/file.tar.gz\n\n**conda:**\n\n conda install -c conda-forge napari-time-series-plotter\n\n\nAlternatively, you can install the plugin directly in the `napari` viewer plugin manager, the napari hub, or the release assets.\n\n
\n\nTo install the latest development version install directly from the relevant GitHub branch.\n\n## Usage\n### Basics and Live plotting\n\n[![basic_demo](./demo_videos/TSP_basic_and_voxel_plotting_demo.jpg)](./demo_videos/TSP_basic_and_voxel_plotting_demo.webm)\n \n1. Select the `TSPExplorer` widget in the `Plugins` tab of the napari viewer\n2. Use the `LayerSelector` to choose the image layers you want to source for plotting\n3. Move the corsor over the layer while holding \"Shift\"\n\nThe `Options` tab offers multiple options to customize your plot. \n- Set custom title or axe labels\n- Switch between autoscaling and manually defined max and min values of the axes\n- Switch to label truncation in the options tab if your layer names are too long for the figure legend (set max length manually)\n- Set a scaling factor for the X-axis\n\nThe plot can be modified and saved through its toolbar above.\n\n### Plotting ROIs\n\n[![roi_demo](./demo_videos/TSP_ROI_plotting_demo.jpg)](./demo_videos//TSP_ROI_plotting_demo.webm)\n\n1. Select the Shapes plotting mode via the `Options` tab (Voxel mode is the default).\n2. Use the `LayerSelector` to choose the image layers you want to source for plotting.\n2. Add one ore more shapes to the \"ROI Selection\" layer.\n
The \"ROI Selection\" shapes are 2D only, effecting the currently displayed slice.\n
(newly added shapes might have to be moved before they are correctly plottet)\n3. Reposition or remove shapes if needed.\n4. Change the ROI mode in the `Options` tab (Default: mean).\n\n### Plotting multiple Points\n\n[![points_demo](./demo_videos/TSP_Points_plotting_demo.jpg)](./demo_videos/TSP_Points_plotting_demo.webm)\n\n1. Select the Shapes plotting mode via the `Options` tab (Voxel mode is the default).\n2. Use the `LayerSelector` to choose the image layers you want to source for plotting.\n3. Add one or more points to the \"Point selection\" layer.\n
The points can be on different slices (3D and 4D support only) or images (grid mode)\n4. Reposition or remove points if needed.\n\n### View time series as table\n\n[![points_demo](./demo_videos/TSP_Inspector_demo.jpg)](./demo_videos/TSP_Inspector_demo.webm)\n\n1. Select the `TSPInspector` widget in the `Plugins` tab of the napari viewer\n2. Press the load from plot button to load the currently displayed plots into the `Inspector`\n\nYou can copy the whole table or a selection to your clipboard or export it to CSV file through the buttons above.\n\n## ToDo (help welcome)\n- [ ] Add Sphinx documentation\n\n## Version 0.1.0 Milestones\n- [X] Update to napari-plugin-engine2 [#5](https://github.com/ch-n/napari-time_series_plotter/issues/5)\n- [X] Update widget GUI [#6](https://github.com/ch-n/napari-time_series_plotter/issues/6)\n- [x] Add widget to save pixel/voxel time series to file [#7](https://github.com/ch-n/napari-time_series_plotter/issues/7)\n- [X] Add ROI and multi-voxel plotting [#14](https://github.com/ch-n/napari-time_series_plotter/issues/14)\n- [ ] Evaluate and close remaining issues ([#22](https://github.com/ch-n/napari-time_series_plotter/issues/22), [#25](https://github.com/ch-n/napari-time_series_plotter/issues/25),)\n\n## Contributing\n\nContributions are very welcome. Tests can be run with [tox], please ensure\nthe coverage at least stays the same before you submit a pull request.\n\n## License\n\nDistributed under the terms of the [BSD-3] license,\n\"napari-time_series_plotter\" is free and open-source software\n\n## Issues\n\nIf you encounter any problems, please [file an issue] along with a detailed description.\n\n--------------\n\n## References\nThis [napari] plugin was generated with [Cookiecutter] using [@napari]'s [cookiecutter-napari-plugin] template.\n\nImages used in the demo gif were taken from [The Cancer Imaging Archive]
\n\n DOI: https://doi.org/10.7937/K9/TCIA.2015.VOSN3HN1\n Images: 1.3.6.1.4.1.9328.50.16.281868838636204210586871132130856898223\n 1.3.6.1.4.1.9328.50.16.254461916058189583774506642993503110733\n\n[The Cancer Imaging Archive]: https://www.cancerimagingarchive.net/\n[napari]: https://github.com/napari/napari\n[Cookiecutter]: https://github.com/audreyr/cookiecutter\n[@napari]: https://github.com/napari\n[MIT]: http://opensource.org/licenses/MIT\n[BSD-3]: http://opensource.org/licenses/BSD-3-Clause\n[GNU GPL v3.0]: http://www.gnu.org/licenses/gpl-3.0.txt\n[GNU LGPL v3.0]: http://www.gnu.org/licenses/lgpl-3.0.txt\n[Apache Software License 2.0]: http://www.apache.org/licenses/LICENSE-2.0\n[Mozilla Public License 2.0]: https://www.mozilla.org/media/MPL/2.0/index.txt\n[cookiecutter-napari-plugin]: https://github.com/napari/cookiecutter-napari-plugin\n\n[file an issue]: https://github.com/ch-n/napari-time_series_plotter/issues\n\n[napari]: https://github.com/napari/napari\n[tox]: https://tox.readthedocs.io/en/latest/\n[pip]: https://pypi.org/project/pip/\n[PyPI]: https://pypi.org/\n","description_content_type":"text/markdown","keywords":null,"home_page":"https://github.com/ch-n/napari-time_series_plotter","download_url":null,"author":"Christopher Nauroth-Kress","author_email":"nauroth_C@ukw.de","maintainer":null,"maintainer_email":null,"license":"BSD-3-Clause","classifier":["Development Status :: 2 - Pre-Alpha","Intended Audience :: Developers","Framework :: napari","Topic :: Software Development :: Testing","Programming Language :: Python","Programming Language :: Python :: 3","Programming Language :: Python :: 3.8","Programming Language :: Python :: 3.9","Programming Language :: Python :: 3.10","Operating System :: OS Independent","License :: OSI Approved :: BSD License"],"requires_dist":["napari-matplotlib (<1.0)","numpy","pandas","qtpy","tox ; extra == 'testing'","pytest ; extra == 'testing'","pytest-cov ; extra == 'testing'","pytest-qt ; extra == 'testing'","napari ; extra == 'testing'","pyqt5 ; extra == 'testing'"],"requires_python":">=3.8","requires_external":null,"project_url":["Bug Tracker, https://github.com/ch-n/napari-time_series_plotter/issues","Documentation, https://github.com/ch-n/napari-time_series_plotter#README.md","Source Code, https://github.com/ch-n/napari-time_series_plotter","User Support, https://github.com/ch-n/napari-time_series_plotter/issues"],"provides_extra":["testing"],"provides_dist":null,"obsoletes_dist":null},"npe1_shim":false}