Skip to main content

Molecular visualization driven by a local WebSocket-hosted page

Project description

molvis

Python package for MolVis molecular visualization. A single mv.Molvis() class works from both plain Python scripts (opens a browser tab) and Jupyter notebooks (mounts the page bundle inline in the cell, isolated by Shadow DOM — no iframe). Both hosts drive the same page bundle over a local WebSocket.

Installation

pip install molvis

Quick start

Plain Python script

import molvis as mv
import molpy as mp

viewer = mv.Molvis()          # starts a local WebSocket + opens a browser tab
viewer.draw_frame(frame)
viewer.snapshot()             # PNG screenshot

Jupyter notebook

import molvis as mv
scene = mv.Molvis(name="protein")
scene.draw_frame(frame)
scene                          # mounts the viewer inline in the cell

Both modes use the same command API (draw_frame, set_style, snapshot, selection, palettes, …) and the same event channel.

Bidirectional events

Frontend interactions (selection, mode, frame navigation, …) flow back into Python. Selection is a shared state — canvas clicks are observable from Python without polling.

viewer = mv.Molvis()

# Subscribe to a frontend event (callback runs on the WS thread)
handle = viewer.on("selection_changed",
                   lambda ev: print("sel:", ev["atom_ids"]))
handle.remove()                            # unsubscribe

# Block until a specific event fires
ev = viewer.wait_for("selection_changed", timeout=30)

# Cached state, updated live by incoming events — no RPC roundtrip
print(viewer.selection)     # Selection(atom_ids=(...), bond_ids=(...))
print(viewer.current_mode)  # "view" | "select" | "edit" | ...
print(viewer.current_frame)

# Force a fresh snapshot from the canvas
viewer.refresh_state()

Transport

mv.Molvis() auto-creates a WebSocketTransport. Outside Jupyter it opens the page in the default browser; inside Jupyter the cell mounts the bundle inline. For advanced setups (CDN-hosted page, explicit port, CORS …) pass your own transport:

viewer = mv.Molvis(transport=mv.WebSocketTransport(
    page_base_url="https://molvis.dev/app",   # host page on a CDN
    port=8765,                                # fixed port instead of OS-assigned
    open_browser=False,
))

Token authentication is automatic: the page URL carries a one-time token that the frontend must echo back in its hello handshake.

Scene registry

a = mv.Molvis()                # default scene
b = mv.Molvis()
assert a is b                  # same instance

protein = mv.Molvis(name="protein")
ligand  = mv.Molvis(name="ligand")
mv.Molvis.list_scenes()
mv.Molvis.get_scene("protein")
protein.close()                # stop transport + drop from registry

Drawing API

scene = mv.Molvis()
scene.draw_frame(frame, style="ball_and_stick")
scene.draw_box(box)
scene.draw_atoms(atoms, style="spacefill")
scene.new_frame()
scene.set_style(style="spacefill", atom_radius=0.5)
scene.set_theme("modern")        # "classic" | "modern"
scene.clear()

Query commands (block until the frontend responds)

png_bytes = scene.snapshot()
frame     = scene.export_frame()
selected  = scene.get_selected()    # mp.Frame with just the selection
scene.select_atom_by_id([0, 2])

Palette utilities

import molvis as mv
from IPython.display import Image

scene = mv.Molvis()
scene                              # render the cell mount first

scene.list_palettes()
scene.palette_entries("cpk")[:5]
scene.palette_colors("glasbey-vivid")[:8]

png = scene.palette_preview("glasbey-vivid")
Image(data=png)

Error handling

Fire-and-forget commands (e.g. draw_frame) log errors asynchronously. Query commands raise MolvisRPCError:

try:
    scene.export_frame()
except mv.MolvisRPCError as exc:
    print(exc.code, exc)

Development

npm run build:page                   # build page bundle + copy to dist/
cd python && python -m pytest tests/ -v

Packaging

npm run build:page
cd python && python -m build --wheel

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

molcrafts_molvis-0.0.5.tar.gz (6.3 MB view details)

Uploaded Source

Built Distribution

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

molcrafts_molvis-0.0.5-py3-none-any.whl (6.3 MB view details)

Uploaded Python 3

File details

Details for the file molcrafts_molvis-0.0.5.tar.gz.

File metadata

  • Download URL: molcrafts_molvis-0.0.5.tar.gz
  • Upload date:
  • Size: 6.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for molcrafts_molvis-0.0.5.tar.gz
Algorithm Hash digest
SHA256 c776af7b5f5105a1764fe52aa8ab83e7941093dd4ee83c9d68603374f8fd07f3
MD5 6d53da88c64309bbd20e797f71378023
BLAKE2b-256 052a4fd08aad31c31164a0ea2c07db7c25e7f8cc88a10cd3ba50855bf56cf9ea

See more details on using hashes here.

Provenance

The following attestation bundles were made for molcrafts_molvis-0.0.5.tar.gz:

Publisher: release-python.yml on MolCrafts/molvis

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file molcrafts_molvis-0.0.5-py3-none-any.whl.

File metadata

File hashes

Hashes for molcrafts_molvis-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 cde345c7d45b0accc4299fc5e9f4634469b3073217e06d6154487c24fe93b7da
MD5 8a60165110f342fb9795214563dfa601
BLAKE2b-256 4da2a9280e80d2b2d492afa975001efad113c629bea003245ce2ed0d22bd42d9

See more details on using hashes here.

Provenance

The following attestation bundles were made for molcrafts_molvis-0.0.5-py3-none-any.whl:

Publisher: release-python.yml on MolCrafts/molvis

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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