提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:吴园园|2019-07-11 10:18:53.910|阅读 618 次
概述:AnyChart是灵活的高度可定制的跨浏览器、跨平台JavaScript (HTML5) 图表控件。本教程将为您介绍如何使用多级X轴编写JS柱形图。
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
相关链接:

我们将继续更新 Challenge AnyChart!我们提供了新的数据可视化教程。他们很好地展示了我们的JavaScript图表库是多么强大,现在我们将向您展示如何构建另一个有趣的图表,其外观不同但代码非常相似 - 具有多级X轴的交互式JS柱形图。
数据可视化任务
以下是客户要求我们解决的问题:
我想在柱形图中显示子类别的数据,是否可能?
为了说明如何放置嵌套轴,他们附上了以下图片:

●使用视图和迭代器对象处理数据,
●使用额外的轴,
●使用自定义比例,
●使用刻度蜱的重量。
方案概述
首先,让我们修改源数据并在其中添加空值,以便按类别直观地分隔数据。
然后,绘制图表并完成比例和边界的计算后,添加一个额外的轴并以首选方式设置刻度和标签。
预处理
在将数据提供给图表之前,让我们将空值添加到数据中,这将使一个类别结束而另一个类别开始的位置可见。
要实现此目的,请在数组的开头添加一个空值,在结尾添加一个空值,并在每次类别名称更改时添加两个空项。
function preprocessData(data){
if (data.length > 0) {
data.unshift([data[0][0]]);
data.push([data[data.length - 1][0]]);
for (var i = 2; i < data.length - 1; i++) {
var previous = data[i-1][0];
var current = data[i][0];
if (current!=previous) {
data.splice(i, 0, [previous], [current]);
i = i+2;
}
else {
data.splice(i, 0, [previous]);
i += 1;
}
}
}
return anychart.data.set(data);}完成后,使用mapAs()方法将子类别名称添加到元数据中 以获取不同的视图,并将它们用作X轴的名称,如下所示:
chart.column(data.mapAs({'year': 0, 'value': 2, 'sub-category': 1}));
chart.xScale().names('sub-category');现在可以绘制JS柱形图本身。
JS柱形图上的额外轴和附加比例
现在是为图表添加额外轴的时候了。要实现此目的,请使用迭代器对象创建一个函数。它将用于探索视图和查找类别和子类别。
之后,在类别之间绘制刻度并设置权重。这将使图表更好看:
var iter = data.mapAs({'category': 0, 'sub-category': 1}).getIterator();while(iter.advance()) { var name = iter.get('category'); var value = iter.get('sub-category');
names.push(name);
if (name && names[names.length - 1] != names[names.length - 2])
ticks.push(iter.getIndex());
}
weights.push(value?0.5:0.2);}轴与秤一起使用。更确切地说,前者可视化后者。因此,为了实现该想法,需要包含类别和子类别的数据的自定义比例。然后让我们将值,名称和刻度传递给此比例:
var customScale = anychart.scales.ordinal(); customScale.values(chart.xScale().values()); customScale.names(names);customScale.ticks(ticks);
并在其上构建新轴:
chart.xAxis(1)
.scale(customScale)
.orientation('top')
.ticks(true);最后,我们将权重与图表比例同步:
chart.xScale().weights(weights);
并禁用主轴上的刻度:
chart.xAxis(0).ticks(false);
如前所述,AnyChart一切皆有可能!现在,已准备好呈现已经在教程中创建的具有多级X轴的整个JS柱形图。

想要购买AnyChart正版授权的朋友可以。
有关产品动态更多的精彩内容,敬请关注下方的微信公众号▼▼▼

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn
文章转载自:



Parasoft C/C++test是一款专为C/C++代码设计的自动化测试工具,通过静态代码分析、单元测试和运行时错误检测等功能,帮助开发团队在早期发现并修复缺陷,提升代码质量和开发效率 。在实际使用中,尤其是在VC6此类旧版开发环境中执行单元测试时,可能会因环境兼容性问题触发链接错误。
本文主要介绍如何在MVVM应用程序中使用虚拟源,欢迎下载最新版组件体验!
Aspose.Slides for Java使用户能够轻松地操作幻灯片、添加注释和转换文件。其易用性和集成能力提高了工作效率,使开发人员能够专注于更关键的任务。
在嵌入式软件测试领域,对交叉编译代码进行单元测试是一大挑战。Parasoft C/C++test作为专业的C/C++测试工具,能够与劳特巴赫Trace32调试器深度集成。下面会详细介绍如何在C++test中配置Trace32调试器,实现对PowerPC架构程序的单元测试,涵盖环境设置、项目导入到测试执行的全过程。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@hmdbvip.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
永利最大(官方)网站