博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
matlab图形着色
阅读量:5847 次
发布时间:2019-06-19

本文共 2372 字,大约阅读时间需要 7 分钟。

hot3.png

matlab图形着色

1.matlab中的颜色查找表函数:

(1)autumn:从红色向橘黄色、黄色平稳过渡;

(2)bone:为含有较高的蓝色组分的gray颜色查找表;

(3)colorcube:包含RGB颜色空间中尽可能多的规则间隔的颜色,它试图提供更多的灰色、纯红、纯绿和纯蓝;

(4)cool:由青色和洋红阴影组成的颜色。在青色和洋红间平滑过渡;

(5)copper:在黑色和亮铜色间平滑过渡;

(6)flag:由红、白、蓝、黑组成。每次索引值增加时,该颜色查找表会完全改变颜色;

(7)gray:线性灰阶颜色查找表;

(8)hot:在黑、红、橘红、黄、白间平滑过渡;

(9)hsv:颜色从红色开始,然后为黄、绿、青、蓝、洋红,最后是红色。特别适合显示周期性函数;

(10)jet:在蓝、青、黄、橘红、红色间过渡;

(11)lines:生成颜色由坐标系对象的colororder属性和灰色阴影确定;

(12)pink:包含品红色的柔和阴影。可以对灰度照片进行棕褐色化;

(13)prism:重复红、橘红、黄、绿、蓝、紫色;

 (14)spring:由洋红和黄色阴影组成;

(15)summer:由绿色和黄色阴影组成;

(16)white:白色;

(17)winter:由蓝色和绿色阴影组成。

2.用colormapeditor可以画出抢眼的图。

[x,y]=meshgrid(-2:0.1:2);

z=x.*exp(-x.^2-y.^2);
surf(x,y,z,gradient(z));
shading interp;
colormapeditor;

图1

图2

图3

3.利用函数del2计算矩阵的拉普拉斯算子,实现表面曲率向颜色映射

具有相似曲率的区域用相同的颜色进行描绘。

p=peaks(40);

c=del2(p);
surf(p,c);
colormap hsv;
%对比
figure
surf(p);
colormap hsv;

图4

4.真彩色表面

创建一个随机着色表面图

z=peaks(25);

c(:,:,1)=rand(25);
c(:,:,2)=rand(25);
c(:,:,3)=rand(25);
surf(z,c);
figure;
surf(z,c,'FaceColor','interp','FaceLighting','phong');
camlight right;

图5
图6

5.纹理映射

纹理映射是通过变换颜色数据将二维图像映射到三维表面上。

clear;

clc;
clf;
load earth;
[x,y,z]=sphere(30);
h=surface(x,y,z);
set(h,'CData',X,'FaceColor','texturemap');%texturemap纹理贴图
colormap(map);
axis equal;
set(gca,'CameraViewAngleMode','manual');
view(3);

图7

6.多边形模型的着色

控制面片着色的属性:

CData:用x,y,z数据指定每个小面或每个顶点的颜色;

CDataMapping:指定是否将颜色数据进行比例化或直接用作颜色映射的索引;

FaceVertexCData:用小面和顶点数据指定每个小面或顶点的颜色;

EdgeColor:指定边的显示,包括隐藏、单色、顶点颜色确定的刻面颜色或顶点颜色确定的插值颜色;

FaceColor:指定小面的显示,包括隐藏、单色、顶点颜色确定的刻面颜色或顶点颜色确定的插值颜色;

MarkerEdgeColor:指定闭合图形的边缘色;

MarkerFaceColor:指定闭合图形的填充色。

%画白色正方体

vert=[1 1 1;1 2 1;2 2 1;2 1 1;1 1 2;1 2 2;2 2 2;2 1 2];

fac=[1 2 3 4;2 6 7 3;4 3 7 8;1 5 8 4;1 2 6 5;5 6 7 8];
patch('Faces',fac,'Vertices',vert,'FaceColor','w');
view(3);
axis square;
axis equal;
%刻面着色

patch('Faces',fac,'Vertices',vert,'FaceVertexCData',hsv(6),'FaceColor','flat');

%插值着色

patch('Faces',fac,'Vertices',vert,'FaceVertexCData',hsv(6),'FaceColor','interp');

 

图7

7.片面边着色

v=[0 0 0;1 0 0;1 1 0;0 1 0];

f=[1 2 3 4];
fvc=[1 1 0;1 0 0;0 1 0;1 0 1];
patch('Vertices',v,'Faces',f,'FaceVertexCData',fvc,'FaceColor','flat','EdgeColor','flat','Marker','o','MarkerFaceColor','flat');
set(gcf,'color','w');
view(-16,76);
axis off;
text(0,0,0.5,'1');
text(1,0,0.5,'2');
text(1,1,0.5,'3');
text(0,1,0.5,'4');

图8

修改:f=[4 3 2 1];

 

 

图9

   f的次序改变不仅仅改变边的颜色,还改变了面的颜色,面的颜色是指定的第一个顶点的颜色。

转载于:https://my.oschina.net/u/1469992/blog/266232

你可能感兴趣的文章
hive报错(2)udf无法找到第三方的类
查看>>
HashCode
查看>>
盘点5款Ubuntu监控工具解决CPU暴增问题
查看>>
java 测试IP
查看>>
C#实现ActiveX控件开发与部署
查看>>
用CSS做导航菜单的4个理由
查看>>
mysql优化综合(转)
查看>>
BZOJ5072:[Lydsy1710月赛]小A的树(树形DP)
查看>>
NOIP2015 运输计划 二分答案+Tarjan LCA+树上差分
查看>>
构建之法读后感
查看>>
hdu题型分类
查看>>
Python爬虫(一)
查看>>
霍夫变换的基本理解(第八天)
查看>>
个人博客作业三:英语学习APP的案例分析
查看>>
基本信息项目目标文档
查看>>
再谈PHP设计模式
查看>>
DNN Web Platform 官方汉化版本 5.5
查看>>
微软职位内部推荐-Senior Dev Lead
查看>>
如何在子线程中操作窗体上的控件
查看>>
【DOM编程艺术】form对象
查看>>