1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-17 22:28:16 +01:00
dotSCAD/examples/perlin_noise_cylinder.scad

59 lines
1.7 KiB
OpenSCAD
Raw Normal View History

2020-03-08 16:01:27 +08:00
use <util/rand.scad>;
2020-04-03 08:13:00 +08:00
use <noise/nz_perlin2s.scad>;
use <surface/sf_solidify.scad>;
2020-03-24 17:12:21 +08:00
use <ptf/ptf_bend.scad>;
2020-03-10 11:46:34 +08:00
use <util/slice.scad>;
2020-03-08 16:01:27 +08:00
radius = 40;
height = 100;
thickness_scale = 1;
step = 4;
module perlin_noise_cylinder(radius, height, thickness_scale, step) {
2020-03-10 11:46:34 +08:00
size = [2 * PI * radius, height];
2020-03-09 08:40:05 +08:00
surface_inside = [
2020-03-08 16:01:27 +08:00
for(y = [0:step:size[1]])
[
each [for(x = [0:step:size[0] - 1]) [x / 10, y / 10, 0]],
[size[0] / 10, y / 10, 0]
]
2020-03-08 16:01:27 +08:00
];
2020-03-10 11:46:34 +08:00
2020-03-08 16:01:27 +08:00
seed = rand(0, 256);
2020-03-10 11:49:31 +08:00
leng_row = len(surface_inside[0]);
2020-03-08 16:01:27 +08:00
surface_outside = [
2020-03-09 08:40:05 +08:00
for(ri = [0:len(surface_inside) - 1])
2020-03-10 11:46:34 +08:00
let(
row = surface_inside[ri],
row_for_noise = [
each slice(row, 0, leng_row - 1),
[0, row[leng_row - 1][1], 0]
],
2020-03-29 11:14:26 +08:00
ns = nz_perlin2s(row_for_noise, seed)
2020-03-10 11:46:34 +08:00
)
2020-03-10 11:49:31 +08:00
[
for(ci = [0:len(ns) - 1])
[surface_inside[ri][ci][0], surface_inside[ri][ci][1], thickness_scale * (ns[ci] + 1)]
]
2020-03-08 16:01:27 +08:00
];
size_div_10 = size / 10;
radius_div_10 = radius / 10;
t_surface_outside = [
for(row = surface_outside)
[for(p = row)
2020-03-10 11:46:34 +08:00
ptf_bend(size_div_10, p, radius_div_10, 360)
2020-03-08 16:01:27 +08:00
]
];
2020-03-10 11:49:31 +08:00
t_surface_inside = [
2020-03-09 08:40:05 +08:00
for(row = surface_inside)
2020-03-08 16:01:27 +08:00
[for(p = row)
2020-03-10 11:46:34 +08:00
ptf_bend(size_div_10, p, radius_div_10, 360)
2020-03-08 16:01:27 +08:00
]
];
2020-03-10 11:49:31 +08:00
sf_solidify(t_surface_outside, t_surface_inside);
2020-03-08 16:01:27 +08:00
}
perlin_noise_cylinder(radius, height, thickness_scale, step);