我正在使用SVG创建这样的网站。我在现场站点上遇到了一些问题。首先,由于某些原因,SVG内部的文本未使用字体。如果我在此处或在Codepen上发布代码,则可以使用,但不能在实际站点上使用。另一个问题是,文本位置在Chrome或Microsoft Edge中不一致。我已包含HTML和JS代码以供参考。
HTML
<svg viewBox="0 40 100 40">
<defs><path id="textPath"/></defs>
<g id="testGroupC2" >
<style type="text/css">
@import url('https://fonts.googleapis.com/css?family=Raleway:thin');
text{
font-size: 4pt;
fill: #ffffff;
text-anchor: middle;
font-family: 'Raleway';
z-index: 2;
}
</style>
<path id="testPath2"/>
<text>
<textpath xlink:href="#textPath" startOffset="50%" >
<tspan x="0" dy="-5.5">Home</tspan>
</textpath>
</text>
</g>
</svg>
JS
// JavaScript Document
const rad = Math.PI / 180;
let cx = 50, cy = 100, R = 50, r = 35, A = 40 , a = 5, o=4;
// o for offset
testGroupC2.setAttributeNS(null, "transform", `rotate(${-90 -(A / 2) - a} ${cx} ${cy})`)
// control points for the quadratic Bézier
let px1 = cx + R * Math.cos(0);
let py1 = cy + R * Math.sin(0);
let px2 = cx + R * Math.cos((2*a + A)*rad);
let py2 = cy + R * Math.sin((2*a + A)*rad);
let px3 = cx + r * Math.cos((2*a + A)*rad);
let py3 = cy + r * Math.sin((2*a + A)*rad);
let px4 = cx + r * Math.cos(0);
let py4 = cy + r * Math.sin(0);
// points used to draw the shape
let x11 = cx + (R-o) * Math.cos(0);
let y11 = cy + (R-o) * Math.sin(0);
let x1 = cx + R * Math.cos(a*rad);
let y1 = cy + R * Math.sin(a*rad);
let x2 = cx + R * Math.cos((a + A)*rad);
let y2 = cy + R * Math.sin((a + A)*rad);
let x21 = cx + (R-o) * Math.cos((2*a + A)*rad);
let y21 = cy + (R-o) * Math.sin((2*a + A)*rad);
let x31 = cx + (r+o) * Math.cos((2*a + A)*rad);
let y31 = cy + (r+o) * Math.sin((2*a + A)*rad);
let x3 = cx + r * Math.cos((a + A)*rad);
let y3 = cy + r * Math.sin((a + A)*rad);
let x4 = cx + r * Math.cos(a*rad);
let y4 = cy + r * Math.sin(a*rad);
let x41 = cx + (r+o) * Math.cos(0);
let y41 = cy + (r+o) * Math.sin(0);
/*
No rounded corners
let d = `M${x1},${y1} A${R},${R},0 0,1 ${x2},${y2}
L${x3},${y3} A${r},${r},0 0,0 ${x4},${y4}
L${x1},${y1}Z`;*/
/*
Beveled corners
let d = `M${x1},${y1}
A${R},${R},0 0,1 ${x2},${y2}
L${x21},${y21}
L${x31},${y31}
L${x3},${y3}
A${r},${r},0 0,0 ${x4},${y4}
L${x41},${y41}
L${x11},${y11}
L${x1},${y1}Z`;*/
// Rounded corners with quadratic Bézier curves
d = `M${x1},${y1}
A${R},${R},0 0,1 ${x2},${y2}
Q${px2},${py2} ${x21},${y21}
L${x31},${y31}
Q${px3},${py3} ${x3},${y3}
A${r},${r},0 0,0 ${x4},${y4}
Q${px4},${py4} ${x41},${y41}
L${x11},${y11}
Q${px1},${py1} ${x1},${y1}Z`;
testPath2.setAttributeNS(null,"d",d);
/* based on the 2nd A-curve of the testPath,
but last point and starting point switched,
as well as the sweep-flag of the curve */
dtext = `M${x4},${y4}
A${r},${r},0 0,1 ${x3},${y3}`;
textPath.setAttributeNS(null,"d",dtext);
答案 0 :(得分:0)
对于字体,如果我访问Google字体网站,则tells me要使用
@import url('https://fonts.googleapis.com/css?family=Raleway:100');
这有区别吗?
对于字体定位,应注意用于字体大小的pt
单位取决于设备,并且可能由不同的软件进行不同的解释。始终最好使用px
值,特别是因为您在viewBox
元素上设置了<svg>
。这样,可以保证字体大小相对于该视图框始终保持相同大小。
现在4pt
是一个相对较小的值,伴随着浏览器可能会应用优化来改善形状渲染(有效地重新定位字形)的风险。 (对于小尺寸的玩具,我经常会把它们称为越野车。)有两种解决方法:
text-rendering: geometricPrecision
以禁用重新定位。<svg>
呈现的最终大小由其width
和height
表示属性控制。