没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:王香|2019-03-28 15:03:05.000|阅读 185 次
概述:通过调用setCustomNodeType启用自定义节点的交互式绘制,然后通过调用setCustomNodeType和setBehavior启用自定义节点的交互式绘制。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
在上篇文章中我们讲到了如何创建一个组织结构图的References和HTML设置,本文接着讲图和节点以及圆形图像。
在文档的read()函数中,我们使用对我们在第I部分中创建的画布中引用创建了Diagram类的实例。
// create a Diagram component that wraps the "diagram" canvas diagram = Diagram.create($("#diagram")[0]);
然后我们通过调用setCustomNodeType启用自定义节点的交互式绘制,然后通过调用setCustomNodeType和setBehavior启用自定义节点的交互式绘制:
// enable drawing of custom nodes interactively diagram.setCustomNodeType(OrgChartNode); diagram.setBehavior(Behavior.Custom);
图中的行为设置为Custom,这意味着当用户开始绘制节点时,库应绘制CustomNodeType指定的节点。setCustomNodeType方法表明图表这些自定义节点的类型为OrgChartNode。
现在,开始创建节点:
var node1 = new OrgChartNode(diagram); node1.setBounds(new Rect(25, 15, 60, 25)); node1.setTitle("CEO"); node1.setFullName("John Smith"); node1.setDetails( "Our beloved leader. \r\n" + "The CEO of this great corporation."); node1.setImage("ceo.png"); diagram.addItem(node1);
我们使用相同的代码创建更多节点,然后将它们绑定在层次结构中。通过调用Diagram Factory类的Diagram Factory createDiagramLink方法创建节点之间的链接:
diagram.getFactory().createDiagramLink(node1, node2); diagram.getFactory().createDiagramLink(node1, node3); diagram.getFactory().createDiagramLink(node1, node4); diagram.getFactory().createDiagramLink(node4, node5);
我们现在想要向节点添加一个custom feature/自定义特征 - 而不是将图像绘制为矩形,我们想要剪切它并将其显示为椭圆。 我们将通过使用替换标准setImage方法的方法来完成此操作。
新方法称为createImageClip,并将两个对象作为参数:一个是图像URL,另一个是使用此图像的节点。
function createImageClip(path, node) { var canvas = document.createElement('canvas'), ctx = canvas.getContext('2d'), img = document.createElement('img'); ..............
我们创建了两个HTMLElements - 画布和图像,我们得到了Canvas的2D上下文。 然后,在图像的onload事件的事件处理程序中,我们将画布剪切到由Path定义的区域。 该路径读取图像的大小并创建一个完整的弧,例如 那个矩形内的一个圆圈。 然后,上下文绘制图像,并使用setImage方法将新画布设置为节点的图像:
img.src = path; img.onload = function () { canvas.width = img.width; canvas.height = img.height; var halfSize = img.width / 2; ctx.save(); ctx.beginPath(); ctx.arc(halfSize, halfSize, halfSize, 0, Math.PI * 2, true); ctx.closePath(); ctx.clip(); ctx.drawImage(img, 0, 0, img.width, img.height); node.setImage(canvas.toDataURL()); };
您可以使用此方法创建具有可变形状的图像的剪辑。
node1.setImage("ceo.png");
用这种方式调用自定义方法:
createImageClip("ceo.png", node1);
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
在许多企业应用程序中,从 Visio 文件读取形状数据是一项常见需求,因为这些应用程序中的图表都包含有意义的元数据。本教程将借助Aspose.Diagram,以清晰实用的方式指导您使用 C# 读取形状数据。
PDF 的页面大小决定了其内容的显示、打印或处理方式。在准备打印、转换格式或标准化布局时,我们通常需要更改PDF文档的纸张大小。在本教程中,您将学习如何使用 Java 编辑任何 PDF 文件的页面大小。我们将通过完整的代码示例,逐步指导您完成操作。
本文主要介绍如何使用DevExpress WPF Grid控件中的节点(Nodes)概述,欢迎下载最新版组件体验!
本教程提供DevExpress WinFormsWinExplorer视图的基本信息,欢迎下载最新版组件体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号