Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/css/34.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript SVG圆图内的居中图标_Javascript_Css_Svg - Fatal编程技术网

Javascript SVG圆图内的居中图标

Javascript SVG圆图内的居中图标,javascript,css,svg,Javascript,Css,Svg,我试图在SVG循环图中放置一个图标,以便它显示如下: 无论我做什么,在内部图标的一侧和显示的SVG路径之间总是有一个微小的间隙。我认为这个问题与SVG圆形图的弧度不是完美圆这一事实有关 以下是我已经尝试过的一切: 创建内部图标图像的静态png,使其不是一个完美的圆圈,然后将SVG包裹在其周围 在illustrator中创建SVG,内部图标为png,有两条外部路径:一条用于周围的灰色填充,另一条用于代表50%的绿色填充。导出文件时,d参数是基于坐标而不是百分比显示的 我开始玩这个,但没走多

我试图在SVG循环图中放置一个图标,以便它显示如下:

无论我做什么,在内部图标的一侧和显示的SVG路径之间总是有一个微小的间隙。我认为这个问题与SVG圆形图的弧度不是完美圆这一事实有关

以下是我已经尝试过的一切:

  • 创建内部图标图像的静态png,使其不是一个完美的圆圈,然后将SVG包裹在其周围

  • 在illustrator中创建SVG,内部图标为png,有两条外部路径:一条用于周围的灰色填充,另一条用于代表50%的绿色填充。导出文件时,d参数是基于坐标而不是百分比显示的


我开始玩这个,但没走多远


这有可能实现吗?我非常感谢所有的帮助/反馈

这是一个快速的解决方案,我不知道它是否好。您应该向第二个svg添加类circle,如下所示:

<svg class="circle" width="120" height="120" viewBox="0 0 120 120" fill="none" xmlns="http://www.w3.org/2000/svg"
                     xmlns:xlink="http://www.w3.org/1999/xlink">
    <circle cx="60" cy="60" r="59" fill="#F07C7C" stroke="#D0CFCF" stroke-width="2"/>
    <rect x="22" y="22" width="75" height="75" fill="url(#pattern2)"/>
    <defs>
         <pattern id="pattern2" patternContentUnits="objectBoundingBox" width="1" height="1">
             <use xlink:href="#image2" transform="scale(0.00390625)"/>
          </pattern>
         <image id="image2" width="256" height="256"
                   xlink:href=""/>
    </defs>
</svg>

这将在第一个svg中生成第二个svg。

这是一个快速解决方案,我不知道它是否好。您应该向第二个svg添加类circle,如下所示:

<svg class="circle" width="120" height="120" viewBox="0 0 120 120" fill="none" xmlns="http://www.w3.org/2000/svg"
                     xmlns:xlink="http://www.w3.org/1999/xlink">
    <circle cx="60" cy="60" r="59" fill="#F07C7C" stroke="#D0CFCF" stroke-width="2"/>
    <rect x="22" y="22" width="75" height="75" fill="url(#pattern2)"/>
    <defs>
         <pattern id="pattern2" patternContentUnits="objectBoundingBox" width="1" height="1">
             <use xlink:href="#image2" transform="scale(0.00390625)"/>
          </pattern>
         <image id="image2" width="256" height="256"
                   xlink:href=""/>
    </defs>
</svg>
这将在第一个svg中生成第二个svg

.circle {
    position: absolute;
    top: 25px;
    left: calc(50% - 108px);
}