【问题标题】:how to make amChart column with 3 axis vertical如何使 3 轴垂直的 amChart 列
【发布时间】:2018-12-11 18:50:29
【问题描述】:

我想使用带有 3 轴的 amChart 创建垂直聚集柱形图。

我已经做了如下代码所示的水平设计,我的问题是......我怎样才能让这个图表垂直?

据我所知(谷歌搜索),amChart 可以通过rotating the labels 轻松做到这一点。我的问题是......我应该把这个“旋转”放在哪里:真的? 我不熟悉javascript。有人可以帮忙吗?

任何帮助将不胜感激。

/**
 * ---------------------------------------
 * This demo was created using amCharts 4.
 * 
 * For more information visit:
 * https://www.amcharts.com/
 * 
 * Documentation is available at:
 * https://www.amcharts.com/docs/v4/
 * ---------------------------------------
 */

// Themes begin
am4core.useTheme(am4themes_animated);
// Themes end

 // Create chart instance
var chart = am4core.create("chartdiv", am4charts.XYChart);

// Add data
chart.data = [{
  "year": 2005,
  "income": 23.5,
  "expenses": 18.1,
  "cumi" : 13
},{
  "year": 2006,
  "income": 26.2,
  "expenses": 22.8,
  "cumi" : 13
},{
  "year": 2007,
  "income": 30.1,
  "expenses": 23.9,
  "cumi" : 13
},{
  "year": 2008,
  "income": 29.5,
  "expenses": 25.1,
  "cumi" : 13
},{
  "year": 2009,
  "income": 24.6,
  "expenses": 25,
  "cumi" : 13
}];

// Create axes
var categoryAxis = chart.yAxes.push(new am4charts.CategoryAxis());
categoryAxis.dataFields.category = "year";
categoryAxis.numberFormatter.numberFormat = "#";
categoryAxis.renderer.inversed = true;
categoryAxis.renderer.grid.template.location = 0;
categoryAxis.renderer.cellStartLocation = 0.1;
categoryAxis.renderer.cellEndLocation = 0.9;

var  valueAxis = chart.xAxes.push(new am4charts.ValueAxis()); 
valueAxis.renderer.opposite = true;

// Create series
function createSeries(field, name) {
  var series = chart.series.push(new am4charts.ColumnSeries());
  series.dataFields.valueX = field;
  series.dataFields.categoryY = "year";
  series.name = name;
  series.columns.template.tooltipText = "{name}: [bold]{valueX}[/]";
  series.columns.template.height = am4core.percent(100);
  series.sequencedInterpolation = true;

  var valueLabel = series.bullets.push(new am4charts.LabelBullet());
  valueLabel.label.text = "{valueX}";
  valueLabel.label.horizontalCenter = "left";
  valueLabel.label.dx = 10;
  valueLabel.label.hideOversized = false;
  valueLabel.label.truncate = false;

  var categoryLabel = series.bullets.push(new am4charts.LabelBullet());
  categoryLabel.label.text = "{name}";
  categoryLabel.label.horizontalCenter = "right";
  categoryLabel.label.dx = -10;
  categoryLabel.label.fill = am4core.color("#fff");
  categoryLabel.label.hideOversized = false;
  categoryLabel.label.truncate = false;
}

createSeries("income", "Income");
createSeries("expenses", "Expenses");
createSeries("cumi", "Cumi");
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}

#chartdiv {
  width: 100%;
  height: 500px;
}
<script src="https://www.amcharts.com/lib/4/core.js"></script>
<script src="https://www.amcharts.com/lib/4/charts.js"></script>
<script src="https://www.amcharts.com/lib/4/themes/animated.js"></script>
<div id="chartdiv"></div>

【问题讨论】:

  • 这篇文章将你已经拥有的东西描述为水平图表,而不是垂直图表,所以这有点令人困惑。您是否要更改方向以使条形图从下到上?
  • @xorspark 很抱歉,已编辑...您能帮帮我吗?

标签: javascript html css charts amcharts


【解决方案1】:

您需要将chart.yAxes 替换为chart.xAxes,将chart.xAxes 替换为chart.yAxes

基本上CategoryAxis 需要转到xAxesValueAxis 需要转到yAxes

您还需要将valueX 更改为valueY,将categoryY 更改为categoryX

series.dataFields.valueY = field;
series.dataFields.categoryX = "year";

下面的示例几乎没有其他更改。我建议您查看有关axes in the documentation 的更多信息。

/**
 * ---------------------------------------
 * This demo was created using amCharts 4.
 * 
 * For more information visit:
 * https://www.amcharts.com/
 * 
 * Documentation is available at:
 * https://www.amcharts.com/docs/v4/
 * ---------------------------------------
 */

// Themes begin
am4core.useTheme(am4themes_animated);
// Themes end

 // Create chart instance
var chart = am4core.create("chartdiv", am4charts.XYChart);

// Add data
chart.data = [{
  "year": 2005,
  "income": 23.5,
  "expenses": 18.1,
  "cumi" : 13
},{
  "year": 2006,
  "income": 26.2,
  "expenses": 22.8,
  "cumi" : 13
},{
  "year": 2007,
  "income": 30.1,
  "expenses": 23.9,
  "cumi" : 13
},{
  "year": 2008,
  "income": 29.5,
  "expenses": 25.1,
  "cumi" : 13
},{
  "year": 2009,
  "income": 24.6,
  "expenses": 25,
  "cumi" : 13
}];

// Create axes
var categoryAxis = chart.xAxes.push(new am4charts.CategoryAxis());
categoryAxis.dataFields.category = "year";
categoryAxis.numberFormatter.numberFormat = "#";
categoryAxis.renderer.inversed = true;
categoryAxis.renderer.grid.template.location = 0;
categoryAxis.renderer.cellStartLocation = 0.1;
categoryAxis.renderer.cellEndLocation = 0.9;

var  valueAxis = chart.yAxes.push(new am4charts.ValueAxis()); 
valueAxis.renderer.opposite = true;

// Create series
function createSeries(field, name) {
  var series = chart.series.push(new am4charts.ColumnSeries());
  series.dataFields.valueY = field;
  series.dataFields.categoryX = "year";
  series.name = name;
  series.columns.template.tooltipText = "{name}: [bold]{valueX}[/]";
  series.columns.template.height = am4core.percent(100);
  series.sequencedInterpolation = true;

  var valueLabel = series.bullets.push(new am4charts.LabelBullet());
  valueLabel.label.text = "{valueX}";
  valueLabel.label.verticalCenter = "bottom";
  valueLabel.label.dx = 10;
  valueLabel.label.hideOversized = false;
  valueLabel.label.truncate = false;

  var categoryLabel = series.bullets.push(new am4charts.LabelBullet());
  categoryLabel.label.text = "{name}";
  categoryLabel.label.verticalCenter = "top";
  categoryLabel.label.dx = -10;
  categoryLabel.label.hideOversized = false;
  categoryLabel.label.truncate = false;
  
  categoryLabel.label.rotation = -90;
}

createSeries("income", "Income");
createSeries("expenses", "Expenses");
createSeries("cumi", "Cumi");
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}

#chartdiv {
  width: 100%;
  height: 500px;
}
<script src="https://www.amcharts.com/lib/4/core.js"></script>
<script src="https://www.amcharts.com/lib/4/charts.js"></script>
<script src="https://www.amcharts.com/lib/4/themes/animated.js"></script>
<div id="chartdiv"></div>

【讨论】:

  • 感谢您的帮助,先生。好的,我会检查更多的 amChart 文档。祝你有美好的一天:)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-09-07
  • 1970-01-01
  • 2021-01-13
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多