2013-04-09 8 views
39

Chciałbym utworzyć legendę paska kolorów dla mapy termicznej, tak aby etykiety znajdowały się pośrodku każdego dyskretnego koloru. Proszę zapoznać się z przykładową ryk (borrowed from here)matplotlib: colorbars i jego etykiety tekstowe

import matplotlib.pyplot as plt 
import numpy as np 
from matplotlib.colors import ListedColormap 

#discrete color scheme 
cMap = ListedColormap(['white', 'green', 'blue','red']) 

#data 
np.random.seed(42) 
data = np.random.rand(4, 4) 
fig, ax = plt.subplots() 
heatmap = ax.pcolor(data, cmap=cMap) 

#legend 
cbar = plt.colorbar(heatmap) 
cbar.ax.set_yticklabels(['0','1','2','>3']) 
cbar.set_label('# of contacts', rotation=270) 

# put the major ticks at the middle of each cell 
ax.set_xticks(np.arange(data.shape[1]) + 0.5, minor=False) 
ax.set_yticks(np.arange(data.shape[0]) + 0.5, minor=False) 
ax.invert_yaxis() 

#lebels 
column_labels = list('ABCD') 
row_labels = list('WXYZ') 
ax.set_xticklabels(column_labels, minor=False) 
ax.set_yticklabels(row_labels, minor=False) 

plt.show() 

który generuje następujące działki: pmesh plot

Idealnie chciałbym wygenerować pasek legendy, która ma cztery kolory i dla każdego koloru, etykietę w jego środek: 0,1,2,3,> 4

Odpowiedz

51
import matplotlib.pyplot as plt 
import numpy as np 
from matplotlib.colors import ListedColormap 

#discrete color scheme 
cMap = ListedColormap(['white', 'green', 'blue','red']) 

#data 
np.random.seed(42) 
data = np.random.rand(4, 4) 
fig, ax = plt.subplots() 
heatmap = ax.pcolor(data, cmap=cMap) 

#legend 
cbar = plt.colorbar(heatmap) 

cbar.ax.get_yaxis().set_ticks([]) 
for j, lab in enumerate(['$0$','$1$','$2$','$>3$']): 
    cbar.ax.text(.5, (2 * j + 1)/8.0, lab, ha='center', va='center') 
cbar.ax.get_yaxis().labelpad = 15 
cbar.ax.set_ylabel('# of contacts', rotation=270) 


# put the major ticks at the middle of each cell 
ax.set_xticks(np.arange(data.shape[1]) + 0.5, minor=False) 
ax.set_yticks(np.arange(data.shape[0]) + 0.5, minor=False) 
ax.invert_yaxis() 

#lebels 
column_labels = list('ABCD') 
row_labels = list('WXYZ') 
ax.set_xticklabels(column_labels, minor=False) 
ax.set_yticklabels(row_labels, minor=False) 

plt.show() 

Byłeś bardzo blisko. Gdy masz już odniesienie do osi paska koloru, możesz zrobić to, co chcesz, włączając w to umieszczanie etykiet tekstowych na środku. Możesz chcieć grać z formatowaniem, aby było bardziej widoczne.

demo

+0

dziękuję! bardzo doceniane. – dimka

+0

Próbowałem tego i prawie działa. Z jakiegoś powodu nazwa etykiety osi "Liczba kontaktów" zniknęła z powodu linii "cbar.ax.axis (" off ")". jakikolwiek sposób na utrzymanie etykiety? – dimka

+0

@dimka zobacz zmiany, po prostu trzeba wyłączyć zaznaczenie nieco inaczej. Nadal musisz poprawić czcionki, aby wyglądać lepiej, ale pozostawiam to jako ćwiczenie dla czytelnika;) – tacaswell