【转载】ggplot2主题设置

2024-01-29 02:32
文章标签 设置 转载 主题 ggplot2

本文主要是介绍【转载】ggplot2主题设置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文摘自http://www.rpubs.com/lihaoyi/156592

library(ggplot2)  #加载ggplot2包
library(gcookbook)  #加载本书的数据包

主题theme参数设置

改变字体类型、大小,图例、坐标轴、背景等各种元素,可通过theme()函数来完成

library(ggplot2)
library(grid)  #为了使用unit函数
p0 <- ggplot(data = mpg, aes(x = displ, fill = factor(cyl))) + geom_bar(colour = 1, binwidth = 0.2) + labs(title = "plot title")
p0  #基础图

这里写图片描述

1.1 图片区参数设置
  • plot.background: 图片区背景设置
  • plot.title: 图片标题设置
  • plot.margin: 图片区边缘距离设置

将图片区背景填充色设置为lightblue,边框颜色设置为黑色,宽度设置为3,线型设置为虚线,图标题的字体颜色为黑色,粗体,字体大小30,顶部对齐,同时设置图边沿距离.

p0 + theme(plot.background = element_rect(colour = "black", size = 3, linetype = 4, fill = "lightblue"), plot.title = element_text(colour = "black", face = "bold", size = 30, vjust = 1), plot.margin = unit(c(0.2, 0.2, 0.2, 0.2), "inches"))

这里写图片描述

1.2 绘图区(轴线围城的区域)参数设置
  • panel.background: 绘图区背景色,colour可以设置边框颜色,fill为填充色
  • panel.border: 绘图区边框
  • panel.grid: 网格线
  • panel.grid.major: 主要网格线
  • panel.grid.minor: 次要网格线
  • panel.grid.major.x: x轴主要网格线
  • panel.grid.major.y: y轴主要网格线
  • panel.grid.minor.x: x轴次要网格线
  • panel.grid.minor.y: y轴次要网格线
p0

这里写图片描述

p0 + theme(panel.background = element_rect(fill = "lightblue"))  #将图片区的背景色设置为lightblue

这里写图片描述

p0 + theme(panel.background = element_rect(fill = "lightblue", colour = "red", size = 3))  #将图片区的背景色设置为lightblue,边框颜色为红色,边框宽度为3

这里写图片描述

1.3 坐标轴参数设置
  • axis.title: 轴标题
  • axis.title.x: x轴标题
  • axis.title.y: y轴标题
  • axis.text: 轴刻度值
  • axis.text.x: x轴刻度值
  • axis.text.y: y轴刻度值
  • axis.ticks: 轴刻度线
  • axis.ticks.x: x轴刻度线
  • axis.ticks.y: y轴刻度线
  • axis.ticks.length: 轴刻度线长度,负值向里
  • axis.ticks.margin: 轴刻度线与轴刻度值的距离
  • axis.line: 轴线
  • axis.line.x: x轴线
  • axis.line.y: y轴线
p0

这里写图片描述

axis_theme<-theme(axis.title=element_text(#family=NULL,face = "bold", #字体("plain", "italic", "bold", "bold.italic")colour = "red", #字体颜色size = 25,#字体大小hjust = .5, #调整轴标题1:纵轴靠上,横轴靠右;0.5居中;0:纵轴靠下,横轴靠左vjust = .5, #1:靠图边框;0靠近轴线;.5居中angle = 0 #为什么只对横轴标题有作用?),axis.title.x=element_text(colour="blue"),#x轴标题设置,优先级高于axis.titleaxis.title.y=element_text(colour="orange"),#同上axis.text=element_text(colour="red"),#设置坐标轴刻度数字axis.text.x=element_text(colour="blue"),#优先级高于aixis.textaxis.text.y=element_text(colour="orange"),#同上axis.ticks=element_line(#坐标轴刻度线的设置colour="red",size=.5,linetype=1,lineend=1),axis.ticks.x=element_line(colour="blue"),#优先级高于axis.ticksaxis.ticks.y=element_line(colour="orange"),#同上axis.ticks.length=unit(.4,"lines"),#设置刻度线的高度axis.ticks.margin=unit(.4,"cm"),#设置刻度数字与刻度线的距离axis.line=element_line(#设置轴线colour="red"),axis.line.x=element_line(colour="blue"),#设置x轴线,优先于axis.lineaxis.line.y=element_line(colour="orange"))#类似axis.line.xp0+axis_theme

这里写图片描述

1.4 图例参数设置
  • legend.background: 图例背景色
  • legend.margin: 图例边界
  • legend.key: 图例分类标识底部背景颜色
  • legend.key.size: 图例标识大小
  • legend.key.height: 图例标识的高度
  • legend.key.width: 图例标识的宽度
  • legend.text: 图例分类标签
  • legend.text.align: 图例分类标签对齐方式
  • legend.title: 图例标题
  • legend.title.align: 图例标题的对齐方式
  • legend.position: 图例位置
  • legend.direction: 图例类别排列方向
  • legend.justification: 图例位置的偏移调整
  • legend.box: 有多个图例时的排列方式
p0

这里写图片描述

legend_theme<-theme(legend.background=element_rect(colour=NA,#图例边框颜色fill="lightblue"),#图例背景填充色legend.margin=unit(.2,"inches"),#图例与图片区边缘的距离legend.key=element_rect(fill="yellow"),legend.key.size=unit(.2,"inches"),#图例分类符号的大小legend.key.height=unit(.5,"inches"),#图例分类符号高度legend.key.width=unit(.5,"inches"),#图例符号的宽度legend.text=element_text(colour="red",size=20),#图例分类标签设置legend.text.align=0,#0左,1右,0.5居中, 图例分类标签的对齐方式legend.title=element_text(colour="blue",size=20),#图例标题设置legend.title.align=1,#图例标题对齐方式legend.position=c(0.6,.7),#"none","left","right","bottom","top",or # two-element numeric vector,(0,0)-(1,1)legend.direction="horizontal",#"vertical" 图例排列方向legend.justification=c(.4,.4),#"center" or two-element numeric vectorlegend.box="vertical",#"horizontal",对图例的排列方式legend.box.just="top"#多图例的居中方式
)p0+legend_theme

这里写图片描述

这篇关于【转载】ggplot2主题设置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/655489

相关文章

Qt 设置软件版本信息的实现

《Qt设置软件版本信息的实现》本文介绍了Qt项目中设置版本信息的三种常用方法,包括.pro文件和version.rc配置、CMakeLists.txt与version.h.in结合,具有一定的参考... 目录在运行程序期间设置版本信息可以参考VS在 QT 中设置软件版本信息的几种方法方法一:通过 .pro

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

mtu设置多少网速最快? 路由器MTU设置最佳网速的技巧

《mtu设置多少网速最快?路由器MTU设置最佳网速的技巧》mtu设置多少网速最快?想要通过设置路由器mtu获得最佳网速,该怎么设置呢?下面我们就来看看路由器MTU设置最佳网速的技巧... 答:1500 MTU值指的是在网络传输中数据包的最大值,合理的设置MTU 值可以让网络更快!mtu设置可以优化不同的网

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、