`
xhload3d
  • 浏览: 208305 次
社区版块
存档分类
最新评论

基于HTML5 Canvas的3D动态Chart图表

阅读更多

发现现在工业SCADA上或者电信网管方面用图表的特别多,虽然绝大部分人在图表制作方面用的是echarts,他确实好用,但是有些时候我们不能调用别的插件,这个时候就得自己写这些美丽的图表了,然而图表轻易做不成美丽的。。。看到有一个网站上在卖的图表,感觉挺好看的,就用 HT for Web 3D 做了一个小例子,挺简单的,也挺好看的,哈哈~

Demo 地址: http://www.hightopo.com/demo/WireframeAnim/index.html

动态效果图如下:

这个例子用 HT 实现真的很容易,首先创建一个 HT 中最基础的 dm 数据模型,然后将数据模型添加进 g3d 3d 组件中,再设置 3d 中的视角并把 3d 组件添加进 body 元素中:

dm = new ht.DataModel();
g3d = new ht.graph3d.Graph3dView(dm);
g3d.setEye(0, 185, 300);
g3d.addToDOM();
g3d.getView().style.background = '#000';

接着就是造这五个chart图表条了,我的思路是这样的,里层有一个节点,外层一个透明的节点,底部一个 3d 的文字显示当前的百分比。

 

里层的节点非常容易,我直接用的 HT 封装的 ht.Node 创建了一个新的节点对象,然后通过 node.s 方法来设置 node 节点的样式:

var node = new ht.Node();
node.s({
    'shape3d': cylinderModel,
    'shape3d.color': color,
    '3d.movable': false
});
node.a({
    'myHeight': s3[1],
});
node.p3([p3[0], s3[1]/2, p3[2]]);
node.s3(s3);
dm.add(node);

其中要说明的是,'shape3d':cylinderModel 这个样式的设置,首先,shape3d 属性指定显示为 3d 模型的图标效果,cylinderModel 是用 HT 自定义的一个 3d 模型,可参考 HT for Web 建模手册

cylinderModel = ht.Default.createCylinderModel(1000, 0, 1000, false, false, true, true);

然后设置了一个动态变化的属性 myHeight,在 HT 中,node.a 方法是预留给用户存储业务数据的,我们可以在这边添加任意多个属性。

接下来我们要创建的是外部的透明节点,这个节点的构造方式基本上与内部节点相同,就是多了一点“透明”的样式设置:

var cNode = new ht.Node();
cNode.s({
    'shape3d': cylinderModel,
    'shape3d.transparent': true,
    'shape3d.opacity': 0.2,	
    'label.color': '#fff',
    '3d.movable': false
});
cNode.p3([p3[0], 50, p3[2]]);
cNode.s3(20, 100, 20);
dm.add(cNode);

要先设置 ‘shape3d.transparent’ 为true,再设置 ‘shape3d.opacity’ 透明度。

最后是 3d 文字,呈现 3d 文字需要一个 json 格式的 typeface 字体,然后通过 ht.Default.loadFontFace 来加载 json 格式的字体到内存中,详情请参考 HT for Web 3D 手册

ht.Default.loadFontFace('./wenquanyi.json', function(){
    //......
    var text = new ht.Node();
    text.s3([5, 5, 5]);
    text.p3(cNode.p3()[0]-5, -10, 0);
    dm.add(text);
    text.s({
        'shape3d' : 'text',
	'shape3d.text': node.a('myHeight')+'%',
	'shape3d.text.curveSegments': 1,
	'3d.movable': false
    });
});

因为我们用的 typeface 字体的绘制方式是无数个三角形构成的一个字,会占用很大的内存,所以我把图形的曲线的精细度调得较低,但是还是很清晰,如果你们能找到性能更好的字体,可以使用并且告知我一下,我们目前没找到占用内存小的字体。

 

最后,要动态的变化 chart 图表中的柱形图,我们得设置动画,并且将 3d 字体也同步更新数值:

setInterval(function(){
    if(node.a('myHeight') < 100){
        node.a('myHeight', (node.getAttr('myHeight')+1));
	node.s3(20, node.a('myHeight'), 20);
	node.p3(p3[0], node.a('myHeight')/2, p3[2]);
    }else{
        node.a('myHeight', 0);
	node.s3([20, 0, 20]);
	node.p3([p3[0], 0, p3[2]]);
    }
    if (text) text.s('shape3d.text', node.a('myHeight')+'%');
}, 100);

这里,我自定义的属性 “myHeight” 就起到了决定性的作用,我用这个属性来存储变量,而且可以任意更改变量的值,这样就能实现动态绑定的效果了。

还有不懂的可以留言,或者直接去我们官网上查看手册 HT for Web,有更多你想不到的效果能快速实现哦~ 

分享到:
评论

相关推荐

    基于HTML5 Canvas的3D动态Chart图表的示例

    【HTML5 Canvas 3D图表】HTML5 Canvas 是一种强大的Web绘图技术,允许开发者在浏览器端进行2D和3D图形的绘制。在本文中,我们将探讨如何使用Canvas实现3D动态图表,特别是在工业SCADA系统和电信网管领域的应用。 ...

    基于HTML5 Canvas实现的图表插件Chart.js实例.zip

    这个压缩包文件"基于HTML5 Canvas实现的图表插件Chart.js实例.zip"包含了使用Chart.js的实例代码,可以帮助开发者快速理解和应用Chart.js。 Chart.js的特点和优势: 1. **简洁API**:Chart.js的API设计简单直观,...

    HTML5 Canvas 3D折线图表.zip

    2. 3D图形:在HTML5 Canvas中,3D图形通常是通过WebGL(Web Graphics Library)实现的,这是一个基于OpenGL标准的JavaScript API,可以实现硬件加速的3D图形渲染。WebGL允许开发者在浏览器环境中创建复杂的3D场景,...

    基于html5的Chart.js图表js库

    **基于HTML5的Chart.js图表JS库** Chart.js是一个轻量级且易于使用的JavaScript库,专为在Web页面上创建动态、美观的数据可视化而设计。它利用HTML5的Canvas元素来绘制各种图表,如条形图、饼图、线形图、雷达图等...

    3D Chart Html5 Canvas demo

    在IT领域,3D图表是一种将复杂数据可视化的重要工具,特别是在网页开发中,利用Html5 Canvas元素可以创建出交互式的3D图表。本文将深入探讨3D图表在Html5 Canvas中的实现及其相关知识点。 首先,Html5是现代网页...

    3D Chart Html5 Canvas

    ### 3D Chart Html5 Canvas:深入解析与技术要点 #### 概述 在现代Web开发领域,数据可视化成为了一项关键技能,特别是在商业智能、数据分析以及报告展示方面。3D图表作为数据可视化的一种高级形式,能够提供更...

    基于html5开发的canvas图表案例.zip

    "基于html5开发的canvas图表案例.zip"是一个压缩包,包含了使用HTML5 Canvas技术进行图表绘制的示例代码,让我们深入探讨一下这个主题。 Canvas是一个基于矢量图形的画布,开发者可以通过JavaScript API在画布上...

    HTML5 Canvas简单实用的图表插件-Chart.js

    Chart.js是一款简单实用的基于HTML5 canvas的js图表插件。该js图表插件利用canvas的特性,动态生成各种类型的图表。图表类型有:柱状图、线性图、饼状图、环状图、极坐标图和雷达图。并可以自定义tooltips。

    HTML5 Canvas实现的图表插件Chart.js实例

    chart.js是一款基于HTML5 Canvas的图表插件,其功能非常强大,不仅提供了常见的柱形图、折线图、饼状图,还提供了环形图、雷达图,样式外观多样,图表的色彩搭配也比较清新。chart.js还有一个特点就是图表在初始化的...

    html5 canvas+Chart.js工资收入曲线图表走势代码

    总结来说,"html5 canvas+Chart.js工资收入曲线图表走势代码"项目利用HTML5的Canvas和Chart.js库,结合CSS样式,创建了一个直观、美观的工资收入变化图表。这种技术可以广泛应用于个人财务跟踪、数据分析展示等领域...

    jquery html5 canvas 图表插件获取表格数据值

    总之,结合jQuery的强大DOM操作、HTML5 Canvas的绘图能力和Chart.js这样的图表插件,可以实现动态且具有交互性的数据可视化。这个过程涉及的技术包括选择和提取表格数据、初始化和更新Canvas图表,以及可能的Ajax...

    XCL-Charts基于原生的Canvas来绘制各种图表,在设计时,尽量在保证开发效率的同时,给使用者提供足够多的定制化能力

    目前支持3D/非3D柱形图(Bar Chart)、3D/非3D饼图(Pie Chart)、堆积图(Stacked Bar Chart)、面积图(Area Chart)、 折线图(Line Chart)、曲线图(Spline Chart)、环形图(Dount Chart)、南丁格尔玫瑰图(Rose Chart)、...

    Chartjs使用canvas标签的实现简洁HTML5图表

    Chart.js是一款轻量级的JavaScript库,专门用于创建HTML5 Canvas元素上的数据可视化图表。它以其简洁、易于理解和使用的API而受到开发者的欢迎。在本文中,我们将深入探讨如何使用Chart.js来创建各种类型的图表,并...

    HTML5基于Canvas实现的折线图表和柱形图表源码.zip

    这个压缩包“HTML5基于Canvas实现的折线图表和柱形图表源码.zip”包含了一组利用HTML5 Canvas API创建的折线图和柱形图的源代码示例。下面我们将深入探讨HTML5 Canvas以及如何利用它来制作这些图表。 Canvas是HTML5...

    android图表,柱形图,仪表盘,曲线图,支持3D

    基于原生的Canvas来绘制各种图表。 目前支持(3D/非3D,背向式/横向/竖向)柱形图(Bar Chart)、3D/非3D饼图(Pie Chart)、堆叠图(Stacked Bar Chart)、面积图(Area Chart)、 折线图(Line Chart)、曲线图(Spline Chart)...

    体会HTML5的canvas元素之图表练习源码

    HTML5的canvas元素是网页开发中的一个重要组成部分,它允许开发者在网页上进行动态图形绘制,提供了丰富的绘图功能,使得创建交互式图表、游戏、动画等成为可能。在这个"体会HTML5的canvas元素之图表练习源码"中,...

Global site tag (gtag.js) - Google Analytics