AntV X6/Xflow 导出 svg/png/jpeg 问题解决

AntV X6/Xflow 导出 svg/png/jpeg 问题解决

导出 svg/png/jpeg 时,处于画布边缘的节点的连接桩或 label 标签显示不完整

问题截图:

界面

导出的图片

解决办法:

  1. 导出 png/jpeg 格式可以通过设置Export.ToImageOptionspadding 解决
  2. 导出 svg 格式,Export.ToSVGOptions暂无直接可用的 padding 配置,所以我的方式是使用getContentBBox获取画布内容的矩形区域,并进行一定的数值增减,将其作为导出时的 viewbox
tsx 复制代码
import React, { useEffect, useRef } from 'react'
import { Graph, Rectangle, useExport, useGraphInstance } from '@antv/xflow'

const handleExportPng = () => {
  exportPNG('png-chart', { padding: 20 })
}

const handleExportJpeg = () => {
  exportJPEG('jpeg-chart', { padding: 20 })
}

const handleExportSvg = () => {
  const box = graph.current?.getContentBBox()
  const { x, y, width, height } = box as Rectangle
  const viewBox = {
    x: x - 20,
    y: y - 20,
    width: width + 40,
    height: height + 40
  }
  exportSVG('svg-chart', { viewBox })
}

如有更好的解决办法,欢迎在评论区交流讨论

效果展示:

更多问题可查阅以下链接

相关推荐
FIT2CLOUD飞致云6 小时前
下拉组件Tag支持自定义背景颜色,图片组支持设置刷新频率,DataEase开源BI工具v2.10.12 LTS版本发布
开源·数据可视化
柳杉1 天前
使用three.js搭建3d隧道监测-2
前端·javascript·数据可视化
summer7772 天前
GIS三维可视化-Cesium
前端·javascript·数据可视化
德育处主任2 天前
p5.js 掌握圆锥体 cone
前端·数据可视化·canvas
菜牙买菜3 天前
Hicharts入门
前端·vue.js·数据可视化
德育处主任5 天前
p5.js 3D盒子的基础用法
前端·数据可视化·canvas
云天徽上5 天前
【数据可视化】基孔肯雅热病例数据分析与可视化:Python + pyecharts洞察疫情动态
数据可视化
云天徽上7 天前
【数据可视化】2023-2024年中国各省人口变化深度分析与可视化:Python + pyecharts打造炫酷暗黑主题大屏
数据可视化
云天徽上7 天前
【数据可视化-87】2023-2024年中国各省人口变化深度分析与可视化:Python + pyecharts打造炫酷暗黑主题大屏
开发语言·python·信息可视化·数据可视化·pyecharts
云天徽上8 天前
【数据可视化】海底捞门店数据分析与可视化:Python + pyecharts打造炫酷暗黑主题大屏
数据可视化