How do I label the grouped horizontal bars in MATLAB?

1 次查看(过去 30 天)
I know someone uses the text function but I am ont able to solve my problem. This is my code:
label = categorical({'A';'B';'C';'D';'E'});
risks = [-1,2;-1.5,1;-5,2.5;-5,NaN;-3.2,NaN;];
temp = abs(risks);
lim_g = max(max(temp));
h = barh(label,risks,'grouped');
set(h(1),'FaceColor',[0.753 0 0])
set(h(2),'FaceColor','g')
xlim([-lim_g-1 lim_g+1])
a=[cellstr(num2str(get(gca,'xtick')'))];
pct = char(ones(size(a,1),1)*'%');
new_yticks = [char(a),pct];
set(gca,'xticklabel',new_yticks)
I would like to put the value on the end of each bar. Can Someone help me? Many thanks!!!!

采纳的回答

Adriano
Adriano 2017-6-28
编辑:Adriano 2017-6-28
I solved adding this code:
yb = [datas{2,2}, datas{3,2}, datas{5,2}, datas{1,2}, datas{4,2}];
for j = 1:size(yb,2)
text(yb(1,j)-0.1,j, cellstr(num2str(yb(1,j),'%0.2f%%')), 'HorizontalAlignment','right','VerticalAlignment','top','FontSize',15);
end
yb = [datas{2,3}, datas{3,3}, NaN, datas{1,3}, NaN];
for j = 1:size(yb,2)
text(yb(1,j)+0.1,j+0.27, cellstr(num2str(yb(1,j),'%0.2f%%')), 'HorizontalAlignment','left','VerticalAlignment','top','FontSize',15);
end

更多回答(1 个)

dpb
dpb 2017-6-28
I don't have HG2 so can't test and the solution to find the bar positions that worked with HG1 does not work with HG2. Contribtor Efstathios Zavvos added to an Answer the following based on a hidden property '[X/Y]Offset' that returns the position of the bar relative to the axis tick for each bar group.
His sample for a normal bar is below; hopefully will get you going...
Y=random('unif',0,100,[4 3]);
h=bar(Y);
yb = cat(1, h.YData);
xb = bsxfun(@plus, h(1).XData, [h.XOffset]');
for i = 1:size(yb,2)
for j = length(yb(:,1))
text(xb(j, i),yb(j, i), cellstr(num2str(Y(i, j))), 'rotation', 90);
end
end
NB: Add your request for the enhancement to be able to do this with builtin properties -- it's near criminal TMW didn't do this 20 yr ago; it's a routine expectation for any decent graphing tool.

类别

Help CenterFile Exchange 中查找有关 Graphics Object Programming 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by