提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2024-03-18 11:12:54.350|阅读 45 次
概述:本文将主要介绍如何用DHTMLX构建自定义JavaScript甘特图,欢迎下载最新版组件体验!
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
DHTMLX Gantt是用于跨浏览器和跨平台应用程序的功能齐全的Gantt图表。可满足项目管理应用程序的所有需求,是最完善的甘特图图表库。
当您声称您的产品具有高级定制功能时,客户一定会对产品进行严格测试,这个规则当然适用于DHTMLX Gantt,官方技术团队收到了很多关于如何在JavaScript甘特图组件中实现某些外观定制的请求,结合实际的案例,我们将在本文中为您展示如何在实践中实现这些定制。在上文中(点击这里回顾>>),我们主要介绍了JavaScript甘特图用例以及如何可是构建一个JS甘特图,本文将继续介绍如何构建JS甘特图。
下一个特性是将资源(在我们的例子中是员工)分配给任务的能力,DHTMLX Gantt以广泛的资源管理能力而闻名,包括一个单独的资源面板。
但是如果您需要对单个元素进行更简单的配置,则可以使用简化形式的资源。
在我们的演示中,有一个数组其中指定了员工的姓名和照片,这意味着这些数据可以从服务器加载。
const resourceData = [ { "key": "1", "label": "John" }, { "key": "2", "label": "Mike" }, { "key": "3", "label": "Anna" }, { "key": "4", "label": "Bill" }, { "key": "5", "label": "Floe" }, ]
DHTMLX Gantt有一个lightbox部分,使您能够为一个任务分配多个资源并指定资源值(小时,天,材料等)。为了使其正常工作,您需要在options参数中指定一个带有资源的数组。
{ name: "resources", type: "resources", map_to: "owners", options: resourceData, default_value: 8 },
如果使用简单的甘特配置() 并且使用load()或parse()方法从服务器加载资源,Gantt将自动向lightbox部分添加必要的参数。
当使用自定义配置时,数组必须包含带有key和label参数的对象。
在我们的演示中,还显示了网格部分中分配给任务的资源(员工照片)。为此需要使用列配置的模板函数,其中将返回getOwnerPics函数的值。
name: "owners", label: "Owners", resize: true, width: 75, template: function (task) { return getOwnerPics(task); }
在这个函数中,有必要使用owner任务属性,其中指定了分配的资源。如果存在分配,则应该将资源ID添加到单独的所有者数组中。
下一步是用资源数据遍历数组,如果资源ID在所有者数组中,则获取带有照片的属性并将其添加到images变量中,之后返回这个包含所有员工照片的变量。
function getOwnerPics(task) { let images = ""; const owners = []; (task.owners || []).forEach(function (el) { owners.push(el.resource_id); }) resourceData.forEach(function (resource) { if (owners.indexOf(resource.key) > -1) { images += " " + resource.img || ""; } }) return images; }
如果您看了Gantt演示,可以看到一些任务栏中显示了任务名称和资源图像。如果它们不适合,这些元素将显示在任务栏的右侧。
要确定任务名称和员工图像是否可以放置在任务栏中,需要应用detectOverflow函数。在这个函数中,首先使用getTaskPosition()方法来获取任务栏的坐标。因为您只需要任务栏的宽度,所以从getTaskPosition()方法返回的对象中获取宽度参数。
const taskWidth = gantt.getTaskPosition(task, task.start_date, task.end_date).width;
然后需要创建canvas元素,使用getComputedStyle()方法查找通常在任务栏中显示的文本字体样式和字体大小。之后在context元素中指定这些参数,并使用measureText()方法来确定文本宽度。
const canvas = document.createElement('canvas'); const context = canvas.getContext("2d"); const bar = document.querySelector(".gantt_task_content") if (bar) { const fontFamily = getComputedStyle(bar)['font-family']; const fontSize = getComputedStyle(bar)['font-size']; context.font = fontSize + ' ' + fontFamily; } const textWidth = context.measureText(task.text).width;
现在是时候将照片添加到任务栏了,您需要指定这些照片的宽度。在我们的演示中,图像的宽度被调整为任务栏的高度,因此您可以使用gantt.config.row_height配置的值。但如果元素的宽度不同,则需要设置一个新值,宽度值必须乘以分配给给定任务的资源数量。
const ownersWidth = (task.owners || []).length * gantt.config.row_height;
现在有必要对文本和图像的宽度值进行总结,如果结果值大于任务栏的宽度,则返回true,这意味着内容(文本+照片)不会包含在任务栏中。
if (textWidth + ownersWidth > taskWidth) { return true; }
如果detectOverflow返回false,则task_text模板包含以下条件。如果任务类型是项目,则只需返回任务文本。如果它是一个常规任务,则返回一个HTML元素,其中包含任务文本和可以从getOwnerPics函数获得的员工照片。
gantt.templates.task_text = function (start, end, task) { if (detectOverflow(task)) { return "" } else { if (task.type == gantt.config.types.project) { return task.text; } else { return `<span style="vertical-align: top" >${task.text}</span>${getOwnerPics(task)}`; } } };
在rightside_text模板中,对“task”类型的任务使用detectOverflow函数。如果此函数返回true,则应该返回一个HTML元素,其中包含来自getOwnerPics函数的任务文本和员工图像。
在DHTMLX Gantt中可以只使用一个模板,您不能多次指定不同的模板并期望它们正常工作,所以必须在一个模板中添加所有的代码:
gantt.templates.rightside_text = function (start, end, task) { if (task.type == gantt.config.types.project) { return `<div class='project-right' style="${getTriangleStyles(task, "right")}"></div>` } if (detectOverflow(task)) { return `<span style="vertical-align: top" >${task.text}</span>${getOwnerPics(task)}`; } return ""; };
由于篇幅有限,下期继续讲解,请持续关注查看最新产品资讯哦~
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn
文章转载自:慧都网Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
在处理电子表格时,尤其是在专业和数据导向型环境中,正确设置 Excel 单元格内的数字格式至关重要。本文将介绍如何使用 Spire.XLS for Java 设置 Excel 单元格的数字格式,帮助轻松创建精美且结构清晰的电子表格。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@pclwef.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢