この記事は、HTML5 ベースのネットワーク トポロジ マップ アプリケーションの急速な開発に関する関連情報を主に紹介します。編集者は、これが非常に優れていると考えたので、参考として共有します。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。
今日から、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体中
addToDOM = function(){ var self = this, view = self.getView(), //获取组件底层 p style = view.style; document.body.appendChild(view);//将底层 p 添加进 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);//设置节点位置 如果组中只有一个节点,那么这个节点的位置可以为组的位置
var edge = new ht.Edge(server, client); dm.add(edge);
edge.s({//节点设置样式属性 'edge.dash': true,//显示虚线 'edge.dash.flow': true,//开启虚线流动 'edge.dash.color': 'yellow',//虚线颜色 'edge.dash.pattern': [8, 8],//虚线样式 'label': 'flow',//节点注释 'label.background': 'pink',//节点注释背景颜色 });
group.s({ 'group.background': 'rgba(255, 255, 0, 0.1)',//设置组的背景颜色 'note': "Double click me!",//标注 显示的内容 'note.position': 13,//标注位置 'note.offset.y': 10,//标注位置y轴偏移 });
すべてのコードが解析されました!進捗が遅いと感じた場合は、公式 Web サイト (HT for Web) にアクセスして学習してください。この記事の内容を自分の知識に変えましょう!
関連する推奨事項:以上がHTML5ネットワークトポロジ図適用例説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。