Skip to main content

No project description provided

Project description

zincware PyPI version 'Threejs

ZnDraw

Install via pip install zndraw or pip install zndraw[webview] to open zndraw in a dedicated window.

CLI

You can use ZnDraw with the CLI zndraw atoms.xyz. For a full list of arguments use zndraw --help.

ZnDraw is designed to work with your Python scripts. To interface you can inherit from zndraw.examples.UpdateScene or follow this base class:

import abc
from pydantic import BaseModel

class UpdateScene(BaseModel, abc.ABC):
    @abc.abstractmethod
    def run(self, atom_ids: list[int], atoms: ase.Atoms, **kwargs) -> list[ase.Atoms]:
        pass

The run method expects as inputs

  • atom_ids: list[int], the ids of the currently selected atoms
  • atoms: ase.Atoms, the configuration as ase.Atoms file where atom_ids where selected.
  • kwargs: dict could be additional information from the scene

and as an output:

  • list[ase.Atoms], a list of ase Atoms objects to display.

You can define the parameters using pydantic.Field which will be displayed in the UI.

class MyUpdateCls(UpdateScene):
    steps: int = Field(100, le=1000, ge=1)
    x: float = Field(0.5, le=5, ge=0)
    symbol: str = Field("same")

To add your method click on the + on the right side of the window. Your should be able to add your method from the working directory via module.MyUpdateCls as long as it can be imported via from module import MyUpdateCls.

ZnDraw UI

ZnDraw UI2

ZnDraw UI3

Development

ZnDraw is developed using https://python-poetry.org/. Furthermore, the javascript packages have to be installed using https://www.npmjs.com/.

cd zndraw/static/
npm install

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

zndraw-0.2.0a8.tar.gz (22.4 MB view details)

Uploaded Source

Built Distribution

zndraw-0.2.0a8-py3-none-any.whl (27.4 MB view details)

Uploaded Python 3

File details

Details for the file zndraw-0.2.0a8.tar.gz.

File metadata

  • Download URL: zndraw-0.2.0a8.tar.gz
  • Upload date:
  • Size: 22.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.9.12 Windows/10

File hashes

Hashes for zndraw-0.2.0a8.tar.gz
Algorithm Hash digest
SHA256 51b9d4d023de1e8d155ef5a7d7f9c1ea2e704651a13d6eba264e9cb94ad65424
MD5 7d40384a2c1a819840c436d8f8aeba9e
BLAKE2b-256 287365d5a44d2b9898953b4ff194a3b22e0991a5af36216d947b7d20a50cefb3

See more details on using hashes here.

File details

Details for the file zndraw-0.2.0a8-py3-none-any.whl.

File metadata

  • Download URL: zndraw-0.2.0a8-py3-none-any.whl
  • Upload date:
  • Size: 27.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.9.12 Windows/10

File hashes

Hashes for zndraw-0.2.0a8-py3-none-any.whl
Algorithm Hash digest
SHA256 33e265e288cee61041dce1483c691b5141a122315cc050c80d0ac5beab23bd08
MD5 613d35952d4546eced98db295794f2fe
BLAKE2b-256 56a077a664b8654fbd11f34decd41cbaa31413aaae68729c592d22e06cd2e6e6

See more details on using hashes here.

Supported by

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