概述
1. 3D图像自动旋转
camorbit函数
官方文档中给出了详细说明:
示例:
%旋转功能核心语句:
axis vis3d %3维坐标系
surf(peaks)
for i = 1:36
camorbit(10,0,'data',[0 0 1]) %%[0 0 1]表示按z轴旋转。36*10=360表示旋转一周
drawnow %%即时显示旋转的结果
end
效果展示:
2. 颜色渐变
MATLAB中提供了多种颜色渐变的色域:包括Opencv中常见的hsv等
使用示例:autumn色域
clc,clear,close all
c = autumn(256);
surf(peaks);
colormap(c);
shading interp;
效果:
更多示例可参考官方文档,百度搜索:MATLAB autumn,jet等.
3. 保留指定颜色线条
核心语句:surf(peaks,'EdgeColor','yellow')
,即在surf或其他绘图函数中添加‘EdgeColor’指定内容.
有效名称包括: ‘red’、‘green’、‘blue’、‘cyan’、‘magenta’、‘yellow’、‘black’、‘white’
和 ‘none’。有 效的十六进制颜色代码由 ‘#’ 后跟三个或六个十六进制数字组成。
示例:保留黄色线条
axis vis3d %3维坐标系
surf(peaks,'EdgeColor','yellow')
for i = 1:36
camorbit(10,0,'data',[0 0 1]) %%[0 0 1]表示按z轴旋转。36*10=360表示旋转一周
drawnow %%即时显示旋转的结果
end
效果:
4. 自动生成GIF至桌面
axis vis3d %3维坐标系
surf(peaks,'EdgeColor','yellow')
for i=1:36
camorbit(10,0,'data',[0,0,1])%[0 0 1]表示按z轴旋转。36*10=360表示旋转一周
M=getframe(gcf);
nn=frame2im(M);
[nn,cm]=rgb2ind(nn,256);
if i==1
imwrite(nn,cm,'out.gif','gif','LoopCount',inf,'DelayTime',0.1);%说明loopcount只是在i==1的时候才有用
else
imwrite(nn,cm,'out.gif','gif','WriteMode','append','DelayTime',0.1)%当i>=2的时候loopcount不起作用
end
end
为了表示色域渐进程度,可以加上一句colorbar.
示例:让MATLAB绘制的lantern旋转起来~
clc,clear,close all
t = 0:pi/10:2*pi;
figure
[X,Y,Z] = cylinder(cos(t),1);
surf(X,Y,Z)
axis square
theta=0:pi/12:2*pi;
phy=0:pi/24:pi;
[theta,phy]=meshgrid(theta,phy);
r=2;
x=r.*sin(phy).*cos(theta);
y=r.*sin(phy).*sin(theta);
z=r.*cos(phy);
figure,surf(x,y,z)
[x,y,z]=ellipsoid(0,0,5,2,2,2) ;
figure,surf(x,y,z,'EdgeColor','yellow')
colormap(autumn(1));
hold on
axis([-2,2,-2,2,0,9])
[x, y, z]=cylinder(0.6) ;
CO1(:,:,1) = ones(size(z)); % red
CO1(:,:,2) = ones(size(z)); % green
CO1(:,:,3) = zeros(size(z));
hold on,surf(x, y, 4*z,CO1)
[x, y, z]=cylinder(0.5) ;
CO2(:,:,1) = ones(size(z)); % red
CO2(:,:,2) = ones(size(z)); % green
CO2(:,:,3) = zeros(size(z));
hold on,surf(x, y, 6.7+0.6*z,CO2)
[X,Y,Z] = cylinder(0.05);
CO3(:,:,1) = ones(size(z)); % red
CO3(:,:,2) = zeros(size(z)); % green
CO3(:,:,3) = zeros(size(z));
surf(X,Y,1*Z+7,CO3,'EdgeColor',[1,0,0]);
hold off
% colorbar
% shading interp; %是否渲染
% 实现并保存为gif至桌面
% shading interp;%颜色渲染
axis vis3d;
for i=1:36
camorbit(10,0,'data',[0,0,1])%[0 0 1]表示按z轴旋转。36*10=360表示旋转一周
M=getframe(gcf);
nn=frame2im(M);
[nn,cm]=rgb2ind(nn,256);
if i==1
imwrite(nn,cm,'out.gif','gif','LoopCount',inf,'DelayTime',0.1);%说明loopcount只是在i==1的时候才有用
else
imwrite(nn,cm,'out.gif','gif','WriteMode','append','DelayTime',0.1)%当i>=2的时候loopcount不起作用
end
end
旋转调速:
for i=1:180
camorbit(2,0,'data',[0,0,1])%[0 0 1]表示按z轴旋转。180*2=360表示旋转一周,步长为2度
总结:
MATLAB figure配色问题实际上还存在着很多很多的技巧,需要多使用多积累,很难一篇文章就总结完所有用法,所以最好的办法就是查阅MATLAB官方文档,里面会给出很多简单易懂的例程,如果担心英文看不懂,就把页面设置为中文;
另外,很多顶刊文献中也不乏很多精彩的配色方案,不妨去从中借鉴汲取灵感。
最后
以上就是勤劳裙子为你收集整理的MATLAB轻松实现三维图像自动旋转、颜色渐变、自动保存为GIF的全部内容,希望文章能够帮你解决MATLAB轻松实现三维图像自动旋转、颜色渐变、自动保存为GIF所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复