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

数据可视化任务
以下是客户制定挑战的任务:
我们有嵌套子类别的数据。如何在AnyChart的帮助下在堆叠列中显示类别和子类别?
此外,客户还分享了以下图片,以说明他想使用AnyChart的JavaScript图表库创建的内容:

要根据此任务构建解决方案,这是我们需要的:
通过视图和迭代器处理数据;
使用额外的轴;
使用自定义秤;
使用刻度蜱的重量。
方案概述
首先,让我们修改源数据并在其中添加空值,以便按类别直观地分隔数据。
然后,一旦绘制了图表并完成了比例和界限的计算,我们将添加额外的轴。
在数据中查找组
将数据作为数据提供给图表后,使用数据集不会停止。
借助mapAs方法,可以获得不同的视图,即按给定参数细分。我们将抓住这个机会。
然后,让我们使用 迭代器对象来探索视图,以便查找类别和子类别。
使用额外轴不作为轴
在我们要构建的JavaScript图表中,我们将使用三个X轴,一个主轴和两个额外轴。
一个X轴将是我们将完全用作轴的默认X轴。我们只会禁用自己的滴答声。
另一个X轴将仅用于定位主要类别。我们不会显示其刻度以及轴线。
第三个X轴将用于定位前两个轴共用的刻度线。
补充计算的附加量表
轴使用刻度并基本上可视化它们。因此,为了实现这个想法,我们需要一个包含有关类别和子类别的数据的自定义比例。
我们将分析数据并创建一组刻度和类别名称。然后我们将在那个尺度上构建轴。
使用Weights for Ticks作为可视化工具
为了获得一个漂亮的图片,其中不同的数据组彼此分开,让我们修改数据并在其中插入空值。
之后,为了将视觉焦点从空点转移到真实数据,我们将使用权重特征。
我们将得到的填充类型应该使得对这种可视化的数据的感知更有效。
结果:具有多级别类别轴的交互式JavaScript图表

使用多级别类别轴检查图表的代码:
anychart.onDocumentReady(function ()
{ var data = preprocessData([
['Accelerate', 'Onsite', 18, NaN, NaN],
['CIS Renew', 'Offshore', 6, NaN, 2],
['CIS Renew', 'Onsite', 7, 1, 4],
['CIS Others', 'Offshore', NaN, NaN, 1],
['CIS Others', 'Onsite', 2, 1, 1] ]);
var chart = anychart.column();
// configure global settings for series labels
chart.labels({position:'center', fontColor:'#000'});
//add subcategory names to the meta of one of the series
chart.column(data.mapAs({'value': 2, 'sub-category': 1}));
chart.column(data.mapAs({'value': 3}));
chart.column(data.mapAs({'value': 4}));
// turn on stacking
chart.yScale().stackMode('value');
// use subcategory names as names of X-axis ticks
chart.xScale().names('sub-category');
// set a container and draw the chart
chart.container('container');
chart.draw();
// calculate extra axes
createTwoLevelAxis(chart, data, 0.1); });
function preprocessData(data){
// to make beautiful spacing between categories, add
// several empty lines with the same category names to the data
if (data.length > 0) {
// add one to the beginning of the array
data.unshift([data[0][0]]);
// add one more to the end of the data
data.push([data[data.length - 1][0]]);
// add two empty items every time the category name changes,
// to each category
for (var i = 2; i < data.length - 2; i++) {
var previous = data[i-1][0];
var current = data[i][0];
if (current!=previous)
{
data.splice(i, 0, [previous], [current]);
i = i+2;
}
}
}
return anychart.data.set(data);
}
function createTwoLevelAxis(chart, data, padding){
// subcategory names
var names = [];
// ticks for axes based on on main categories
var ticks = [];
// weights of ticks (to make spacing between categories by using
// the empty lines created in preprocessData)
var weights = [];
// the iterator feature allows us to go over data, so
// create an iterator for the new breakdown
var iter = data.mapAs({'category': 0, 'sub-category': 1}).getIterator();
while(iter.advance()) {
var name = iter.get('category');
var value = iter.get('sub-category');
// store category names
names.push(name);
// when the border between categories is identified, create a tick
if (name && names[names.length - 1] != names[names.length - 2]) {
ticks.push(iter.getIndex());
}
// assign weight to the tick
weights.push(value?1:padding);
}
// create a custom scale
var customScale = anychart.scales.ordinal();
// supply values from the chart to the scale
customScale.values(chart.xScale().values());
// names of main categories only
customScale.names(names);
// weights for new ticks
customScale.weights(weights);
// synchronize weights with the
chart scale chart.xScale().weights(weights);
customScale.ticks(ticks);
// disable ticks along the main axis
chart.xAxis(0).ticks(false);
// create an extra chart axis and hide its ticks and the axis line, leaving only labels displayed
chart.xAxis(1)
.scale(customScale)
.stroke('none')
.ticks(false);
// draw one more extra axis without the axis line and labels, leaving only big ticks
var additionalXaxis = chart.xAxis(2);
additionalXaxis.scale(customScale);
additionalXaxis.labels(false);
additionalXaxis.stroke('none');
additionalXaxis.ticks()
.length(46)
.position('inside'); }本篇教程对您是否有用?欢迎分享您的疑问和看法~
想要购买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幢
永利最大(官方)网站