forked from JustinSDK/dotSCAD
-
Notifications
You must be signed in to change notification settings - Fork 0
/
distorted_vase.scad
86 lines (74 loc) · 1.79 KB
/
distorted_vase.scad
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
use <shape_circle.scad>
use <bezier_curve.scad>
use <sweep.scad>
use <path_scaling_sections.scad>
use <bijection_offset.scad>
use <util/rand.scad>
use <noise/nz_perlin2s.scad>
use <noise/nz_perlin3s.scad>
beginning_radius = 15;
thickness = 2;
fn = 180;
amplitude = 10;
curve_step = 0.01;
smoothness = 15;
// Perlin noise 2D or 3D
perlin = 2; // [2, 3]
bottom = "YES"; // ["YES", "NO"]
epsilon = 0.000001;
distorted_vase(beginning_radius, thickness, fn, amplitude, curve_step, smoothness, perlin, epsilon);
module distorted_vase(beginning_radius, thickness, fn, amplitude,curve_step, smoothness, perlin, epsilon) {
seed = rand() * 1000;
section = shape_circle(radius = beginning_radius, $fn = fn);
pt = [beginning_radius, 0, 0];
edge_path = bezier_curve(curve_step, [
pt,
pt + [15, 0, 20],
pt + [45, 0, 50],
pt + [20, 0, 70],
pt + [5, 0, 80],
pt + [-5, 0, 100],
pt + [10, 0, 140]
]);
sections = path_scaling_sections(section, edge_path);
noise = perlin == 2 ? function(pts, seed) nz_perlin2s(pts, seed) :
function(pts, seed) nz_perlin3s(pts, seed);
noisy = [
for(section = sections)
let(nz = noise(section / smoothness, seed))
[
for(i = [0:len(nz) - 1])
let(
p = section[i],
p2d = [p[0], p[1]],
noisyP = p2d + p2d / norm(p2d) * nz[i] * amplitude
)
[noisyP[0], noisyP[1], p[2]]
]
];
offset_noisy = [
for(section = noisy)
let(
offset_s = bijection_offset(section, thickness, epsilon)
)
[
for(i = [0:len(offset_s) - 1])
[offset_s[i][0], offset_s[i][1], section[i][2]]
]
];
all = [
for(i = [0:len(offset_noisy) - 1])
concat(
offset_noisy[i],
noisy[i]
)
];
sweep(all, triangles = "HOLLOW");
if(bottom == "YES") {
sweep([
for(section = noisy)
if(section[0][2] < thickness)
section
]);
}
}