qq_26083679 2024-03-09 20:40 采纳率: 69.2%
浏览 21

echarts绘制graph时的问题

echarts绘制graph时,在series中设置draggable为TRUE后,每次拖动节点后,节点都会返回原来的位置,怎么让节点被拖动后不回调呢

  • 写回答

4条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-03-09 20:41
    关注

    引自免费微信小程序:皆我百晓生

    在 ECharts 中,通过 draggable 设置节点可拖拽后,默认情况下节点确实会在鼠标释放后恢复到初始位置。若想实现拖动后节点保持在新位置的效果,需要监听 'mouseup' 事件,并在事件回调中更新 series.data 中对应节点的位置信息。

    以下是一个示例代码:

    var chart = echarts.init(document.getElementById('main'));
    
    // 假设已有一个 graph 数据
    var option = {
        series: [{
            type: 'graph',
            layout: 'force',
            draggable: true,
            data: [
                // 节点数据...
            ],
            edges: [
                // 边数据...
            ],
            force: {
                // 引力、斥力等参数配置...
            }
        }]
    };
    
    chart.setOption(option);
    
    // 监听鼠标释放事件
    chart.on('mouseup', function (params) {
        if (params.seriesType === 'graph' && params.dataIndex !== -1) {
            var nodeData = params.data;
            // 获取当前鼠标位置,这里使用图形坐标系(即图表内相对坐标)
            var position = chart.convertFromPixel({seriesIndex: params.seriesIndex}, [params.event.zrX, params.event.zrY]);
            
            // 更新节点的 x 和 y 坐标
            option.series[0].data[nodeData.dataIndex].x = position[0];
            option.series[0].data[nodeData.dataIndex].y = position[1];
    
            // 应用新的option以使节点停留在新位置
            chart.setOption(option);
        }
    });
    

    请注意,上述示例代码仅适用于情况较为简单的场景,对于复杂布局或带有特定约束条件的情况,可能需要根据实际需求调整节点坐标更新逻辑。同时,在力导向图布局中,设置固定坐标可能会与布局算法产生冲突,导致视觉效果不符合预期。

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 3月9日

悬赏问题

  • ¥15 两台交换机分别是trunk接口和access接口为何无法通信,通信过程是如何?
  • ¥15 C语言使用vscode编码错误
  • ¥15 用KSV5转成本时,如何不生成那笔中间凭证
  • ¥20 ensp怎么配置让PC1和PC2通讯上
  • ¥50 有没有适合匹配类似图中的运动规律的图像处理算法
  • ¥15 dnat基础问题,本机发出,别人返回的包,不能命中
  • ¥15 请各位帮我看看是哪里出了问题
  • ¥15 vs2019的js智能提示
  • ¥15 关于#开发语言#的问题:FDTD建模问题图中代码没有报错,但是模型却变透明了
  • ¥15 uniapp的h5项目写一个抽奖动画