【Antv G6】导出图片

需求

将Antv G6生成的树形图导出成图片

代码

<div style="height: calc(100% - 50px);">
    <div id="miniMap" class="minimap"></div>
    <div id="containerG6" ref="containerG6" class="containerWrap"></div>
</div>
var that = this
this.treeGraph.toFullDataURL(
    res => {
        // 为了防止下载的图片影响到G6显示,这里作一个深度拷贝
        var canvas = document.getElementById('containerG6').childNodes[0].cloneNode(true)
        var img = new Image()
        img.onload = function () {
            canvas.width = img.width + 32
            canvas.height = img.height + 32
            var ctx = canvas.getContext('2d')
            ctx.fillStyle = '#fff'
            ctx.fillRect(0, 0, canvas.width, canvas.height)
            ctx.drawImage(img, 16, 16)
            // 下载
            var oA = document.createElement('a')
            oA.download = '组织架构图-' + that.modelTitle
            oA.href = canvas.toDataURL('image/png')
            document.body.appendChild(oA)
            oA.click()
            oA.remove() // 下载之后把创建的元素删除
        }
        img.src = res
    },
    'image/png',
    {
        imageConfig: {
            padding: 16
        }
    }
)

扩展

浏览器上的任意元素都可转化成canvas,然后下载下来。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值