博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
svg image 图片无法铺满 circle 的问题解决
阅读量:4353 次
发布时间:2019-06-07

本文共 1837 字,大约阅读时间需要 6 分钟。

引子

使用d3.js绘制了力布图后,需要在circle中绘制图片,方法如下:

// 绘制图片 drawPattern(gContainer) {      let that = this;      let gPattern = gContainer.append("g").attr("class", "g-pattern");      //  添加pattern      pattern = gPattern.selectAll("pattern").data(that.nodes, function(node) {        return "pattern" + node.id;      });            // 赋予宽高      pattern        .enter()        .append("pattern")        .attr("id", function(node) {          return "pattern" + node.id;        })        .attr("x", 0)        .attr("y", 0)        .attr("height", 64)        .attr("width", 64)        .append("svg:image");           // 插入图片      pattern        .selectAll("image")        .data(that.nodes, function(node) {          return "pattern-image" + node.id;        })                .attr("xlink:href", function(node) {          return node.image;        })        .attr("x", 0)        .attr("y", 0)        .attr("height", function(node) {          return that.imageHeight;        })        .attr("width", function(node) {          return that.imageWidth        });    }

circle中加入指向

circles.style('fill',function(node){ return "url(#" + "pattern" + node.id + ")"; })

实现后的:

1414921-20190604135156251-2058218818.png

发现一个问题就是当图片宽高不一致的时候,会出现无法填充圆圈的问题

1414921-20190604135624215-211641784.png

问题解决

给图片加入preserveAspectRatio的属性后问题解决了~

... 省略代码...        pattern        .selectAll("image")        .data(that.nodes, function(node) {          return "pattern-image" + node.id;        })        .attr("preserveAspectRatio","none")         .attr("xlink:href", function(node) {          return node.icon;        })        ....省略代码...

1414921-20190604135742934-694724136.png

一脸懵逼吗.gif

关于preserveAspectRatio

<image>的控制图片比例的属性,指的是引用的图像如何与参考视图进行匹配,以及是否应该相对于当前用户坐标系保留参考图像的长宽比

它的值有2个 <align> <meetOrSlice>

<align>

1414921-20190604153256655-97198485.png

<meetOrSlice> 是可选的,如果提供的话, 与 间隔一个或多个的空格

1414921-20190604154753010-469378747.png

上面尼,我们就是希望图片按照我们指定的宽高使得元素的边界完全匹配视图圆形,因此设置成"none"

参数说明源自:

该属性可还和viewBox属性联用,关于该部分的说明,张鑫旭的这篇博客介绍的很全面:

转载于:https://www.cnblogs.com/webhmy/p/10973156.html

你可能感兴趣的文章
when not exists 用法
查看>>
easyui_datagrid_method_扩展
查看>>
Jquery插件 自制分步滑动页面(全屏横移)
查看>>
iOS封装功能生成 .framework
查看>>
maven-java包管理工具-01
查看>>
flask中的CBV,flash,Flask-Session,WTForms - MoudelForm,DBUtils 数据库连接池
查看>>
最近整理的提供免费代理列表的几个网站
查看>>
探偵ガリレオー転写る2
查看>>
快速排序算法C++实现[评注版]
查看>>
七尖记
查看>>
VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
查看>>
java面试题(摘录)
查看>>
hdu 3555 数位DP
查看>>
[036] 微信公众帐号开发教程第12篇-符号表情的发送(下)
查看>>
PQ分区魔术师图解教程
查看>>
[翻译] VBFPopFlatButton
查看>>
PlaceholderImageView
查看>>
Ubuntu14.04一直进入guest session解决办法
查看>>
排序算法的总结
查看>>
mac 修改root的密码
查看>>