-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathscadRotateExtrude.m
57 lines (56 loc) · 1.99 KB
/
scadRotateExtrude.m
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
function object = scadRotateExtrude(angles, object, varargin)
%scadRotateExtrude - Rotational extrusion spins a 2D shape around the
%Z-axis to form a solid which has rotational symmetry.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Parameters:
% object - scadStructure
% convexity : If the extrusion fails for a non-trival 2D shape, try setting
% the convexity parameter (the default is not 10, but 10 is a "good" value
% to try). See explanation further down.
%
% angle [Note: Requires version 2019.05] : Defaults to 360. Specifies the
% number of degrees to sweep, starting at the positive X axis. The
% direction of the sweep follows the Right Hand Rule, hence a negative
% angle sweeps clockwise.
%
% $fa : minimum angle (in degrees) of each fragment.
%
% $fs : minimum circumferential length of each fragment.
%
% $fn : fixed number of fragments in 360 degrees. Values of 3 or more
% override $fa and $fs
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
param = '';
color = [];
position = [];
while ~isempty(varargin)
switch lower(varargin{1})
case 'convexity'
param =[', convexity = ' num2str(varargin{2})];
case 'fa'
param =[', $fa = ' num2str(varargin{2})];
case 'fs'
param =[', $fs = ' num2str(varargin{2})];
case 'fn'
param =[', $fn = ' num2str(varargin{2})];
case 'position'
position = varargin{2};
case 'color'
color = varargin{2};
otherwise
error(['scadRotateExtrude: unknown paramiter - ' varargin{1}])
end
varargin(1:2) = [];
end
rotate_extrude = ['rotate_extrude( angle = ' num2str(angles) '' param '){' newline];
rotate_extrude = [rotate_extrude char(object.structure) newline];
rotate_extrude = ([rotate_extrude '}' ]);
object.structure = rotate_extrude;
if ~isempty(position)
object = scadTranslate(position, object);
end
if ~isempty(color)
object = scadColor(color, object);
end
end