提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2024-04-09 10:03:11.407|阅读 119 次
概述:本教程将为大家介绍如何使用图表控件LightningChart JS创建堆叠条形图,欢迎下载组件体验!
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
LightningChartJS是Web上性能特高的图表库,具有出色的执行性能 - 使用高数据速率同时监控数十个数据源。 GPU加速和WebGL渲染确保您的设备的图形处理器得到有效利用,从而实现高刷新率和流畅的动画,常用于贸易,工程,航空航天,医药和其他领域的应用。
LightningChart JS提供了堆叠条形图,用于轻松创建具有可定制功能的数据应用程序。
当看到来自不同类别或彼此值的大量数据时,堆叠条形图非常有用。我们可以看到一个类别是如何被分成几个部分的,从最大到最小的部分相对于总量,堆叠条形图有两种类型:
简单的堆叠条形图将每个值连续地放在一个段中,条形图的总价值就是该段的总价值,它是比较片段之间总数量的理想方法。
100%堆叠条形图显示了每个细分市场中每个类别的总百分比,并用每个值占该细分市场总数量的百分比表示,这使得我们更容易看到各组数量的百分比差异。
根据数据分析的目标,我们可以根据可视化需求评估每个数据的有用性。在这种情况下,JavaScript堆叠条形图对于任何类型的用户来说都很容易理解。JavaScript堆叠条形图的另一个特性是以多色条形显示数据,其中每个条形代表一个主要类别,每种颜色代表一个次要维度,这使我们能够方便地查询每个段类别的次要维度及其关系之间的关系。
在本文中,我们将解释100%堆叠条形图,并使用LightningChart JS和Node JS创建堆叠条形图。请记住,您可以下载这个项目的模板并试用它,
1. 下载提供的模板来学习本教程。
2. 下载模板后,您会看到如下的文件树:
3. 打开一个新终端,运行npm install命令。
今天最新的版本是LightningChart JS 5.1.0和,建议您查看最新版本就并进行更新,因为一些LightningChart JS工具在以前的版本中不存在。
在项目的package.json文件中,你可以找到LightningChart JS依赖项:
"dependencies": {
"@arction/lcjs": "^5.1.0",
"@arction/xydata": "^1.4.0",
"webgl-obj-loader": "^2.0.8",
}
我们将从导入创建图表所需的库开始。
// Import LightningChartJS
const lcjs = require('@arction/lcjs')
const { lightningChart, BarChartSorting, LegendBoxBuilders, Themes } = lcjs
安装LightningChart JS库之后,我们将把它们导入到chart.ts文件中,注意,您将需要试用许可证,这是免费的。然后将其添加到一个变量中,该变量将用于创建JavaScript堆叠条形图对象。
let license = undefined
try {
license = 'xxxxxxxxxxxxx'
} catch (e) {}
LightningChart JS为您提供了完全自定义图表对象属性的可能性,将使用以下属性来创建这个JavaScript堆叠条形图:
const barChart = lightningChart({license: license})
.BarChart({
theme: Themes.cyberSpace,
})
.setTitle('% of market share by mobile OS in 1999-2021')
.setValueLabels(undefined)
.setCursorResultTableFormatter((builder, category, value, bar) => {
builder.addRow('OS:', bar.subCategory).addRow('Share:', String(value), '%')
return builder
})
– :定义JavaScript堆叠条形图的外观和感觉,注意您必须事先指定图表组件的颜色主题。
– :当光标指向本系列时,配置光标悬停结果表的格式,结果表将显示为一个带有数据值的弹出框。
每一行被生成为一行(.addrow),我们可以用需要的文本对其进行格式化。子类别和值属性对应于分配给图表的数据。子类别包含图表的类别或分组的名称,Value包含按类别堆叠的每个条的值。
.setCursorResultTableFormatter((builder, category, value, bar) => {
builder.addRow('OS:', bar.subCategory).addRow('Share:', String(value), '%')
要将类别和堆叠条形图添加到JavaScript堆叠条形图中,我们将使用setdatastack函数,这个函数允许添加水平轴分组和属于每个分组的类别。值数组中的值将按照其连续顺序对应于分组,例如值51将对应于组2004,每个类别将堆叠在另一个类别之上,但值将根据其位置和匹配组进行排序。
barChart.setDataStacked(
['1999', '2004', '2009', '2014', '2019', '2021'],
[
{ subCategory: 'Symbian OS', values: [1, 51, 43, 0, 0, 0] },
{ subCategory: 'Palm OS', values: [66, 18, 1, 0, 0, 0] },
{ subCategory: 'BlackBerry OS', values: [1, 7, 20, 0.5, 0, 0] },
{ subCategory: 'Windows Mobile', values: [20, 13, 7, 2, 0, 0] },
{ subCategory: 'iOS', values: [0, 0, 15, 19, 14, 27] },
{ subCategory: 'Android', values: [0, 0, 8, 77, 82, 72] },
{ subCategory: 'Other', values: [12, 11, 6, 1.5, 4, 1] },
],
)
最后我们将添加图例框,通过颜色指示类别,并在单击它们时隐藏想要的类别。
const legend = barChart
.addLegendBox(LegendBoxBuilders.VerticalLegendBox)
.setAutoDispose({
type: 'max-width',
maxWidth: 0.3,
})
legend.add(barChart)
图例框可以横向和纵向添加,此图例框可以在满足条件时自动删除,例如超过相对于图表大小的最大宽度,当图表分辨率太小或当图表太大时释放内存时,这很有用。
最后,在终端中运行npm start命令来可视化本地服务器上的JavaScript堆叠条形图。
JavaScript堆叠条形图是一种帮助我们更有效地可视化数据的资源,因为它能够轻松地表示复杂的数据集。即使这种类型的图表可能并不总是在所有仪表板报告中使用或看到,它也是简化按组或类别显示大量数据的一个很好的资源。
在这种情况下,LightningChart JS为我们提供了一个简单实用的图表组件:JavaScript堆叠条形图,同样我们不必过于担心用于开发图表应用程序的代码。
只需向我们的对象提供一个数据数组,就可以创建带有所有动画和可用控件的JavaScript堆叠条形图:
barChart.setDataStacked(
['1999', '2004', '2009', '2014', '2019', '2021'],
[
{ subCategory: 'Symbian OS', values: [1, 51, 43, 0, 0, 0] },
{ subCategory: 'Palm OS', values: [66, 18, 1, 0, 0, 0] },
{ subCategory: 'BlackBerry OS', values: [1, 7, 20, 0.5, 0, 0] },
{ subCategory: 'Windows Mobile', values: [20, 13, 7, 2, 0, 0] },
{ subCategory: 'iOS', values: [0, 0, 15, 19, 14, 27] },
{ subCategory: 'Android', values: [0, 0, 8, 77, 82, 72] },
{ subCategory: 'Other', values: [12, 11, 6, 1.5, 4, 1] },
],
)
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn
文章转载自:慧都网



在现代软件开发过程中,自动化单元测试是确保代码质量与可靠性的关键环节。尤其对于特定框架(如MFC)的代码,测试复杂度显著增加,常因依赖外部资源或交互操作而难以在静默环境中顺利执行。Parasoft C/C++test作为专业的软件测试工具,致力于帮助开发团队高效实施自动化测试,通过其强大的桩函数功能,能够有效模拟依赖组件的行为,从而实现对复杂逻辑的隔离测试。
本文将为大家介绍如何在MyEclipse中使用XDoclet开发EJB 2 Session Bean,欢迎下载最新版体验!
如果能将 CSV 自动转换为 PDF ,就能快速生成清晰、美观的报表,既节省手动排版时间,又能保持数据的专业呈现。本文将介绍如何使用 Spire.XLS for Java 实现这一过程——从加载 CSV 到输出高质量 PDF,仅需数行代码即可完成。
Parasoft C/C++test是一款专为C/C++代码设计的自动化测试工具,通过静态代码分析、单元测试和运行时错误检测等功能,帮助开发团队在早期发现并修复缺陷,提升代码质量和开发效率 。在实际使用中,尤其是在VC6此类旧版开发环境中执行单元测试时,可能会因环境兼容性问题触发链接错误。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@hmdbvip.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
永利最大(官方)网站