提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:王香|2019-03-26 13:47:42.000|阅读 438 次
概述:在本文中,我们将创建一个组织结构图,该图使用每个员工的自定义节点。该图将使用Diagramming for JavaScript库创建。对于节点,我们使用CompositeNode类,这使我们能够创建图表节点,其外观可以通过组件和布局容器的组合来定义。
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
相关链接:
在本文中,我们将创建一个组织结构图,该图使用每个员工的自定义节点。该图将使用Diagramming for JavaScript库创建。对于节点,我们使用CompositeNode类,这使我们能够创建图表节点,其外观可以通过组件和布局容器的组合来定义。

我们要做的第一件事是为示例创建一个网页,并添加对必要的JavaScript文件的引用。在页面的部分中,我们提供了对以下jQuery文件的引用:
<a href="//common/jquery.min.js">//common/jquery.min.js</a> <a href="//common/jquery-ui.min.js">//common/jquery-ui.min.js</a>
在HTML页面的末尾,就在结束标记之前,我们放置了对Diagramming库使用的两个JavaScript文件的引用:
<a href="//MindFusion.Common.js">//MindFusion.Common.js</a> <a href="//MindFusion.Diagramming.js">//MindFusion.Diagramming.js</a>
我们的示例将其JS代码放在一个名为Script.js的单独文件中。我们也提到了它的引用:
<a href="//Script.js">//Script.js</a>
图库需要HTML Canvas来绘制自己。我们在网页中间添加一个:
<div style="width: 100%; height: 100%; overflow: auto;"> <canvas id="diagram" width="2100" height="2100"> This page requires a browser that supports HTML 5 Canvas element. </canvas> </div>
在Script.js文件中,我们首先将映射添加到我们将从图库中使用的一些枚举和类中:
var Diagram = MindFusion.Diagramming.Diagram; var CompositeNode = MindFusion.Diagramming.CompositeNode; var Behavior = MindFusion.Diagramming.Behavior; var Alignment = MindFusion.Drawing.Alignment; var Rect = MindFusion.Drawing.Rect;
现在我们调用CompositeNode 的classFromTemplate方法,该方法使用我们将提供的JSON模板生成节点类:
var OrgChartNode = CompositeNode.classFromTemplate("OrgChartNode",
{
component: "GridPanel",
rowDefinitions: ["*"],
columnDefinitions: ["22", "*"],
...............
在此代码中,我们指出CompositeNode将使用的面板是GridPanel。然后我们声明两个列表,用于设置网格行和列的宽度和高度。每个数组中的成员数表示网格有多少行/列。在我们的例子中,我们有一行占据所有位置和两列:一列是固定的22像素,另一列占用剩余的可用空间。
CompositeNode的JSON定义继续使用包含子项的数组:
children:
[
{
component: "Rect",
name: "Background",
pen: "black",
brush: "white",
columnSpan: 2
},
{
component: "Image",
name: "Image",
autoProperty: true,
location: "ceo.png",
margin: "1",
imageAlign: "Fit"
},
第一个子节点使用我们称之为“背景” 的Rect组件。它使用白色笔刷进行渲染,具有黑色轮廓并跨越两列,例如,它填充所有可用空间或每个节点。
第二个子类是一个对象。请注意行:
autoProperty: true
这意味着我们希望能够将此组件作为属性进行访问。在这种情况下,库使用组件的名称生成自动set / get方法。在我们的示例中,它们将是setImage / getImage。
第三个子节点是StackPanel组件。这是节点旁边的文本标签的容器。这个孩子有自己的子节点集合:
component: "StackPanel",
orientation: "Vertical",
gridColumn: 1,
margin: "1",
verticalAlignment: "Near",
children:
[
{
component: "Text",
name: "Title",
autoProperty: true,
text: "title",
font: "Arial bold"
},
{
component: "Text",
name: "FullName",
autoProperty: true,
text: "full name",
pen: "blue",
padding: "1,0,1,0"
},
{
component: "Text",
name: "Details",
autoProperty: true,
text: "details",
font: "Arial 3"
}
这个新StackPanel的子代是文本组件,称为Title,FullName和Details。他们将autoProperty设置为true,这意味着我们可以通过自动setter和getter方法访问它们的值。
购买Mindfusion正版授权,请点击“”哟!
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn
FlowChart.NET是一款能够帮助你轻松创建流程图和示意图的.NET控件,可以自定义设计样式和图表框颜色。
在嵌入式软件测试领域,对交叉编译代码进行单元测试是一大挑战。Parasoft C/C++test作为专业的C/C++测试工具,能够与劳特巴赫Trace32调试器深度集成。下面会详细介绍如何在C++test中配置Trace32调试器,实现对PowerPC架构程序的单元测试,涵盖环境设置、项目导入到测试执行的全过程。
本文将为大家介绍如何使用DevExpress WinForms数据网格控件实现摘要文本的格式化,欢迎下载最新版组件体验!
Parasoft C/C++test作为一款功能强大的自动化测试工具,为嵌入式开发提供了全面的测试解决方案。特别是在CCS开发环境中,C++test能够无缝集成,为F2812等DSP项目提供专业的单元测试支持。下面将介绍如何在CCS3环境下配置和使用C++test进行F2812项目的单元测试。
在嵌入式开发中,尤其是基于ARM架构的安全关键领域,单元测试是验证代码在目标硬件上运行时行为正确性的关键环节,对于保障最终产品的可靠性至关重要。下面将介绍如何利用Parasoft C/C++test开展单元测试,包括配置、执行及解决可能遇到的许可证问题,完成从静态检查到动态运行的完整测试闭环。
相关产品
它能帮助你创建工作流图,流程图和图表处理
MindFusion.Diagramming for WinFormsFlowChart.NET是一款能够帮助你轻松创建流程图和示意图的.NET控件,可以自定义设计样式和图表框颜色。
MindFusion.Diagramming for ASP.NETASP.NET下灵活的图表组件
MindFusion.Diagramming for Java为您图表的自定义以及个性化提供了多种不同选项
MindFusion.Scheduling for WinForms帮助你管理时间以及重新安排即将到来的预约与事件
最新文章 MORE
永利最大(官方)网站相关的文章 MORE
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@hmdbvip.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
永利最大(官方)网站 