A Python library to interface with the OpenSCAD app.
Project description
A Python library to interface with and run the OpenSCAD interpreter.
ColorScheme Enum Class
- ColorScheme defines the following enums:
cornfield
metallic
sunset
starnight
beforedawn
nature
deepocean
solarized
tomorrow
tomorrow_night
monotone
RenderMode Enum Class
- RenderMode defines the following enums::
test_only
render
preview
thrown_together
wireframe
OpenScadRunner Class
The OpenScadRunner class provides the following methods:
- __init__() The initializer method, which has the following arguments:
scriptfile = The name of the script file to process.
outfile = The name of the file to output to.
imgsize = The size of the imagefile to output to, if outputting to a PNG or GIF. Default: (640,480)
antialias = The antialiasing scaling factor. If greater than 1.0, images are generated at a larger size, then scaled down to the target size with anti-aliasing. Default: 1.0 (no anti-aliasing)
animate = If given an integer number of frames, creates that many frames of animation, and collates them into an animated GIF or APNG. Default: None
animate_duration = Number of milliseconds per frame for an animated GIF or APNG. Default: 250
render_mode = The rendering mode to use when generating an image. See RenderMode Enum. Default: RenderMode.preview
show_axes = If True, show axes in the rendering. Default: True
show_scales = If True, show the scales along the axes. Default: True
show_edges = If True, shows the edges of all the faces. Default: False
show_crosshairs = If True, shows the crosshairs for the center of the camera translation. Default: False
camera = Gives the camera position as either [translate_x,y,z,rot_x,y,z,dist] or [eye_x,y,z,center_x,y,z]
orthographic = If True, render orthographic. If False, render with perspective. Default: False
auto_center = If True, and script does not set $vpt, $vpr, or $vpd, then centers the shape in the rendered image. Default: False
view_all = If True, and script does not set $vpd, then the field of view is scaled to show the complete rendered shape. Default: False
color_scheme = The color scheme to render an image with. See ColorScheme Enum. Default: ColorScheme.cornfield,
csg_limit = If given, the maximum number of CSG elements to render.
deps_file = If given, the file to write Makefile dependancies out to.
make_file = If given, the Makefile script to run when missing a dependency.
set_vars = An optional dictionary of script variables and values to set.
customizer_file = If given, specifies the file containing Customizer Parameters.
customizer_params = An optional dictionary of customizer parameter names and values to set.
hard_warnings = Stop at first WARNING, as if it were an ERROR. Default: False
quiet = Suppresses non-error, non-warning messages. Default: False
good() Returns True if the run() method was called, and processing completed successfully.
__bool__() Returns True if the run() method was called, and processing completed, whether or not it was successful.
- run() Run the OpenSCAD app with the current settings. This sets some instance variables:
.complete = A boolean value indicating if the processing has completed yet.
.success = A boolean value indicating if the processing completed sucessfully.
.script = The script that was evaluated, as a list of line strings.
.cmdline = The commandline arguments used to launch the OpenSCAD app.
.return_code = The return code from OpenSCAD. Generally 0 if successful.
.echos = A list of ECHO: output line strings.
.warnings = A list of WARNING: output line strings.
.errors = A list of ERROR: or TRACE: output line strings.
Creating an STL file:
from openscad_runner import OpenScadRunner osr = OpenScadRunner("example.scad", "example.stl") osr.run() for line in osr.echos: print(line) for line in osr.warnings: print(line) for line in osr.errors: print(line) if osr.good(): print("Successfully created example.stl")
Creating a Preview PNG:
from openscad_runner import RenderMode, OpenScadRunner osr = OpenScadRunner("example.scad", "example.png", render_mode=RenderMode.preview, imgsize=(800,600), antialias=2.0) osr.run() for line in osr.echos: print(line) for line in osr.warnings: print(line) for line in osr.errors: print(line) if osr.good(): print("Successfully created example.png")
Creating a Fully Rendered PNG:
from openscad_runner import RenderMode, OpenScadRunner osr = OpenScadRunner("example.scad", "example.png", render_mode=RenderMode.render, imgsize=(800,600), antialias=2.0) osr.run() for line in osr.echos: print(line) for line in osr.warnings: print(line) for line in osr.errors: print(line) if osr.good(): print("Successfully created example.png")
Rendering an animated GIF:
from openscad_runner import OpenScadRunner osr = OpenScadRunner("example.scad", "example.gif", imgsize=(320,200), animate=36, animate_duration=200) osr.run() for line in osr.echos: print(line) for line in osr.warnings: print(line) for line in osr.errors: print(line) if osr.good(): print("Successfully created example.gif")
Rendering an animated PNG:
from openscad_runner import OpenScadRunner osr = OpenScadRunner("example.scad", "example.png", imgsize=(320,200), animate=36, animate_duration=200) osr.run() for line in osr.echos: print(line) for line in osr.warnings: print(line) for line in osr.errors: print(line) if osr.good(): print("Successfully created example.png")
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 Distributions
Built Distribution
File details
Details for the file openscad_runner-1.1.2-py2.py3-none-any.whl
.
File metadata
- Download URL: openscad_runner-1.1.2-py2.py3-none-any.whl
- Upload date:
- Size: 7.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6f114eaf748759aa21523cf11dd27afbad7820a7d345e32eddae99937e5682e1 |
|
MD5 | d46027a9cb53e890f4f3f3b2a02b4559 |
|
BLAKE2b-256 | ae91a7bfbf9f8fc36de7b1a9f0f2be205104b60604ca49e7572dbed6903e95d3 |