投影变化matlab,求助大佬【如用MATLAB实现满足投影关系的三视图】

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

请问,在只能利用三维投影变换矩阵的前提下,如何用MATLAB画出满足投影关系的三视图?

目前小弟还只是画出了三视图,立体图,但是侧视图和俯视图不满足投影关系,求大佬指教。

下面是MATLAB代码及运行结果:

close all

>> clear all

>> v=[0 0 0;

70 0 0;

70 40 0;

0 40 0;

70 0 10;

70 40 10;

30 40 10;

30 10 10;

55 10 10;

55 0 10;

19.376 30 27;

19.376 40 27;

0 40 27;

0 30 27;

55 0 42;

55 10 42;

10 10 42;

10 30 42;

0 30 42;

0 0 42];%构建顶点表

f=[1 2 3 4 1 2;

1 2 5 10 15 20;

2 3 6 5 2 3;

3 4 13 12 7 6;

4 13 14 19 20 1;

5 6 7 8 9 10;

10 9 16 15 10 9;

9 8 17 16 9 8;

8 7 12 11 18 17;

11 12 13 14 11 12;

11 14 19 18 11 14;

15 16 17 18 19 20];%构建面表

>> subplot(2,2,4);

>> patch('faces',f,'vertices',v,'FaceColor','b');

view(120,30)

axis equal

axis off

>> title('立体图')

>> %1.画三视图

T1=[1 0 0 0;

0 0 0 0;

0 0 1 0;

0 0 0 1];%构建变换矩阵;

x=[1;1;1;1;1;1;1;1;1;1;1;1;1;1;1;1;1;1;1;1];

c=[v,x];

v1=c*T1;

v1(:,4)=[];

>> subplot(2,2,1);

>> patch('faces',f,'vertices',v1,'FaceColor','b');

view(30,30)

axis tight

patch('faces',f,'vertices',v1,'FaceColor','b');

view(180,30)

axis tight

axis off

>> title('正视图')

>>

T3=[0 0 0 0;

-1 0 0 0;

0 0 1 0;

0 0 0 1];

v3=c*T3;

v3(:,4)=[];

>> subplot(2,2,2);

>> patch('faces',f,'vertices',v3,'FaceColor','b');

view(30,30)

axis tight

>> patch('faces',f,'vertices',v3,'FaceColor','b');

view(180,30)

axis tight

axis off

%侧视图

>> title('侧视图')

>> T2=[1 0 0 0;

0 0 -1 0;

0 0 0 0;

0 0 0 1];%构建变化矩阵

v2=c*T2;

v2(:,4)=[];

>> subplot(2,2,3)

>> patch('faces',f,'vertices',v2,'FaceColor','b');

view(30,30)

axis tight%俯视图

>> patch('faces',f,'vertices',v2,'FaceColor','b');

view(0,150)

axis tight

axis off

%俯视图

>> title('俯视图')

运行结果如下:

8da9237b1c7f06edc8d0cf0a035af498.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值