mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-04 03:09:45 +00:00
Added img2scad.py script.
This commit is contained in:
parent
b6a1b83f51
commit
31e91f69a2
3 changed files with 89 additions and 0 deletions
79
scripts/img2scad.py
Executable file
79
scripts/img2scad.py
Executable file
|
@ -0,0 +1,79 @@
|
||||||
|
#!env python3
|
||||||
|
|
||||||
|
import re
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import os.path
|
||||||
|
import argparse
|
||||||
|
|
||||||
|
from PIL import Image
|
||||||
|
|
||||||
|
|
||||||
|
def img2scad(filename, varname, resize, outf):
|
||||||
|
indent = " " * 4
|
||||||
|
im = Image.open(filename).convert('L')
|
||||||
|
if resize:
|
||||||
|
print("Resizing to {}x{}".format(resize[0],resize[1]))
|
||||||
|
im = im.resize(resize)
|
||||||
|
pix = im.load()
|
||||||
|
width, height = im.size
|
||||||
|
print("// Image {} ({}x{})".format(filename, width, height), file=outf)
|
||||||
|
print("{} = [".format(varname), file=outf)
|
||||||
|
line = indent
|
||||||
|
for x in range(width):
|
||||||
|
line += "[ "
|
||||||
|
for y in range(height):
|
||||||
|
line += "{:d}, ".format(pix[x,y])
|
||||||
|
if len(line) > 60:
|
||||||
|
print(line, file=outf)
|
||||||
|
line = indent * 2
|
||||||
|
line += " ],"
|
||||||
|
if line != indent:
|
||||||
|
print(line, file=outf)
|
||||||
|
line = indent
|
||||||
|
print("];", file=outf)
|
||||||
|
print("", file=outf)
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
parser = argparse.ArgumentParser(prog='img2scad')
|
||||||
|
parser.add_argument('-o', '--outfile',
|
||||||
|
help='Output .scad file.')
|
||||||
|
parser.add_argument('-v', '--varname',
|
||||||
|
help='Variable to use in .scad file.')
|
||||||
|
parser.add_argument('-r', '--resize',
|
||||||
|
help='Resample image to WIDTHxHEIGHT.')
|
||||||
|
parser.add_argument('infile', help='Input image file.')
|
||||||
|
opts = parser.parse_args()
|
||||||
|
|
||||||
|
non_alnum = re.compile(r'[^a-zA-Z0-9_]')
|
||||||
|
if not opts.varname:
|
||||||
|
if opts.outfile:
|
||||||
|
opts.varname = os.path.splitext(os.path.basename(opts.outfile))[0]
|
||||||
|
opts.varname = non_alnum.sub("", opts.varname)
|
||||||
|
else:
|
||||||
|
opts.varname = "image_data"
|
||||||
|
size_pat = re.compile(r'^([0-9][0-9]*)x([0-9][0-9]*)$')
|
||||||
|
if opts.resize:
|
||||||
|
m = size_pat.match(opts.resize)
|
||||||
|
if not m:
|
||||||
|
print("Expected WIDTHxHEIGHT resize format.", file=sys.stderr)
|
||||||
|
sys.exit(-1)
|
||||||
|
opts.resize = (int(m.group(1)), int(m.group(2)))
|
||||||
|
|
||||||
|
if not opts.varname or non_alnum.search(opts.varname):
|
||||||
|
print("Bad variable name: {}".format(opts.varname), file=sys.stderr)
|
||||||
|
sys.exit(-1)
|
||||||
|
|
||||||
|
if opts.outfile:
|
||||||
|
with open(opts.outfile, "w") as outf:
|
||||||
|
img2scad(opts.infile, opts.varname, opts.resize, outf)
|
||||||
|
else:
|
||||||
|
img2scad(opts.infile, opts.varname, opts.resize, sys.stdout)
|
||||||
|
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
|
|
|
@ -2775,6 +2775,8 @@ module interior_fillet(l=1.0, r, ang=90, overlap=0.01, d, anchor=CENTER, spin=0,
|
||||||
// Description:
|
// Description:
|
||||||
// Given a regular rectangular 2D grid of scalar values, or a function literal, generates a 3D
|
// Given a regular rectangular 2D grid of scalar values, or a function literal, generates a 3D
|
||||||
// surface where the height at any given point is the scalar value for that position.
|
// surface where the height at any given point is the scalar value for that position.
|
||||||
|
// One script to convert a grayscale image to a heightfield array in a .scad file can be found at:
|
||||||
|
// https://raw.githubusercontent.com/revarbat/BOSL2/master/scripts/img2scad.py
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// data = This is either the 2D rectangular array of heights, or a function literal that takes X and Y arguments.
|
// data = This is either the 2D rectangular array of heights, or a function literal that takes X and Y arguments.
|
||||||
// size = The [X,Y] size of the surface to create. If given as a scalar, use it for both X and Y sizes. Default: `[100,100]`
|
// size = The [X,Y] size of the surface to create. If given as a scalar, use it for both X and Y sizes. Default: `[100,100]`
|
||||||
|
@ -2902,6 +2904,8 @@ function heightfield(data, size=[100,100], bottom=-20, maxz=100, xrange=[-1:0.04
|
||||||
// Given a regular rectangular 2D grid of scalar values, or a function literal of signature (x,y), generates
|
// Given a regular rectangular 2D grid of scalar values, or a function literal of signature (x,y), generates
|
||||||
// a cylindrical 3D surface where the height at any given point above the radius `r=`, is the scalar value
|
// a cylindrical 3D surface where the height at any given point above the radius `r=`, is the scalar value
|
||||||
// for that position.
|
// for that position.
|
||||||
|
// One script to convert a grayscale image to a heightfield array in a .scad file can be found at:
|
||||||
|
// https://raw.githubusercontent.com/revarbat/BOSL2/master/scripts/img2scad.py
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// data = This is either the 2D rectangular array of heights, or a function literal of signature `(x, y)`.
|
// data = This is either the 2D rectangular array of heights, or a function literal of signature `(x, y)`.
|
||||||
// l = The length of the cylinder to wrap around.
|
// l = The length of the cylinder to wrap around.
|
||||||
|
|
|
@ -2125,6 +2125,8 @@ function _get_texture(tex,n,m) =
|
||||||
// Topics: Sweep, Extrusion, Textures, Knurling
|
// Topics: Sweep, Extrusion, Textures, Knurling
|
||||||
// Description:
|
// Description:
|
||||||
// Given a single polygon path, creates a linear extrusion of that polygon vertically, with a given texture tiled evenly over the side surfaces.
|
// Given a single polygon path, creates a linear extrusion of that polygon vertically, with a given texture tiled evenly over the side surfaces.
|
||||||
|
// One script to convert a grayscale image to a texture heightfield array in a .scad file can be found at:
|
||||||
|
// https://raw.githubusercontent.com/revarbat/BOSL2/master/scripts/img2scad.py
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// path = The path to sweep/extrude.
|
// path = The path to sweep/extrude.
|
||||||
// texture = A texture name string, or a rectangular array of scalar height values (0.0 to 1.0) that define the texture to apply to vertical surfaces.
|
// texture = A texture name string, or a rectangular array of scalar height values (0.0 to 1.0) that define the texture to apply to vertical surfaces.
|
||||||
|
@ -2320,6 +2322,8 @@ module textured_linear_sweep(
|
||||||
// Description:
|
// Description:
|
||||||
// Given a single 2D path, fully in the X+ half-plane, revolves that path around the Z axis (after rotating its Y+ to Z+).
|
// Given a single 2D path, fully in the X+ half-plane, revolves that path around the Z axis (after rotating its Y+ to Z+).
|
||||||
// This creates a solid from that surface of revolution, capped top and bottom, with the sides covered in a given tiled texture.
|
// This creates a solid from that surface of revolution, capped top and bottom, with the sides covered in a given tiled texture.
|
||||||
|
// One script to convert a grayscale image to a texture heightfield array in a .scad file can be found at:
|
||||||
|
// https://raw.githubusercontent.com/revarbat/BOSL2/master/scripts/img2scad.py
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// path = The path to sweep/extrude.
|
// path = The path to sweep/extrude.
|
||||||
// texture = A texture name string, or a rectangular array of scalar height values (0.0 to 1.0) that define the texture to apply to vertical surfaces. See {{textured_linear_sweep()}} for what textures are supported.
|
// texture = A texture name string, or a rectangular array of scalar height values (0.0 to 1.0) that define the texture to apply to vertical surfaces. See {{textured_linear_sweep()}} for what textures are supported.
|
||||||
|
@ -2454,6 +2458,8 @@ module textured_revolution(
|
||||||
// Topics: Sweep, Extrusion, Textures, Knurling
|
// Topics: Sweep, Extrusion, Textures, Knurling
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a cylinder or cone with optional chamfers or roundings, covered in a textured surface.
|
// Creates a cylinder or cone with optional chamfers or roundings, covered in a textured surface.
|
||||||
|
// One script to convert a grayscale image to a texture heightfield array in a .scad file can be found at:
|
||||||
|
// https://raw.githubusercontent.com/revarbat/BOSL2/master/scripts/img2scad.py
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// h | l = The height of the cylinder.
|
// h | l = The height of the cylinder.
|
||||||
// r = The radius of the cylinder.
|
// r = The radius of the cylinder.
|
||||||
|
|
Loading…
Reference in a new issue