非常好的问题,我很高兴你问了。这个功能将在
这个拉取请求中添加。目前,您可以通过
require(devtools); install_github("rCharts","timelyportfolio",ref="dimple_layer")
进行测试。这里是重新制作的示例,几乎可以正常工作。另外,我添加了一些其他考虑因素。我仍在努力让
rCharts中的dimple聚合正确工作。您将看到一个不太完美的解决方法。
library(rCharts)
df <- data.frame(id = 1:10, a = rnorm(10), b = rnorm(10))
d1 <- dPlot(b~a,
groups = "a",
data = df,
type = "bubble"
,defaultColors = "#!['blue']!#"
)
d1$xAxis(type="addMeasureAxis")
d1$yAxis(type="addMeasureAxis",overrideMin = -2, overrideMax = 2)
d1
d1$layer(
y ~ x
,groups = c("x","y")
,data = data.frame(x = c(1,10), y = rep(0,2))
,type="line"
)
d1
目前,更好的处理方法可能是使用afterScript
在顶部绘制一条线。正如您所看到的,这绝对是一个正在进行中的工作,并且过于不专业。
library(rCharts)
df <- data.frame(id = 1:10, a = rnorm(10), b = rnorm(10))
d1 <- dPlot(b~a,
groups = "a",
data = df,
type = "bubble"
,defaultColors = "#!['blue']!#"
)
d1$xAxis(type="addMeasureAxis")
d1$yAxis(type="addMeasureAxis",overrideMin = -2, overrideMax = 2)
d1
d1$setTemplate(
afterScript = sprintf(
'
<script>
var line = d3.svg.line()
.x(function(d) { return myChart.axes[0]._draw.scale()(d.x); })
.y(function(d) { return myChart.axes[1]._draw.scale()(d.y); });
d3.select("#%s svg g")
.append("path")
.datum([{x:myChart.axes[0]._min,y:0},{x:myChart.axes[0]._max,y:0}])
.attr("d",line)
.style("stroke","blue")
.style("stroke-width",3)
</script>
'
,d1$params$dom
))
d1
.datum([{x:-2,y:0},{x:2,y:0}])
。不确定“_max”指的是什么,但在我的设置中它停在了右手边轴的限制之前。 - PatrickT