Set Colorbar TickLabels and TickMarks

481 次查看(过去 30 天)
Hi all,
I am having trouble setting my colorbar ticklabels as I wish.
Specifically I have 8 points, and have created a colormap such that these 8 points get values from the darkest to the lightest color in the colormap. Similarly, I would like my colorbar's labels to follow the same pattern. Below is the code that I have written:
cmapdef = colormap(winter) ; %Define Colormap
cmap = cmapdef(1:8:end, :) ; %Find Values of colors corresponding to each point plotted
cbh = colorbar('YTickLabel', num2cell(1:8)) ;
However, the resulting colorbar has labels going as follows: 1 2 3 4 5 6 7 8 1 2 3. Instead I would expect the whole span of the color bar to be covered by 1 2 3 4 5 6 7 8.
What am I doing wrong?
Thanks in advance for your responses,
KMT.
  2 个评论
José-Luis
José-Luis 2017-8-10
Do you mean you want colored text in your colorbar?
Konstantinos Tsitsilonis
编辑:Konstantinos Tsitsilonis 2017-8-10
Hi Jose,
I would not like to have colored text. It is just that tick labels appear on the color bar on the following order: 1 2 3 4 5 6 7 8 1 2 3, instead of the normal 1 2 3 4 5 6 7 8.
Thanks anyway!

请先登录,再进行评论。

采纳的回答

Konstantinos Tsitsilonis
编辑:Konstantinos Tsitsilonis 2017-8-10
Actually I managed to find a fix.
All the ticks range from 0 to 1, and they should have a tick label associated to them.
Therefore the following code solves the problem:
cmap = colormap(winter(8)) ; %Create Colormap
cbh = colorbar ; %Create Colorbar
cbh.Ticks = linspace(0, 1, 8) ; %Create 8 ticks from zero to 1
cbh.TickLabels = num2cell(1:8) ; %Replace the labels of these 8 ticks with the numbers 1 to 8

更多回答(1 个)

José-Luis
José-Luis 2017-8-10
plot(rand(10,1))
cH = colorbar;
cH.TickLabelInterpreter = 'tex';
idx = 955;
for ii = 1:numel(cH.TickLabels)
cH.TickLabels{ii} = [sprintf('\\color[rgb]{%f,%f,%f} ', rand(1,3)), char(idx)];
idx = idx + 1;
end
You'd need to replace the random color with the actual color you want.

类别

Help CenterFile Exchange 中查找有关 Colormaps 的更多信息

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by