4.4 Additional Modifications
heatmap_args and anno_args are used to modify the heatmaps: changing the row and column labels, labeling specific features, changing the colors of labels, changing font size, adding different types of annotations, splitting rows or columns into groups, etc. The ComplexHeatmap Complete Reference goes more into detail about each of these modifications, but we will cover a few of them in this section in the context of MSnSets.
We will use a random subset of the MSnSet to explore some of these modifications. This is just so we can see the row and column names more easily.
set.seed(99)
# subset to 25 features and 40 samples
m_sub <- m[sample(1:nrow(m), size = 25), 
           sample(1:ncol(m), size = 40)]4.4.1 Change row or column labels
By default, the row and column labels are the row and column names of the matrix passed to Heatmap. In the case of the default expression heatmap, the row names are the featureNames of the MSnSet and the column names are the sampleNames. We can instead use any column in fData and any column in pData to label the rows and columns, respectively. Duplicate labels are also allowed, which is especially useful if there are multiple peptides that map to the same protein, multiple proteins that map to the same gene, etc.
# Default row labels - peptides
complex_heatmap(m_sub, show_row_names = TRUE, 
                heatmap_title = "Default Row Labels")
Suppose, for example, we want to label the rows by the Protein column of fData(m_sub). We can do this by modifying the row_labels argument of ComplexHeatmap::Heatmap with the heatmap_args list. We will also reduce the font size of the labels so that they do not overlap.
# Label rows with proteins and change font size
complex_heatmap(m_sub, show_row_names = TRUE, 
                heatmap_title = "New Row Labels",
                heatmap_args = list(row_labels = fData(m_sub)[["Protein"]],
                                    # Change font size of row labels
                                    row_names_gp = gpar(fontsize = 10)))
4.4.2 Change label colors
# One color
complex_heatmap(m_sub, show_row_names = TRUE, 
                heatmap_args = list(row_names_gp = gpar(col = "orange")))
# Multiple colors
# If peptide begins with "A", color it red
# If peptide begins with "G", color it blue
# Otherwise, color it black
row_colors <- featureNames(m_sub) %>% 
  {case_when(grepl("^A", .) ~ "red",
             grepl("^G", .) ~ "blue",
             TRUE ~ "black")}
complex_heatmap(m_sub, show_row_names = TRUE,
                heatmap_args = list(
                  row_names_gp = gpar(col = row_colors)))
4.4.3 Label specific features
We can use mark annotation to label specific features or samples. For this example, we will label all non-human proteins. We need the indices of the proteins to label and the column in fData used to select these labels.
# Indices of non-human proteins
idx <- which(!grepl("HUMAN", fData(m)[["Protein"]]))
# Row annotation object. The name can be anything, so we just use anno
ra <- rowAnnotation(anno = anno_mark(at = idx, 
                                     labels = fData(m)[["Protein"]][idx]))
# Heatmap with labels for select features
complex_heatmap(m, heatmap_args = list(row_labels = fData(m)[["Protein"]],
                                       right_annotation = ra)) 
4.4.4 Change heatmap body color
complex_heatmap(m, heatmap_args = list(col = circlize::colorRamp2(
  breaks = c(min(exprs(m), na.rm = TRUE), 0, 
             max(exprs(m), na.rm = TRUE)), 
  colors = c("purple", "white", "orange")
))
)
If changing the colors of the heatmap body, color_range will not work. Instead, the breaks and colors need to be modified so that the minimum value and the lower limit are the same color and the maximum value and the upper limit are the same color.
complex_heatmap(m, heatmap_args = list(col = circlize::colorRamp2(
  breaks = c(min(exprs(m), na.rm = TRUE), 
             -1.5, 0, 1.5, # add color limits
             max(exprs(m), na.rm = TRUE)), 
  colors = c("purple", "purple", "white", "orange", "orange")
))
)