Skip to main content

Use point and shape layer to edit swc format in napari

Project description

napari-swc-editor

License BSD-3 PyPI Python Version tests codecov napari hub

Use point and shape layer to edit swc format in napari.


This napari plugin was generated with copier using the napari-plugin-template.

Features

https://github.com/user-attachments/assets/cba1820f-d0b5-436c-a981-62bae0e1a6ba

IO

READER

  • Your .swc should follow the following specs: http://www.neuronland.org/NLMorphologyConverter/MorphologyFormats/SWC/Spec.html
  • the reader will create 2 napari layer: point_layer and shape_layer. Only point_layer is interactive, shape_layer is used to render path between swc points.
  • The raw swc can be accessed in the point layer metadata. Such as point_layer.metadata["raw_swc"]
  • A pd.DataFrame object is also saved in the metadata: point_layer.metadata["swc_data"]

WRITER

  • With the point_layer selected, you can use napari interface to save with .swc extension name.
  • You can also do it in command line: napari.save_layers('test.swc', [point_layer])

Napari Interface

Structure ID and point symbol

In swc, structure id allow to label the type of neuron structure the point belongs to. In this plugin by default, the points will follow this symbol mapping:

SWC_SYMBOL = {
    0: "clobber",  # undefined
    1: "star",  # soma
    2: "disc",  # axon
    3: "triangle_down",  # basal dendrite
    4: "triangle_up",  # apical dendrite
}

image

SWC Edition

ALL INTERACTIONS ARE ONLY BOUND TO THE point_layer THERE IS NO CTRL-Z (please save your progress)

  • Add point: You can edit the "r" and the "structure_id" using the point_size and symbol image
  • Remove point: (Select the point and press 1 or suppr or delete) All the link pointing to this point will be removed
  • Add edge: Select 2 or more point(s) and press on your keyboard l (aka: link).
  • Remove edge: Select 1 or more point(s) and press on your keyboard u (aka: unlink).

Installation

You can install napari-swc-editor via pip:

pip install napari-swc-editor

To install latest development version :

pip install git+https://github.com/LaboratoryOpticsBiosciences/napari-swc-editor.git

Contributing

Contributions are very welcome. Tests can be run with tox, please ensure the coverage at least stays the same before you submit a pull request.

License

Distributed under the terms of the BSD-3 license, "napari-swc-editor" is free and open source software

Issues

If you encounter any problems, please file an issue along with a detailed description.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

napari_swc_editor-0.0.3.tar.gz (492.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

napari_swc_editor-0.0.3-py3-none-any.whl (19.4 kB view details)

Uploaded Python 3

File details

Details for the file napari_swc_editor-0.0.3.tar.gz.

File metadata

  • Download URL: napari_swc_editor-0.0.3.tar.gz
  • Upload date:
  • Size: 492.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for napari_swc_editor-0.0.3.tar.gz
Algorithm Hash digest
SHA256 1c8297ad967f82c7b2f5e11ef4acda25333494826355a217b8f1363b29b23527
MD5 191c0a532658aab8ccbddbd1e7e74bff
BLAKE2b-256 00822005538a0104a7314b1be122cca8ff407247fe2e3b82f94713f67f86cbdf

See more details on using hashes here.

File details

Details for the file napari_swc_editor-0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for napari_swc_editor-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5574c5d8985f2434c754b99acea8996066bb9108403e66696913aa6f2828365d
MD5 3a637edc275fc2b3f09839ba27c60f24
BLAKE2b-256 accbc760f502e4b672c5cdd998ba814f5b18508f5a682f4466021982c095c0ee

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page