- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 ggplot2
中有一个三面板显示。这些面板一个接一个地垂直排列。
我正在尝试添加三个横跨面板的垂直线。换句话说,不应将垂直线剪裁到绘图区域。这是我想要的:
但是,当我使用内置的 ggplot2::geom_hline()
时(因为坐标在此图上翻转),我得到了这个:
在咨询了以前的解决方案(例如 here 和 here)之后,我决定尝试使用 gtable
修改绘图布局和/或使用 gtable_add_grob
添加额外 grob 的解决方案。
我尝试将 gtable_add_grob
与 moveToGrob
和 lineToGrob
( here ) 的组合或 segmentsGrob
( here ) 结合使用,但都没有解决我的问题。 moveToGrob
和 lineToGrob
似乎只适用于一条垂直线,我想要多条; segmentsGrob
似乎只应用于单个绘图区域。
此时我很困惑。有人有什么建议吗?
数据
reprex <- data.frame(
diff = c(1.31662094999948, 0.866821096444503, 1.51890736785243,
2.38852458319537, 1.50276154671547, 1.58942354388551,
0.579285478632874, 0.705737525937795, 0.820822837588395,
0.803116467811481, 1.22496342202883, 0.65562485652129, 8.95737110367273,
0.489705699642001, 18.291335204432, 1.32585187406239,
0.423474055403873, 3.13089280711167, 0.642914242106793, 0.777062294322688,
0.827365124783434, 1.79046662862126, 1.18259455819337,
1.51401561610137, 0.328081138137496, 1.72740789953949,
0.189926848328619, 1.45456392298709, 0.905411049427828, 1.60652327349693,
1.81017750948238, 1.34335500622466, 1.34750494180214,
0.722144243864773, 0.963665848513251, 0.749372041127016, 0.714812829735733,
0.902315301989547, 0.792198501077858, 19.892119154905,
1.75845439073389, 11.3122747224641, 2.74831540769519, 0.969397798638758,
2.83507494194274, 0.658301650479607, 0.819696564064323,
0.803104074531595, 1.34654008741793, 0.925244768606367,
1.45533391066467, 0.24199160083309, 0.991764875430923, 0.244000979292541,
1.19499450951635, 0.797225062653057, 1.49894247621815,
2.41249071570669, 1.48095400287587, 1.62901123939155, 0.800939314874935,
1.00449220172611, 0.797357424476374, 0.603543063256566,
0.900713546848067, 0.670072150428499, 29.3000907867695,
1.81141098721977, 16.1752860027313, 1.94316437225496, 0.650354223810153,
2.98785538882299, 0.517693257397596, 0.606327251215883,
0.853818224992284, 2.19310287140208, 1.50701879957261, 1.45525913281509,
0.212947121365625, 1.0411346565884, 0.204533697940102),
lb = c(0.492454940483492, 0.339355619743384, 0.957348434323997,
1.26044791901582, 0.844261377268072, 1.09110321652908,
0.322705783295933, 0.415474890828733, 0.583295860864908,
0.451122506616931, 0.729128070092705, 0.467566913587157, 2.78767229589579,
0.14257769192107, 9.50350595115945, 0.577593901163453,
0.190917776501861, 1.84466415977226, 0.35956473247075,
0.457078546874678, 0.599890772825811, 0.578883702093973, 0.402412042012875,
0.820368078181714, 0.17260752641746, 0.927458567625053,
0.131153965856016, 0.615148567644514, 0.407648792438177,
0.932285544146073, 1.03364348457678, 0.826087466195112, 0.897205256605993,
0.4275157755967, 0.612992386963926, 0.511383739399791,
0.428874429875268, 0.583105952158013, 0.542148907801877, 4.43826058874205,
0.372974670653646, 5.40020940786844, 1.14206113589909,
0.422048214601624, 1.56677388916208, 0.397809279336784,
0.528064920170086, 0.561512990408551, 0.458191509483684, 0.340370706390903,
0.721212596438438, 0.125077100435655, 0.526945268441644,
0.160890120433013, 0.361795965773801, 0.250825296360952,
0.943872992434227, 1.15365773535204, 0.747771285996631, 1.12039094496198,
0.409936729464542, 0.539876902216984, 0.567250295904343,
0.313988141767326, 0.492823474852442, 0.479070611433729,
3.90299786822159, 0.233618126135971, 8.62862044975527, 0.720592578735177,
0.248713293467573, 1.77546875882829, 0.257921470181596,
0.315074709151686, 0.619835605030249, 0.543099639646348,
0.390664978249036, 0.792229860646373, 0.0958528256717599, 0.477302677009191,
0.142069312041543),
ub = c(3.52010018272045, 2.21413399256342, 2.40986406766882,
4.52620818239219, 2.67487335923648, 2.31533292504986,
1.03986876940221, 1.19878593510989, 1.15507442433696, 1.4297581065218,
2.05798603408287, 0.919320721799612, 28.7818970712727,
1.68197190619848, 35.2052121901469, 3.04345871452908,
0.939306328022599, 5.31396987234459, 1.14955301612451, 1.32105480203952,
1.14109614735927, 5.53784937563499, 3.47536788927362,
2.7941644083463, 0.623595247760335, 3.21732760422109, 0.27503710986249,
3.43942312042942, 2.01096920592577, 2.76837611018766,
3.17008975021737, 2.18451767711803, 2.02380620801309, 1.21982003639318,
1.51494845179116, 1.0981155886614, 1.191391572828, 1.39626923922028,
1.1575758174161, 89.1557394076067, 8.2905411213909,
23.6967772416461, 6.6136893575566, 2.22659890385437, 5.13006374565649,
1.08936891504055, 1.27238608639718, 1.1486397742285,
3.95723222603287, 2.51513384013216, 2.93671630527504, 0.468190697336216,
1.86660290365135, 0.370044336690687, 3.94700884715508,
2.53390630747049, 2.38043525455315, 5.04492040838695, 2.93301548174711,
2.36852826238615, 1.5648848712587, 1.86895305056603,
1.12080833973652, 1.16012097512602, 1.64619774599523, 0.937224442626833,
219.957926982961, 14.0451848445645, 30.3223300635011,
5.23997594345012, 1.70059513317832, 5.02812554719921, 1.03910042295524,
1.16681131455086, 1.17612727538199, 8.85601803691856,
5.81343552330794, 2.67318773103787, 0.473084399756679, 2.2710146524667,
0.294462139584516),
xmin = c(5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 2, 2, 2, 3, 3, 3, 0, 0,
0, 4, 4, 4, 1, 1, 1, 5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 2,
2, 2, 3, 3, 3, 0, 0, 0, 4, 4, 4, 1, 1, 1, 5, 5, 5, 6, 6, 6, 7,
7, 7, 8, 8, 8, 2, 2, 2, 3, 3, 3, 0, 0, 0, 4, 4, 4, 1, 1, 1),
xmax = c(6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 3, 3, 3, 4, 4, 4, 1, 1,
1, 5, 5, 5, 2, 2, 2, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 3,
3, 3, 4, 4, 4, 1, 1, 1, 5, 5, 5, 2, 2, 2, 6, 6, 6, 7, 7, 7, 8,
8, 8, 9, 9, 9, 3, 3, 3, 4, 4, 4, 1, 1, 1, 5, 5, 5, 2, 2, 2),
ymin = c(2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0),
ymax = c(3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1),
var = as.factor(c("18 - 29", "18 - 29", "18 - 29", "30 - 44",
"30 - 44", "30 - 44", "45 - 59", "45 - 59",
"45 - 59", "60 +", "60 +", "60 +", "Black", "Black",
"Black", "Hispanic", "Hispanic", "Hispanic", "Male", "Male",
"Male", "Other", "Other", "Other", "White", "White",
"White", "18 - 29", "18 - 29", "18 - 29", "30 - 44",
"30 - 44", "30 - 44", "45 - 59", "45 - 59",
"45 - 59", "60 +", "60 +", "60 +", "Black", "Black", "Black",
"Hispanic", "Hispanic", "Hispanic", "Male", "Male",
"Male", "Other", "Other", "Other", "White", "White",
"White", "18 - 29", "18 - 29", "18 - 29", "30 - 44",
"30 - 44", "30 - 44", "45 - 59", "45 - 59",
"45 - 59", "60 +", "60 +", "60 +", "Black", "Black", "Black",
"Hispanic", "Hispanic", "Hispanic", "Male", "Male",
"Male", "Other", "Other", "Other", "White", "White",
"White")),
comparison = as.factor(c("Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1", "Comparison 2", "Comparison 3",
"Comparison 1", "Comparison 2", "Comparison 3",
"Comparison 1", "Comparison 2", "Comparison 3",
"Comparison 1", "Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1", "Comparison 2", "Comparison 3",
"Comparison 1", "Comparison 2", "Comparison 3",
"Comparison 1", "Comparison 2", "Comparison 3",
"Comparison 1", "Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1",
"Comparison 2", "Comparison 3", "Comparison 1", "Comparison 2",
"Comparison 3", "Comparison 1")),
sig = as.factor(c("Non-significant", "Non-significant",
"Non-significant", "Less prevalent & significant",
"Non-significant", "Less prevalent & significant",
"Non-significant", "Non-significant",
"Non-significant", "Non-significant", "Non-significant",
"More prevalent & significant", "Less prevalent & significant",
"Non-significant", "Less prevalent & significant",
"Non-significant", "More prevalent & significant",
"Less prevalent & significant", "Non-significant",
"Non-significant", "Non-significant", "Non-significant",
"Non-significant", "Non-significant",
"More prevalent & significant", "Non-significant",
"More prevalent & significant", "Non-significant", "Non-significant",
"Non-significant", "Less prevalent & significant",
"Non-significant", "Non-significant", "Non-significant",
"Non-significant", "Non-significant",
"Non-significant", "Non-significant", "Non-significant",
"Less prevalent & significant", "Non-significant",
"Less prevalent & significant", "Less prevalent & significant",
"Non-significant", "Less prevalent & significant",
"Non-significant", "Non-significant", "Non-significant",
"Non-significant", "Non-significant",
"Non-significant", "More prevalent & significant", "Non-significant",
"More prevalent & significant", "Non-significant",
"Non-significant", "Non-significant",
"Less prevalent & significant", "Non-significant",
"Less prevalent & significant", "Non-significant", "Non-significant",
"Non-significant", "Non-significant",
"Non-significant", "More prevalent & significant",
"Less prevalent & significant", "Non-significant",
"Less prevalent & significant", "Non-significant", "Non-significant",
"Less prevalent & significant", "Non-significant",
"Non-significant", "Non-significant", "Non-significant",
"Non-significant", "Non-significant",
"More prevalent & significant", "Non-significant",
"More prevalent & significant")),
sample = as.factor(c("Yes/No", "Yes/No", "Yes/No", "Yes/No", "Yes/No",
"Yes/No", "Yes/No", "Yes/No", "Yes/No", "Yes/No",
"Yes/No", "Yes/No", "Yes/No", "Yes/No", "Yes/No",
"Yes/No", "Yes/No", "Yes/No", "Yes/No", "Yes/No",
"Yes/No", "Yes/No", "Yes/No", "Yes/No", "Yes/No", "Yes/No",
"Yes/No", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Quantitative",
"Quantitative", "Quantitative", "Strict", "Strict", "Strict",
"Strict", "Strict", "Strict", "Strict", "Strict",
"Strict", "Strict", "Strict", "Strict", "Strict", "Strict",
"Strict", "Strict", "Strict", "Strict", "Strict",
"Strict", "Strict", "Strict", "Strict", "Strict",
"Strict", "Strict", "Strict")))
基本 GGPLOT
p <- ggplot(reprex, aes(xmin=xmin, xmax=xmax, ymin=ymin, ymax=ymax)) +
geom_rect(color="white", aes(fill=sig, alpha=abs(log(diff)))) +
scale_fill_manual(values=c("green", "grey", "red")) +
scale_x_continuous(breaks=1:length(levels(plot_dat$var)) - .75, labels=levels(plot_dat$var), expand=c(0, 0)) +
scale_y_continuous(breaks=1:length(levels(plot_dat$sample)) - .5, labels=levels(plot_dat$sample), expand=c(0, .0)) +
facet_grid(rows=vars(comparison)) +
theme_minimal(base_size=20) +
theme(panel.grid=element_blank(), legend.title=element_blank(), axis.text.x=element_text(angle=90, hjust=1), strip.text=element_text(size=12))
分段粗略尝试
gb <- ggplot_build(p)
g <- ggplot_gtable(gb)
xs <- c(1, 5)/length(unique(reprex$var))
g <- gtable_add_grob(g,
list(segmentsGrob(x0=xs, x1=xs, y0=0, y1=1),
segmentsGrob(x0=xs, x1=xs, y0=0, y1=1),
segmentsGrob(x0=xs, x1=xs, y0=0, y1=1),
segmentsGrob(x0=xs, x1=xs, y0=0, y1=1)),
clip="off", t=c(7, 9, 11, 14), l=5)
grid.newpage()
grid.draw(g)
MOVETOGROB 和 LINETOGROB 尝试
gb <- ggplot_build(p)
g <- ggplot_gtable(gb)
xs <- c(1, 5)/length(unique(reprex$var))
for(i in xs) {
g <- gtable_add_grob(g, moveToGrob(i, 1), clip="off", t=7, l=5)
g <- gtable_add_grob(g, lineToGrob(i, 0), clip="off", t=14, l=5)
}
grid.newpage()
grid.draw(g)
最佳答案
g <- gtable_add_grob(g, segmentsGrob(x0=xs, x1=xs, y0=0, y1=1),
t=7, b=14, l=5)
g$layout$clip <- 'off'
关于r - ggplot2 和 gtable : drawing multiple lines across panels,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55885362/
我正在尝试设计我的输入:文件。以下 SO 问题让我完成了 95% 的任务。区别在于我使用的是 HTML5 multiple=multiple 属性。 How to style "input file"
我一直在进行一项实验,其中多个调查参与者使用可穿戴技术聆听多首音乐来跟踪多条信息,两个例子是 BPM(心率)和 T(体温)。 目标是衡量每首音乐(以用户反馈为特征)对人类情感的影响。 目前,所有数据都
我使用 jquery 添加/删除输入 我使用append为日期/收入添加多个Tr 我还使用另一个附加来添加多个 td 以获取同一日期 Tr 中的收入 我添加多个日期输入,并在此表中添加多个收入输入 我
在 Android 中,有一种方法可以为项目中的所有模块生成签名的 APK。例如。我有以下项目 Project -- Library Module -- Module 1 -- Modul
我有一个用于网站展示的系统。 展览数据可能来自差异表中的多个数据。 喜欢这个设计: Table [ExhibitionType] used for differentiate category. Ta
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我正在使用 UILocalnotification...收到通知时,当应用程序处于事件模式时我打开 viewcontroller...但是如果同时收到多个通知...我如何打开多个 viewcontro
我遇到的问题是一个策略浏览器游戏,它有 7 种类型的值。问题如下: 我在 $_POST 中获得了 7 个不同的值,包括从索引 unit_1 到索引 unit_7。这 7 个值是 0 到 20 之间的整
这个问题已经有答案了: Search Large Text File for Thousands of strings (3 个回答) 已关闭10 年前。 我想在多个文件上“grep”多个正则表达式。
我经常对如何在我的应用程序中解决这个问题感到矛盾。我使用了很多选项,包括: 一个通用的多选 - 这是我最不喜欢和最很少使用的选项。我发现可用性非常糟糕,一个简单的误点击就会毁了你所有的辛勤工作。 “自
以下是 couchbase 中的示例文档之一。 { "name":"abc", "friends":["a","b","c"], "bestfriends":["x","y","z"] }
我有 4 张 table 。 表组 | ID | NAME | 1 Premium 2 Silver 表用户 | ID | group_id | NAME | 1
我正在开发一个使用第三方服务(Facebook、Google 等)对用户进行身份验证的应用程序。我为每个用户提供一个内部 ID(uuid v4),该 ID 与他们的第 3 方 ID 相关联。现在,我的
我是 bicep 新手,一直在努力实现 Bicep 脚本来部署具有许多主题和订阅的 Azure 服务总线。 我添加的每个主题都有可变数量的订阅(例如,通知主题可能有 3 个订阅,但分析主题可能有 2
我是 bicep 新手,一直在努力实现 Bicep 脚本来部署具有许多主题和订阅的 Azure 服务总线。 我添加的每个主题都有可变数量的订阅(例如,通知主题可能有 3 个订阅,但分析主题可能有 2
我必须创建一个大型数据库。它将保存来自 100 多个设备的数据,并不断更新数据库。每 10 秒,每个设备都会更新数据库中的一行。是为每个设备数据建立一个单独的表还是将数据与设备 ID 放在同一个表中更
我需要在 Activity 开始时显示“正在加载”进度对话框,然后在加载完成后显示一些内容。在我的 onresume 中,我有类似这样的代码: loadThread = true; Thread sh
我有一个 html 表单 当我提交表单时,假设对于 id = 1,数量为 5 或 对于 id = 3,数量为 8。如何在java脚本或jquery中获取这些值并将这些信息提交到服务器?我
我正在创建一个 Mozilla 扩展程序,通过单击“转换按钮”(标签:转换)将网页内容转换为其他语言它的标签被转换为英文,以便单击该按钮(标签:英文)内容被转换为原始形式 我尝试为每个选项卡设置属性“
我正在尝试根据 进行搜索 我通过运行代码从 select 中获取值: for($i=0;$i= '$age_from' AND users.user_age = '$age_from' AND u
我是一名优秀的程序员,十分优秀!