5
我想迫使所有的刻度线和刻度线标签出现在nvd3
库的rCharts
nPlot中沿轴出现。我尝试了几种方法,但都没有成功。rCharts nvd3库力刻度
这是默认的行为:
df <- data.frame(x = 1:13, y = rnorm(13))
library(rCharts)
n <- nPlot(data = df, y ~ x, type = 'lineChart')
n$yAxis(showMaxMin = FALSE)
我想在1:13
显示沿x轴的所有数据。
最终,我有自定义刻度线我想告诉等距有以下替换:
n$xAxis(tickFormat = "#! function (x) {
ticklabels = ['0-1000', '1000-1500', '1500-1700', '1700-1820', '1820-1913',
'1913-1950', '1950-1970', '1970-1990', '1990-2012', '2012-2030',
'2030-2050', '2050-2070', '2070-2100']
return ticklabels[x-1];
} !#")
我希望这是清楚我为什么要拥有所有刻度线和标签打印(和等距)。
为了让成品的想法,这里是一个ggplot2
印象:
library(ggplot2)
df <- data.frame(x = c('0-1000', '1000-1500', '1500-1700', '1700-1820', '1820-1913',
'1913-1950', '1950-1970', '1970-1990', '1990-2012', '2012-2030', '2030-2050',
'2050-2070', '2070-2100'), y = rnorm(13), z = "group1")
ggplot(data = df, aes(x = x, y = y, group = z)) + geom_line()
这里有几件事情我已经试过了,基于几个建议,我发现这里和那里:没有工作。
根据我的文档的阅读,我想这会工作:
n$xAxis(tickFormat = "#! function (x) {
return [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13][x-1];
} !#")
我也试过这样,在关闭的机会:
n$xAxis(ticks = 13)
我也试图结合tickValues
和tickFormat
但没有成功。
我也想过编写一个脚本,但我对nvd3
库的理解还不够。
n$setTemplate(afterScript =
"<script>
var chart = nv.models.lineChart();
var newAxisScale = d3.scale.linear();
.range(d3.extent(chart.axes[0]._scale.range()))
.domain([1, d3.max(chart.axes[0]._scale.domain())])
chart.axes[0].shapes.call(
d3.svg.axis()
.orient('bottom')
.scale(newAxisScale)
.ticks(13)
//.tickValues()
//.tickFormat(d3.format())
).selectAll('text')
.attr('transform','')
</script>"
)
控制台中没有这些报告错误,但没有一个修改上面第一个绘图的外观。
这里有一个相关的问题,但它并没有答案,有评论并不适用于我的问题(它们适用于沿x轴的日期,但我有一个任意的字符串) 。 http://stackoverflow.com/questions/25120598/strings-as-tick-values-for-rcharts-nvd3-line-chart – PatrickT
这也是类似的问题,我只是注意到现在表明,没有希望... http ://stackoverflow.com/questions/25481853/rcharts-nvd3-linechart-with-categorical-x-axis – PatrickT