首頁 >web前端 >H5教程 >基於HTML5 Canvas實現的3D動態Chart圖表

基於HTML5 Canvas實現的3D動態Chart圖表

不言
不言原創
2018-06-20 10:53:582296瀏覽

這篇文章主要介紹了基於HTML5 Canvas的3D動態Chart圖表的範例,內容挺不錯的,現在分享給大家,也給大家做個參考。

發現現在工業SCADA上或電信網管方面用圖表的特別多,雖然絕大部分人在圖表製作方面用的是echarts,他確實好用,但是有些時候我們不能調用別的插件,這時候就得自己寫這些美麗的圖表了,然而圖表輕易做不成美麗的。 。 。看到有一個網站上在賣的圖表,感覺蠻好看的,就用HT for Web 3D 做了一個小例子,挺簡單的,也挺好看的,哈哈~

動態效果圖如下:

這個範例用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(&#39;myHeight&#39;) < 100){
        node.a(&#39;myHeight&#39;, (node.getAttr(&#39;myHeight&#39;)+1));
    node.s3(20, node.a(&#39;myHeight&#39;), 20);
    node.p3(p3[0], node.a(&#39;myHeight&#39;)/2, p3[2]);
    }else{
        node.a(&#39;myHeight&#39;, 0);
    node.s3([20, 0, 20]);
    node.p3([p3[0], 0, p3[2]]);
    }
    if (text) text.s(&#39;shape3d.text&#39;, node.a(&#39;myHeight&#39;)+&#39;%&#39;);
}, 100);

#這裡,我自訂的屬性「myHeight」 就起到了決定性的作用,我用這個屬性來儲存變量,而且可以任意更改變數的值,這樣就能實現動態綁定的效果了。

還有不懂的可以留言,或是直接去我們官網上查看手冊HT for Web,有更多你想不到的效果能快速實現哦~

以上就是本文的全部內容,希望對大家的學習有幫助,更多相關內容請關注PHP中文網!

相關推薦:

如何利用canvas實作按住滑鼠移動繪製出軌跡

用HTML5 Canvas來繪製三角形和矩形等多邊形的方法

JS和CSS實作漸變背景特效的程式碼

以上是基於HTML5 Canvas實現的3D動態Chart圖表的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn