Skip to main content

VPython for Jupyter Notebook

Project description

VPython

This package enables one to run VPython in a browser, using the GlowScript VPython API, documented in the Help at https://www.glowscript.org. If the code is in a cell in a Jupyter notebook, the 3D scene appears in the Jupyter notebook. If the code is launched outside a notebook (e.g. from the command line), a browser window will open displaying the scene.

VPython makes it unusually easy to create navigable real-time 3D animations. The one-line program "sphere()" produces a 3D sphere with appropriate lighting and with the camera positioned so that the scene fills the view. It also activates mouse interactions to zoom and rotate the camera view. This implementation of VPython was begun by John Coady in May 2014. Ruth Chabay, Matt Craig, and Bruce Sherwood are assisting in its further development.

Installation

For more detailed instructions on how to install vpython, see https://vpython.org, where you will also find a link to the VPython forum, which is a good place to report issues and to request assistance.

Briefly:

  • If you use the anaconda python distribution, install like this: conda install -c vpython vpython
  • If you use any other python distribution, install this way: pip install vpython

Sample program

Here is a simple example:

from vpython import *
sphere()

This will create a canvas containing a 3D sphere, with mouse and touch controls available to zoom and rotate the camera:

Right button drag or Ctrl-drag to rotate "camera" to view scene.
To zoom, drag with middle button or Alt/Option depressed, or use scroll wheel.
     On a two-button mouse, middle is left + right.
Shift-drag to pan left/right and up/down.
Touch screen: pinch/extend to zoom, swipe or two-finger rotate.

Currently, to re-run a VPython program in a Jupyter notebook you need to click the circular arrow icon to "restart the kernel" and then click the red-highlighted button, then click in the first cell, then click the run icon. Alternatively, if you insert "scene = canvas()" at the start of your program, you can rerun the program without restarting the kernel.

Run example VPython programs: Binder

vpython build status (for the vpython developers)

Build Status Build status

Working with the source code

Here is an overview of the software architecture:

https://vpython.org/contents/VPythonArchitecture.pdf

The vpython module uses the GlowScript library (vpython/vpython_libraries/glow.min.js). The GlowScript repository is here:

https://github.com/vpython/glowscript

In the GlowScript repository's docs folder, GlowScriptOverview.txt provides more details on the GlowScript architecture.

Here is information on how to run GlowScript VPython locally, which makes possible testing changes to the GlowScript library:

https://www.glowscript.org/docs/GlowScriptDocs/local.html

If you execute build_original_no_overload.py, and change the statement "if True:" to "if False", you will generate into the ForInstalledPython folder an un-minified glow.min.js which can be copied to site-packages/vpython/vpython_libraries and tested by running your test in (say) idle or spyder. (Running in Jupyter notebook or Jupyterlab requires additional fiddling.)

Note that in site-packages/vpython/vpython_libraries it is glowcomm.html that is used by launchers such as idle or spyder; glowcomm.js is used with Jupyter notebook (and a modified version is used in Jupyterlab).

Placing console.log(....) statements in the GlowScript code or in the JavaScript section of glowcomm.html can be useful in debugging. You may also need to put debugging statements into site-packages/vpython/vpython.py.

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

vpython-7.5.1a2.tar.gz (3.6 MB view details)

Uploaded Source

Built Distributions

vpython-7.5.1a2-py3.7-linux-x86_64.egg (3.8 MB view details)

Uploaded Egg

vpython-7.5.1a2-cp37-cp37m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.7mWindows x86-64

vpython-7.5.1a2-cp37-cp37m-win32.whl (3.6 MB view details)

Uploaded CPython 3.7mWindows x86

vpython-7.5.1a2-cp37-cp37m-macosx_10_7_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.7mmacOS 10.7+ x86-64

vpython-7.5.1a2-cp36-cp36m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.6mWindows x86-64

vpython-7.5.1a2-cp36-cp36m-win32.whl (3.6 MB view details)

Uploaded CPython 3.6mWindows x86

vpython-7.5.1a2-cp36-cp36m-macosx_10_7_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.6mmacOS 10.7+ x86-64

vpython-7.5.1a2-cp35-cp35m-macosx_10_6_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.5mmacOS 10.6+ x86-64

File details

Details for the file vpython-7.5.1a2.tar.gz.

File metadata

  • Download URL: vpython-7.5.1a2.tar.gz
  • Upload date:
  • Size: 3.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for vpython-7.5.1a2.tar.gz
Algorithm Hash digest
SHA256 c8d2920f1ee1ccc7a7c4ac096d46f5efab36e01416cea780e24f3c1d2c90454b
MD5 ac5ce64ad450405bc54cb529f28f336c
BLAKE2b-256 b46c534d5940130bdaa611a0fa36a62bb9373e9f6806b67a245201e40f1e5f6f

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-py3.7-linux-x86_64.egg.

File metadata

  • Download URL: vpython-7.5.1a2-py3.7-linux-x86_64.egg
  • Upload date:
  • Size: 3.8 MB
  • Tags: Egg
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for vpython-7.5.1a2-py3.7-linux-x86_64.egg
Algorithm Hash digest
SHA256 f11518938907bb9eae267e30eb1e04c64aa0f7e1309d3aa94154a4d302be2618
MD5 72f39ecfb7b42dba8fd6801b697696f8
BLAKE2b-256 e3d1c43af8cb4a571bba52c2266a55c065feab45ddf836392ae49630717681aa

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.5.1a2-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.1

File hashes

Hashes for vpython-7.5.1a2-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 a973caae6b20b6c587f7701dd221c188d279874acfaaba1b50e2a461e61f4164
MD5 136864ebec8ef843307f022ae7026c17
BLAKE2b-256 fb825a03e442e523f46d52887bb1f31fffc18c58740941e4a4d68d2f9b30bdd1

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-cp37-cp37m-win32.whl.

File metadata

  • Download URL: vpython-7.5.1a2-cp37-cp37m-win32.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, Windows x86
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.1

File hashes

Hashes for vpython-7.5.1a2-cp37-cp37m-win32.whl
Algorithm Hash digest
SHA256 4105fca803b30753a5a3ae8bb186796dd0a0dca57cc445db9e2167e6e3e01159
MD5 1d34c12185db1af259d1d0f1cc82eb66
BLAKE2b-256 1f1d11de210243cb25f345499875e5dc6b0b62c35abc143d682ea037e2d4459f

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-cp37-cp37m-macosx_10_7_x86_64.whl.

File metadata

  • Download URL: vpython-7.5.1a2-cp37-cp37m-macosx_10_7_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, macOS 10.7+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for vpython-7.5.1a2-cp37-cp37m-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 9fcd20d340dcef77814257148f8c1ab6cd87982190b08a76907a820ca2ce33ac
MD5 f7ab742d36b4c9153a3c16cc7f2ca663
BLAKE2b-256 d3b0363a2ac93c442a1f274719f14cb96264764d34244c9fa9fa182895ac8309

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-cp36-cp36m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.5.1a2-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/39.2.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.6.5

File hashes

Hashes for vpython-7.5.1a2-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 e5eae5ec885b4027230c3dbffc55892a8aa459a5914c6ca5546672132b3c91d6
MD5 70451b7f5545ca3d8ce386c474f2e754
BLAKE2b-256 b27b23e0ca5b8be197905d3e27dbf798b735ac8338cbd7d7c408d19518b24b74

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-cp36-cp36m-win32.whl.

File metadata

  • Download URL: vpython-7.5.1a2-cp36-cp36m-win32.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, Windows x86
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/39.2.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.6.5

File hashes

Hashes for vpython-7.5.1a2-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 627d080f6729eab8db080bba106aebd0b495a5370af28331c13ee11f1795106d
MD5 1ba93fc6a699f4daed7d144b0a74b455
BLAKE2b-256 99fcf9f26e5e8e6ca8ea2ebcdca9dcf0f58eecfd72a99413ed732f60823e8e61

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-cp36-cp36m-macosx_10_7_x86_64.whl.

File metadata

  • Download URL: vpython-7.5.1a2-cp36-cp36m-macosx_10_7_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, macOS 10.7+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for vpython-7.5.1a2-cp36-cp36m-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 6a7eb97f91189fe4ee5140d4c6e7d479145a8a81b29e5d9bcb82f3b7b6806dfc
MD5 1d78495a47763b01535e0a2b78cff795
BLAKE2b-256 b3a08128b31a1246046eb82fbf78a23ae933a90263a565561845c4c776badc9c

See more details on using hashes here.

File details

Details for the file vpython-7.5.1a2-cp35-cp35m-macosx_10_6_x86_64.whl.

File metadata

  • Download URL: vpython-7.5.1a2-cp35-cp35m-macosx_10_6_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.5m, macOS 10.6+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.0 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for vpython-7.5.1a2-cp35-cp35m-macosx_10_6_x86_64.whl
Algorithm Hash digest
SHA256 bdd5e98d44351ae890143f6ae9854136e1881a0f3c25404fd1b4d9406b0ca70c
MD5 ba46cde78c57d79dc83c98bffa2fcd5b
BLAKE2b-256 70d5b0292b74ae1f42ec853f6577b7a9201dab2c06dd75a376484c029b2ae2dd

See more details on using hashes here.

Supported by

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