Bezier曲线的绘制 matlab

式中:

称为基函数。

因为n表示次数,点数为n+1,显然i表示第i个控制点。

显然在Matlab中可以同矩阵的形式来计算C(u)。

关键代码为:

clc
clear
% 假设控制点P取值为:
P = [4,7;
     13,12;
     19,4;
     25,12;
     30,3]; 
% 因此:
n = 4;
i = (0:n);
Bcof_temp = factorial(n)./(factorial(i).*factorial(n-i));
u_temp = linspace(0,1,100)';
[Bcof,u] = meshgrid(Bcof_temp,u_temp);
B = Bcof.*u.^(i).*(1-u).^(n-i);  % 计算bezier的B系数矩阵
xb = B*P(:,1); % 计算bezier的x坐标
yb = B*P(:,2); % 计算bezier的y坐标

% 画图
figure(1)
plot(P(:,1),P(:,2),'--o')
hold on
plot(xb,yb)
axis equal

结果如图所示:

三维也类似:

clc
clear
% 假设控制点P取值为:
P = [4,7,1;
     13,12,3;
     19,4,5;
     25,12,6;
     30,3,7]; 
% 因此:
n = 4;
i = (0:n);
Bcof_temp = factorial(n)./(factorial(i).*factorial(n-i));
u_temp = linspace(0,1,100)';
[Bcof,u] = meshgrid(Bcof_temp,u_temp);
B = Bcof.*u.^(i).*(1-u).^(n-i);  % 计算bezier的B系数矩阵
xb = B*P(:,1); % 计算bezier的x坐标
yb = B*P(:,2); % 计算bezier的y坐标
zb = B*P(:,3); % 计算bezier的y坐标

% 画图
figure(1)
plot3(P(:,1),P(:,2),P(:,3),'--o')
hold on
plot3(xb,yb,zb)
axis equal

函数就留给大家自己去封装了。

function C_u = mBezierf(P)
    % 因此:
    [row,col] = size(P);
    n = row - 1;
    m = col;
    i = (0:n);
    Bcof_temp = factorial(n)./(factorial(i).*factorial(n-i));
    u_temp = linspace(0,1,100)';
    [Bcof,u] = meshgrid(Bcof_temp,u_temp);
    B = Bcof.*u.^(i).*(1-u).^(n-i);  % 计算bezier的B系数矩阵
    xb = B*P(:,1); % 计算bezier的x坐标
    yb = B*P(:,2); % 计算bezier的y坐标
    C_u = [xb,yb];
    if(m==3)
        zb = B*P(:,3); % 计算bezier的y坐标
        C_u = [C_u,zb];
    end
end

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值