打印

三维网图的高级处理

[复制链接]
150|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
cooldog123pp|  楼主 | 2023-5-27 16:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
三维网图的高级处理

1. 消隐处理


例.比较网图消隐前后的图形


z=peaks(50);


subplot(2,1,1);


mesh(z);


title('消隐前的网图')


hidden off


subplot(2,1,2)


mesh(z);


title('消隐后的网图')


hidden on


colormap([0 0 1])












2.       裁剪处理


利用不定数NaN的特点,可以对网图进行裁剪处理


例.图形裁剪处理


P=peaks(30);


subplot(2,1,1);


mesh(P);


title('裁剪前的网图')


subplot(2,1,2);


P(20:23,9:15)=NaN*ones(4,7);        %剪孔


meshz(P)                         %垂帘网线图


title('裁剪后的网图')


colormap([0 0 1])                   %蓝色网线


  



注意裁剪时矩阵的对应关系,即大小一定要相同.





3.       三维旋转体的绘制


为了一些专业用户可以更方便地绘制出三维旋转体,matlab专门提供了2个函数:柱面函数cylinder和球面函数sphere


(1)   柱面图


柱面图绘制由函数cylinder实现.


[X,Y,Z]=cylinder(R,N)  此函数以母线向量R生成单位柱面.母线向量R是在单位高度里等分刻度上定义的半径向量.N为旋转圆周上的分格线的条数.可以用surf(X,Y,Z)来表示此柱面.


[X,Y,Z]=cylinder(R)或[X,Y,Z]=cylinder此形式为默认N=20且R=[1 1]





例.柱面函数演示举例


x=0:pi/20:pi*3;


r=5+cos(x);


[a,b,c]=cylinder(r,30);


mesh(a,b,c)






例.旋转柱面图.

r=abs(exp(-0.25*t).*sin(t));


t=0:pi/12:3*pi;


r=abs(exp(-0.25*t).*sin(t));


[X,Y,Z]=cylinder(r,30);


mesh(X,Y,Z)


colormap([1 0 0])
































(2).球面图


球面图绘制由函数sphere来实现


[X,Y,Z]=sphere(N)             此函数生成3个(N+1)*(N+1)的矩阵,利用函数        surf(X,Y,Z) 可产生单位球面.


[X,Y,Z]=sphere         此形式使用了默认值N=20.


Sphere(N)             只是绘制了球面图而不返回任何值.


例.绘制地球表面的气温分布示意图.


[a,b,c]=sphere(40);


t=abs(c);


surf(a,b,c,t);


axis('equal')   %此两句控制坐标轴的大小相同.


axis('square')


colormap('hot')

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1592

主题

5838

帖子

29

粉丝