Matlab读取ascii格式的stl文件,并在显示其三维模型

clc
clear all;
% 打开STL文件
fid = fopen('1.stl','rt');
% 初始化数据矩阵
vertices = [];
faces = [];
normal = [];
% 读取STL文件头部
hdr = fgetl(fid);
disp(['STL文件头部: ' hdr]);

% 循环读取三角形面
while (~feof(fid))
    tmp = fgetl(fid);
    if strfind(tmp,'normal') ~= 0
        normal = [normal;sscanf(tmp,'%*s %*s %f %f %f')'];
    elseif strfind(tmp,'vertex') ~= 0
        vertices = [vertices; sscanf(tmp,'%*s %f %f %f')'];
    elseif strncmpi(tmp,'endsolid',8) == 1
        disp('over')
        break;
    end
end
% 关闭文件
fclose(fid);
% 输出结果
disp(['顶点数: ' num2str(size(vertices,1))]);

% 创建figure和axes
fig = figure;
ax = axes('Parent',fig);
for i = 1:size(vertices,1)/3
    v1 = vertices((i -1)*3+1,:);
    v2 = vertices((i -1)*3+2,:);
    v3 = vertices((i -1)*3+3,:);
    n = normal(i,:);
    patch([v1(1) v2(1) v3(1)], [v1(2) v2(2) v3(2)], [v1(3) v2(3) v3(3)], 'y', 'FaceAlpha', 0.5, 'EdgeColor', 'black', 'FaceNormals', n, 'Parent', ax);
end
% 设置坐标轴和视角
axis equal;
axis tight;
view(3);

  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值