发现现在工业SCADA上或者电信网管方面用图表的特别多,虽然绝大部分人在图表制作方面用的是echarts,他确实好用,但是有些时候我们不能调用别的插件,这个时候就得自己写这些美丽的图表了,然而图表轻易做不成美丽的。。。看到有一个网站上在卖的图表,感觉挺好看的,就用 HT for Web 3D 做了一个小例子,挺简单的,也挺好看的,哈哈~
Demo 地址: http://www.hightopo.com/demo/3DBar/index.html
动态效果图如下:
这个例子用 HT 实现真的很容易,首先创建一个 HT 中最基础的 dm 数据模型,然后将数据模型添加进 g3d 3d 组件中,再设置 3d 中的视角并把 3d 组件添加进 body 元素中:
1 dm = new ht.DataModel();
2 g3d = new ht.graph3d.Graph3dView(dm);
3 g3d.setEye(0, 185, 300);
4 g3d.addToDOM();
5 g3d.getView().style.background = '#000';
知识兔接着就是造这五个chart图表条了,我的思路是这样的,里层有一个节点,外层一个透明的节点,底部一个 3d 的文字显示当前的百分比。
里层的节点非常容易,我直接用的 HT 封装的 ht.Node 创建了一个新的节点对象,然后通过 node.s 方法来设置 node 节点的样式:
1 var node = new ht.Node();
2 node.s({
3 'shape3d': cylinderModel,
4 'shape3d.color': color,
5 '3d.movable': false
6 });
7 node.a({
8 'myHeight': s3[1],
9 });
10 node.p3([p3[0], s3[1]/2, p3[2]]);
11 node.s3(s3);
12 dm.add(node);
知识兔