热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

金字塔图表:自定义可视化与模拟漏斗分析

金子塔图,自定义图表,伪漏斗图简易的金字塔图,设置不太灵活,可供使用者参考,需要使用者根据页面的需求复杂度等再做修改。另附链接地址:https:www.isqqw.compcent

金子塔图,自定义图表,伪漏斗图

简易的金字塔图,设置不太灵活,可供使用者参考,需要使用者根据页面的需求复杂度等再做修改。

另附链接地址:https://www.isqqw.com/pcenter?userid=6427

// 原始数据
let data = [
{ name: '测试数据', value: 4 },
{ name: '测试原理', value: 2 },
{ name: '测试功能', value: 8 },
]
// 将数据根据从小到大排序
let newdata = sortObject(data);
// 图例数据
let lengthData = [];
// 返回数据
let resultData = data.map((item, index) => {
let graw = item.value > 9 ? 78 : 83;
lengthData.push({
type: 'group',
top: index * 25,
scale: [1, 1],
children: [
{
type: 'circle',
shape: {
cx: 0,
cy: 7,
r: 5
},
style: {
fill:
index === 0 ? '#07a9ab' : index === 1 ? '#008CD2' : '#0847e7'
}
},
{
type: 'text',
style: {
text: item.name,
fill: '#fff',
fontSize: 14,
x: 10,
y: 2
}
},
{
type: 'text',
name: item.name,
style: {
text: item.value,
fill: '#fff',
fontSize: 17,
x: 70,
y: 0
}
},
{
type: 'text',
style: {
text: '个',
fill: '#fff',
fontSize: 14,
x: graw,
y: 2
}
}
]
});
if (index === 0) {
return {
style: {
fill: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
{ offset: 0, color: '#07a9ab' },
{ offset: 1, color: '#09fffb' }
])
},
...item
};
} else if (index === 1) {
return {
style: {
fill: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
{ offset: 0, color: '#025279' },
{ offset: 1, color: '#16a7ef' }
])
},
...item
};
} else {
return {
style: {
fill: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
{ offset: 0, color: '#0332a9' },
{ offset: 1, color: '#0847e7' }
])
},
...item
};
}
});
// 获取计算的数据
let getData = pyramidChart(
resultData,
document.getElementById('container')
);
option = {
backgroundColor: '#022c32',
graphic: [
{
type: 'group',
left: '5%',
top: 'center',
scale: [1, 1],
onclick: function (params) {
},
children: getData
},
{
type: 'group',
left: '55%',
top: 'center',
scale: [1, 1],
onclick: function (params) {
},
children: lengthData
}
],
series: []
};
// 排序
function sortObject(arr) {
return arr.sort(function (a, b) {
return a['value'] - b['value'];
});
}
// 数据处理
function pyramidChart(data = [], dom, option = {}) {
let domHeight = dom ? dom.clientHeight : 0;
let domWidth = dom ? dom.clientWidth : 0;
// 默认获取一个正方形空间
let maxDistance = domHeight > domWidth / 2 ? domWidth / 2 : domHeight;
// 合并设置
let resultOption = Object.assign(
{
slanted: 1, // 每层底部的倾斜度
maxWidth: maxDistance, // 金字塔最大宽度
maxHeight: maxDistance, // 金字塔最大高度
offset: 35 //偏差
},
option
);
if (data.length === 1) {
resultOption.slanted = 50;
}
if (data.length === 2) {
resultOption.slanted = 25;
}
if (data.length === 3) {
resultOption.slanted = 10;
}
// 减去多余的误差边距
resultOption.maxHeight = resultOption.maxHeight - resultOption.offset;
// 一半最大宽度,用于计算左右边距
let halfMaxWidth = resultOption.maxWidth / 2;
// 数据最终
let resultData = [];
// 数据值 数组
let dataNums = data.map(item => item.value || 0);
// 计算数据总和
let dataNumSum =
dataNums.length > 0 &&
dataNums.reduce(function (prev, curr) {
return Number(prev || 0) + Number(curr || 0);
});
// 中间数据点坐标数组 根据长度比值算出
let midlinePoint = [];
let multipleLayer = [0.6];
// 计算倍数等基础数据
dataNums.forEach((item, index, arr) => {
let itemNext = arr[index + 1];
if (itemNext) {
multipleLayer.push(itemNext / dataNums[0]); // 计算倍数
}
// 计算点坐标 长度
let point =
Math.round((item / dataNumSum) * resultOption.maxHeight * 1000) / 1000;
midlinePoint.push(point);
});
// 三角形的高度
let triangleHeight = 0;
let triangleHeightLayer = [];
// 三角形tan角度
let triangleRatio = halfMaxWidth / resultOption.maxHeight;
midlinePoint.forEach(item => {
triangleHeight = triangleHeight + item;
triangleHeightLayer.push(triangleHeight);
});
// 中间数据点 最后的数据长度
let midlinePointFinally =
triangleHeightLayer[triangleHeightLayer.length - 1] || 0;
// 开始拼接数据
data.forEach((item, index) => {
let arrObj = [];
let triangleHeightLayerOne= triangleHeightLayer[index];
let triangleHeightLayerOneLast= triangleHeightLayer[index - 1] || 0;
let multipleLayerOne= multipleLayer[index];
let multipleLayerOneLast= multipleLayer[index - 1] || 0;
// 第一层数据单独处理
if (index === 0) {
arrObj.push(
[0, 0],
[
-triangleRatio *
(triangleHeightLayerOne - resultOption.slanted * multipleLayerOne),
triangleHeightLayerOne - resultOption.slanted * multipleLayerOne
],
[0, triangleHeightLayerOne],
[
triangleRatio *
(triangleHeightLayerOne - resultOption.slanted * multipleLayerOne),
triangleHeightLayerOne - resultOption.slanted * multipleLayerOne
]
);
} else {
arrObj.push(
[0, triangleHeightLayerOneLast],
[
-triangleRatio *
(triangleHeightLayerOneLast -
resultOption.slanted * multipleLayerOneLast),
triangleHeightLayerOneLast -
resultOption.slanted * multipleLayerOneLast
],
[
-triangleRatio *
(triangleHeightLayerOne - resultOption.slanted * multipleLayerOne),
triangleHeightLayerOne - resultOption.slanted * multipleLayerOne
],
[0, triangleHeightLayerOne],
[
triangleRatio *
(triangleHeightLayerOne - resultOption.slanted * multipleLayerOne),
triangleHeightLayerOne - resultOption.slanted * multipleLayerOne
],
[
triangleRatio *
(triangleHeightLayerOneLast -
resultOption.slanted * multipleLayerOneLast),
triangleHeightLayerOneLast -
resultOption.slanted * multipleLayerOneLast
]
);
}
resultData.push({
type: 'polygon',
z: 1,
shape: {
points: arrObj
},
name: item.name,
style: item.style
});
});
// 添加线
resultData.push({
type: 'polyline',
shape: {
points: [
[0, 0],
[0, midlinePointFinally]
]
},
style: {
stroke: '#f2f2f2',
opacity: 0.2,
lineWidth: 1
},
z: 2
});
// 返回
return resultData;
};

  

 

转载标明来路-博客园,

联系方式1763907618@qq.com



推荐阅读
  • 本文介绍如何从字符串中移除大写、小写、特殊、数字和非数字字符,并提供了多种编程语言的实现示例。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • Linux环境下C语言实现定时向文件写入当前时间
    本文介绍如何在Linux系统中使用C语言编程,实现在每秒钟向指定文件中写入当前时间戳。通过此示例,读者可以了解基本的文件操作、时间处理以及循环控制。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 在尝试使用C# Windows Forms客户端通过SignalR连接到ASP.NET服务器时,遇到了内部服务器错误(500)。本文将详细探讨问题的原因及解决方案。 ... [详细]
  • 本文介绍了 Python 的 Pmagick 库中用于图像处理的木炭滤镜方法,探讨其功能和用法,并通过实例演示如何应用该方法。 ... [详细]
  • 本文详细介绍如何使用 HTML5 和 JavaScript 实现一个交互式的画板功能。通过具体代码示例,帮助读者理解 Canvas API 的基本用法及其在绘图应用中的实际应用。 ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • CSS高级技巧:动态高亮当前页面导航
    本文介绍了如何使用CSS实现网站导航栏中当前页面的高亮显示,提升用户体验。通过为每个页面的body元素添加特定ID,并结合导航项的类名,可以轻松实现这一功能。 ... [详细]
  • yikesnews第11期:微软Office两个0day和一个提权0day
    点击阅读原文可点击链接根据法国大选被黑客干扰,发送了带漏洞的文档Trumps_Attack_on_Syria_English.docx而此漏洞与ESET&FireEy ... [详细]
  • 深入解析动态代理模式:23种设计模式之三
    在设计模式中,动态代理模式是应用最为广泛的一种代理模式。它允许我们在运行时动态创建代理对象,并在调用方法时进行增强处理。本文将详细介绍动态代理的实现机制及其应用场景。 ... [详细]
  • Python + Pytest 接口自动化测试中 Token 关联登录的实现方法
    本文将深入探讨 Python 和 Pytest 在接口自动化测试中如何实现 Token 关联登录,内容详尽、逻辑清晰,旨在帮助读者掌握这一关键技能。 ... [详细]
  • Symfony是一个功能强大的PHP框架,以其依赖注入(DI)特性著称。许多流行的PHP框架如Drupal和Laravel的核心组件都基于Symfony构建。本文将详细介绍Symfony的安装方法及其基本使用。 ... [详细]
  • 本文介绍如何在MySQL中创建一个自定义函数,用于将包含多个班级编号的字符串拆分为对应的班级名称。通过详细解释代码逻辑和功能,帮助读者理解并应用这一技术。 ... [详细]
  • 深入解析MySQL中的七种JOIN查询
    本文详细介绍了MySQL中常用的七种JOIN查询方法,包括内连接、左外连接、右外连接、全外连接以及排除连接等,并通过实例进行说明。 ... [详细]
author-avatar
曾军78930
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有