grouped stacked bar with specific colours

22 Ansichten (letzte 30 Tage)
Fabrizio Gattuso
Fabrizio Gattuso am 5 Dez. 2017
Bearbeitet: Adam Danz am 10 Jun. 2021
I am using the function in the link below to plot grouped stacked bars.
I have slightly modified it to add the legend to the plot. I get the following histogram:
I would like to change the colours of the bars with specific colours (for example: dark blue, blue and light blue for the first stacked bars, dark green, green and light green for the second stacked bars, and dark orange, orange and light orange for the third stacked bars). I have tried with adding the following lines inside the loop, but it did not work:
if i == 1
col = ['[0.8 0 0.8]','[0 0.6 0]','[0.9 0.5 0 ]'];
elseif i == 2
col = ['[1 0 1]','[0 0.8 0 ]','[1 0.6 0]'];
else
col = ['[1 0.2 1]','[0 1 0]','[1 0.9 0]'];
end
set(h(i,:),'Color',col);
  2 Kommentare
Benedikt Prusas
Benedikt Prusas am 23 Sep. 2019
Did you made any progress? I have the exact same Question.
Yuhan Wang
Yuhan Wang am 10 Jun. 2021
How can I assign "names" to colors

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Adam Danz
Adam Danz am 23 Sep. 2019
Bearbeitet: Adam Danz am 25 Sep. 2019
Within the plotBarStackGroups() function, bar handles are stored in 'h'. Add that as an output to the function so you have access to the bar handles (this output should have been included in the first place, it currently has no outputs).
function h = plotBarStackGroups(stackData, groupLabels)
'h' is an n-by-m array of bar handles with n bars per group and m segments per bar.
To change the color of each segment within each bar,
% Create a stacked, grouped bar chart using the function
stackData = randi(100,3,5,7);
groupLabels = {'a' 'b' 'c'};
h = plotBarStackGroups(stackData, groupLabels)
% Chance the colors of each bar segment
colors = jet(size(h,2)); %or define your own color order; 1 for each m segments
colors = repelem(colors,size(h,1),1);
colors = mat2cell(colors,ones(size(colors,1),1),3);
set(h,{'FaceColor'},colors)

Kategorien

Mehr zu Data Distribution Plots finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by