目前试图整理一些代码,我想将曲线添加到一个数组中,然后简单地使用该数组来绘制而不是单独调用,这也将帮助我在以后填写。我有我的数组,但由于某种原因,我得到了一个奇怪的输出,这与我期望的不同,随机线从中间切开。
试图改变数组填充曲线的顺序无效
% Outer Spade
% Lower Curve Control Points
p1 = [0, 0, 0.5, 0.6;
-1, 0, 0.1, 0];
p2 = refy(p1);
% Higher Curve Control Points
p3 = [0.6, 0.75, 0.75 , 0;
0, 0.15, 0.4 , 1];
p4 = refy(p3);
outer = [];
t = linspace(0,1,100);
C1 = cubic_bezier(p1,t);
C2 = cubic_bezier(p2,t);
C3 = cubic_bezier(p3,t);
C4 = cubic_bezier(p4,t);
outer =[outer C1,C3,C2,C4];
plot(outer(1,:),outer(2,:),'-b')
axis([-2 2 -1 3])
function C = cubic_bezier(P,t)
M = [-1,3,-3,1;
3,-6,3,0;
-3,3,0,0;
1,0,0,0];
T = [t.^3;t.^2;t;t.^0];
C = P * M * T;
end
function r = refy(m)
r = [-1,0;0,1] * m;
end
如果我用以下代码替换外部并绘制外部
hold on
plot(C1(1,:),C1(2,:))
plot(C2(1,:),C2(2,:))
plot(C3(1,:),C3(2,:))
plot(C4(1,:),C4(2,:))
然后我得到了我的预期,希望这会有所帮助。先感谢您