echarts brush区域选择框(获取选择框的值)

最近在搞echarts的brush的时候遇到一个这样的问题,大概是这样的:
在echart的demo里面做了一个brushEnd的监听事件,为了获取到选框的范围。

在这里不用brushSelected的原因是使用echarts的过程中会频繁的触发该事件,虽然可以用brush.throttleType和brush。throttleDelay来解决,但总的来说体验不好。

问题描述:
1.首先我在echarts的demo里面进行了第一次brush,并console了内容
在这里插入图片描述
这时候可以看到coordRange里面的数组是正常的坐标轴数值

2.然后选择了保持选择框,在同一页进行了第二次brush
在这里插入图片描述
可以看到console打印了两个数组,且都是正常打印的坐标轴数值

3.拉动滚动条后进行第三次brush(问题出现)
在这里插入图片描述
从console的内容发现,打印了三个数值,但是前两个数组的数值明显不是之前brush的坐标值。

解决办法:
经过观察发现areas里面的range每次都是不一样的,于是想到了用range(像素)转换成坐标轴上的值
参考echarts的官方文档后:
在这里插入图片描述
在这里插入图片描述
转换了range的值发现和coordRange的值基本一致。

如果有更好的解决办法欢迎各位大佬指导一下!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,你可以使用 echartsbrush 组件来实现框选数据并删除数据,然后使用 `setOption` 方法更新图表。首先,需要在图表中启用 brush 组件: ```python from pyecharts import options as opts from pyecharts.charts import Line # 创建图表实例 line_chart = Line() # 启用 brush 组件 line_chart = line_chart.add_js_funcs(""" myChart.on('brushSelected', function(params) { var brushComponent = params.batch[0]; if (brushComponent) { var selectedDataIndices = brushComponent.selected[0].dataIndex; var option = myChart.getOption(); option.series[0].data = option.series[0].data.filter(function(data, index) { return selectedDataIndices.indexOf(index) === -1; }); myChart.setOption(option, true); } }); """) ``` 这里我们使用了 `add_js_funcs` 方法添加了 JavaScript 代码,当 brush 组件框选数据时,会触发 `brushSelected` 事件,我们在事件处理函数中获取选中的数据索引,然后过滤出未选中的数据,最后使用 `setOption` 方法更新图表。 然后,需要设置图表的配置项和数据: ```python # 设置图表配置项和数据 line_chart = line_chart.set_global_opts( tooltip_opts=opts.TooltipOpts(trigger="axis"), brush_opts=opts.BrushOpts(), datazoom_opts=opts.DataZoomOpts(), ) line_chart = line_chart.add_xaxis(xaxis_data=x_data) line_chart = line_chart.add_yaxis( series_name="", y_axis=y_data, is_smooth=True, linestyle_opts=opts.LineStyleOpts(width=2), label_opts=opts.LabelOpts(is_show=False), ) ``` 这里我们启用了 tooltip、brush 和 datazoom 组件,然后添加了 x 和 y 数据。注意,这里的 `x_data` 和 `y_data` 需要根据你的数据进行设置。 最后,将图表渲染到 HTML 文件中: ```python # 渲染图表 line_chart.render("line.html") ``` 这样就可以实现 brush 框选数据并删除数据,然后更新图表了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值