无法实现的最低示例:
[X,Y,Z] = peaks;
figure;
pcolor(X,Y,Z);
shading flat;
hold all;
axes;
contour(X,Y,Z);
colormap gray; % this should only apply to the contour plot axes...
axis off; % ... but it doesn't
这显示了灰度色彩图中的等高线图和伪色图。但是,我想要实现的只是将轮廓变成灰色。
这只是一个简约的例子,实际上轮廓图是具有不同范围的不同数据,因此也需要两个独立的caxis
设置。
答案 0 :(得分:5)
您可以通过连接两个色彩映射来确定问题,并确保函数的值能够访问色彩映射的正确部分:
cm = [jet(64);gray(64)];
figure,
pcolor(X,Y,Z)
shading flat
hold on
%# Z in the contour starts after the maximum
%# of Z in pcolor
contour(X,Y,Z-min(Z(:))+max(Z(:))+2,'LineWidth',2)
%# apply the colormap
colormap(cm)
要获得更方便的解决方案,您可能还需要查看this file exchange pick of the week