来源:自学PHP网 时间:2018-02-07 18:22 作者: 阅读:次
[导读] 本文介绍如何绘制SVG文字,以及SVG文字的各种属性和注意事项。我们可以使用SVG的text元素来在SVG图像上绘制文字。...
我们可以使用SVG 的 <svg xmlns="http://www.w3.org/2000/svg"> <text x="20" y="40">这里是SVG文字</text> </svg> 这个例子中定义一个位于 文字的定义在深入了解SVG文字之前,先来看看下面的三个定义:
文字的位置SVG文字的位置有 注意观察,文字的 Text Anchor文字的anchor决定哪个部分的文字放置在 要设置文字的anchor,可以使用CSS的 垂直的直线是三串文本的 上效果的代码如下: <text x="50" y="20" style="text-anchor: start"> Start </text> <text x="50" y="40" style="text-anchor: middle"> Middle </text> <text x="50" y="60" style="text-anchor: end"> End </text> 文字的描边和填充和其它SVG图形一样,SVG文字也可以进行描边和填充操作。如果你只指定了文字的描边属性,文字将会渲染为一个文字轮廓。如果你只指定了文字的填充属性,那么文字看起来和平常是一样的。来看看下面的三种文字描边和填充的效果: 你也可以使用 SVG文字的间距和字距调整我们可以使用 <svg xmlns="http://www.w3.org/2000/svg"> <text x="20" y="20" >Example SVG text</text> <text x="20" y="40" style="kerning:2;">Example SVG text</text> <text x="20" y="60" style="letter-spacing:2;">Example SVG text</text> </svg> 下面是上面代码的返回结果: 上面的 单词间距你可以使用 <svg xmlns="http://www.w3.org/2000/svg"> <text x="20" y="20"> Word spacing is normal </text> <text x="20" y="40" style="word-spacing: 4;"> Word spacing is 4 </text> <text x="20" y="60" style="word-spacing: 8;"> Word spacing is 8 </text> </svg> 下面是返回的结果。注意:Firefox浏览器有可能不支持这个
文字布局-SVG文字没有自动换行功能SVG文字是没有自动换行功能的。你必须自己定位每一行文本。需要制作多行文本的话, 你还可以将文字放置在一条路径上,例如一个圆或一条曲线上。达到这种效果你需要使用 旋转文本你可以像旋转其它SVG图形一样旋转SVG文字。旋转SVG文字需要使用SVG transform属性。 <svg xmlns="http://www.w3.org/2000/svg"> <text x="20" y="40" transform="rotate(30 20,40)" style="stroke:none; fill:#000000;" >Rotated SVG text</text> </svg> 上面代码的返回结果是: 关于SVG的 垂直文字你可以使用旋转的方法来制作垂直的SVG文字,但是还有一种简单的方法来显示垂直文字。那就是使用 <svg xmlns="http://www.w3.org/2000/svg"> <text x="10" y="20" style="writing-mode: tb;"> 垂直文字 </text> </svg> 上面的代码的返回结果是: 我们在来看看英文的情况: <svg xmlns="http://www.w3.org/2000/svg"> <text x="10" y="20" style="writing-mode: tb;"> Vertical </text> </svg> 你会发现如果是英文的话,字母也被旋转了90度。如果你需要每个字母都不被旋转,可以设置 <text x="10" y="10" style="writing-mode: tb; glyph-orientation-vertical: 0;"> Vertical </text> <text x="110" y="10" style="writing-mode: tb; glyph-orientation-vertical: 90;"> Vertical </text> 上面的代码的返回结果是: 文字的方向你可以使用 <text x="130" y="40" style="direction: rtl;">从右向左显示</text> <text x="130" y="80" style="direction: rtl; unicode-bidi: bidi-override;">right to Left</text> SVG文字样式下面列出了一组可以使用在SVG文字上的CSS属性。你还可以为文字的描边和填充设置渐变,填充模式和遮罩等效果。 注意,下面的CSS属性名称必须是小写,否则渲染时会被忽略!
下面是一个使用了上面的一些属性的例子: <svg xmlns="http://www.w3.org/2000/svg"> <text x="20" y="40" style="font-family: Arial; font-size : 34; stroke : #000000; fill : #00ff00; " >Styled SVG text</text> </svg> 上面的代码的返回结果是: 文字的长度你可以使用 <text x="5" y="20" textLength="140" lengthAdjust="spacing"> A long, long, long text. </text> <text x="5" y="40" textLength="200" lengthAdjust="spacing"> A long, long, long text. </text> <text x="5" y="60" textLength="200" lengthAdjust="spacingAndGlyphs"> A long, long, long text. </text> 上面的代码的返回结果如下。注意最后两串文字的间距和字符大小: 返回SVG教程目录 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com