国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > HTML5 > 正文

詳解快速開發基于 HTML5 網絡拓撲圖應用

2024-09-05 07:22:18
字體:
來源:轉載
供稿:網友

今天開始我們就從最基礎解析如何構建 HTML5 Canvas 拓撲圖應用,HT 內部封裝了一個拓撲圖形組件 ht.graph.GraphView(以下簡稱 GraphView)是 HT 框架中 2D 功能最豐富的組件,其相關類庫都在 ht.graph 包下。GraphView 具有基本圖形的呈現和編輯功能,拓撲節點連線及自動布局功能,電力和電信等行業預定義對象,具有動畫渲染等特效,因此其應用面很廣泛,可作為監控領域的繪圖工具和人機界面,可作為一般性的圖形化編輯工具,可擴展成工作流和組織圖等企業應用。簡單說來就是:拓撲圖是泛化的說法,電信網管的網絡拓撲圖、電力的電網拓撲圖、工業控制的監控圖、工作流程圖、思維腦圖等等,簡單說就是節點連線構成的這些都是這里指的拓撲圖。

用 HT 開發一個網絡拓撲圖是非常容易的一件事,只需要短短幾行代碼就能完成一個簡單的服務器與客戶端的拓撲圖:

這個例子非常基礎,幾乎完成了服務器與客戶端在拓撲上的所有功能。話不多說,猜猜看這個例子包括 HTML 標簽的所有部分總共花了多少行代碼?減去空行也就 50 行,我還做了很多樣式部分的設計,畢竟給大家看的例子不能太丑嘛~

大家可以在 tuputu_jb51.rar 自行下載代碼,注意因為有 json 文件,會存在圖片跨域問題,需要用 Firefox 或者本地服務器跑起來。

我們在最開始就說明一下,HT 是基于 HTML5 標準的企業應用圖形界面一站式解決方案, 其包含通用組件、拓撲組件和 3D 渲染引擎等豐富的圖形界面開發類庫,用戶只需要引入 ht.js 即可,而且跟別的任何東西完全不沖突,因為 HT 只是聲明了一個全局變量 ht,僅此而已。

接下來解析代碼部分,首先,搭建拓撲圖場景:

dm = new ht.DataModel();//數據容器gv = new ht.graph.GraphView(dm);//拓撲組件 參數為dm 綁定的數據模型gv.addToDOM();//將拓撲圖添加進body體中

HT 的所有組件的根部都是一個 div,通過 getView() 方法獲取,我們在 addToDOM 方法中就用到了這個方法:

addToDOM = function(){       var self = this,        view = self.getView(),  //獲取組件底層 div        style = view.style;     document.body.appendChild(view);//將底層 div 添加進 body 體中               style.left = '0';//HT 一般將組件都設置為 absolute 的絕對定位    style.right = '0';    style.top = '0';    style.bottom = '0';          window.addEventListener('resize', function () { self.iv(); }, false); //事件監聽窗口大小變化,iv 為延時刷新組件         }

然后向拓撲場景中添加“服務器”以及“客戶端”節點:

var server = new ht.Node();server.setName('server');//設置節點名稱,顯示在節點下方server.setImage('serverImage');//設置節點圖片server.setSize(20, 60);//設置節點大小dm.add(server);//將節點添加進數據容器dm中server.setPosition(100, 100);//設置節點坐標(x, y)var group = new ht.Group();//組,組中可以有多個節點group.setImage('groupImage');//設置圖片dm.add(group);var client = new ht.Node();//這個節點是添加進組中的client.setName('client');client.setImage('clientImage');dm.add(client);group.addChild(client);//組添加孩子group.setExpanded(true);//設置組為展開模式client.setPosition(200, 100);//設置節點位置 如果組中只有一個節點,那么這個節點的位置可以為組的位置

服務端與客戶端的連線?2 行代碼搞定!其實 HT 中添加節點的方法非常簡單,一般就 2 行代碼能結束:先聲明實例變量,然后將這個實例變量添加進數據容器中。

var edge = new ht.Edge(server, client);dm.add(edge);

我們很好奇虛線是怎么做出來的?虛線的形成是搭建在連線之上的,步驟有 3 個:

  1. 引入 ht-dashflow.js 文件 ;
  2. 將連線的樣式屬性 edge.dash.flow 設置為 true;
  3. 在場景組件中打開虛線流動的開關,這里就是 gv.enableDashFlow(true);

是不是非常簡單!接下來我們看看怎么設置:

edge.s({//節點設置樣式屬性    'edge.dash': true,//顯示虛線    'edge.dash.flow': true,//開啟虛線流動    'edge.dash.color': 'yellow',//虛線顏色    'edge.dash.pattern': [8, 8],//虛線樣式    'label': 'flow',//節點注釋    'label.background': 'pink',//節點注釋背景顏色        });

這樣所有的顯示部分就介紹完畢啦~等等,好像還少點什么?對了,我忘了介紹 HT 中的 ht.Group 類了,顧名思義,就是“組”的意思,組中可以包含很多節點,雙擊可顯示或隱藏組內的所有節點,上面代碼有寫到,但是我還做了一點小動作,就是組右上角的顯示部分,其實就是一個標注,用來提示說明的:

group.s({    'group.background': 'rgba(255, 255, 0, 0.1)',//設置組的背景顏色    'note': "Double click me!",//標注 顯示的內容    'note.position': 13,//標注位置    'note.offset.y': 10,//標注位置y軸偏移});

我們可以通過 note.position 來改變標注的位置(具體位置信息請參考HT for Web 位置手冊 ),也可以使用 note.offset.x 和 note.offset.y 來改變標注的位置。

全部代碼解析完畢!我會盡快更新,如果大家覺得進度慢的話,可以自己去我們官網( HT for Web )上學習,希望大家能有更多的收獲,學習是自己的事情,快動手實踐將這片文章的內容變成你自己的知識吧!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 定边县| 吐鲁番市| 本溪市| 临澧县| 双鸭山市| 禄劝| 旺苍县| 汉川市| 长白| 建始县| 平泉县| 颍上县| 梧州市| 阜新市| 高州市| 平舆县| 宁国市| 洛扎县| 承德市| 永靖县| 逊克县| 康乐县| 枞阳县| 韶山市| 牡丹江市| 宁强县| 湖州市| 江油市| 大姚县| 肃宁县| 平山县| 桦川县| 黄陵县| 潞西市| 舟山市| 廊坊市| 周宁县| 高碑店市| 宜昌市| 雅安市| 海门市|