web-dev-qa-db-fra.com

Comment changer la couleur de fond d'une parcelle faite avec ggplot2

Par défaut, ggplot2 produit des tracés avec un fond gris. Comment changer la couleur de l'arrière-plan de l'intrigue?

Par exemple, une parcelle produite par le code suivant:

library(ggplot2)
myplot<-ggplot(data=data.frame(a=c(1,2,3), b=c(2,3,4)), aes(x=a, y=b)) + geom_line()
myplot
85
Jack Edmonds

Pour changer la couleur d'arrière-plan du panneau, utilisez le code suivant:

myplot + theme(panel.background = element_rect(fill = 'green', colour = 'red'))

Pour changer la couleur du tracé (mais pas la couleur du panneau), vous pouvez faire:

myplot + theme(plot.background = element_rect(fill = 'green', colour = 'red'))

Voir ici pour plus de détails sur les thèmes Fiche de référence rapide pour les légendes, les axes et les thèmes .

107
Jack Edmonds

Pour éviter les obsolètes opts et theme_rect, Utilisez:

myplot + theme(panel.background = element_rect(fill='green', colour='red'))

Pour définir votre propre thème personnalisé, basé sur theme_gray mais avec certaines de vos modifications et quelques ajouts supplémentaires, notamment le contrôle de la couleur/de la taille du quadrillage (plus d’options disponibles pour jouer avec sur ggplot2.org ):

theme_jack <- function (base_size = 12, base_family = "") {
    theme_gray(base_size = base_size, base_family = base_family) %+replace% 
        theme(
            axis.text = element_text(colour = "white"),
            axis.title.x = element_text(colour = "pink", size=rel(3)),
            axis.title.y = element_text(colour = "blue", angle=45),
            panel.background = element_rect(fill="green"),
            panel.grid.minor.y = element_line(size=3),
            panel.grid.major = element_line(colour = "orange"),
            plot.background = element_rect(fill="red")
    )   
}

Pour que votre thème personnalisé soit le thème par défaut lors de l'appel futur de ggplot, sans masquage:

theme_set(theme_jack())

Si vous souhaitez modifier un élément du thème actuellement défini:

theme_update(plot.background = element_rect(fill="pink"), axis.title.x = element_text(colour = "red"))

Pour stocker le thème par défaut actuel en tant qu'objet:

theme_pink <- theme_get()

Notez que theme_pink Est une liste alors que theme_jack Était une fonction. Donc, pour retourner le thème à theme_jack, utilisez theme_set(theme_jack()) alors que pour revenir à theme_pink, utilisez theme_set(theme_pink).

Vous pouvez remplacer theme_gray Par theme_bw Dans la définition de theme_jack Si vous préférez. Pour que votre thème personnalisé ressemble à theme_bw Mais que tous les traits de la grille (x, y, majeurs et mineurs) soient désactivés:

theme_nogrid <- function (base_size = 12, base_family = "") {
    theme_bw(base_size = base_size, base_family = base_family) %+replace% 
        theme(
            panel.grid = element_blank()
    )   
}

Enfin, un thème plus radical utile lors du traçage choroplèthes ou d'autres cartes de ggplot, basé sur la discussion ici mais mis à jour pour éviter les déprécations. L'objectif ici est de supprimer le fond gris et toutes les autres fonctionnalités susceptibles de détourner l'attention de la carte.

theme_map <- function (base_size = 12, base_family = "") {
    theme_gray(base_size = base_size, base_family = base_family) %+replace% 
        theme(
            axis.line=element_blank(),
            axis.text.x=element_blank(),
            axis.text.y=element_blank(),
            axis.ticks=element_blank(),
            axis.ticks.length=unit(0.3, "lines"),
            axis.ticks.margin=unit(0.5, "lines"),
            axis.title.x=element_blank(),
            axis.title.y=element_blank(),
            legend.background=element_rect(fill="white", colour=NA),
            legend.key=element_rect(colour="white"),
            legend.key.size=unit(1.2, "lines"),
            legend.position="right",
            legend.text=element_text(size=rel(0.8)),
            legend.title=element_text(size=rel(0.8), face="bold", hjust=0),
            panel.background=element_blank(),
            panel.border=element_blank(),
            panel.grid.major=element_blank(),
            panel.grid.minor=element_blank(),
            panel.margin=unit(0, "lines"),
            plot.background=element_blank(),
            plot.margin=unit(c(1, 1, 0.5, 0.5), "lines"),
            plot.title=element_text(size=rel(1.2)),
            strip.background=element_rect(fill="grey90", colour="grey50"),
            strip.text.x=element_text(size=rel(0.8)),
            strip.text.y=element_text(size=rel(0.8), angle=-90) 
        )   
}
49
Silverfish