ZingChart条形图未正确生成

时间:2016-11-18 08:39:10

标签: angularjs charts zingchart

  

html文件

<zingchart id="timesheet-bar-chart" zc-json="myObj"></zingchart>
  

在controller.js

$scope.myObj = {
  "type": "bar",
  "utc": true,
  "plotarea":{
      "margin":'dynamic'
    },
  "plot":{
    "stacked":true,
    "stack-type":"normal" /* Optional specification */
  },
 "scaleX":{
      "transform":{
        "type":"date",
        "all":"%d %M",
        "item": {
          "visible":false
        }
      },
    },
  "series":[{ 
      "values": $scope.barValues,
      "backgroundColor":"#f15662"
    }]
  };
zingchart.render({ 
id : 'timesheet-bar-chart', 
height: 400, 
width: "100%"
});

在$ scope.barValues中,数据以下面的格式动态添加

  

[[[1478025000000,10],[1477938600000,20],[1478889000000,30]]]

我没有犯错的地方。生成的栏不是格式。请帮助我第一次使用ZingChart库。 enter image description here

1 个答案:

答案 0 :(得分:6)

你的条形图生成得很好。条形图从标签上看是因为您正在绘制[[]](数组数组)。如果您查看绘制的时间戳,则确实没有在11月4日准确绘制条形图。如果您要引用标签本身,则可以确定all属性显示标签的内容。您可以将step属性设置为更加线性或使用缩放。

scale docs

token docs

条形偏移是非线性数据的乘积。由于非线性数据,条形尺寸现在被挤压得更小。这是由于尺寸随着时间的推移。您可以通过添加zooming(单击并拖动以缩放)来查看条形将增加大小。

zooming docs

&#13;
&#13;
var myConfig = {
  "type": "bar",
  "utc": true,
  "plotarea":{
      "margin":'dynamic'
    },
  "plot":{
    "stacked":true,
    "stack-type":"normal" /* Optional specification */
  },
 "scaleX":{
   "zooming":true,
      "transform":{
        "type":"date",
        "all":"%d %M %Y<br> %h:%i:%s",
      },
    },
  "series":[{ 
      "values": [[1478025000000,10],[1477938600000,20],[1478889000000,30]],
      "backgroundColor":"#f15662"
    }]
  };

zingchart.render({ 
	id: 'myChart', 
	data: myConfig, 
	height: '100%', 
	width: '100%' 
});
&#13;
html, body {
	height:100%;
	width:100%;
	margin:0;
	padding:0;
}
#myChart {
	height:100%;
	width:100%;
	min-height:150px;
}
&#13;
<!DOCTYPE html>
<html>
	<head>
		<script src= "https://cdn.zingchart.com/zingchart.min.js"></script>
	</head>
	<body>
		<div id="myChart"></div>
	</body>
</html>
&#13;
&#13;
&#13;

您可以通过使用bar-width属性设置固定大小来避免这种情况。

plot docs

&#13;
&#13;
var myConfig = {
  "type": "bar",
  "utc": true,
  "plotarea":{
      "margin":'dynamic'
    },
  "plot":{
    "bar-width": 30,
    "stacked":true,
    "stack-type":"normal" /* Optional specification */
  },
 "scaleX":{
   "zooming":true,
      "transform":{
        "type":"date",
         "all":"%d %M %Y<br> %h:%i:%s",
      },
    },
  "series":[{ 
      "values": [[1478025000000,10],[1477938600000,20],[1478889000000,30]],
      "backgroundColor":"#f15662"
    }]
  };

zingchart.render({ 
	id: 'myChart', 
	data: myConfig, 
	height: '100%', 
	width: '100%' 
});
&#13;
html, body {
	height:100%;
	width:100%;
	margin:0;
	padding:0;
}
#myChart {
	height:100%;
	width:100%;
	min-height:150px;
}
&#13;
<!DOCTYPE html>
<html>
	<head>
	<!--Assets will be injected here on compile. Use the assets button above-->
		<script src= "https://cdn.zingchart.com/zingchart.min.js"></script>
	</head>
	<body>
		<div id="myChart"></div>
	</body>
</html>
&#13;
&#13;
&#13;