AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题

问题[echarts](coding)

Martin Hope
94michalg
Asked: 2025-04-14 16:53:43 +0800 CST

如何创建一个多类别工具提示来显示甘特图所有类别的当前状态?

  • 6

我正在制作甘特图。它看起来像这样:

甘特图

以下是代码:

// Create a new Map
const modeColors = new Map();

// Adding entries to the map
modeColors.set(0, 'brown');
modeColors.set(1, 'lightgrey');
modeColors.set(2, '#ffa500');
modeColors.set(3, '#663300');

// Create a new Map
const statusColors = new Map();

// Adding entries to the map
statusColors.set(0, '#32cd32');
statusColors.set(1, 'lightblue');
statusColors.set(2, 'yellow');

const delayColors = new Map();
delayColors.set(0, '#32cd32');
delayColors.set(1, 'darkred');
delayColors.set(2, '#3399ff');
delayColors.set(3, 'crimson');

function getColor(categoryIndex, stateIndex) {
  switch (categoryIndex) {
    case 0:
      return modeColors.get(stateIndex);
    case 1:
      return statusColors.get(stateIndex);
    case 2:
      return delayColors.get(stateIndex);
    default:
      return '#777777';
  }
}

option = {
  tooltip: {
    trigger: 'axis',
    axisPointer: {
      type: 'cross'
    }
  },
  grid: {
    left: '180em',
    right: '40em',
    height: '30%',
    top: '55%'
  },
  xAxis: {
    name: 'Time',
    type: 'time',
    id: 'time',
    position: 'bottom',
    min: '2025-04-14 06:00:00',
    max: '2025-04-14 22:00:00',
    nameLocation: 'middle',
    nameGap: 25
  },
  yAxis: {
    type: 'category',
    data: ['Mode', 'Status', 'Delay'],
    name: 'ganttCategoryAxis',
    axisTick: { show: false },
    splitLine: { show: true },
    inverse: true,
    nameTextStyle: { fontSize: 0 }
  },
  series: [
    {
      type: 'custom',
      encode: {
        x: [0, 1],
        y: 2
      },
      data: [
        // startTime, endTime, category, state
        ['2025-04-14 06:00:00', '2025-04-14 10:00:00', 0, 0],
        ['2025-04-14 10:00:00', '2025-04-14 14:00:00', 0, 1],
        ['2025-04-14 14:00:00', '2025-04-14 15:15:00', 0, 2],
        ['2025-04-14 15:15:00', '2025-04-14 18:00:00', 0, 3],
        ['2025-04-14 18:00:00', '2025-04-14 23:00:00', 0, 0],
        ['2025-04-14 06:00:00', '2025-04-14 10:00:00', 1, 1],
        ['2025-04-14 10:00:00', '2025-04-14 22:00:00', 1, 2],
        ['2025-04-14 22:00:00', '2025-04-14 23:00:00', 1, 0],
        ['2025-04-14 12:00:00', '2025-04-14 12:40:00', 2, 1]
      ],
      renderItem: renderGanttItem
    }
  ]
};

function renderGanttItem(params, api) {
  var categoryIndex = api.value(2);
  var stateIndex = api.value(3);
  var timeArrival = api.coord([api.value(0), categoryIndex]);
  var timeDeparture = api.coord([api.value(1), categoryIndex]);
  var barLength = timeDeparture[0] - timeArrival[0];
  var barHeight = 30;
  var x = timeArrival[0];
  var y = timeArrival[1] - barHeight / 2;
  var color = getColor(categoryIndex, stateIndex);

  return {
    type: 'rect',
    shape: {
      x: x,
      y: y,
      width: barLength,
      height: barHeight
    },
    style: {
      fill: color,
      opacity: 0.66,
      stroke: 'black'
    }
  };
}

它有 3 个类别:模式、状态和延迟。现在,工具提示会显示特定类别的所有元素列表。我想创建一个多类别状态工具提示,显示特定时间所有类别(模式、状态、延迟)的当前状态。例如,当我将鼠标悬停在 12:20 时,它应该显示:

Mode - 1
Status - 2
Delay - 1

因为这 3 个数据元素(每个类别一个)在 12:20 处于活动状态:

data: [
        // startTime, endTime, category, state
        ['2025-04-14 06:00:00', '2025-04-14 10:00:00', 0, 0]
        ['2025-04-14 10:00:00', '2025-04-14 14:00:00', 0, 1] //FIRST ONE
        ['2025-04-14 14:00:00', '2025-04-14 15:15:00', 0, 2]
        ['2025-04-14 15:15:00', '2025-04-14 18:00:00', 0, 3]
        ['2025-04-14 18:00:00', '2025-04-14 23:00:00', 0, 0]
        ['2025-04-14 06:00:00', '2025-04-14 10:00:00', 1, 1]
        ['2025-04-14 10:00:00', '2025-04-14 22:00:00', 1, 2] // SECOND
        ['2025-04-14 22:00:00', '2025-04-14 23:00:00', 1, 0]
        ['2025-04-14 12:00:00', '2025-04-14 12:40:00', 2, 1] // THIRD
      ]

我尝试添加自定义格式化程序:

formatter: function (params) {
    /* Iterating over all elements and displaying the element when the mouse-hover time is within the element's start and end time */
    }

问题是,当我遍历所有参数时,我只能看到鼠标当前指向的类别内的元素。

echarts
  • 1 个回答
  • 69 Views
Martin Hope
asiannoob
Asked: 2025-04-03 19:52:38 +0800 CST

多个工具提示值格式化程序

  • 5

是否可以配置tooltip选项以接受valueFormatter每个系列的多个数据?假设我有一个包含温度数据的系列和另一个包含心率的系列。我想用不同的单位(分别为°C 和 Bpm)和小数位数来格式化它们。

我知道我可以使用该formatter选项来完成此任务,但这会删除我想要保留的默认工具提示样式。有人知道方法吗?

echarts
  • 1 个回答
  • 20 Views
Martin Hope
Alice
Asked: 2025-03-22 11:30:25 +0800 CST

echarts中如何知道点击事件的实际目标?

  • 6

我想为我的 echarts 图表添加注释功能。如果有任何注释,它将被标记为带有绿色方形标记的绿色虚线。当用户单击绿色方形标记时,将打开一个弹出窗口以显示实际注释。

当我运行下面的命令时,只要我单击注释标记线上的任意位置,它就会被触发。如何判断用户是否专门单击了绿色方形标记?

myChart.on('click', "series.line", function(params) {
  console.log('normal click series.markLine', params)
})

以下是演示:https://codepen.io/lora999/pen/azbGPKY

在此处输入图片描述

echarts
  • 1 个回答
  • 23 Views
Martin Hope
somerandomusername
Asked: 2025-02-27 23:33:04 +0800 CST

如何移动 Apache Echarts 的分区和标签,使其不从零开始

  • 5

我有一张图表,其中分区和标签的间隔为 7。底部 X 轴从 0 开始,每 7 个值显示一个间隔,这是正确的。对于顶部轴,我想做同样的事情,但要与系列点对齐,基本上向左移动 1 个值。我不知道如何移动它。

在此处输入图片描述

echarts
  • 1 个回答
  • 16 Views
Martin Hope
Steven Magana-Zook
Asked: 2025-01-07 07:44:26 +0800 CST

将标记线设置为右侧索引边界,而不是单元格中间

  • 4

我有一个热图,其中有针对特定 x 值的垂直标记线。现在,垂直线出现在我指定的 x 轴索引的中间。这会将热图单元格一分为二,并且会让寻找特定项目之间边界的用户感到困惑。是否可以使用内置选项让该垂直线出现在指定 x 轴索引的右侧边界上?

带有每个类别 x 值标记线的热图

以下是我的 eChart 选项 JavaScript 的相关部分:

series: [
                {
                    type: 'heatmap',
                    data: mutation_map_data,
                    color: colorPalette,                    
                    markLine: {
                        silent: true,
                        data: position_boundaries,
                        lineStyle: {
                            width: 5,
                            color: "white",
                        }
                    },
                    ...
]

其中变量 position_boundaries 是以下形式的项目数组:

{"symbol": "none", "xAxis": index, "name": current_position}
echarts
  • 1 个回答
  • 41 Views
Martin Hope
Jlv
Asked: 2024-11-25 00:19:50 +0800 CST

深入探究后在顶层显示后退按钮

  • 6

我正在学习如何使用 eCharts 并尝试不同的类型。我剪切并粘贴了两种 eChart 条形类型,一种带有向下钻取 (id = main2),一种带有负值的水平 (id = main1);它们排列在单个表格行中。

两者都能正确呈现,向下钻取功能也运行良好;后退按钮按预期工作并显示正确的初始条形图;只不过返回后它在图表的顶层仍然可见。刷新页面会将其删除。

<head>
    <meta charset='utf-8' />


    
  </head>

<body>
  <table class="container-drilldown" >
    <thead>
        
    </thead>
    <tbody>
        <tr>  
          <td class='drilldown' class ='center' id='main2' style='width: 30vw; height:45vh' >
            <script type='text/javascript'>
    
              var chartDom = document.getElementById('main2');
              var myChart = echarts.init(chartDom);
              var option = {
                xAxis: {
                  data: ['Animals', 'Fruits', 'Cars']
                },
                yAxis: {},
                dataGroupId: '',
                animationDurationUpdate: 500,
                series: {
                  type: 'bar',
                  id: 'sales',
                  data: [
                    {
                      value: 5,
                      groupId: 'animals'
                    },
                    {
                      value: 2,
                      groupId: 'fruits'
                    },
                    {
                      value: 4,
                      groupId: 'cars'
                    }
                  ],
                  universalTransition: {
                    enabled: true,
                    divideShape: 'clone'
                  }
                }
              };
              const drilldownData = [
                {
                  dataGroupId: 'animals',
                  data: [
                    ['Cats', 4],
                    ['Dogs', 2],
                    ['Cows', 1],
                    ['Sheep', 2],
                    ['Pigs', 1]
                  ]
                },
                {
                  dataGroupId: 'fruits',
                  data: [
                    ['Apples', 4],
                    ['Oranges', 2]
                  ]
                },
                {
                  dataGroupId: 'cars',
                  data: [
                    ['Toyota', 4],
                    ['Opel', 2],
                    ['Volkswagen', 2]
                  ]
                }
              ];
              myChart.on('click', function (event) {
                if (event.data) {
                  var subData = drilldownData.find(function (data) {
                    return data.dataGroupId === event.data.groupId;
                  });
                  if (!subData) {
                    return;
                  }
                  myChart.setOption({
                    xAxis: {
                      data: subData.data.map(function (item) {
                        return item[0];
                      })
                    },
                    series: {
                      type: 'bar',
                      id: 'sales',
                      dataGroupId: subData.dataGroupId,
                      data: subData.data.map(function (item) {
                        return item[1];
                      }),
                      universalTransition: {
                        enabled: true,
                        divideShape: 'clone'
                      }
                    },
                    graphic: [
                      {
                        type: 'text',
                        left: 50,
                        top: 20,
                        style: {
                          text: 'Back',
                          fontSize: 18
                        },
                        onclick: function () {
                          myChart.setOption(option);
                        }
                      }
                    ]
                  });
                }
              });
              
              option && myChart.setOption(option);
              
            
          </script>
        </td>
         

        <td class='drilldown' class ='center' id='main1' style='width: 30vw; height:45vh' >
          <script type='text/javascript'>
            var chartDom1 = document.getElementById('main1');
            var myChart1 = echarts.init(chartDom1);

            var option1 = {
              tooltip: {
                trigger: 'axis',
                axisPointer: {
                  type: 'shadow'
                }
              },
              legend: {
                data: ['Profit', 'Expenses', 'Income']
              },
              grid: {
                left: '3%',
                right: '4%',
                bottom: '3%',
                containLabel: true
              },
              xAxis: [
                {
                  type: 'value'
                }
              ],
              yAxis: [
                {
                  type: 'category',
                  axisTick: {
                    show: false
                  },
                  data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
                }
              ],
              series: [
                {
                  name: 'Profit',
                  type: 'bar',
                  label: {
                    show: true,
                    position: 'inside'
                  },
                  emphasis: {
                    focus: 'series'
                  },
                  data: [200, 170, 240, 244, 200, 220, 210]
                },
                {
                  name: 'Income',
                  type: 'bar',
                  stack: 'Total',
                  label: {
                    show: true
                  },
                  emphasis: {
                    focus: 'series'
                  },
                  data: [320, 302, 341, 374, 390, 450, 420]
                },
                {
                  name: 'Expenses',
                  type: 'bar',
                  stack: 'Total',
                  label: {
                    show: true,
                    position: 'left'
                  },
                  emphasis: {
                    focus: 'series'
                  },
                  data: [-120, -132, -101, -134, -190, -230, -210]
                }
              ]
            };

            option && myChart1.setOption(option1);
          </script>
      </td>

  </tr>
echarts
  • 1 个回答
  • 23 Views
Martin Hope
Jlv
Asked: 2024-11-13 00:21:01 +0800 CST

在 Apache eChart 中设置图表周围的边框

  • 5

有没有办法在 Apache eChart 中创建边框?我查看了文档,尝试了各种组合,但似乎无法在图表周围添加边框。

我将它们放在表格中并可以通过这种方式添加边框,但如果能够将它们添加到图表而不是表格中就更好了。

echarts
  • 1 个回答
  • 16 Views
Martin Hope
Josh Garrison
Asked: 2024-09-27 05:10:20 +0800 CST

当我使用 echarts 更新数据以显示在漏斗图上时,标签会从屏幕上消失

  • 6

这是令我感到困扰的一张图表。

Echart示例

问题是,如果您更改任何数据值,漏斗图上的标签就会消失。我的目标是即使我更改数据值,标签仍保留在屏幕右侧。

无需重新加载图表即可动态更新任何值。

data: [
        { value: 60, name: 'Visit' },
        { value: 40, name: 'Inquiry' },
        { value: 20, name: 'Order' },
        { value: 80, name: 'Click' },
        { value: 100, name: 'Show' }
      ]

我需要将标签放在屏幕右侧,而我知道的唯一方法是使用 labelLayout 选项。问题是,当包含该选项时,就会出现问题。

我曾尝试查看有关 echarts 的文档和其他问题,但一无所获。

我正在开展一个 Angular 17 项目,但您可以在上面的示例中使用 echarts 网站看到此问题。

echarts
  • 1 个回答
  • 27 Views
Martin Hope
Hp Lam
Asked: 2024-08-05 12:54:45 +0800 CST

有没有办法在 ECharts 中创建一个充满点的饼图?

  • 5

我想在 ECharts 中创建如下图表:

在此处输入图片描述

所以有人有什么想法吗?我尝试使用 ECharts 页面中的示例,但它似乎不像我的 UI。我制作了一排点,但无法将圆拉伸成具有半径的矩形,更不用说上面和下面的 2 个蓝色半圆了

https://echarts.apache.org/examples/en/editor.html?c=pie-parliament-transition

echarts
  • 1 个回答
  • 23 Views
Martin Hope
Alex
Asked: 2024-03-01 21:18:06 +0800 CST

Echarts如何使图表跨越2个(或更多)网格单元

  • 5

在 Apache echarts 中,我想制作更高级的布局matplotlib gridspec,类似于plotly. 这可行吗?例如在echarts中可以做这样的布局吗?

echarts
  • 1 个回答
  • 13 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve