合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
>#### 旭日图菜单 ~~~ const sourceData = [{ id: "1470876252852527106", parentId: "0", children: [{ id: "1470876252852527107", parentId: "1470876252852527106", children: [{ id: "1470876252852527108", parentId: "1470876252852527107", children: [], nodeName: "低频", }, { id: "1470876252852527109", parentId: "1470876252852527107", children: [], nodeName: "高频", }, ], nodeName: "基本面", }, { id: "1470876252852527110", parentId: "1470876252852527106", children: [{ id: "1470876252852527111", parentId: "1470876252852527110", children: [], nodeName: "风险溢价", }, { id: "1470876252852527112", parentId: "1470876252852527110", children: [], nodeName: "RAI", }, { id: "1470876252852527113", parentId: "1470876252852527110", children: [], nodeName: "均线动量", }, { id: "1470876252852527114", parentId: "1470876252852527110", children: [], nodeName: "资金", }, ], nodeName: "市场趋势", }, ], nodeName: "债券", }, { id: "1470876252852527115", parentId: "0", children: [{ id: "1470876252852527116", parentId: "1470876252852527115", children: [{ id: "1470876252852527117", parentId: "1470876252852527116", children: [], nodeName: "估值", }, { id: "1470876252852527118", parentId: "1470876252852527116", children: [], nodeName: "盈利", }, ], nodeName: "基本面", }, { id: "1470876252852527119", parentId: "1470876252852527115", children: [{ id: "1470876252852527120", parentId: "1470876252852527119", children: [], nodeName: "风险溢价", }, { id: "1470876252852527121", parentId: "1470876252852527119", children: [], nodeName: "成交量", }, { id: "1470876252852527122", parentId: "1470876252852527119", children: [], nodeName: "机构行为", }, ], nodeName: "市场趋势", }, { id: "1470876252852527123", parentId: "1470876252852527115", children: [], nodeName: "尾部信号", }, ], nodeName: "股票", }, { id: "1470876252852527124", parentId: "0", children: [], nodeName: "股票风格", }, ]; const gapDeg = 3; function getDepthAndSum(arr, depth, endNodeSum) { var flag = false; var temp = []; for (let i = 0; i < arr.length; i++) { arr[i].name = arr[i].nodeName; if (arr[i].children instanceof Array) { // 判断是否是数组 for (let j = 0; j < arr[i].children.length; j++) { temp.push(arr[i].children[j]); // 解析出arr下第一层 } flag = true; if (arr[i].children.length === 0) { endNodeSum++; arr[i].value = 1; } } } if (flag) { // 如果还有数组,则继续解析,直到最后一层有不为数组为止 depth++; return getDepthAndSum(temp, depth, endNodeSum); } else { return { depth, endNodeSum }; } } const { depth, endNodeSum } = getDepthAndSum(sourceData, 0, 0); const realData = []; const list = ["债券", "股票风格", "股票"]; list.forEach((name) => { const el = sourceData.find(({ nodeName }) => nodeName === name); realData.push(el); realData.push({ value: (gapDeg / 360) * endNodeSum, itemStyle: { opacity: 0, color: "transparent" }, cursor: "auto", type: "gap", }); }); function handleSunburstData(arr, level, func) { arr.forEach((item) => { func(item, level); if (item.children && item.children.length > 0 && item.type !== "hideItem") { handleSunburstData(item.children, level + 1, func); } }); } function getSunburstData(index) { const res = []; const cloneData = JSON.parse(JSON.stringify(realData)); let dataIndex = 0; handleSunburstData(cloneData, 1, (item, level) => { dataIndex++; if (item.type === "gap") { return; } if (index === 0) { if (!item.children || (level < depth && item.children.length === 0)) { item.dataIndex = dataIndex; item.label = { show: false }; item.itemStyle = { opacity: 0 }; item.emphasis = { label: { show: false } }; item.type = "hideItem"; if (level === 1) { item.seriesIndex = 1; item.children = [{ id: item.id, value: 1, dataIndex: dataIndex, seriesIndex: 1, itemStyle: { opacity: 0 }, children: [{ id: item.id, value: 1, dataIndex: dataIndex, seriesIndex: 1, itemStyle: { opacity: 0 }, }, ], }, ]; } if (level === 2) { item.seriesIndex = 2; item.children = [{ id: item.id, value: 1, dataIndex: dataIndex, seriesIndex: 2, itemStyle: { opacity: 0 }, }, ]; } } } else { if (level !== index || item.children.length !== 0) { item.label = { show: false }; item.itemStyle = { opacity: 0 }; item.cursor = "auto"; item.emphasis = { label: { show: false } }; } } }); return cloneData; } option = { title: { text: '旭日图菜单', left: 'center', top: '10px', textStyle: { color: '#ffffff' } }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: "#0f375f", series: [{ type: "sunburst", radius: ["20%", "80%"], center: ["50%", "50%"], data: getSunburstData(0), emphasis: { focus: "none", }, sort: null, label: { rotate: 0, }, nodeClick: false, z: 3, startAngle: 90 - gapDeg / 2, }, { type: "sunburst", radius: ["20%", "200%"], center: ["50%", "50%"], data: getSunburstData(1), emphasis: { focus: "none", }, sort: null, label: { rotate: 0, }, nodeClick: false, silent: true, startAngle: 90 - gapDeg / 2, }, { type: "sunburst", radius: ["0%", "120%"], center: ["50%", "50%"], data: getSunburstData(2), emphasis: { focus: "none", }, sort: null, label: { rotate: 0, }, nodeClick: false, silent: true, startAngle: 90 - gapDeg / 2, }, ], }; myChart.on("mouseover", function (params) { // 控制台打印数据的名称 if (params.data.dataIndex) { const { seriesIndex, dataIndex } = params.data; myChart.dispatchAction({ type: "highlight", seriesIndex: seriesIndex, dataIndex: dataIndex, }); } }); myChart.on("mouseout", function (params) { // 控制台打印数据的名称 if (params.data.dataIndex) { const { seriesIndex, dataIndex } = params.data; myChart.dispatchAction({ type: "downplay", seriesIndex: seriesIndex, dataIndex: dataIndex, }); } }); myChart.on("click", function (params) { // 控制台打印数据的名称 console.log(params.data.id); }); ~~~ >#### 效果图 ![](https://img.kancloud.cn/1f/d8/1fd8f14bf3ff555e4b8b3632a0f88ef9_800x450.png) <hr> >#### 中心标题 ~~~ var giftImageUrl = ""; option = { backgroundColor: "#0f375f", tooltip: { trigger: "item", formatter: "{a} <br/>{b}: {c} ({d}%)", }, toolbox: { feature: { saveAsImage: {} } }, graphic: { elements: [{ type: "image", style: { image: giftImageUrl, width: 100, height: 100, }, left: "center", top: "center", }, ], }, title: { text: "类型分析", left: "center", top: "55%", padding: [24, 0], textStyle: { color: "#fff", fontSize: 20, align: "center", }, }, legend: { orient: "horizontal", icon: "circle", bottom: 20, x: "center", data: [ "社工", "养老护理员", "康复师", "心理咨询师", "医生", "护士", "管理人员", "后勤人员", "其他人员", ], textStyle: { color: "#fff", }, }, series: [{ name: "人员类型", type: "pie", hoverAnimation: false, legendHoverLink: false, radius: ["38%", "45%"], color: [ "#006495", "#1D5F84", "#255C6D", "#3C5C67", "#40486C", "#3F3C73", "#403D84", "#1F3A8D", "#0B3B77", ], label: { normal: { position: "inner", }, }, labelLine: { normal: { show: false, }, }, tooltip: { show: false, }, data: [{ value: 100, name: "", }, { value: 100, name: "", }, { value: 100, name: "", }, { value: 100, name: "", }, { value: 100, name: "", }, { value: 100, name: "", }, { value: 100, name: "", }, { value: 100, name: "", }, { value: 100, name: "", }, ], }, { name: "人员类型", type: "pie", radius: ["43%", "55%"], color: [ "#00FFFF", "#44EAB1", "#7BDD43", "#FEBE12", "#EBEC2F", "#FF7C44", "#FA3E5F", "#6635EF", "#FFAFDA", ], labelLine: { normal: { show: true, length: 20, length2: 20, lineStyle: { width: 2, }, }, }, label: { normal: { formatter: "{c|{c}}\n{hr|}\n{d|{d}%}", rich: { b: { fontSize: 20, color: "#12EABE", align: "left", padding: 4, }, hr: { borderColor: "#12EABE", width: "100%", borderWidth: 2, height: 0, }, d: { fontSize: 20, color: "#fff", align: "left", padding: 4, }, c: { fontSize: 20, color: "#fff", align: "left", padding: 4, }, }, }, }, data: [{ value: 100, name: "社工", }, { value: 100, name: "养老护理员", }, { value: 100, name: "康复师", }, { value: 100, name: "心理咨询师", }, { value: 100, name: "医生", }, { value: 100, name: "护士", }, { value: 100, name: "管理人员", }, { value: 100, name: "后勤人员", }, { value: 100, name: "其他人员", }, ], }, ], }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/6b/6c/6b6cc5d648effef927170e9a9414c6a3_800x450.png) <hr> >#### 分类嵌套 ~~~ option = { title: { text: "分类嵌套", subtext: "", top: '10px', left: "center", textStyle: { color: "#fff", fontSize: 18, }, }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: "#0f375f", tooltip: { trigger: "item", formatter: "{a} <br/>{b}:({d}%)", }, series: [{ name: "事业线", type: "pie", radius: ["10%", "50%"], color: ["#ec5d51", "#59abe1", "#f4cf42", "#3dc6a8"], label: { normal: { position: "inner", }, }, data: [{ value: 11, name: "APP事业部", }, { value: 15, name: "家长事业部", }, { value: 9, name: "TV事业部", }, { value: 9, name: "公共", }, ], }, { name: "分组", type: "pie", radius: ["54%", "72%"], color: [ "#a0dca0", "#60bbb6", "#f78db3", "#feadac", "#fae395", "#91d4e5", "#8eb3e8", ], label: { normal: { formatter: "{b}\n{d}%", }, }, data: [{ value: 6, name: "2D线", }, { value: 5, name: "3D线", }, { value: 8, name: "宝宝产品大全", }, { value: 7, name: "大全产品线", }, { value: 9, name: "TV事业部", }, { value: 9, name: "公共", }, ], }, ], }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/9a/2f/9a2fcf6c5de0f99259a92466333ba4fc_800x450.png) <hr> >#### 高校学生类别分类 ~~~ option = { tooltip: { formatter: (params) => { let str = ''; params.treePathInfo.forEach((item, index) => { if (index > 0 && index < params.treePathInfo.length - 1) { str += item.name + '-'; } else if (index !== 0) { str += item.name + ':' + item.value; } }); return str; }, }, title: { text: "高校学生类别分类", subtext: "", top: '10px', left: "center", textStyle: { color: "#fff", fontSize: 18, }, }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: "#0f375f", color: [ '#1B95E6', '#6674C4', '#FF95D2', '#6BBEAC', '#FACF5B', '#3DC0E4', '#0DCB74', '#8368D9', '#AF65BE', '#4C6471', '#1C436F', '#E57B88', '#F4B246', '#A77C56', ], series: { type: 'sunburst', data: [{ name: '硕士', children: [{ name: '全日制', children: [{ name: '学术型', value: 11, }, { name: '专业型', value: 44, }, ], }, { name: '非全日制', children: [{ name: '专业型', value: 66, }, ], }, ], }, { name: '博士', children: [{ name: '全日制', children: [{ name: '学术型', value: 22, }, ], }, { name: '非全日制', children: [{ name: '学术型', value: 33, }, { name: '专业型', value: 55, }, ], }, ], }, ], radius: ['10%', '70%'], label: { rotate: 0, }, itemStyle: { borderColor: '#fff', borderWidth: 1, borderRadius: 6, }, emphasis: { focus: 'ancestor', }, levels: [{ // 留给数据下钻点的空白配置 itemStyle: { color: '#fff', }, radius: ['10%', '10%'], }, { radius: ['10%', '35%'], }, { radius: ['37%', '62%'], itemStyle: { opacity: 0.95 } }, { radius: ['64%', '70%'], label: { position: 'outside', distance: 12, }, itemStyle: { opacity: 0.9 }, downplay: { label: { opacity: 0.5, }, }, }, ], }, }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/7b/dd/7bddcb1fbaa99fba9d53911e03b6755f_800x450.png) <hr>